aboutsummaryrefslogtreecommitdiffstats
path: root/arch/um/kernel/trap_user.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/um/kernel/trap_user.c')
-rw-r--r--arch/um/kernel/trap_user.c58
1 files changed, 0 insertions, 58 deletions
diff --git a/arch/um/kernel/trap_user.c b/arch/um/kernel/trap_user.c
deleted file mode 100644
index 5590b5739db9..000000000000
--- a/arch/um/kernel/trap_user.c
+++ /dev/null
@@ -1,58 +0,0 @@
1/*
2 * Copyright (C) 2000, 2001, 2002 Jeff Dike (jdike@karaya.com)
3 * Licensed under the GPL
4 */
5
6#include <stdlib.h>
7#include <errno.h>
8#include <setjmp.h>
9#include <signal.h>
10#include <sys/time.h>
11#include <sys/wait.h>
12#include <asm/page.h>
13#include <asm/unistd.h>
14#include <asm/ptrace.h>
15#include "init.h"
16#include "sysdep/ptrace.h"
17#include "sigcontext.h"
18#include "sysdep/sigcontext.h"
19#include "irq_user.h"
20#include "time_user.h"
21#include "task.h"
22#include "mode.h"
23#include "choose-mode.h"
24#include "kern_util.h"
25#include "user_util.h"
26#include "os.h"
27
28void segv_handler(int sig, union uml_pt_regs *regs)
29{
30 struct faultinfo * fi = UPT_FAULTINFO(regs);
31
32 if(UPT_IS_USER(regs) && !SEGV_IS_FIXABLE(fi)){
33 bad_segv(*fi, UPT_IP(regs));
34 return;
35 }
36 segv(*fi, UPT_IP(regs), UPT_IS_USER(regs), regs);
37}
38
39void usr2_handler(int sig, union uml_pt_regs *regs)
40{
41 CHOOSE_MODE(syscall_handler_tt(sig, regs), (void) 0);
42}
43
44void (*sig_info[NSIG])(int, union uml_pt_regs *);
45
46void os_fill_handlinfo(struct kern_handlers h)
47{
48 sig_info[SIGTRAP] = h.relay_signal;
49 sig_info[SIGFPE] = h.relay_signal;
50 sig_info[SIGILL] = h.relay_signal;
51 sig_info[SIGWINCH] = h.winch;
52 sig_info[SIGBUS] = h.bus_handler;
53 sig_info[SIGSEGV] = h.page_fault;
54 sig_info[SIGIO] = h.sigio_handler;
55 sig_info[SIGVTALRM] = h.timer_handler;
56 sig_info[SIGALRM] = h.timer_handler;
57 sig_info[SIGUSR2] = usr2_handler;
58}