aboutsummaryrefslogtreecommitdiff
path: root/sim/erc32/run.c
blob: a571c4ad535f05b11d1bc8577bdcab76349feb28 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
/*
 * run front end support for ERC32SIM Copyright (C) 1987, 1992 Free Software
 * Foundation, Inc.
 * 
 * This file is part of ERC32SIM
 * 
 * ERC32SIM is free software; you can redistribute it and/or modify it under the
 * terms of the GNU General Public License as published by the Free Software
 * Foundation; either version 2, or (at your option) any later version.
 * 
 * ERC32SIM is distributed in the hope that it will be useful, but WITHOUT ANY
 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 * FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
 * details.
 * 
 * You should have received a copy of the GNU General Public License along with
 * ERC32SIM; see the file COPYING.  If not, write to the Free Software
 * Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
 */

#include <varargs.h>
#include <stdio.h>
#include "bfd.h"

main(ac, av)
    int             ac;
    char          **av;
{
    bfd            *abfd;
    bfd_vma         start_address;
    asection       *s;
    int             i;
    int             verbose = 0;
    int             trace = 0;
    char           *name = "";
    for (i = 1; i < ac; i++) {
	if (strcmp(av[i], "-v") == 0) {
	    verbose = 1;
	} else if (strcmp(av[i], "-t") == 0) {
	    trace = 1;
	} else {
	    name = av[i];
	}
    }
    if (verbose) {
	printf("run %s\n", name);
    }
    sim_open(0);
    abfd = bfd_openr(name, "a.out-sunos-big");

    if (abfd) {

	if (bfd_check_format(abfd, bfd_object)) {
	    for (s = abfd->sections; s; s = s->next) {
		char           *buffer = malloc(bfd_section_size(abfd, s));
		bfd_get_section_contents(abfd, s, buffer, 0, bfd_section_size(abfd, s));
		sim_write(s->vma, buffer, bfd_section_size(abfd, s));
	    }

	    start_address = bfd_get_start_address(abfd);
	    sim_create_inferior(start_address, NULL, NULL);
	    if (trace) {
		int             done = 0;
		while (!done) {
		    /*
		     * done = sim_trace();
		     */
		}
	    } else {
		sim_resume(0, 0);
	    }
	    if (verbose) {
		sim_info(0);
	    }
	    return 0;
	}
    }
    return 1;
}

void
printf_filtered(va_alist)
va_dcl
{
    char           *msg;
    va_list         args;

    va_start(args);
    msg = va_arg(args, char *);
    vfprintf(stdout, msg, args);
    va_end(args);
}