Fix SH simulator to handle program exit correctly.

This commit is contained in:
Jim Wilson 1995-10-22 20:22:02 +00:00
parent 9ef450d85d
commit 3be50301d5
2 changed files with 64 additions and 47 deletions

View File

@ -1,3 +1,12 @@
Sat Oct 21 12:31:01 1995 Jim Wilson <wilson@chestnut.cygnus.com>
* run.c (main): Always return sigrc at end.
Tue Oct 10 12:03:13 1995 J.T. Conklin <jtc@rtl.cygnus.com>
* run.c (main): Print error diagnostic and exit if bfd_openr() or
bfd_check_format() fails.
Thu Sep 28 15:40:36 1995 steve chamberlain <sac@slash.cygnus.com>
* run.c, run.1: From sh directory.

View File

@ -86,57 +86,65 @@ main (ac, av)
{
printf ("run %s\n", name);
}
abfd = bfd_openr (name, 0);
sim_set_callbacks (&default_callback);
default_callback.init (&default_callback);
if (abfd)
if (!abfd)
{
if (bfd_check_format (abfd, bfd_object))
{
for (s = abfd->sections; s; s = s->next)
{
unsigned char *buffer = (unsigned char *)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);
target_byte_order = abfd->xvec->byteorder_big_p ? 4321 : 1234;
if (trace)
{
int done = 0;
while (!done)
{
done = sim_trace ();
}
}
else
{
sim_resume (0, 0);
}
if (verbose)
sim_info (0);
sim_stop_reason (&reason, &sigrc);
if (sigrc == SIGQUIT)
{
return sim_get_quit_code();
}
else
return sigrc;
}
fprintf (stderr, "run: can't open %s: %s\n",
name, bfd_errmsg(bfd_get_error()));
exit (1);
}
return 1;
if (!bfd_check_format (abfd, bfd_object))
{
fprintf (stderr, "run: can't load %s: %s\n",
name, bfd_errmsg(bfd_get_error()));
exit (1);
}
sim_set_callbacks (&default_callback);
default_callback.init (&default_callback);
for (s = abfd->sections; s; s = s->next)
if (abfd)
{
unsigned char *buffer = (unsigned char *)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);
target_byte_order = abfd->xvec->byteorder_big_p ? 4321 : 1234;
if (trace)
{
int done = 0;
while (!done)
{
done = sim_trace ();
}
}
else
{
sim_resume (0, 0);
}
if (verbose)
sim_info (0);
sim_stop_reason (&reason, &sigrc);
/* If reason is sim_exited, then sigrc holds the exit code which we want
to return. If reason is sim_stopped or sim_signalled, then sigrc holds
the signal that the simulator received; we want to return that to
indicate failure. */
return sigrc;
}
void