GFS2: Check if iopen is held when deleting inode
authorBob Peterson <rpeterso@redhat.com>
Fri, 18 Dec 2015 17:54:55 +0000 (11:54 -0600)
committerBob Peterson <rpeterso@redhat.com>
Thu, 14 Jan 2016 13:47:42 +0000 (08:47 -0500)
commit7508abc4bdac43dc87d2fdd31527063f72da7020
treeef25c3648ace05e47eca1ecc76ddbba541bd4f03
parent67990608c8b95d2b8ccc29932376ae73d5818727
GFS2: Check if iopen is held when deleting inode

This patch fixes an error condition in which an inode is partially
created in gfs2_create_inode() but then some error is discovered,
which causes it to fail and call iput() before the iopen glock is
created or held. In that case, gfs2_delete_inode would try to
unlock an iopen glock that doesn't yet exist. Therefore, we test
its holder (which must exist) for the HIF_HOLDER bit before trying
to dq it.

Signed-off-by: Bob Peterson <rpeterso@redhat.com>
Acked-by: Steven Whitehouse <swhiteho@redhat.com>
fs/gfs2/glock.c
fs/gfs2/super.c