gfs2: release iopen glock early in evict
authorBob Peterson <rpeterso@redhat.com>
Thu, 28 Oct 2021 16:53:10 +0000 (11:53 -0500)
committerAndreas Gruenbacher <agruenba@redhat.com>
Sat, 6 Nov 2021 09:25:31 +0000 (10:25 +0100)
commit49462e2be119d38c5eb5759d0d1b712df3a41239
treec63de98635a35bf1964af15b1e0dc0e795d0ad6f
parent7a92deaae613c3b95f0fd02814bb09be7f7a5820
gfs2: release iopen glock early in evict

Before this patch, evict would clear the iopen glock's gl_object after
releasing the inode glock.  In the meantime, another process could reuse
the same block and thus glocks for a new inode.  It would lock the inode
glock (exclusively), and then the iopen glock (shared).  The shared
locking mode doesn't provide any ordering against the evict, so by the
time the iopen glock is reused, evict may not have gotten to setting
gl_object to NULL.

Fix that by releasing the iopen glock before the inode glock in
gfs2_evict_inode.

Signed-off-by: Bob Peterson <rpeterso@redhat.com>gl_object
Signed-off-by: Andreas Gruenbacher <agruenba@redhat.com>
fs/gfs2/super.c