aboutsummaryrefslogtreecommitdiff
path: root/gdb/remote-sim.c
diff options
context:
space:
mode:
Diffstat (limited to 'gdb/remote-sim.c')
-rw-r--r--gdb/remote-sim.c47
1 files changed, 22 insertions, 25 deletions
diff --git a/gdb/remote-sim.c b/gdb/remote-sim.c
index 6d4333d..2a3e527 100644
--- a/gdb/remote-sim.c
+++ b/gdb/remote-sim.c
@@ -1,7 +1,7 @@
/* Generic remote debugging interface for simulators.
- Copyright 1993 Free Software Foundation, Inc.
+ Copyright 1993, 1994 Free Software Foundation, Inc.
Contributed by Cygnus Support.
- Steve Chamberlain (sac@cygnus.com) and Doug Evans (dje@cygnus.com).
+ Steve Chamberlain (sac@cygnus.com).
This file is part of GDB.
@@ -119,6 +119,9 @@ int regno;
}
}
+/* Kill the running program. This may involve closing any open files
+ and releasing other resources acquired by the simulated program. */
+
static void
gdbsim_kill ()
{
@@ -141,9 +144,13 @@ gdbsim_load (prog, fromtty)
if (sr_get_debug ())
printf_filtered ("gdbsim_load: prog \"%s\"\n", prog);
- inferior_pid = 0;
+ inferior_pid = 0;
+
+ /* This must be done before calling gr_load_image. */
program_loaded = 1;
- gr_load_image (prog, fromtty);
+
+ if (sim_load (prog, fromtty) != 0)
+ gr_load_image (prog, fromtty);
}
@@ -161,8 +168,9 @@ gdbsim_create_inferior (exec_file, args, env)
char *args;
char **env;
{
- int len,entry_pt;
+ int len;
char *arg_buf,**argv;
+ CORE_ADDR entry_pt;
if (! program_loaded)
error ("No program loaded.");
@@ -174,7 +182,7 @@ gdbsim_create_inferior (exec_file, args, env)
if (exec_file == 0 || exec_bfd == 0)
error ("No exec file specified.");
- entry_pt = (int) bfd_get_start_address (exec_bfd);
+ entry_pt = (CORE_ADDR) bfd_get_start_address (exec_bfd);
gdbsim_kill (NULL, NULL);
remove_breakpoints ();
@@ -188,11 +196,7 @@ gdbsim_create_inferior (exec_file, args, env)
strcat (arg_buf, args);
argv = buildargv (arg_buf);
make_cleanup (freeargv, (char *) argv);
- /* FIXME: remote-sim.h says targets that don't support this return
- non-zero. Perhaps distinguish between "not supported" and other errors?
- Or maybe that can be the only error. */
- if (sim_set_args (argv, env) != 0)
- return;
+ sim_create_inferior (entry_pt, argv, env);
inferior_pid = 42;
insert_breakpoints (); /* Needed to get correct instruction in cache */
@@ -210,15 +214,9 @@ gdbsim_open (args, from_tty)
int from_tty;
{
if (sr_get_debug ())
- printf_filtered ("gdbsim_open: args \"%s\"\n", args);
+ printf_filtered ("gdbsim_open: args \"%s\"\n", args ? args : "(null)");
- if (sim_open (args) != 0)
- {
- /* FIXME: This is totally bogus. sim_open should have a way to
- tell us what the error was, so we can tell the user. */
- error ("Unable to initialize simulator (insufficient memory?).");
- return;
- }
+ sim_open (args);
push_target (&gdbsim_ops);
target_fetch_registers (-1);
@@ -244,8 +242,7 @@ gdbsim_close (quitting)
program_loaded = 0;
- /* FIXME: Need to call sim_close() to close all files and
- delete all mappings. */
+ sim_close (quitting);
}
/* Takes a program previously attached to and detaches it.
@@ -384,7 +381,7 @@ gdbsim_files_info (target)
{
printf_filtered ("\tAttached to %s running program %s\n",
target_shortname, file);
- sim_info (printf_filtered, 0);
+ sim_info (0);
}
}
@@ -415,10 +412,10 @@ struct target_ops gdbsim_ops =
0, 0, /* Breakpoints */
0, 0, 0, 0, 0, /* Terminal handling */
gdbsim_kill, /* kill */
- gdbsim_load,
+ gdbsim_load, /* load */
0, /* lookup_symbol */
- gdbsim_create_inferior, /* create_inferior */
- gdbsim_mourn_inferior, /* mourn_inferior */
+ gdbsim_create_inferior, /* create_inferior */
+ gdbsim_mourn_inferior, /* mourn_inferior */
0, /* can_run */
0, /* notice_signals */
process_stratum, 0, /* next */