Oleg Nesterov
eac1b5e57d
ptrace: do_wait(traced_leader_killed_by_mt_exec) can block forever
...
Test-case:
void *tfunc(void *arg)
{
execvp("true", NULL);
return NULL;
}
int main(void)
{
int pid;
if (fork()) {
pthread_t t;
kill(getpid(), SIGSTOP);
pthread_create(&t, NULL, tfunc, NULL);
for (;;)
pause();
}
pid = getppid();
assert(ptrace(PTRACE_ATTACH, pid, 0,0) == 0);
while (wait(NULL) > 0)
ptrace(PTRACE_CONT, pid, 0,0);
return 0;
}
It is racy, exit_notify() does __wake_up_parent() too. But in the
likely case it triggers the problem: de_thread() does release_task()
and the old leader goes away without the notification, the tracer
sleeps in do_wait() without children/tracees.
Change de_thread() to do __wake_up_parent(traced_leader->parent).
Since it is already EXIT_DEAD we can do this without ptrace_unlink(),
EXIT_DEAD threads do not exist from do_wait's pov.
Signed-off-by: Oleg Nesterov <oleg@redhat.com>
Acked-by: Tejun Heo <tj@kernel.org>
2011-07-22 15:10:49 +02:00
..
2011-05-28 01:02:53 -04:00
2011-03-31 11:26:23 -03:00
2011-05-28 01:02:53 -04:00
2011-05-28 01:02:53 -04:00
2011-05-30 01:50:53 -04:00
2011-03-31 11:26:23 -03:00
2011-05-28 01:02:50 -04:00
2011-05-28 13:03:41 -07:00
2011-03-31 11:26:23 -03:00
2011-05-26 07:26:53 -04:00
2011-05-29 11:17:34 -07:00
2011-05-28 01:02:53 -04:00
2011-05-28 01:02:54 -04:00
2011-01-13 08:03:23 -08:00
2011-05-19 16:55:28 +09:30
2011-03-22 17:44:17 -07:00
2011-05-26 13:19:00 -07:00
2011-05-29 14:24:25 -05:00
2011-03-10 08:52:07 +01:00
2011-05-26 07:26:57 -04:00
2011-03-15 02:21:44 -04:00
2011-05-26 07:26:56 -04:00
2011-05-27 07:04:40 -04:00
2011-05-27 07:04:40 -04:00
2011-05-28 01:02:54 -04:00
2011-05-10 10:16:21 +02:00
2011-05-25 08:39:44 -07:00
2011-05-28 01:02:53 -04:00
2011-05-26 13:19:00 -07:00
2011-05-28 01:02:52 -04:00
2011-05-28 01:02:52 -04:00
2011-05-28 01:02:52 -04:00
2011-05-28 01:02:54 -04:00
2011-01-07 17:50:26 +11:00
2011-05-26 09:20:31 -07:00
2011-03-24 10:16:26 -07:00
2011-05-24 00:27:53 +02:00
2011-05-26 09:53:20 -07:00
2011-05-28 13:03:41 -07:00
2011-05-28 01:02:51 -04:00
2011-01-25 15:24:47 -05:00
2011-05-28 01:02:51 -04:00
2011-05-28 01:02:54 -04:00
2011-05-28 01:02:53 -04:00
2011-05-29 14:10:13 -07:00
2011-03-31 11:26:23 -03:00
2011-05-29 11:21:12 -07:00
2011-05-28 01:02:51 -04:00
2011-04-07 11:14:49 -07:00
2011-03-31 11:26:23 -03:00
2011-05-27 10:23:10 -07:00
2011-05-28 01:02:52 -04:00
2011-01-07 17:50:26 +11:00
2011-05-30 07:42:51 +02:00
2011-06-22 19:26:29 +02:00
2011-05-16 11:05:00 -07:00
2011-03-10 08:52:07 +01:00
2011-05-25 08:39:26 -07:00
2011-04-14 16:06:56 -07:00
2011-05-28 01:02:51 -04:00
2011-01-07 17:50:26 +11:00
2011-05-29 11:19:45 -07:00
2011-05-13 16:05:51 -07:00
2011-05-28 01:02:50 -04:00
2011-06-03 18:12:31 +03:00
2011-05-28 01:02:52 -04:00
2011-05-28 01:02:51 -04:00
2011-05-27 07:04:40 -04:00
2011-03-24 10:16:26 -07:00
2011-01-16 13:47:07 -05:00
2011-05-28 12:02:09 -04:00
2011-01-07 17:50:29 +11:00
2011-04-14 16:06:55 -07:00
2011-05-03 10:10:51 +10:00
2011-03-17 11:11:05 +01:00
2011-05-28 14:44:46 +02:00
2011-06-01 08:28:47 +02:00
2011-05-28 01:03:21 -04:00
2011-01-13 10:45:01 -08:00
2011-01-07 14:39:20 -08:00
2011-04-09 15:53:56 +02:00
2011-05-25 08:39:26 -07:00
2011-03-24 10:16:26 -07:00
2011-05-25 08:39:26 -07:00
2011-02-21 15:07:04 -08:00
2011-03-31 11:26:23 -03:00
2011-07-22 15:10:49 +02:00
2011-03-23 19:47:13 -07:00
2011-04-14 16:06:56 -07:00
2011-03-21 00:16:09 -04:00
2011-03-16 13:26:17 -07:00
2011-04-28 11:28:20 -07:00
2011-04-17 10:42:01 -07:00
2011-01-16 13:47:07 -05:00
2011-05-27 07:04:40 -04:00
2011-03-23 19:47:13 -07:00
2011-05-27 09:43:00 -04:00
2011-03-24 21:17:51 -04:00
2011-03-21 00:16:08 -04:00
2011-05-26 09:52:14 -07:00
2011-05-26 07:26:50 -04:00
2011-03-24 08:20:39 -07:00
2011-03-16 19:01:29 -07:00
2011-05-25 08:39:26 -07:00
2011-05-26 10:01:43 -06:00
2011-05-30 01:48:27 -04:00
2011-05-26 07:26:44 -04:00
2011-03-14 09:15:28 -04:00
2011-03-21 01:10:41 -04:00
2011-01-20 16:21:59 -08:00
2011-01-07 17:50:33 +11:00
2011-01-25 15:24:47 -05:00
2011-01-12 20:06:58 -05:00
2011-03-21 00:16:08 -04:00
2011-05-23 19:58:53 +02:00
2011-03-15 02:21:45 -04:00
2011-03-14 09:15:28 -04:00
2011-05-26 10:50:56 -07:00
2011-03-24 10:16:26 -07:00
2011-05-23 13:59:53 +02:00
2011-03-23 19:47:13 -07:00
2011-05-28 12:02:09 -04:00