Oleg Nesterov
d36174bc2b
uglify kill_pid_info() to fix kill() vs exec() race
...
kill_pid_info()->pid_task() could be the old leader of the execing process.
In that case it is possible that the leader will be released before we take
siglock. This means that kill_pid_info() (and thus sys_kill()) can return a
false -ESRCH.
Change the code to retry when lock_task_sighand() fails. The endless loop is
not possible, __exit_signal() both clears ->sighand and does detach_pid().
Signed-off-by: Oleg Nesterov <oleg@tv-sign.ru>
Cc: "Eric W. Biederman" <ebiederm@xmission.com>
Cc: Davide Libenzi <davidel@xmailserver.org>
Cc: Pavel Emelyanov <xemul@openvz.org>
Cc: Roland McGrath <roland@redhat.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2008-02-08 09:22:28 -08:00
..
2008-01-30 13:33:24 +01:00
2008-02-07 01:27:17 -05:00
2008-02-06 10:41:03 -08:00
2008-01-07 14:55:37 -08:00
2007-10-21 02:37:45 -04:00
2008-02-01 14:25:04 -05:00
2007-10-21 02:37:45 -04:00
2008-02-01 14:24:33 -05:00
2008-02-01 14:24:45 -05:00
2008-01-30 13:33:08 +01:00
2008-02-05 09:44:20 -08:00
2007-10-19 11:53:36 -07:00
2008-02-07 08:42:22 -08:00
2007-10-18 15:12:41 -07:00
2008-01-25 21:08:02 +01:00
2008-02-08 09:22:24 -08:00
2007-10-18 14:37:28 -07:00
2007-10-18 14:37:24 -07:00
2007-10-18 14:37:26 -07:00
2008-02-08 09:22:27 -08:00
2008-01-29 17:13:18 +11:00
2008-02-07 08:42:18 -08:00
2008-02-01 17:45:14 +01:00
2008-02-01 17:45:14 +01:00
2008-02-05 09:44:07 -08:00
2007-10-18 14:37:26 -07:00
2008-02-06 10:41:01 -08:00
2008-01-25 21:08:29 +01:00
2008-01-25 21:08:33 +01:00
2008-02-07 08:42:25 -08:00
2007-07-16 09:05:50 -07:00
2008-01-17 15:38:59 -08:00
2008-02-06 10:41:11 -08:00
2008-01-24 20:40:40 -08:00
2008-01-25 21:08:33 +01:00
2008-01-25 21:08:34 +01:00
2007-10-11 22:11:11 +02:00
2008-01-25 21:08:02 +01:00
2008-02-08 09:22:23 -08:00
2007-11-14 18:45:40 -08:00
2008-02-08 09:22:24 -08:00
2007-12-06 17:37:59 -05:00
2008-02-06 10:41:02 -08:00
2007-10-19 11:53:37 -07:00
2008-02-08 09:22:23 -08:00
2008-02-06 22:07:51 -05:00
2008-02-06 10:41:08 -08:00
2008-02-08 09:22:23 -08:00
2008-02-08 09:22:27 -08:00
2008-02-05 09:44:22 -08:00
2008-01-25 21:08:32 +01:00
2008-02-05 09:44:07 -08:00
2008-02-06 10:41:04 -08:00
2008-01-25 21:08:33 +01:00
2008-02-08 09:22:26 -08:00
2008-01-25 21:08:24 +01:00
2008-01-25 21:08:24 +01:00
2008-01-25 21:08:24 +01:00
2008-01-25 21:08:25 +01:00
2008-01-25 21:08:02 +01:00
2008-02-06 10:41:07 -08:00
2008-02-07 08:42:18 -08:00
2007-11-14 18:45:39 -08:00
2007-07-16 09:05:49 -07:00
2007-10-19 11:53:43 -07:00
2008-01-24 20:40:40 -08:00
2007-10-19 11:53:43 -07:00
2007-12-18 15:21:13 +01:00
2008-01-25 21:08:35 +01:00
2008-01-31 22:45:22 +01:00
2008-01-25 21:08:29 +01:00
2008-01-25 21:08:34 +01:00
2007-11-28 15:52:56 +01:00
2008-02-01 11:45:47 +11:00
2007-07-16 09:05:50 -07:00
2008-02-08 09:22:28 -08:00
2008-01-30 13:30:04 +01:00
2008-02-02 14:27:45 +11:00
2008-01-30 13:31:20 +01:00
2008-02-06 10:41:02 -08:00
2008-02-06 10:41:08 -08:00
2008-02-05 09:44:07 -08:00
2008-02-08 09:22:28 -08:00
2008-02-05 09:44:20 -08:00
2008-02-08 09:22:23 -08:00
2007-11-14 18:45:44 -08:00
2008-02-06 10:41:11 -08:00
2008-02-06 10:41:10 -08:00
2008-02-06 10:41:00 -08:00
2007-10-18 14:37:28 -07:00
2008-02-08 09:22:23 -08:00
2008-02-08 09:22:23 -08:00
2007-11-29 09:24:53 -08:00
2007-09-19 11:24:17 -07:00
2007-12-06 17:34:36 -05:00
2008-01-25 21:08:02 +01:00