|
@@ -1525,8 +1525,6 @@ static int handle_mount_opt(struct super_block *sb, char *opt, int token,
|
|
|
arg = JBD2_DEFAULT_MAX_COMMIT_AGE;
|
|
|
sbi->s_commit_interval = HZ * arg;
|
|
|
} else if (token == Opt_max_batch_time) {
|
|
|
- if (arg == 0)
|
|
|
- arg = EXT4_DEF_MAX_BATCH_TIME;
|
|
|
sbi->s_max_batch_time = arg;
|
|
|
} else if (token == Opt_min_batch_time) {
|
|
|
sbi->s_min_batch_time = arg;
|
|
@@ -2809,10 +2807,11 @@ static void print_daily_error_info(unsigned long arg)
|
|
|
es = sbi->s_es;
|
|
|
|
|
|
if (es->s_error_count)
|
|
|
- ext4_msg(sb, KERN_NOTICE, "error count: %u",
|
|
|
+ /* fsck newer than v1.41.13 is needed to clean this condition. */
|
|
|
+ ext4_msg(sb, KERN_NOTICE, "error count since last fsck: %u",
|
|
|
le32_to_cpu(es->s_error_count));
|
|
|
if (es->s_first_error_time) {
|
|
|
- printk(KERN_NOTICE "EXT4-fs (%s): initial error at %u: %.*s:%d",
|
|
|
+ printk(KERN_NOTICE "EXT4-fs (%s): initial error at time %u: %.*s:%d",
|
|
|
sb->s_id, le32_to_cpu(es->s_first_error_time),
|
|
|
(int) sizeof(es->s_first_error_func),
|
|
|
es->s_first_error_func,
|
|
@@ -2826,7 +2825,7 @@ static void print_daily_error_info(unsigned long arg)
|
|
|
printk("\n");
|
|
|
}
|
|
|
if (es->s_last_error_time) {
|
|
|
- printk(KERN_NOTICE "EXT4-fs (%s): last error at %u: %.*s:%d",
|
|
|
+ printk(KERN_NOTICE "EXT4-fs (%s): last error at time %u: %.*s:%d",
|
|
|
sb->s_id, le32_to_cpu(es->s_last_error_time),
|
|
|
(int) sizeof(es->s_last_error_func),
|
|
|
es->s_last_error_func,
|
|
@@ -3880,38 +3879,19 @@ static int ext4_fill_super(struct super_block *sb, void *data, int silent)
|
|
|
goto failed_mount2;
|
|
|
}
|
|
|
}
|
|
|
-
|
|
|
- /*
|
|
|
- * set up enough so that it can read an inode,
|
|
|
- * and create new inode for buddy allocator
|
|
|
- */
|
|
|
- sbi->s_gdb_count = db_count;
|
|
|
- if (!test_opt(sb, NOLOAD) &&
|
|
|
- EXT4_HAS_COMPAT_FEATURE(sb, EXT4_FEATURE_COMPAT_HAS_JOURNAL))
|
|
|
- sb->s_op = &ext4_sops;
|
|
|
- else
|
|
|
- sb->s_op = &ext4_nojournal_sops;
|
|
|
-
|
|
|
- ext4_ext_init(sb);
|
|
|
- err = ext4_mb_init(sb);
|
|
|
- if (err) {
|
|
|
- ext4_msg(sb, KERN_ERR, "failed to initialize mballoc (%d)",
|
|
|
- err);
|
|
|
- goto failed_mount2;
|
|
|
- }
|
|
|
-
|
|
|
if (!ext4_check_descriptors(sb, &first_not_zeroed)) {
|
|
|
ext4_msg(sb, KERN_ERR, "group descriptors corrupted!");
|
|
|
- goto failed_mount2a;
|
|
|
+ goto failed_mount2;
|
|
|
}
|
|
|
if (EXT4_HAS_INCOMPAT_FEATURE(sb, EXT4_FEATURE_INCOMPAT_FLEX_BG))
|
|
|
if (!ext4_fill_flex_info(sb)) {
|
|
|
ext4_msg(sb, KERN_ERR,
|
|
|
"unable to initialize "
|
|
|
"flex_bg meta info!");
|
|
|
- goto failed_mount2a;
|
|
|
+ goto failed_mount2;
|
|
|
}
|
|
|
|
|
|
+ sbi->s_gdb_count = db_count;
|
|
|
get_random_bytes(&sbi->s_next_generation, sizeof(u32));
|
|
|
spin_lock_init(&sbi->s_next_gen_lock);
|
|
|
|
|
@@ -3946,6 +3926,14 @@ static int ext4_fill_super(struct super_block *sb, void *data, int silent)
|
|
|
sbi->s_stripe = ext4_get_stripe_size(sbi);
|
|
|
sbi->s_extent_max_zeroout_kb = 32;
|
|
|
|
|
|
+ /*
|
|
|
+ * set up enough so that it can read an inode
|
|
|
+ */
|
|
|
+ if (!test_opt(sb, NOLOAD) &&
|
|
|
+ EXT4_HAS_COMPAT_FEATURE(sb, EXT4_FEATURE_COMPAT_HAS_JOURNAL))
|
|
|
+ sb->s_op = &ext4_sops;
|
|
|
+ else
|
|
|
+ sb->s_op = &ext4_nojournal_sops;
|
|
|
sb->s_export_op = &ext4_export_ops;
|
|
|
sb->s_xattr = ext4_xattr_handlers;
|
|
|
#ifdef CONFIG_QUOTA
|
|
@@ -4135,13 +4123,21 @@ no_journal:
|
|
|
if (err) {
|
|
|
ext4_msg(sb, KERN_ERR, "failed to reserve %llu clusters for "
|
|
|
"reserved pool", ext4_calculate_resv_clusters(sb));
|
|
|
- goto failed_mount5;
|
|
|
+ goto failed_mount4a;
|
|
|
}
|
|
|
|
|
|
err = ext4_setup_system_zone(sb);
|
|
|
if (err) {
|
|
|
ext4_msg(sb, KERN_ERR, "failed to initialize system "
|
|
|
"zone (%d)", err);
|
|
|
+ goto failed_mount4a;
|
|
|
+ }
|
|
|
+
|
|
|
+ ext4_ext_init(sb);
|
|
|
+ err = ext4_mb_init(sb);
|
|
|
+ if (err) {
|
|
|
+ ext4_msg(sb, KERN_ERR, "failed to initialize mballoc (%d)",
|
|
|
+ err);
|
|
|
goto failed_mount5;
|
|
|
}
|
|
|
|
|
@@ -4218,8 +4214,11 @@ failed_mount8:
|
|
|
failed_mount7:
|
|
|
ext4_unregister_li_request(sb);
|
|
|
failed_mount6:
|
|
|
- ext4_release_system_zone(sb);
|
|
|
+ ext4_mb_release(sb);
|
|
|
failed_mount5:
|
|
|
+ ext4_ext_release(sb);
|
|
|
+ ext4_release_system_zone(sb);
|
|
|
+failed_mount4a:
|
|
|
dput(sb->s_root);
|
|
|
sb->s_root = NULL;
|
|
|
failed_mount4:
|
|
@@ -4243,14 +4242,11 @@ failed_mount3:
|
|
|
percpu_counter_destroy(&sbi->s_extent_cache_cnt);
|
|
|
if (sbi->s_mmp_tsk)
|
|
|
kthread_stop(sbi->s_mmp_tsk);
|
|
|
-failed_mount2a:
|
|
|
- ext4_mb_release(sb);
|
|
|
failed_mount2:
|
|
|
for (i = 0; i < db_count; i++)
|
|
|
brelse(sbi->s_group_desc[i]);
|
|
|
ext4_kvfree(sbi->s_group_desc);
|
|
|
failed_mount:
|
|
|
- ext4_ext_release(sb);
|
|
|
if (sbi->s_chksum_driver)
|
|
|
crypto_free_shash(sbi->s_chksum_driver);
|
|
|
if (sbi->s_proc) {
|