vm: fatal_error if VM-less thread gets a signal
parent
41c36752fc
commit
3726f61c70
|
@ -142,9 +142,7 @@ void factor_vm::synchronous_signal_handler_impl()
|
||||||
|
|
||||||
void synchronous_signal_handler_impl()
|
void synchronous_signal_handler_impl()
|
||||||
{
|
{
|
||||||
factor_vm *vm = current_vm_p();
|
current_vm()->synchronous_signal_handler_impl();
|
||||||
if (vm)
|
|
||||||
vm->synchronous_signal_handler_impl();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void factor_vm::fp_signal_handler_impl()
|
void factor_vm::fp_signal_handler_impl()
|
||||||
|
|
|
@ -153,9 +153,13 @@ void memory_signal_handler(int signal, siginfo_t *siginfo, void *uap)
|
||||||
|
|
||||||
void synchronous_signal_handler(int signal, siginfo_t *siginfo, void *uap)
|
void synchronous_signal_handler(int signal, siginfo_t *siginfo, void *uap)
|
||||||
{
|
{
|
||||||
factor_vm *vm = current_vm();
|
factor_vm *vm = current_vm_p();
|
||||||
|
if (vm)
|
||||||
|
{
|
||||||
vm->signal_number = signal;
|
vm->signal_number = signal;
|
||||||
vm->dispatch_signal(uap,factor::synchronous_signal_handler_impl);
|
vm->dispatch_signal(uap,factor::synchronous_signal_handler_impl);
|
||||||
|
} else
|
||||||
|
fatal_error("Foreign thread received signal ", signal);
|
||||||
}
|
}
|
||||||
|
|
||||||
void next_safepoint_signal_handler(int signal, siginfo_t *siginfo, void *uap)
|
void next_safepoint_signal_handler(int signal, siginfo_t *siginfo, void *uap)
|
||||||
|
@ -163,6 +167,8 @@ void next_safepoint_signal_handler(int signal, siginfo_t *siginfo, void *uap)
|
||||||
factor_vm *vm = current_vm_p();
|
factor_vm *vm = current_vm_p();
|
||||||
if (vm)
|
if (vm)
|
||||||
vm->enqueue_safepoint_signal(signal);
|
vm->enqueue_safepoint_signal(signal);
|
||||||
|
else
|
||||||
|
fatal_error("Foreign thread received signal ", signal);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ignore_signal_handler(int signal, siginfo_t *siginfo, void *uap)
|
void ignore_signal_handler(int signal, siginfo_t *siginfo, void *uap)
|
||||||
|
|
Loading…
Reference in New Issue