[GFS2] Fix ordering of page disposal vs. glock_dq
authorSteven Whitehouse <swhiteho@redhat.com>
Mon, 8 Jan 2007 14:31:40 +0000 (14:31 +0000)
committerSteven Whitehouse <swhiteho@redhat.com>
Mon, 5 Feb 2007 18:36:24 +0000 (13:36 -0500)
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 <swhiteho@redhat.com>
fs/gfs2/ops_super.c

index b2837839eed9e44a6615ad72cb13b25a8b4f9aef..c22738cdbf2dc2a18c8adc6e49fddcda1b2d8d11 100644 (file)
@@ -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);