summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTheodore Ts'o <tytso@mit.edu>2014-08-09 12:33:11 -0400
committerTheodore Ts'o <tytso@mit.edu>2014-08-10 16:21:08 -0400
commitc82815e5097f130c8b926b3303a1e063a19dcdd0 (patch)
treebc5464d51f74b6321066948ecc5982c318638a01
parent7a4352dccd18928ffddd188cc927f4983ba80f72 (diff)
downloade2fsprogs-c82815e5097f130c8b926b3303a1e063a19dcdd0.tar.gz
resize2fs: disable the meta_bg feature if necessary
When shrinking a file system, if the number block groups drops below the point where we started using the meta_bg layout, disable the meta_bg feature and set s_first_meta_bg to zero. This is necessary to avoid creating an invalid/corrupted file system after the shrink. Addresses-Debian-Bug: #756922 Signed-off-by: Theodore Ts'o <tytso@mit.edu> Reported-by: Marcin Wolcendorf <antymat+debian@chelmska.waw.pl> Tested-by: Marcin Wolcendorf <antymat+debian@chelmska.waw.pl>
-rw-r--r--resize/resize2fs.c17
1 files changed, 13 insertions, 4 deletions
diff --git a/resize/resize2fs.c b/resize/resize2fs.c
index 9641b1e5..b3755f62 100644
--- a/resize/resize2fs.c
+++ b/resize/resize2fs.c
@@ -489,6 +489,13 @@ retry:
fs->super->s_reserved_gdt_blocks = new;
}
+ if ((fs->super->s_feature_incompat & EXT2_FEATURE_INCOMPAT_META_BG) &&
+ (fs->super->s_first_meta_bg > fs->desc_blocks)) {
+ fs->super->s_feature_incompat &=
+ ~EXT2_FEATURE_INCOMPAT_META_BG;
+ fs->super->s_first_meta_bg = 0;
+ }
+
/*
* Update the location of the backup superblocks if the
* sparse_super2 feature is enabled.
@@ -998,13 +1005,15 @@ static errcode_t blocks_to_move(ext2_resize_t rfs)
ext2fs_mark_block_bitmap2(rfs->reserve_blocks, blk);
}
- if (fs->super->s_feature_incompat & EXT2_FEATURE_INCOMPAT_META_BG) {
+ if (old_fs->super->s_feature_incompat & EXT2_FEATURE_INCOMPAT_META_BG)
old_blocks = old_fs->super->s_first_meta_bg;
+ else
+ old_blocks = old_fs->desc_blocks +
+ old_fs->super->s_reserved_gdt_blocks;
+ if (fs->super->s_feature_incompat & EXT2_FEATURE_INCOMPAT_META_BG)
new_blocks = fs->super->s_first_meta_bg;
- } else {
- old_blocks = old_fs->desc_blocks + old_fs->super->s_reserved_gdt_blocks;
+ else
new_blocks = fs->desc_blocks + fs->super->s_reserved_gdt_blocks;
- }
retval = reserve_sparse_super2_last_group(rfs, meta_bmap);
if (retval)