On 6 Jun 2017, at 9:15, Jeff Layton wrote: > On Tue, 2017-06-06 at 09:00 -0400, Benjamin Coddington wrote: >> It would, but I think fl_nspid is completely unnecessary. The reason we >> have it so that we can translate the pid number into other namespaces, >> the >> most common case being that F_GETLK and views of /proc/locks within a >> namespace represent the same pid numbers as the processes in that >> namespace >> that are holding the locks. >> >> It is much simpler to just keep using fl_pid as the pid number in the >> init >> namespace, but move the translation of that pid number to lookup time, >> rather than creation time. >> > > I think that would also work and I like the idea of getting rid of a > field in file_lock. > > So, to be clear: > > fl_pid would then store the pid of the process in the init_pid_ns, and > you'd just translate it as appropriate to the requestor's namespace? Right! > If we want to go that route, then you'll probably still need a flag of > some sort to indicate that the fl_pid is to be expressed "as is", for > remote filesystems. Yes, the hack I have now still uses that flag. > OTOH, if the lock is held remotely, I wonder if we'd be better off > simply reporting the pid as '-1', like we do with OFD locks. Hardly > anything pays attention to l_pid anyway and it's more or less > meaningless once the filesystem extends beyond the machine you're on. > > That said, I'd be inclined to do that in a separate set so we could > revert it if it caused problems somewhere. I think keeping that change separate is a good idea. It might be a good idea to just stay away from that change unless there's a compelling reason for it. If l_sysid ever happens, then there's no need to change the behavior for l_pid back again. I'll send some patches in a bit when I am happy with them. Ben