diff options
Diffstat (limited to 'arch/ppc64/kernel/ptrace32.c')
| -rw-r--r-- | arch/ppc64/kernel/ptrace32.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/arch/ppc64/kernel/ptrace32.c b/arch/ppc64/kernel/ptrace32.c index ee81b1b776cc..16436426c7e2 100644 --- a/arch/ppc64/kernel/ptrace32.c +++ b/arch/ppc64/kernel/ptrace32.c | |||
| @@ -26,6 +26,7 @@ | |||
| 26 | #include <linux/ptrace.h> | 26 | #include <linux/ptrace.h> |
| 27 | #include <linux/user.h> | 27 | #include <linux/user.h> |
| 28 | #include <linux/security.h> | 28 | #include <linux/security.h> |
| 29 | #include <linux/signal.h> | ||
| 29 | 30 | ||
| 30 | #include <asm/uaccess.h> | 31 | #include <asm/uaccess.h> |
| 31 | #include <asm/page.h> | 32 | #include <asm/page.h> |
| @@ -293,7 +294,7 @@ int sys32_ptrace(long request, long pid, unsigned long addr, unsigned long data) | |||
| 293 | case PTRACE_SYSCALL: /* continue and stop at next (return from) syscall */ | 294 | case PTRACE_SYSCALL: /* continue and stop at next (return from) syscall */ |
| 294 | case PTRACE_CONT: { /* restart after signal. */ | 295 | case PTRACE_CONT: { /* restart after signal. */ |
| 295 | ret = -EIO; | 296 | ret = -EIO; |
| 296 | if ((unsigned long) data > _NSIG) | 297 | if (!valid_signal(data)) |
| 297 | break; | 298 | break; |
| 298 | if (request == PTRACE_SYSCALL) | 299 | if (request == PTRACE_SYSCALL) |
| 299 | set_tsk_thread_flag(child, TIF_SYSCALL_TRACE); | 300 | set_tsk_thread_flag(child, TIF_SYSCALL_TRACE); |
| @@ -325,7 +326,7 @@ int sys32_ptrace(long request, long pid, unsigned long addr, unsigned long data) | |||
| 325 | 326 | ||
| 326 | case PTRACE_SINGLESTEP: { /* set the trap flag. */ | 327 | case PTRACE_SINGLESTEP: { /* set the trap flag. */ |
| 327 | ret = -EIO; | 328 | ret = -EIO; |
| 328 | if ((unsigned long) data > _NSIG) | 329 | if (!valid_signal(data)) |
| 329 | break; | 330 | break; |
| 330 | clear_tsk_thread_flag(child, TIF_SYSCALL_TRACE); | 331 | clear_tsk_thread_flag(child, TIF_SYSCALL_TRACE); |
| 331 | set_single_step(child); | 332 | set_single_step(child); |
