aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--fs/ext4/super.c15
1 files changed, 15 insertions, 0 deletions
diff --git a/fs/ext4/super.c b/fs/ext4/super.c
index 4e104dd0ec21..2bf9cdd7a036 100644
--- a/fs/ext4/super.c
+++ b/fs/ext4/super.c
@@ -1004,6 +1004,7 @@ static int parse_options (char *options, struct super_block *sb,
1004 int qtype, qfmt; 1004 int qtype, qfmt;
1005 char *qname; 1005 char *qname;
1006#endif 1006#endif
1007 ext4_fsblk_t last_block;
1007 1008
1008 if (!options) 1009 if (!options)
1009 return 1; 1010 return 1;
@@ -1326,6 +1327,20 @@ set_qf_format:
1326 set_opt (sbi->s_mount_opt, EXTENTS); 1327 set_opt (sbi->s_mount_opt, EXTENTS);
1327 break; 1328 break;
1328 case Opt_noextents: 1329 case Opt_noextents:
1330 /*
1331 * When e2fsprogs support resizing an already existing
1332 * ext3 file system to greater than 2**32 we need to
1333 * add support to block allocator to handle growing
1334 * already existing block mapped inode so that blocks
1335 * allocated for them fall within 2**32
1336 */
1337 last_block = ext4_blocks_count(sbi->s_es) - 1;
1338 if (last_block > 0xffffffffULL) {
1339 printk(KERN_ERR "EXT4-fs: Filesystem too "
1340 "large to mount with "
1341 "-o noextents options\n");
1342 return 0;
1343 }
1329 clear_opt (sbi->s_mount_opt, EXTENTS); 1344 clear_opt (sbi->s_mount_opt, EXTENTS);
1330 break; 1345 break;
1331 case Opt_i_version: 1346 case Opt_i_version: