1995-09-21 22:23:56 +00:00
|
|
|
/* This file is part of the program psim.
|
|
|
|
|
|
|
|
Copyright (C) 1994-1995, Andrew Cagney <cagney@highland.com.au>
|
|
|
|
|
|
|
|
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 <stdarg.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
#include "psim.h"
|
1995-11-08 18:57:06 +00:00
|
|
|
#include "function_unit.h"
|
1995-11-12 14:20:39 +00:00
|
|
|
#include "options.h"
|
1995-09-21 22:23:56 +00:00
|
|
|
|
1995-11-02 20:21:35 +00:00
|
|
|
#ifdef HAVE_STDLIB_H
|
|
|
|
#include <stdlib.h>
|
|
|
|
#endif
|
|
|
|
|
1995-11-08 18:57:06 +00:00
|
|
|
#ifdef HAVE_UNISTD_H
|
|
|
|
#include <unistd.h>
|
|
|
|
#endif
|
|
|
|
|
1995-11-02 20:21:35 +00:00
|
|
|
#ifdef HAVE_STRING_H
|
|
|
|
#include <string.h>
|
|
|
|
#else
|
|
|
|
#ifdef HAVE_STRINGS_H
|
|
|
|
#include <strings.h>
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
1995-09-21 22:23:56 +00:00
|
|
|
extern char **environ;
|
|
|
|
extern char *optarg;
|
|
|
|
extern int optind;
|
|
|
|
extern int optopt;
|
|
|
|
extern int opterr;
|
|
|
|
|
|
|
|
void
|
1995-10-01 17:54:45 +00:00
|
|
|
printf_filtered(const char *msg, ...)
|
1995-09-21 22:23:56 +00:00
|
|
|
{
|
|
|
|
va_list ap;
|
|
|
|
va_start(ap, msg);
|
|
|
|
vprintf(msg, ap);
|
1995-10-26 16:43:00 +00:00
|
|
|
va_end(ap);
|
1995-09-21 22:23:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
error (char *msg, ...)
|
|
|
|
{
|
|
|
|
va_list ap;
|
|
|
|
va_start(ap, msg);
|
|
|
|
vprintf(msg, ap);
|
1995-10-26 16:43:00 +00:00
|
|
|
va_end(ap);
|
1995-09-21 22:23:56 +00:00
|
|
|
exit (1);
|
|
|
|
}
|
|
|
|
|
|
|
|
void *
|
|
|
|
zalloc(long size)
|
|
|
|
{
|
|
|
|
void *memory = malloc(size);
|
|
|
|
if (memory == NULL)
|
|
|
|
error("zmalloc failed\n");
|
1995-11-13 16:07:30 +00:00
|
|
|
memset(memory, 0, size);
|
1995-09-21 22:23:56 +00:00
|
|
|
return memory;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
zfree(void *chunk)
|
|
|
|
{
|
|
|
|
free(chunk);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
usage(void)
|
|
|
|
{
|
1995-11-08 18:57:06 +00:00
|
|
|
printf_filtered("Usage:\n\tpsim [ -t <trace-option> ] [-m model] [-i] [-I] <image> [ <image-args> ... ]\n");
|
1995-11-02 14:27:18 +00:00
|
|
|
trace_usage();
|
|
|
|
error("");
|
1995-09-21 22:23:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
main(int argc, char **argv)
|
|
|
|
{
|
|
|
|
psim *system;
|
|
|
|
const char *name_of_file;
|
|
|
|
char *arg_;
|
|
|
|
psim_status status;
|
|
|
|
int letter;
|
1995-10-02 18:19:17 +00:00
|
|
|
int print_info = 0;
|
1995-09-21 22:23:56 +00:00
|
|
|
|
1995-10-02 15:47:57 +00:00
|
|
|
/* check for arguments -- note sim_calls.c also contains argument processing
|
|
|
|
code for the simulator linked within gdb. */
|
1995-11-08 18:57:06 +00:00
|
|
|
while ((letter = getopt (argc, argv, "Iim:t:")) != EOF)
|
1995-09-21 22:23:56 +00:00
|
|
|
{
|
1995-10-01 17:54:45 +00:00
|
|
|
switch (letter) {
|
1995-11-02 14:27:18 +00:00
|
|
|
case 't':
|
|
|
|
trace_option(optarg);
|
1995-09-21 22:23:56 +00:00
|
|
|
break;
|
1995-11-08 18:57:06 +00:00
|
|
|
case 'm':
|
1995-11-12 14:20:39 +00:00
|
|
|
model_set(optarg);
|
1995-11-08 18:57:06 +00:00
|
|
|
break;
|
|
|
|
case 'i':
|
1995-10-02 18:19:17 +00:00
|
|
|
print_info = 1;
|
|
|
|
break;
|
1995-11-08 18:57:06 +00:00
|
|
|
case 'I':
|
|
|
|
print_info = 2;
|
|
|
|
break;
|
1995-09-21 22:23:56 +00:00
|
|
|
default:
|
|
|
|
usage();
|
|
|
|
}
|
|
|
|
}
|
1995-10-01 17:54:45 +00:00
|
|
|
if (optind >= argc)
|
1995-09-21 22:23:56 +00:00
|
|
|
usage();
|
1995-10-01 17:54:45 +00:00
|
|
|
name_of_file = argv[optind];
|
1995-09-21 22:23:56 +00:00
|
|
|
|
1995-11-12 14:20:39 +00:00
|
|
|
if (ppc_trace[trace_opts])
|
|
|
|
print_options ();
|
|
|
|
|
1995-09-21 22:23:56 +00:00
|
|
|
/* create the simulator */
|
1995-11-02 14:27:18 +00:00
|
|
|
system = psim_create(name_of_file);
|
1995-09-21 22:23:56 +00:00
|
|
|
|
|
|
|
/* fudge the environment so that _=prog-name */
|
1995-10-01 17:54:45 +00:00
|
|
|
arg_ = (char*)zalloc(strlen(argv[optind]) + strlen("_=") + 1);
|
1995-09-21 22:23:56 +00:00
|
|
|
strcpy(arg_, "_=");
|
1995-10-01 17:54:45 +00:00
|
|
|
strcat(arg_, argv[optind]);
|
1995-09-21 22:23:56 +00:00
|
|
|
putenv(arg_);
|
|
|
|
|
|
|
|
/* initialize it */
|
1995-10-26 16:43:00 +00:00
|
|
|
psim_init(system);
|
1995-10-01 17:54:45 +00:00
|
|
|
psim_stack(system, &argv[optind], environ);
|
1995-09-21 22:23:56 +00:00
|
|
|
|
|
|
|
psim_run(system);
|
|
|
|
|
1995-10-26 16:43:00 +00:00
|
|
|
/* any final clean up */
|
1995-10-02 18:19:17 +00:00
|
|
|
if (print_info)
|
1995-11-08 18:57:06 +00:00
|
|
|
psim_print_info (system, print_info);
|
1995-10-02 18:19:17 +00:00
|
|
|
|
1995-09-21 22:23:56 +00:00
|
|
|
/* 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:
|
1995-10-26 16:43:00 +00:00
|
|
|
printf ("%s: Caught signal %d at address 0x%lx\n",
|
1995-11-02 14:27:18 +00:00
|
|
|
name_of_file, (int)status.signal,
|
|
|
|
(long)status.program_counter);
|
1995-09-21 22:23:56 +00:00
|
|
|
return status.signal;
|
|
|
|
default:
|
|
|
|
error("unknown halt condition\n");
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|