Re: [PATCH 7/7][v8] SI_USER: Masquerade si_pid when crossing pid ns boundary

From: Eric W. Biederman
Date: Thu Feb 19 2009 - 23:05:10 EST


Roland McGrath <roland@xxxxxxxxxx> writes:

>> > think it would be best to fully elucidate what we think about desireable
>> > semantics for the whole spectrum of cross-NS signal-sending cases before
>> > actually choosing the implementation details.
>
> ... and then you answered all the questions that are already well settled,
> and did not address the new question that you had raised earlier today.

Oh sorry. I misunderstood what you were asking.

> To which processes should a pgrp-wide signal sent from user mode inside a
> pid_ns go? Should they go to a pgrp member in a different pid_ns, or not?
>
> If your answer is that you don't care, my inclination is to leave it as it
> is ("my pgrp" can include processes outside your pid_ns, which you could
> not explicitly target in any other way). The way we are going just for the
> sake of cleanliness happens to make the si_pid values all work out right
> for this. Possibly the semantics are even what you want: If e.g. the
> sub-init acts like many terminal apps and might use the tty in raw mode but
> then handle something like ^Z by fiddling the tty and then kill(0,SIGTSTP)
> to act like ^Z was hit in cooked mode, then this preserves the proper
> effect of that suspending a whole script/pipeline.

As it is are the easiest and most intuitive semantics to me. It is
simply weird to people expecting that signals will never exit out of a
pid namespace. Additionally I like having a prominent easy to create
case because it makes it much easier for people to realize it can
happen.

What I don't have is a compelling usage that means we must send to
every process in our process group if our process group spans multiple
pid namespaces. Your description of manually implementing ^Z sounds
as close as I can come to a compelling case.

I simply have a compelling case for process groups and sessions that
span pid namespaces where the tty sends the signals to all of the
processes.

A nearly compelling case for the current process group semantics
and comes from using pid namespaces as inescapable process groups.
In that use case I would find it very convenient to be able to
set SIGCHLD to SIG_IGN and exec an arbitrary program a pid namespace
leader.

Ouch!

I have just recalled a use case that will cause problems with the
current ignoring of signals in this patchset. Currently a container
init can not send SIGSTOP to itself. And I have been taking advantage
of that in usages such as supporting the bash suspend command or the
M-x suspend-emacs. And it is very handy for getting back to a shell
outside of a chroot like container. SIGTSTP will still work, but
SIGSTOP which I'm pretty certain bash sends itself will not.

So I have the question. How few special cases do we need to implement
to signal handling in a container init and still support running
programs written to be /sbin/init, on linux. Can we limit this our
special case to just ignoring SIGKILL and SIGSTOP when sent from other
process in the same pid namespace? Or do we actually need more?

>> Another case where we can send signals between namespaces is posix
>> message queues. Implemented in ipc/mqueue.c. In that case because it
>> is a unicast message we are generating the proper si_pid when we
>> generate the signal.
>
> Ah, this is the clear example of "any to any", since all the sender and
> recipient have to share is the mqueue they each have a descriptor on.
> But, as you say, it's got no problems because the sender is just
> "current in mq_timedsend" to a single recipient, no different than
> "current in sys_kill" when that is going to a single recipient.

I suspect there are others buried in the kernel somewhere or there
will be others in the future. We have a very similar pattern with
fcntl and SIGIO and SIGURG, but they all look they are coming from the
kernel. Everything except the tty code appears to slowly approach
the general case.

>> I think that is where we need to go, to be safe and to be certain
>> weird things won't sneak up on us. We already handle half of the logic in
>> send_signal anyway. We might as well handle the other half.
>
> Agreed.


Eric
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/