On 26 May 2017, at 12:49, Jeff Layton wrote:
On Fri, 2017-05-26 at 11:22 -0400, Benjamin Coddington wrote:
On 19 May 2017, at 8:35, Benjamin Coddington wrote:
So, the client considers remote pids to be bogus, which makes a lot
of sense
to me.
Yeah, not much it can do with a pid, really...
Additionally, after testing, today's kernel returns lockd's pid on a
local
F_GETLCK for a remotely-held NFS lock. So, I think our understanding
of the
situation needs to be reversed. Lock manager's locks are locally
reporting
the local lock pid, but sometimes a remote lock needs to override the
local
pid to set fl_pid.
Fair enough. Now that I look...v4 locks set by knfsd just pick up the
pid of whatever the nfsd thread it happens to be running in. From
nfsd4_lock:
file_lock->fl_pid = current->tgid;
So, it sounds like it really is totally meaningless then. In that case
I'll reverse my earlier opinion, and say that if it's easier to just
set it to whatever lockd's pid is, then that'd be fine with me.
OTOH, pid_t is an int, and I don't think negative pids are valid (are
they?)
Maybe we should set it to -1 for a remote lock (like we do for OFD
locks). Or, could consider declaring a new value (-2?) to represent a
remote lock?
OK, for my own clarity I'd like to nail down the desired behavior for
all
four cases:
1) F_GETLK on a remote file with a remote lock.
I think the filesystem should determine the l_pid to return here.
NFS
is returning 0 for v3. Other filesystems are doing different things.
This
is easy to do from locks.c by setting a flag on the lock in the
ops->lock
path for F_GETLK.
2) F_GETLK on a local file with a remote lock.
I think this should be the l_pid of the lock manager. That seems
to be
the case now for NFS.
3) F_GETLK on a remote file with a local lock, and..
4) F_GETLK on a local file with a local lock.
Should set l_pid of the local locking process
This is still an unreliable mess, but I don't see any way around it
until we
have something like l_sysid.
Ben