|
@@ -1263,17 +1263,21 @@ static int gfs2_get_sb_meta(struct file_system_type *fs_type, int flags,
|
|
|
static void gfs2_kill_sb(struct super_block *sb)
|
|
|
{
|
|
|
struct gfs2_sbd *sdp = sb->s_fs_info;
|
|
|
- if (sdp) {
|
|
|
- gfs2_meta_syncfs(sdp);
|
|
|
- dput(sdp->sd_root_dir);
|
|
|
- dput(sdp->sd_master_dir);
|
|
|
- sdp->sd_root_dir = NULL;
|
|
|
- sdp->sd_master_dir = NULL;
|
|
|
+
|
|
|
+ if (sdp == NULL) {
|
|
|
+ kill_block_super(sb);
|
|
|
+ return;
|
|
|
}
|
|
|
+
|
|
|
+ gfs2_meta_syncfs(sdp);
|
|
|
+ dput(sdp->sd_root_dir);
|
|
|
+ dput(sdp->sd_master_dir);
|
|
|
+ sdp->sd_root_dir = NULL;
|
|
|
+ sdp->sd_master_dir = NULL;
|
|
|
shrink_dcache_sb(sb);
|
|
|
kill_block_super(sb);
|
|
|
- if (sdp)
|
|
|
- gfs2_delete_debugfs_file(sdp);
|
|
|
+ gfs2_delete_debugfs_file(sdp);
|
|
|
+ kfree(sdp);
|
|
|
}
|
|
|
|
|
|
struct file_system_type gfs2_fs_type = {
|