From: Steven Whitehouse Date: Mon, 8 Jan 2007 14:31:40 +0000 (+0000) Subject: [GFS2] Fix ordering of page disposal vs. glock_dq X-Git-Tag: v6.6-pxa1908~56056^2~15^2~43 X-Git-Url: https://git.dujemihanovic.xyz/?a=commitdiff_plain;h=49686f71060e342bce6644a5c69fbc6ad0e75a13;p=linux.git [GFS2] Fix ordering of page disposal vs. glock_dq In case of unlinked files with dirty pages GFS2 wasn't clearing the pages in quite the right order. This patch clears the pages earlier (before the qlock_dq) to avoid the situation that the release of the glock results in attempting to write back data that has already been deallocated. This fixes Red Hat bugzilla: #220117 Signed-off-by: Steven Whitehouse --- diff --git a/fs/gfs2/ops_super.c b/fs/gfs2/ops_super.c index b2837839eed9..c22738cdbf2d 100644 --- a/fs/gfs2/ops_super.c +++ b/fs/gfs2/ops_super.c @@ -429,6 +429,12 @@ static void gfs2_delete_inode(struct inode *inode) } error = gfs2_dinode_dealloc(ip); + /* + * Must do this before unlock to avoid trying to write back + * potentially dirty data now that inode no longer exists + * on disk. + */ + truncate_inode_pages(&inode->i_data, 0); out_unlock: gfs2_glock_dq(&ip->i_iopen_gh);