summaryrefslogtreecommitdiffstats
path: root/fs/gfs2/util.c
diff options
context:
space:
mode:
authorBob Peterson <rpeterso@redhat.com>2022-08-18 20:32:36 +0200
committerAndreas Gruenbacher <agruenba@redhat.com>2022-08-25 17:10:59 +0200
commit04133b607a78f2fd3daadbe5519513942b0f3a05 (patch)
tree87c33d5a8aff04a8e114e280fd14d139f2029416 /fs/gfs2/util.c
parentgfs2: Use TRY lock in gfs2_inode_lookup for UNLINKED inodes (diff)
downloadlinux-04133b607a78f2fd3daadbe5519513942b0f3a05.tar.xz
linux-04133b607a78f2fd3daadbe5519513942b0f3a05.zip
gfs2: Prevent double iput for journal on error
When a gfs2 file system is withdrawn it does iput on its journal to allow recovery from another cluster node. If it's unable to get a replacement inode for whatever reason, the journal descriptor would still be pointing at the evicted inode. So when unmount clears out the list of journals, it would do a second iput referencing the pointer. To avoid this, set the inode pointer to NULL. Signed-off-by: Bob Peterson <rpeterso@redhat.com> Signed-off-by: Andreas Gruenbacher <agruenba@redhat.com>
Diffstat (limited to 'fs/gfs2/util.c')
-rw-r--r--fs/gfs2/util.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/fs/gfs2/util.c b/fs/gfs2/util.c
index 8241029a2a5d..95c79a3ec161 100644
--- a/fs/gfs2/util.c
+++ b/fs/gfs2/util.c
@@ -204,6 +204,7 @@ static void signal_our_withdraw(struct gfs2_sbd *sdp)
* exception code in glock_dq.
*/
iput(inode);
+ sdp->sd_jdesc->jd_inode = NULL;
/*
* Wait until the journal inode's glock is freed. This allows try locks
* on other nodes to be successful, otherwise we remain the owner of