aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAl Viro <viro@zeniv.linux.org.uk>2012-05-02 21:45:12 -0400
committerRalf Baechle <ralf@linux-mips.org>2012-09-22 09:47:11 -0400
commitf76f330809e0c9e7235584273b5a5d6adccded52 (patch)
tree7130f75428064a7df4c6d8da1b6ce66ebb3d5419
parente376fdf42062e7373b82093b278f99aa2b547db7 (diff)
MIPS: Prevent hitting do_notify_resume() with !user_mode(regs).
Too late to do anything there... Signed-off-by: Al Viro <viro@zeniv.linux.org.uk> Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
-rw-r--r--arch/mips/kernel/entry.S3
-rw-r--r--arch/mips/kernel/signal.c8
2 files changed, 3 insertions, 8 deletions
diff --git a/arch/mips/kernel/entry.S b/arch/mips/kernel/entry.S
index 37acfa036d44..4b0937f19862 100644
--- a/arch/mips/kernel/entry.S
+++ b/arch/mips/kernel/entry.S
@@ -167,6 +167,9 @@ work_notifysig: # deal with pending signals and
167FEXPORT(syscall_exit_work_partial) 167FEXPORT(syscall_exit_work_partial)
168 SAVE_STATIC 168 SAVE_STATIC
169syscall_exit_work: 169syscall_exit_work:
170 LONG_L t0, PT_STATUS(sp) # returning to kernel mode?
171 andi t0, t0, KU_USER
172 beqz t0, resume_kernel
170 li t0, _TIF_WORK_SYSCALL_EXIT 173 li t0, _TIF_WORK_SYSCALL_EXIT
171 and t0, a2 # a2 is preloaded with TI_FLAGS 174 and t0, a2 # a2 is preloaded with TI_FLAGS
172 beqz t0, work_pending # trace bit set? 175 beqz t0, work_pending # trace bit set?
diff --git a/arch/mips/kernel/signal.c b/arch/mips/kernel/signal.c
index f2c09cfc60ac..0e1a5b8ae817 100644
--- a/arch/mips/kernel/signal.c
+++ b/arch/mips/kernel/signal.c
@@ -560,14 +560,6 @@ static void do_signal(struct pt_regs *regs)
560 siginfo_t info; 560 siginfo_t info;
561 int signr; 561 int signr;
562 562
563 /*
564 * We want the common case to go fast, which is why we may in certain
565 * cases get here from kernel mode. Just return without doing anything
566 * if so.
567 */
568 if (!user_mode(regs))
569 return;
570
571 signr = get_signal_to_deliver(&info, &ka, regs, NULL); 563 signr = get_signal_to_deliver(&info, &ka, regs, NULL);
572 if (signr > 0) { 564 if (signr > 0) {
573 /* Whee! Actually deliver the signal. */ 565 /* Whee! Actually deliver the signal. */