Linux NFS development
 help / color / mirror / Atom feed
* [PATCH] exportfs: remove locking around ->get_parent() call.
@ 2025-03-13 22:29 NeilBrown
  2025-03-14 10:40 ` Christian Brauner
  0 siblings, 1 reply; 2+ messages in thread
From: NeilBrown @ 2025-03-13 22:29 UTC (permalink / raw)
  To: Chuck Lever, Jeff Layton, Amir Goldstein, linux-fsdevel,
	linux-nfs


The locking around the ->get_parent() call brings no value.
We are locking a child which is only used to find an inode and thence the
parent inode number.  All further activity involves the parent inode
which may have several children so locking one child cannot protect the
parent in any useful way.

The filesystem must already ensure that only one 'struct inode' exists
for a given inode, and will call d_obtain_alias() which contains the
required locking to ensure only one dentry will be attached to that
inode.

So remove the unnecessary locking.

Signed-off-by: NeilBrown <neil@brown.name>
---

I've been reviewing locking in directories and this stood out has
unnecessary.  It isn't harmful, but it doesn't bring any value.
NeilBrown


 fs/exportfs/expfs.c | 2 --
 1 file changed, 2 deletions(-)

diff --git a/fs/exportfs/expfs.c b/fs/exportfs/expfs.c
index 0c899cfba578..b5845c4846b8 100644
--- a/fs/exportfs/expfs.c
+++ b/fs/exportfs/expfs.c
@@ -126,10 +126,8 @@ static struct dentry *reconnect_one(struct vfsmount *mnt,
 	int err;
 
 	parent = ERR_PTR(-EACCES);
-	inode_lock(dentry->d_inode);
 	if (mnt->mnt_sb->s_export_op->get_parent)
 		parent = mnt->mnt_sb->s_export_op->get_parent(dentry);
-	inode_unlock(dentry->d_inode);
 
 	if (IS_ERR(parent)) {
 		dprintk("get_parent of %lu failed, err %ld\n",
-- 
2.48.1


^ permalink raw reply related	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2025-03-14 10:40 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-03-13 22:29 [PATCH] exportfs: remove locking around ->get_parent() call NeilBrown
2025-03-14 10:40 ` Christian Brauner

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox