Re: [PATCH] fork: Allow init to become a session leader.

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Oleg Nesterov <[email protected]> writes:

> "Eric W. Biederman" wrote:
>> 
>> With the bug fixes from killing session == 0 and pgrp == 0 we
>> have essentially made pid == 1 a session leader.  However reading
>> through the code I can see nothing, that sets the session->leader
>> flag.  In fact we actively clear it in all cases during clone.
>> And setsid will fail to set it because the session == 1 and
>> process group == 1 already exist.
>> 
>> So this patch forces the session leader flag and for good measure
>> the pgrp, session and tty of init as well.
>> 
>> --- a/kernel/fork.c
>> +++ b/kernel/fork.c
>> @@ -1179,9 +1179,16 @@ static task_t *copy_process(unsigned lon
>>                 attach_pid(p, PIDTYPE_PID, p->pid);
>>                 attach_pid(p, PIDTYPE_TGID, p->tgid);
>>                 if (thread_group_leader(p)) {
>> -                       p->signal->tty = current->signal->tty;
>> -                       p->signal->pgrp = process_group(current);
>> -                       p->signal->session = current->signal->session;
>> +                       if (unlikely(p->pid == 1)) {
>> +                               p->signal->tty = NULL;
>> +                               p->signal->leader = 1;
>> +                               p->signal->pgrp = 1;
>> +                               p->signal->session = 1;
>
> Isn't it enough to just set current->signal->leader = 1
> in init/main.c:init() ? This process was already forked
> with (1,1) special pids and ->tty == NULL.

At the moment yes.  Being explicit can help readability.

This allows us the opportunity to leave the unhashed idle task as
(0,0) and more interesting to me, if we ever fork another process with
pid == 1 in a different process id namespace we do need to do all of
this.

Eric
-
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]
  Powered by Linux