Commit 896567ee authored by Trond Myklebust's avatar Trond Myklebust

NFS: nfs_igrab_and_active must first reference the superblock

Before referencing the inode, we must ensure that the superblock can be
referenced. Otherwise, we can end up with iput() calling superblock
operations that are no longer valid or accessible.

Fixes: ea7c38fe ("NFSv4: Ensure we reference the inode for return-on-close in delegreturn")
Signed-off-by: default avatarTrond Myklebust <trond.myklebust@hammerspace.com>
parent 113aac6d
...@@ -599,12 +599,14 @@ extern void nfs4_test_session_trunk(struct rpc_clnt *clnt, ...@@ -599,12 +599,14 @@ extern void nfs4_test_session_trunk(struct rpc_clnt *clnt,
static inline struct inode *nfs_igrab_and_active(struct inode *inode) static inline struct inode *nfs_igrab_and_active(struct inode *inode)
{ {
inode = igrab(inode); struct super_block *sb = inode->i_sb;
if (inode != NULL && !nfs_sb_active(inode->i_sb)) {
iput(inode); if (sb && nfs_sb_active(sb)) {
inode = NULL; if (igrab(inode))
return inode;
nfs_sb_deactive(sb);
} }
return inode; return NULL;
} }
static inline void nfs_iput_and_deactive(struct inode *inode) static inline void nfs_iput_and_deactive(struct inode *inode)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment