[Devel] Re: [PATCH 0/6] Unshare support for the pid namespace.
Eric W. Biederman
ebiederm at xmission.com
Sun Jun 20 14:00:05 PDT 2010
Oleg Nesterov <oleg at redhat.com> writes:
> On 06/20, Eric W. Biederman wrote:
>>
>> Oleg Nesterov <oleg at redhat.com> writes:
>>
>> > On 06/18, Oleg Nesterov wrote:
>> >>
>> >> I only try to discuss the idea to break the circular reference.
>> >
>> > I don't know what I have missed, but this looks really right to me.
>> > Besides, we have yet another problem: proc_flush_task()->mntput()
>> > is just wrong. Consider the multithreaded execing init.
>> >
>> > I am going to simplify, test, and send the fix which moves mntput()
>> > into free_pid_ns() paths.
>>
>> free_pid_ns is comparatively late, to release the kern_mount.
>
> Why?
>
> Once again, it is very possible I am wrong. I forgot this code if ever
> knew. But could you please explain?
There are two kinds of dead for a pid namespace. There are:
- no processes left.
- no more references to struct pid_namespace.
I just looked and I don't see any references to proc_mnt except from
living processes.
So while it isn't necessary that we kill the proc_mnt earlier it does
mean that we hold the resources longer then necessary.
>> > But first of all I think we should cleanup the pid_ns_prepare_proc()
>> > logic. Imho, this code is really ugly. Please see the patches.
>>
>> Since I have a patchset that makes it possible to unshare the pid
>> namespace about ready to send I figure we should combine the two
>> efforts.
>>
>> This patchset is a prerequisite to my patches for giving namespaces
>> file descriptors and allowing you to join and existing namespace.
>
> I do not understand.
>
> Eric, why you can't do these changes on top of the cleanups I sent?
Because there are conflicts, and if we are going to be going to
be working on this we should all be on the same page.
> OK, personally I certainly dislike 1/6, but perhaps it is needed for
> 6/6 which I didn't read yet. But, in any case, it is orthogonal to
> pid_ns_prepare_proc() cleanups?
1/6 is. If you unshare a pid namespace. Your first child is pid one.
Which means we can on longer count on CLONE_PID.
Frankly that 1/6 is also a cleanup.
> Now. You joined the first 2 patches I sent into 2/6. It is not that
> I care about the "From:" tag, but why? And (unless I missed something)
> you added the following changes compared to my patches:
I wrote that patch in March. So it is equally fair to say you split
my patch in two.
> - remove the MS_KERNMOUNT check around ei->pid = find_pid(1).
> OK, I agree it was not strictly needed, but imho makes the
> code cleaner.
>
> Or I missed something and this check was wrong?
The MS_KERNMOUNT check was simply unnecessary, and it makes the code
uglier to read and more brittle. Since I already had something
that was only looking at the essential details I didn't see the
point of such and ugly addition.
> - introduce the bug in create_pid_namespace(). If
> pid_ns_prepare_proc() fails, we return the wrong error
> code and leak parent_pid_ns().
Because I goofed, in March when I wrote it. Your patch got that right
mine gets it wrong.
> So. Afaics - nack to 2/6 at least. Could you please do this on top of
> the cleanups I sent? Of course, unless you think they are wrong.
Well I think that entire MS_KERNMOUNT test is unnecessary and
too horrible to live.
> And. I do not think these series can fix the discussed problems. ns->dead
> definitely can't, no?
I'm am fairly confident that we have the signal sending races fixed so
we can reasonably expect having sent SIGKILL to all processes in a pid
namespace
ns->dead certainly doesn't help in it's current form. I do think my
series informs us of the direction the code is going, and that is
important in it's own way.
> I think we should fix the bugs first.
Your patchset currently goes beyond the minimal that would make sense
for 2.6.35. So we are talking about code for 2.6.36, and I think the
unshare of the pid namespace code is certainly close enough that it
can also be ready for 2.6.36.
So what we get is more brains engaged and caring on the project so
hopefully get better code review.
Eric
_______________________________________________
Containers mailing list
Containers at lists.linux-foundation.org
https://lists.linux-foundation.org/mailman/listinfo/containers
More information about the Devel
mailing list