diff options
author | Trond Myklebust <trond.myklebust@hammerspace.com> | 2022-11-14 23:30:39 +0100 |
---|---|---|
committer | Trond Myklebust <trond.myklebust@hammerspace.com> | 2022-11-28 04:10:00 +0100 |
commit | 35e3b6ae84935d0d7ff76cbdaa83411b0ad5e471 (patch) | |
tree | 76b6984d626089263e9d2df43175f5ef71ef97ab /fs/nfs | |
parent | NFSv4: Fix a deadlock between nfs4_open_recover_helper() and delegreturn (diff) | |
download | linux-35e3b6ae84935d0d7ff76cbdaa83411b0ad5e471.tar.xz linux-35e3b6ae84935d0d7ff76cbdaa83411b0ad5e471.zip |
NFS: Fix an Oops in nfs_d_automount()
When mounting from a NFSv4 referral, path->dentry can end up being a
negative dentry, so derive the struct nfs_server from the dentry
itself instead.
Fixes: 2b0143b5c986 ("VFS: normal filesystems (and lustre): d_inode() annotations")
Signed-off-by: Trond Myklebust <trond.myklebust@hammerspace.com>
Diffstat (limited to 'fs/nfs')
-rw-r--r-- | fs/nfs/namespace.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/nfs/namespace.c b/fs/nfs/namespace.c index 2f336ace7555..88a23af2bd5c 100644 --- a/fs/nfs/namespace.c +++ b/fs/nfs/namespace.c @@ -147,7 +147,7 @@ struct vfsmount *nfs_d_automount(struct path *path) struct nfs_fs_context *ctx; struct fs_context *fc; struct vfsmount *mnt = ERR_PTR(-ENOMEM); - struct nfs_server *server = NFS_SERVER(d_inode(path->dentry)); + struct nfs_server *server = NFS_SB(path->dentry->d_sb); struct nfs_client *client = server->nfs_client; int timeout = READ_ONCE(nfs_mountpoint_expiry_timeout); int ret; |