Quoting Eric W. Biederman (ebiederm@xxxxxxxxxxxx): > Glauber Costa <glommer@xxxxxxxxxxxxx> writes: > > > Hi, > > > > devpts mounts in user namespaces is queued for 3.9. However, while playing > > with it I found it to be less than ideal. Although it could possibly work > > with custom software that can be made to point to /dev/pts/ptmx, a few things > > prevent it from working correctly for people that, like us, are booting full > > distributions. > > Full distributions that have not been modified to be minimally container > aware. Right, in fact in this case it doesn't need to be minimally container aware, you just create the bind mount yourself and init just needs to accept that it shouldn't touch it. > > In those scenarios, things like udev will kick in, maybe remount /dev undoing > > any setup we might have done, and then software like sshd or anything else > > calling openpty will search for /dev/ptmx, not /dev/pts/ptmx. > > I believe udev stopped running in containers a year or so ago. No, udev runs fine in containers, we just don't allow udevadm trigger. > > One of the problems that I am addressing in here is that we are disallowing > > mknod in usernamespaces. Although I understand the motivation for that, I > > believe that to be too restrictive, specially because we already control access > > to the files separately. There should be no harm in mknod'ing something per se, > > if manipulating it is forbidden. > > mknod in userspace needs to be a separate patchset. There is no need to > solve mknod in userspace to solve devpts. > > > > Last, /dev/ptmx will still always be the global ptmx device. We need to somehow > > link it to our namespaces'. My proposal is to multiplex it and return the > > correct "root ptmx" depending on which userns is reading that device. > > Doable. I still strongly prefer my version of having /dev/ptmx act like > a link to /dev/pts/ptmx. Letting the mount namespace control it. Right, Glauber have you seen this patch? Eric did already solve this. (And again that's a nice safeguard, but it shouldn't be necessary) > In testing that works, and it allows a lot of devpts complexity to just > go away. For older versions of udev you can even configure them with a > rule to make /dev/ptmx a symlink to /dev/pts/ptmx. Newer versions of > udev completely gave up on creating devices and can longer be configured > to do anything useful in this regard. > > So we might even be able to just get away with a bit of udev and > devtmpfs configuration. devtmpfs? Until we get multiple separate mounts of devtmpfs, don't use it in a container :) > And treat devpts as if newinstance is always > specified. Certainly that has worked in my testing so far. > > Eric -serge -- To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html