On Mon, Dec 17, 2012 at 01:34:28PM +0100, Oleg Nesterov wrote: > @@ -455,6 +468,14 @@ static int umh_pipe_setup(struct subproc > /* and disallow core files too */ > current->signal->rlim[RLIMIT_CORE] = (struct rlimit){1, 1}; > > + > + if (cp->switch_ns) { > + get_fs_root(cp->cprocess->fs, &root); > + set_fs_root(current->fs, &root); > + switch_task_namespaces(current, cp->cprocess->nsproxy); > > How? You can't simply change ->nsproxy this way. > Why not? This is exactly how fork, exit, and setns use this call.
> If nothing else this breaks sys_getpid(), no? > hmm, I think you're inferring here that there is a chance that a pid allocated in the init namespace might conflict with another process who holds the same pid in another namespace? Yes, hand't thought about that. What do you propose we do about this? Is there a way to switch all namespaces, except for the pid namespace? Or do we need to modify the kthread and umh apis to allow for namespace inheritance through the fork call? > And a lot more problems, afaics. For example, this thread can continue > to run after, say, this cprocess->nsproxy->pid_ns was already destroyed. > zap_pid_ns_processes() obviously won't see this thread. > Hmm, I don't think so. The crashing process won't exit until the pipe reader is done, so the reference on the namespace should never decrement to zero. Actually I take that back. switch_task_namespaces doesn't add a ref count to the name space being switched to. So if the pipe reader doesn't exit immediately after closing the pipe, it may live on after the namespace is destroyed. It would seem a get_nsproxy call is needed here to hold an additional reference. Or do you think more is necessecary? > Even ->nsproxy itself can go away. Just suppose that the coredumping > task is the only process in this namespace (sub-init). > Again, that shouldn't be a problem, should it? As that process won't exit until the pipe reader is done, save the condition above. Neil -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/