From: Al Viro Date: Thu, 26 Apr 2012 22:17:28 +0000 (-0400) Subject: unicore32: if there's no handler we need to restore sigmask, syscall or no syscall X-Git-Tag: firefly_0821_release~3680^2~2783^2 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=415d04d08fec74b226c92c1fb54ad117c9c6bac4;p=firefly-linux-kernel-4.4.55.git unicore32: if there's no handler we need to restore sigmask, syscall or no syscall Signed-off-by: Al Viro --- diff --git a/arch/unicore32/kernel/signal.c b/arch/unicore32/kernel/signal.c index 72d953190419..7754df6ef7d4 100644 --- a/arch/unicore32/kernel/signal.c +++ b/arch/unicore32/kernel/signal.c @@ -447,15 +447,12 @@ static void do_signal(struct pt_regs *regs, int syscall) regs->UCreg_00 == -ERESTARTNOINTR) { setup_syscall_restart(regs); } - - /* If there's no signal to deliver, we just put the saved - * sigmask back. - */ - if (test_thread_flag(TIF_RESTORE_SIGMASK)) { - clear_thread_flag(TIF_RESTORE_SIGMASK); - sigprocmask(SIG_SETMASK, ¤t->saved_sigmask, NULL); - } } + /* If there's no signal to deliver, we just put the saved + * sigmask back. + */ + if (test_and_clear_thread_flag(TIF_RESTORE_SIGMASK)) + set_current_blocked(¤t->saved_sigmask); } asmlinkage void do_notify_resume(struct pt_regs *regs,