forked from Imagelibrary/binutils-gdb
* remote-sim.c (gdbsim_wait): Pass target signal numbers to
sim_resume. Expect target signal numbers from sim_stop_reason. * wrapper.c (gdb/signals.h): Include it. (SIGTRAP): Don't define. (SIGBUS): Likewise. (sim_stop_reason): Use TARGET_SIGNAL_* instead of SIG*. * sim-reason.c (sim_stop_reason): Use sim_signal_to_target, not sim_signal_to_host. * sim-signal.c (sim_signal_to_host): Fix typo. (sim_signal_to_target): New function. * interp.c (gdb/signals.h): Include it. (sim_stop_reason): Use TARGET_SIGNAL_*. * interf.c: (gdb/signals.h): Include it. (sim_stop_reason): Use TARGET_SIGNAL_*. * sim_calls.c (gdb/signals.h): Include it. (sim_stop_reason): Use TARGET_SIGNAL_*. * psim.c (cntrl_c_simulation): Use TARGET_SIGNAL_*.
This commit is contained in:
@@ -674,8 +674,7 @@ gdbsim_wait (ptid_t ptid, struct target_waitstatus *status)
|
||||
#else
|
||||
prev_sigint = signal (SIGINT, gdbsim_cntrl_c);
|
||||
#endif
|
||||
sim_resume (gdbsim_desc, resume_step,
|
||||
target_signal_to_host (resume_siggnal));
|
||||
sim_resume (gdbsim_desc, resume_step, resume_siggnal);
|
||||
signal (SIGINT, prev_sigint);
|
||||
resume_step = 0;
|
||||
|
||||
@@ -690,24 +689,20 @@ gdbsim_wait (ptid_t ptid, struct target_waitstatus *status)
|
||||
case sim_stopped:
|
||||
switch (sigrc)
|
||||
{
|
||||
case SIGABRT:
|
||||
case TARGET_SIGNAL_ABRT:
|
||||
quit ();
|
||||
break;
|
||||
case SIGINT:
|
||||
case SIGTRAP:
|
||||
case TARGET_SIGNAL_INT:
|
||||
case TARGET_SIGNAL_TRAP:
|
||||
default:
|
||||
status->kind = TARGET_WAITKIND_STOPPED;
|
||||
/* The signal in sigrc is a host signal. That probably
|
||||
should be fixed. */
|
||||
status->value.sig = target_signal_from_host (sigrc);
|
||||
status->value.sig = sigrc;
|
||||
break;
|
||||
}
|
||||
break;
|
||||
case sim_signalled:
|
||||
status->kind = TARGET_WAITKIND_SIGNALLED;
|
||||
/* The signal in sigrc is a host signal. That probably
|
||||
should be fixed. */
|
||||
status->value.sig = target_signal_from_host (sigrc);
|
||||
status->value.sig = sigrc;
|
||||
break;
|
||||
case sim_running:
|
||||
case sim_polling:
|
||||
|
||||
Reference in New Issue
Block a user