/* This file is part of the program psim. Copyright (C) 1994-1995, Andrew Cagney This program 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 of the License, or (at your option) any later version. This program 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 this program; if not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #include #include #include #include #include "psim.h" extern char **environ; extern char *optarg; extern int optind; extern int optopt; extern int opterr; void printf_filtered(const char *msg, ...) { va_list ap; va_start(ap, msg); vprintf(msg, ap); va_end(ap); } void error (char *msg, ...) { va_list ap; va_start(ap, msg); vprintf(msg, ap); va_end(ap); exit (1); } void * zalloc(long size) { void *memory = malloc(size); if (memory == NULL) error("zmalloc failed\n"); bzero(memory, size); return memory; } void zfree(void *chunk) { free(chunk); } static void usage(void) { error ("Usage: psim [ -a -p -c -C -s -i -I -t -g ] [ ... ]\n"); } int main(int argc, char **argv) { psim *system; const char *name_of_file; char *arg_; unsigned_word stack_pointer; psim_status status; int letter; int i; int print_info = 0; /* check for arguments -- note sim_calls.c also contains argument processing code for the simulator linked within gdb. */ while ((letter = getopt (argc, argv, "acCiIpstg")) != EOF) { switch (letter) { case 'a': for (i = 0; i < nr_trace; i++) ppc_trace[i] = 1; break; case 'p': ppc_trace[trace_cpu] = ppc_trace[trace_semantics] = 1; break; case 'c': ppc_trace[trace_core] = 1; break; case 'C': ppc_trace[trace_console_device] = 1; break; case 's': ppc_trace[trace_create_stack] = 1; break; case 'i': ppc_trace[trace_icu_device] = 1; break; case 'I': print_info = 1; break; case 't': ppc_trace[trace_device_tree] = 1; break; case 'g': ppc_trace[trace_gdb] = 1; break; default: usage(); } } if (optind >= argc) usage(); name_of_file = argv[optind]; /* create the simulator */ system = psim_create(name_of_file, ((WITH_SMP > 0) ? WITH_SMP : 1)); /* fudge the environment so that _=prog-name */ arg_ = (char*)zalloc(strlen(argv[optind]) + strlen("_=") + 1); strcpy(arg_, "_="); strcat(arg_, argv[optind]); putenv(arg_); /* initialize it */ psim_init(system); psim_stack(system, &argv[optind], environ); psim_run(system); /* any final clean up */ if (print_info) psim_print_info (system, 1); /* why did we stop */ status = psim_get_status(system); switch (status.reason) { case was_continuing: error("psim: continuing while stoped!\n"); return 0; case was_trap: error("psim: no trap insn\n"); return 0; case was_exited: return status.signal; case was_signalled: printf ("%s: Caught signal %d at address 0x%lx\n", name_of_file, (int)status.signal, (long)status.program_counter); return status.signal; default: error("unknown halt condition\n"); return 0; } }