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. > 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. > 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. 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. And treat devpts as if newinstance is always specified. Certainly that has worked in my testing so far. Eric _______________________________________________ Containers mailing list Containers@xxxxxxxxxxxxxxxxxxxxxxxxxx https://lists.linuxfoundation.org/mailman/listinfo/containers