/* * Copyright (C) 2000, 2001, 2002 Jeff Dike (jdike@karaya.com) * Licensed under the GPL */ #include #include #include #include #include #include #include #include #include #include "init.h" #include "sysdep/ptrace.h" #include "sigcontext.h" #include "sysdep/sigcontext.h" #include "irq_user.h" #include "time_user.h" #include "task.h" #include "mode.h" #include "choose-mode.h" #include "kern_util.h" #include "user_util.h" #include "os.h" void segv_handler(int sig, union uml_pt_regs *regs) { struct faultinfo * fi = UPT_FAULTINFO(regs); if(UPT_IS_USER(regs) && !SEGV_IS_FIXABLE(fi)){ bad_segv(*fi, UPT_IP(regs)); return; } segv(*fi, UPT_IP(regs), UPT_IS_USER(regs), regs); } void usr2_handler(int sig, union uml_pt_regs *regs) { CHOOSE_MODE(syscall_handler_tt(sig, regs), (void) 0); } void (*sig_info[NSIG])(int, union uml_pt_regs *); void os_fill_handlinfo(struct kern_handlers h) { sig_info[SIGTRAP] = h.relay_signal; sig_info[SIGFPE] = h.relay_signal; sig_info[SIGILL] = h.relay_signal; sig_info[SIGWINCH] = h.winch; sig_info[SIGBUS] = h.bus_handler; sig_info[SIGSEGV] = h.page_fault; sig_info[SIGIO] = h.sigio_handler; sig_info[SIGVTALRM] = h.timer_handler; sig_info[SIGALRM] = h.timer_handler; sig_info[SIGUSR2] = usr2_handler; }