aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDave Chinner <dchinner@redhat.com>2010-06-24 21:08:40 -0400
committerAlex Elder <aelder@sgi.com>2010-07-26 14:16:45 -0400
commit2727ccc950ae17375b15005403e1c35ba8fec1df (patch)
tree7e405f93bc25589e8506701f73da8344f2856907
parentcca28fb83d9e60779bb348edc33a62068e5f04a4 (diff)
xfs: unregister inode shrinker before freeing filesystem structures
Currently we don't remove the XFS mount from the shrinker list until late in the unmount path. By this time, we have already torn down the internals of the filesystem (e.g. the per-ag structures), and hence if the shrinker is executed between the teardown and the unregistering, the shrinker will get NULL per-ag structure pointers and panic trying to dereference them. Fix this by removing the xfs mount from the shrinker list before tearing down it's internal structures. Signed-off-by: Dave Chinner <dchinner@redhat.com> Reviewed-by: Eric Sandeen <sandeen@redhat.com> Signed-off-by: Alex Elder <aelder@sgi.com>
-rw-r--r--fs/xfs/linux-2.6/xfs_super.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/fs/xfs/linux-2.6/xfs_super.c b/fs/xfs/linux-2.6/xfs_super.c
index 22faaea5f3e1..c734bc6cf32e 100644
--- a/fs/xfs/linux-2.6/xfs_super.c
+++ b/fs/xfs/linux-2.6/xfs_super.c
@@ -1156,9 +1156,13 @@ xfs_fs_put_super(
1156 1156
1157 XFS_bflush(mp->m_ddev_targp); 1157 XFS_bflush(mp->m_ddev_targp);
1158 1158
1159 /*
1160 * Unregister the memory shrinker before we tear down the mount
1161 * structure so we don't have memory reclaim racing with us here.
1162 */
1163 xfs_inode_shrinker_unregister(mp);
1159 xfs_unmountfs(mp); 1164 xfs_unmountfs(mp);
1160 xfs_freesb(mp); 1165 xfs_freesb(mp);
1161 xfs_inode_shrinker_unregister(mp);
1162 xfs_icsb_destroy_counters(mp); 1166 xfs_icsb_destroy_counters(mp);
1163 xfs_close_devices(mp); 1167 xfs_close_devices(mp);
1164 xfs_free_fsname(mp); 1168 xfs_free_fsname(mp);