--- --- linux-2.6.16-cmm/fs/ext3/resize.c | 10 ++++++++++ linux-2.6.16-cmm/fs/ext3/super.c | 10 ++++++++++ 2 files changed, 20 insertions(+) diff -puN fs/ext3/resize.c~ext3_check_sector_t_overflow fs/ext3/resize.c --- linux-2.6.16/fs/ext3/resize.c~ext3_check_sector_t_overflow 2006-05-23 15:26:58.000000000 -0700 +++ linux-2.6.16-cmm/fs/ext3/resize.c 2006-05-23 15:37:15.000000000 -0700 @@ -926,6 +926,16 @@ int ext3_group_extend(struct super_block if (n_blocks_count == 0 || n_blocks_count == o_blocks_count) return 0; + if (n_blocks_count > (sector_t)(~0ULL) >> (sb->s_blocksize_bits - 9)) { + printk(KERN_ERR "EXT3-fs: filesystem on %s" + " too large to resize to %lu blocks safely\n", + sb->s_id, n_blocks_count); + if (sizeof(sector_t) < 8) + ext3_warning(sb, __FUNCTION__, + "CONFIG_LBD not enabled\n"); + return -EINVAL; + } + if (n_blocks_count < o_blocks_count) { ext3_warning(sb, __FUNCTION__, "can't shrink FS - resize aborted"); diff -puN fs/ext3/super.c~ext3_check_sector_t_overflow fs/ext3/super.c --- linux-2.6.16/fs/ext3/super.c~ext3_check_sector_t_overflow 2006-05-23 15:26:58.000000000 -0700 +++ linux-2.6.16-cmm/fs/ext3/super.c 2006-05-23 15:39:29.000000000 -0700 @@ -1579,6 +1579,16 @@ static int ext3_fill_super (struct super goto failed_mount; } + if (le32_to_cpu(es->s_blocks_count) > + (sector_t)(~0ULL) >> (sb->s_blocksize_bits - 9)) { + printk(KERN_ERR "EXT3-fs: filesystem on %s" + " too large to mount safely\n", sb->s_id); + if (sizeof(sector_t) < 8) + printk(KERN_WARNING + "EXT3-fs: CONFIG_LBD not enabled\n"); + goto failed_mount; + } + bgl_lock_init(&sbi->s_blockgroup_lock); for (i = 0; i < db_count; i++) { _