diff options
Diffstat (limited to 'kernel/ptrace.c')
-rw-r--r-- | kernel/ptrace.c | 8 |
1 files changed, 3 insertions, 5 deletions
diff --git a/kernel/ptrace.c b/kernel/ptrace.c index 43485866749a..20d5efdeee02 100644 --- a/kernel/ptrace.c +++ b/kernel/ptrace.c | |||
@@ -112,16 +112,14 @@ int ptrace_check_attach(struct task_struct *child, int kill) | |||
112 | */ | 112 | */ |
113 | read_lock(&tasklist_lock); | 113 | read_lock(&tasklist_lock); |
114 | if ((child->ptrace & PT_PTRACED) && child->parent == current) { | 114 | if ((child->ptrace & PT_PTRACED) && child->parent == current) { |
115 | ret = 0; | ||
116 | /* | 115 | /* |
117 | * child->sighand can't be NULL, release_task() | 116 | * child->sighand can't be NULL, release_task() |
118 | * does ptrace_unlink() before __exit_signal(). | 117 | * does ptrace_unlink() before __exit_signal(). |
119 | */ | 118 | */ |
120 | spin_lock_irq(&child->sighand->siglock); | 119 | spin_lock_irq(&child->sighand->siglock); |
121 | if (task_is_stopped(child)) | 120 | WARN_ON_ONCE(task_is_stopped(child)); |
122 | child->state = TASK_TRACED; | 121 | if (task_is_traced(child) || kill) |
123 | else if (!task_is_traced(child) && !kill) | 122 | ret = 0; |
124 | ret = -ESRCH; | ||
125 | spin_unlock_irq(&child->sighand->siglock); | 123 | spin_unlock_irq(&child->sighand->siglock); |
126 | } | 124 | } |
127 | read_unlock(&tasklist_lock); | 125 | read_unlock(&tasklist_lock); |