diff options
-rw-r--r-- | arch/um/os-Linux/irq.c | 2 | ||||
-rw-r--r-- | arch/um/os-Linux/main.c | 2 | ||||
-rw-r--r-- | arch/um/os-Linux/process.c | 10 | ||||
-rw-r--r-- | arch/um/os-Linux/signal.c | 28 | ||||
-rw-r--r-- | arch/um/os-Linux/skas/process.c | 4 | ||||
-rw-r--r-- | arch/um/os-Linux/skas/trap.c | 5 | ||||
-rw-r--r-- | arch/um/os-Linux/trap.c | 1 |
7 files changed, 17 insertions, 35 deletions
diff --git a/arch/um/os-Linux/irq.c b/arch/um/os-Linux/irq.c index 2fe482219b6b..6aa6f95d6524 100644 --- a/arch/um/os-Linux/irq.c +++ b/arch/um/os-Linux/irq.c | |||
@@ -146,6 +146,6 @@ void init_irq_signals(int on_sigstack) | |||
146 | flags = on_sigstack ? SA_ONSTACK : 0; | 146 | flags = on_sigstack ? SA_ONSTACK : 0; |
147 | 147 | ||
148 | set_handler(SIGIO, (__sighandler_t) sig_handler, flags | SA_RESTART, | 148 | set_handler(SIGIO, (__sighandler_t) sig_handler, flags | SA_RESTART, |
149 | SIGUSR1, SIGIO, SIGWINCH, SIGALRM, SIGVTALRM, -1); | 149 | SIGUSR1, SIGIO, SIGWINCH, SIGVTALRM, -1); |
150 | signal(SIGWINCH, SIG_IGN); | 150 | signal(SIGWINCH, SIG_IGN); |
151 | } | 151 | } |
diff --git a/arch/um/os-Linux/main.c b/arch/um/os-Linux/main.c index 1518f7a45a24..82c3778627b8 100644 --- a/arch/um/os-Linux/main.c +++ b/arch/um/os-Linux/main.c | |||
@@ -161,7 +161,7 @@ int __init main(int argc, char **argv, char **envp) | |||
161 | * some time) and cause a segfault. | 161 | * some time) and cause a segfault. |
162 | */ | 162 | */ |
163 | 163 | ||
164 | /* stop timers and set SIG*ALRM to be ignored */ | 164 | /* stop timers and set SIGVTALRM to be ignored */ |
165 | disable_timer(); | 165 | disable_timer(); |
166 | 166 | ||
167 | /* disable SIGIO for the fds and set SIGIO to be ignored */ | 167 | /* disable SIGIO for the fds and set SIGIO to be ignored */ |
diff --git a/arch/um/os-Linux/process.c b/arch/um/os-Linux/process.c index 90b480cf78f4..37781db4ceca 100644 --- a/arch/um/os-Linux/process.c +++ b/arch/um/os-Linux/process.c | |||
@@ -238,15 +238,15 @@ out: | |||
238 | void init_new_thread_signals(void) | 238 | void init_new_thread_signals(void) |
239 | { | 239 | { |
240 | set_handler(SIGSEGV, (__sighandler_t) sig_handler, SA_ONSTACK, | 240 | set_handler(SIGSEGV, (__sighandler_t) sig_handler, SA_ONSTACK, |
241 | SIGUSR1, SIGIO, SIGWINCH, SIGALRM, SIGVTALRM, -1); | 241 | SIGUSR1, SIGIO, SIGWINCH, SIGVTALRM, -1); |
242 | set_handler(SIGTRAP, (__sighandler_t) sig_handler, SA_ONSTACK, | 242 | set_handler(SIGTRAP, (__sighandler_t) sig_handler, SA_ONSTACK, |
243 | SIGUSR1, SIGIO, SIGWINCH, SIGALRM, SIGVTALRM, -1); | 243 | SIGUSR1, SIGIO, SIGWINCH, SIGVTALRM, -1); |
244 | set_handler(SIGFPE, (__sighandler_t) sig_handler, SA_ONSTACK, | 244 | set_handler(SIGFPE, (__sighandler_t) sig_handler, SA_ONSTACK, |
245 | SIGUSR1, SIGIO, SIGWINCH, SIGALRM, SIGVTALRM, -1); | 245 | SIGUSR1, SIGIO, SIGWINCH, SIGVTALRM, -1); |
246 | set_handler(SIGILL, (__sighandler_t) sig_handler, SA_ONSTACK, | 246 | set_handler(SIGILL, (__sighandler_t) sig_handler, SA_ONSTACK, |
247 | SIGUSR1, SIGIO, SIGWINCH, SIGALRM, SIGVTALRM, -1); | 247 | SIGUSR1, SIGIO, SIGWINCH, SIGVTALRM, -1); |
248 | set_handler(SIGBUS, (__sighandler_t) sig_handler, SA_ONSTACK, | 248 | set_handler(SIGBUS, (__sighandler_t) sig_handler, SA_ONSTACK, |
249 | SIGUSR1, SIGIO, SIGWINCH, SIGALRM, SIGVTALRM, -1); | 249 | SIGUSR1, SIGIO, SIGWINCH, SIGVTALRM, -1); |
250 | signal(SIGHUP, SIG_IGN); | 250 | signal(SIGHUP, SIG_IGN); |
251 | 251 | ||
252 | init_irq_signals(1); | 252 | init_irq_signals(1); |
diff --git a/arch/um/os-Linux/signal.c b/arch/um/os-Linux/signal.c index fbad174775ee..e9800b0b5689 100644 --- a/arch/um/os-Linux/signal.c +++ b/arch/um/os-Linux/signal.c | |||
@@ -15,8 +15,7 @@ | |||
15 | #include "user.h" | 15 | #include "user.h" |
16 | 16 | ||
17 | /* | 17 | /* |
18 | * These are the asynchronous signals. SIGVTALRM and SIGARLM are handled | 18 | * These are the asynchronous signals. SIGPROF is excluded because we want to |
19 | * together under SIGVTALRM_BIT. SIGPROF is excluded because we want to | ||
20 | * be able to profile all of UML, not just the non-critical sections. If | 19 | * be able to profile all of UML, not just the non-critical sections. If |
21 | * profiling is not thread-safe, then that is not my problem. We can disable | 20 | * profiling is not thread-safe, then that is not my problem. We can disable |
22 | * profiling when SMP is enabled in that case. | 21 | * profiling when SMP is enabled in that case. |
@@ -27,9 +26,6 @@ | |||
27 | #define SIGVTALRM_BIT 1 | 26 | #define SIGVTALRM_BIT 1 |
28 | #define SIGVTALRM_MASK (1 << SIGVTALRM_BIT) | 27 | #define SIGVTALRM_MASK (1 << SIGVTALRM_BIT) |
29 | 28 | ||
30 | #define SIGALRM_BIT 2 | ||
31 | #define SIGALRM_MASK (1 << SIGALRM_BIT) | ||
32 | |||
33 | /* | 29 | /* |
34 | * These are used by both the signal handlers and | 30 | * These are used by both the signal handlers and |
35 | * block/unblock_signals. I don't want modifications cached in a | 31 | * block/unblock_signals. I don't want modifications cached in a |
@@ -55,7 +51,7 @@ void sig_handler(int sig, struct sigcontext *sc) | |||
55 | set_signals(enabled); | 51 | set_signals(enabled); |
56 | } | 52 | } |
57 | 53 | ||
58 | static void real_alarm_handler(int sig, struct sigcontext *sc) | 54 | static void real_alarm_handler(struct sigcontext *sc) |
59 | { | 55 | { |
60 | struct uml_pt_regs regs; | 56 | struct uml_pt_regs regs; |
61 | 57 | ||
@@ -63,7 +59,7 @@ static void real_alarm_handler(int sig, struct sigcontext *sc) | |||
63 | copy_sc(®s, sc); | 59 | copy_sc(®s, sc); |
64 | regs.is_user = 0; | 60 | regs.is_user = 0; |
65 | unblock_signals(); | 61 | unblock_signals(); |
66 | timer_handler(sig, ®s); | 62 | timer_handler(SIGVTALRM, ®s); |
67 | } | 63 | } |
68 | 64 | ||
69 | void alarm_handler(int sig, struct sigcontext *sc) | 65 | void alarm_handler(int sig, struct sigcontext *sc) |
@@ -72,27 +68,20 @@ void alarm_handler(int sig, struct sigcontext *sc) | |||
72 | 68 | ||
73 | enabled = signals_enabled; | 69 | enabled = signals_enabled; |
74 | if (!signals_enabled) { | 70 | if (!signals_enabled) { |
75 | if (sig == SIGVTALRM) | 71 | pending |= SIGVTALRM_MASK; |
76 | pending |= SIGVTALRM_MASK; | ||
77 | else pending |= SIGALRM_MASK; | ||
78 | |||
79 | return; | 72 | return; |
80 | } | 73 | } |
81 | 74 | ||
82 | block_signals(); | 75 | block_signals(); |
83 | 76 | ||
84 | real_alarm_handler(sig, sc); | 77 | real_alarm_handler(sc); |
85 | set_signals(enabled); | 78 | set_signals(enabled); |
86 | } | 79 | } |
87 | 80 | ||
88 | void timer_init(void) | 81 | void timer_init(void) |
89 | { | 82 | { |
90 | set_handler(SIGVTALRM, (__sighandler_t) alarm_handler, | 83 | set_handler(SIGVTALRM, (__sighandler_t) alarm_handler, |
91 | SA_ONSTACK | SA_RESTART, SIGUSR1, SIGIO, SIGWINCH, | 84 | SA_ONSTACK | SA_RESTART, SIGUSR1, SIGIO, SIGWINCH, -1); |
92 | SIGALRM, -1); | ||
93 | set_handler(SIGALRM, (__sighandler_t) alarm_handler, | ||
94 | SA_ONSTACK | SA_RESTART, SIGUSR1, SIGIO, SIGWINCH, | ||
95 | SIGALRM, -1); | ||
96 | } | 85 | } |
97 | 86 | ||
98 | void set_sigstack(void *sig_stack, int size) | 87 | void set_sigstack(void *sig_stack, int size) |
@@ -267,11 +256,8 @@ void unblock_signals(void) | |||
267 | if (save_pending & SIGIO_MASK) | 256 | if (save_pending & SIGIO_MASK) |
268 | sig_handler_common_skas(SIGIO, NULL); | 257 | sig_handler_common_skas(SIGIO, NULL); |
269 | 258 | ||
270 | if (save_pending & SIGALRM_MASK) | ||
271 | real_alarm_handler(SIGALRM, NULL); | ||
272 | |||
273 | if (save_pending & SIGVTALRM_MASK) | 259 | if (save_pending & SIGVTALRM_MASK) |
274 | real_alarm_handler(SIGVTALRM, NULL); | 260 | real_alarm_handler(NULL); |
275 | } | 261 | } |
276 | } | 262 | } |
277 | 263 | ||
diff --git a/arch/um/os-Linux/skas/process.c b/arch/um/os-Linux/skas/process.c index 3e64814e888e..9936531a2620 100644 --- a/arch/um/os-Linux/skas/process.c +++ b/arch/um/os-Linux/skas/process.c | |||
@@ -222,7 +222,6 @@ static int userspace_tramp(void *stack) | |||
222 | sigemptyset(&sa.sa_mask); | 222 | sigemptyset(&sa.sa_mask); |
223 | sigaddset(&sa.sa_mask, SIGIO); | 223 | sigaddset(&sa.sa_mask, SIGIO); |
224 | sigaddset(&sa.sa_mask, SIGWINCH); | 224 | sigaddset(&sa.sa_mask, SIGWINCH); |
225 | sigaddset(&sa.sa_mask, SIGALRM); | ||
226 | sigaddset(&sa.sa_mask, SIGVTALRM); | 225 | sigaddset(&sa.sa_mask, SIGVTALRM); |
227 | sigaddset(&sa.sa_mask, SIGUSR1); | 226 | sigaddset(&sa.sa_mask, SIGUSR1); |
228 | sa.sa_flags = SA_ONSTACK; | 227 | sa.sa_flags = SA_ONSTACK; |
@@ -539,8 +538,7 @@ int start_idle_thread(void *stack, jmp_buf *switch_buf) | |||
539 | int n; | 538 | int n; |
540 | 539 | ||
541 | set_handler(SIGWINCH, (__sighandler_t) sig_handler, | 540 | set_handler(SIGWINCH, (__sighandler_t) sig_handler, |
542 | SA_ONSTACK | SA_RESTART, SIGUSR1, SIGIO, SIGALRM, | 541 | SA_ONSTACK | SA_RESTART, SIGUSR1, SIGIO, SIGVTALRM, -1); |
543 | SIGVTALRM, -1); | ||
544 | 542 | ||
545 | /* | 543 | /* |
546 | * Can't use UML_SETJMP or UML_LONGJMP here because they save | 544 | * Can't use UML_SETJMP or UML_LONGJMP here because they save |
diff --git a/arch/um/os-Linux/skas/trap.c b/arch/um/os-Linux/skas/trap.c index e53face44200..3b1b9244f468 100644 --- a/arch/um/os-Linux/skas/trap.c +++ b/arch/um/os-Linux/skas/trap.c | |||
@@ -58,9 +58,8 @@ void sig_handler_common_skas(int sig, void *sc_ptr) | |||
58 | 58 | ||
59 | handler = sig_info[sig]; | 59 | handler = sig_info[sig]; |
60 | 60 | ||
61 | /* unblock SIGALRM, SIGVTALRM, SIGIO if sig isn't IRQ signal */ | 61 | /* unblock SIGVTALRM, SIGIO if sig isn't IRQ signal */ |
62 | if (sig != SIGIO && sig != SIGWINCH && | 62 | if ((sig != SIGIO) && (sig != SIGWINCH) && (sig != SIGVTALRM)) |
63 | sig != SIGVTALRM && sig != SIGALRM) | ||
64 | unblock_signals(); | 63 | unblock_signals(); |
65 | 64 | ||
66 | handler(sig, r); | 65 | handler(sig, r); |
diff --git a/arch/um/os-Linux/trap.c b/arch/um/os-Linux/trap.c index d3a34ca8a891..2a1c9843e32e 100644 --- a/arch/um/os-Linux/trap.c +++ b/arch/um/os-Linux/trap.c | |||
@@ -20,5 +20,4 @@ void os_fill_handlinfo(struct kern_handlers h) | |||
20 | sig_info[SIGSEGV] = h.page_fault; | 20 | sig_info[SIGSEGV] = h.page_fault; |
21 | sig_info[SIGIO] = h.sigio_handler; | 21 | sig_info[SIGIO] = h.sigio_handler; |
22 | sig_info[SIGVTALRM] = h.timer_handler; | 22 | sig_info[SIGVTALRM] = h.timer_handler; |
23 | sig_info[SIGALRM] = h.timer_handler; | ||
24 | } | 23 | } |