Re: [PATC_H] locks: Set fl_nspid at file_lock allocation

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



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



[Index of Archives]     [Linux Ext4 Filesystem]     [Union Filesystem]     [Filesystem Testing]     [Ceph Users]     [Ecryptfs]     [AutoFS]     [Kernel Newbies]     [Share Photos]     [Security]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux Cachefs]     [Reiser Filesystem]     [Linux RAID]     [Samba]     [Device Mapper]     [CEPH Development]
  Powered by Linux