chore: Improve default signal handler

master
Sean McBride 5 years ago
parent 9d5859aeaa
commit de9e20ce89

@ -102,9 +102,6 @@ software_interrupt_handle_signals(int signal_type, siginfo_t *signal_info, void
case SIGUSR1: { case SIGUSR1: {
/* SIGUSR1 restores a preempted sandbox using mcontext. */ /* SIGUSR1 restores a preempted sandbox using mcontext. */
/* Assumption: Always sent by a thread, never by the kernel */
assert(signal_info->si_code == SI_TKILL);
/* Assumption: Caller disables interrupt before triggering SIGUSR1 */ /* Assumption: Caller disables interrupt before triggering SIGUSR1 */
assert(!software_interrupt_is_enabled()); assert(!software_interrupt_is_enabled());
@ -121,7 +118,12 @@ software_interrupt_handle_signals(int signal_type, siginfo_t *signal_info, void
return; return;
} }
default: default:
panic("Handler unexpectedly called for signal other than SIGALRM or SIGUSR1\n"); if (signal_info->si_code == SI_TKILL) {
panic("Unexpectedly received signal %d from a thread kill, but we have no handler\n",
signal_type);
} else if (signal_info->si_code == SI_KERNEL) {
panic("Unexpectedly received signal %d from the kernel, but we have no handler\n", signal_type);
}
} }
#endif #endif
} }

Loading…
Cancel
Save