Oleg Nesterov <[email protected]> writes:
> p->exit_state != 0 doesn't mean this process is dead, it may have sub-threads.
>
> However, the new "p->exit_state && thread_group_empty(p)" check is not correct
> either, this is just the temporary hack. Perhaps we can just remove this check,
> but I don't understand orphaned process groups magic. At all. However, I think
> exit_notify() is obviously and completely wrong wrt this helper.
The problem that orphaned processes groups address is what happens if
an entire process group is stopped, and there is not a process that
can wake them up.
The rule for an unprivileged process sending a signal to a process
group is that it must be in the same session as the process group.
The rule for sending a signal to a process group is that the signal sender
must be in the same session.
So we are testing for a process group that does not have a living
member with a parent outside of the process that can send the process
group a signal.
The test for init seems bogus. /sbin/init rarely if ever starts
processes in it's own session which is likely why this has not caused
problems. If we keep the test for init we need to make the test
is_container_init rather the is global_init.
As for exit_notify I agree. We need a thread_group_exit_notify.
That is responsible for performing work when we know the entire
thread group has exited. Sending the exit_signal and performing
the through group orphaned check look like two of those tasks
that need to be performed only at thread group exit.
Oleg what do you see wrong with checking p->exit_state &&
thread_group_empty(p)? Since non-leader threads all self reap
that seems to be a valid test for an dead thread group.
Eric
> Signed-off-by: Oleg Nesterov <[email protected]>
>
> --- PT/kernel/exit.c~4_orphaned_pgrp 2007-12-06 18:06:09.000000000 +0300
> +++ PT/kernel/exit.c 2007-12-07 20:25:40.000000000 +0300
> @@ -219,9 +219,9 @@ static int will_become_orphaned_pgrp(str
> int ret = 1;
>
> do_each_pid_task(pgrp, PIDTYPE_PGID, p) {
> - if (p == ignored_task
> - || p->exit_state
> - || is_global_init(p->real_parent))
> + if ((p == ignored_task) ||
> + (p->exit_state && thread_group_empty(p)) ||
> + is_global_init(p->real_parent))
> continue;
> if (task_pgrp(p->real_parent) != pgrp &&
> task_session(p->real_parent) == task_session(p)) {
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
[Index of Archives]
[Kernel Newbies]
[Netfilter]
[Bugtraq]
[Photo]
[Stuff]
[Gimp]
[Yosemite News]
[MIPS Linux]
[ARM Linux]
[Linux Security]
[Linux RAID]
[Video 4 Linux]
[Linux for the blind]
[Linux Resources]