aboutsummaryrefslogtreecommitdiffstats
path: root/fs/ext3/resize.c
diff options
context:
space:
mode:
Diffstat (limited to 'fs/ext3/resize.c')
-rw-r--r--fs/ext3/resize.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/fs/ext3/resize.c b/fs/ext3/resize.c
index 34b39e9a1e5a..a31dff81ed77 100644
--- a/fs/ext3/resize.c
+++ b/fs/ext3/resize.c
@@ -925,6 +925,16 @@ int ext3_group_extend(struct super_block *sb, struct ext3_super_block *es,
925 if (n_blocks_count == 0 || n_blocks_count == o_blocks_count) 925 if (n_blocks_count == 0 || n_blocks_count == o_blocks_count)
926 return 0; 926 return 0;
927 927
928 if (n_blocks_count > (sector_t)(~0ULL) >> (sb->s_blocksize_bits - 9)) {
929 printk(KERN_ERR "EXT3-fs: filesystem on %s:"
930 " too large to resize to %lu blocks safely\n",
931 sb->s_id, n_blocks_count);
932 if (sizeof(sector_t) < 8)
933 ext3_warning(sb, __FUNCTION__,
934 "CONFIG_LBD not enabled\n");
935 return -EINVAL;
936 }
937
928 if (n_blocks_count < o_blocks_count) { 938 if (n_blocks_count < o_blocks_count) {
929 ext3_warning(sb, __FUNCTION__, 939 ext3_warning(sb, __FUNCTION__,
930 "can't shrink FS - resize aborted"); 940 "can't shrink FS - resize aborted");