diff options
Diffstat (limited to 'arch/sh/kernel/signal_64.c')
| -rw-r--r-- | arch/sh/kernel/signal_64.c | 13 |
1 files changed, 6 insertions, 7 deletions
diff --git a/arch/sh/kernel/signal_64.c b/arch/sh/kernel/signal_64.c index 74793c80a57a..feb3dddd3192 100644 --- a/arch/sh/kernel/signal_64.c +++ b/arch/sh/kernel/signal_64.c | |||
| @@ -101,7 +101,7 @@ static int do_signal(struct pt_regs *regs, sigset_t *oldset) | |||
| 101 | if (try_to_freeze()) | 101 | if (try_to_freeze()) |
| 102 | goto no_signal; | 102 | goto no_signal; |
| 103 | 103 | ||
| 104 | if (test_thread_flag(TIF_RESTORE_SIGMASK)) | 104 | if (current_thread_info()->status & TS_RESTORE_SIGMASK) |
| 105 | oldset = ¤t->saved_sigmask; | 105 | oldset = ¤t->saved_sigmask; |
| 106 | else if (!oldset) | 106 | else if (!oldset) |
| 107 | oldset = ¤t->blocked; | 107 | oldset = ¤t->blocked; |
| @@ -115,11 +115,9 @@ static int do_signal(struct pt_regs *regs, sigset_t *oldset) | |||
| 115 | /* | 115 | /* |
| 116 | * If a signal was successfully delivered, the | 116 | * If a signal was successfully delivered, the |
| 117 | * saved sigmask is in its frame, and we can | 117 | * saved sigmask is in its frame, and we can |
| 118 | * clear the TIF_RESTORE_SIGMASK flag. | 118 | * clear the TS_RESTORE_SIGMASK flag. |
| 119 | */ | 119 | */ |
| 120 | if (test_thread_flag(TIF_RESTORE_SIGMASK)) | 120 | current_thread_info()->status &= ~TS_RESTORE_SIGMASK; |
| 121 | clear_thread_flag(TIF_RESTORE_SIGMASK); | ||
| 122 | |||
| 123 | tracehook_signal_handler(signr, &info, &ka, regs, 0); | 121 | tracehook_signal_handler(signr, &info, &ka, regs, 0); |
| 124 | return 1; | 122 | return 1; |
| 125 | } | 123 | } |
| @@ -146,8 +144,8 @@ no_signal: | |||
| 146 | } | 144 | } |
| 147 | 145 | ||
| 148 | /* No signal to deliver -- put the saved sigmask back */ | 146 | /* No signal to deliver -- put the saved sigmask back */ |
| 149 | if (test_thread_flag(TIF_RESTORE_SIGMASK)) { | 147 | if (current_thread_info()->status & TS_RESTORE_SIGMASK) { |
| 150 | clear_thread_flag(TIF_RESTORE_SIGMASK); | 148 | current_thread_info()->status &= ~TS_RESTORE_SIGMASK; |
| 151 | sigprocmask(SIG_SETMASK, ¤t->saved_sigmask, NULL); | 149 | sigprocmask(SIG_SETMASK, ¤t->saved_sigmask, NULL); |
| 152 | } | 150 | } |
| 153 | 151 | ||
| @@ -176,6 +174,7 @@ sys_sigsuspend(old_sigset_t mask, | |||
| 176 | while (1) { | 174 | while (1) { |
| 177 | current->state = TASK_INTERRUPTIBLE; | 175 | current->state = TASK_INTERRUPTIBLE; |
| 178 | schedule(); | 176 | schedule(); |
| 177 | set_restore_sigmask(); | ||
| 179 | regs->pc += 4; /* because sys_sigreturn decrements the pc */ | 178 | regs->pc += 4; /* because sys_sigreturn decrements the pc */ |
| 180 | if (do_signal(regs, &saveset)) { | 179 | if (do_signal(regs, &saveset)) { |
| 181 | /* pc now points at signal handler. Need to decrement | 180 | /* pc now points at signal handler. Need to decrement |
