diff options
Diffstat (limited to 'fs/ext3/resize.c')
-rw-r--r-- | fs/ext3/resize.c | 10 |
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"); |