diff options
author | Tejun Heo <tj@kernel.org> | 2011-06-02 05:14:00 -0400 |
---|---|---|
committer | Oleg Nesterov <oleg@redhat.com> | 2011-06-04 12:17:11 -0400 |
commit | 6dfca32984237a8a011b5bf367e53341a265b2a4 (patch) | |
tree | a879c682f00921959ee28b563b9024c0ac54f861 /fs/exec.c | |
parent | 3759a0d94c18764247b66511d1038f2b93aa95de (diff) |
job control: make task_clear_jobctl_pending() clear TRAPPING automatically
JOBCTL_TRAPPING indicates that ptracer is waiting for tracee to
(re)transit into TRACED. task_clear_jobctl_pending() must be called
when either tracee enters TRACED or the transition is cancelled for
some reason. The former is achieved by explicitly calling
task_clear_jobctl_pending() in ptrace_stop() and the latter by calling
it at the end of do_signal_stop().
Calling task_clear_jobctl_trapping() at the end of do_signal_stop()
limits the scope TRAPPING can be used and is fragile in that seemingly
unrelated changes to tracee's control flow can lead to stuck TRAPPING.
We already have task_clear_jobctl_pending() calls on those cancelling
events to clear JOBCTL_STOP_PENDING. Cancellations can be handled by
making those call sites use JOBCTL_PENDING_MASK instead and updating
task_clear_jobctl_pending() such that task_clear_jobctl_trapping() is
called automatically if no stop/trap is pending.
This patch makes the above changes and removes the fallback
task_clear_jobctl_trapping() call from do_signal_stop().
Signed-off-by: Tejun Heo <tj@kernel.org>
Signed-off-by: Oleg Nesterov <oleg@redhat.com>
Diffstat (limited to 'fs/exec.c')
-rw-r--r-- | fs/exec.c | 2 |
1 files changed, 1 insertions, 1 deletions
@@ -1772,7 +1772,7 @@ static int zap_process(struct task_struct *start, int exit_code) | |||
1772 | 1772 | ||
1773 | t = start; | 1773 | t = start; |
1774 | do { | 1774 | do { |
1775 | task_clear_jobctl_pending(t, JOBCTL_STOP_PENDING); | 1775 | task_clear_jobctl_pending(t, JOBCTL_PENDING_MASK); |
1776 | if (t != current && t->mm) { | 1776 | if (t != current && t->mm) { |
1777 | sigaddset(&t->pending.signal, SIGKILL); | 1777 | sigaddset(&t->pending.signal, SIGKILL); |
1778 | signal_wake_up(t, 1); | 1778 | signal_wake_up(t, 1); |