diff options
author | Al Viro <viro@zeniv.linux.org.uk> | 2012-04-22 03:33:45 -0400 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2012-05-21 23:52:39 -0400 |
commit | f2ccfb3e565f51f1063d68f119d5b42a7f5fd984 (patch) | |
tree | c810ac134bdcb6647ab5fb69f743aededa198dea | |
parent | 58e4257bc6336db015673a8cb598bd6cdbecf6d1 (diff) |
score: ->restart_block.fn needs to be reset on rt_sigreturn
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
-rw-r--r-- | arch/score/kernel/signal.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/arch/score/kernel/signal.c b/arch/score/kernel/signal.c index 5a5bd1763336..c3fded7357f0 100644 --- a/arch/score/kernel/signal.c +++ b/arch/score/kernel/signal.c | |||
@@ -152,6 +152,9 @@ score_rt_sigreturn(struct pt_regs *regs) | |||
152 | stack_t st; | 152 | stack_t st; |
153 | int sig; | 153 | int sig; |
154 | 154 | ||
155 | /* Always make any pending restarted system calls return -EINTR */ | ||
156 | current_thread_info()->restart_block.fn = do_no_restart_syscall; | ||
157 | |||
155 | frame = (struct rt_sigframe __user *) regs->regs[0]; | 158 | frame = (struct rt_sigframe __user *) regs->regs[0]; |
156 | if (!access_ok(VERIFY_READ, frame, sizeof(*frame))) | 159 | if (!access_ok(VERIFY_READ, frame, sizeof(*frame))) |
157 | goto badframe; | 160 | goto badframe; |