Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit d5e03cbb authored by Theodore Ts'o's avatar Theodore Ts'o
Browse files

ext4: rearrange initialization to fix EXT4FS_DEBUG



The EXT4FS_DEBUG is a *very* developer specific #ifdef designed for
ext4 developers only.  (You have to modify fs/ext4/ext4.h to enable
it.)

Rearrange how we initialize data structures to avoid calling
ext4_count_free_clusters() until the multiblock allocator has been
initialized.

This also allows us to only call ext4_count_free_clusters() once, and
simplifies the code somewhat.

(Thanks to Chen Gang <gang.chen.5i5j@gmail.com> for pointing out a
!CONFIG_SMP compile breakage in the original patch.)

Signed-off-by: default avatarTheodore Ts'o <tytso@mit.edu>
Reviewed-by: default avatarLukas Czerner <lczerner@redhat.com>
parent 1795cd9b
Loading
Loading
Loading
Loading
+39 −49
Original line number Original line Diff line number Diff line
@@ -2142,10 +2142,6 @@ static int ext4_check_descriptors(struct super_block *sb,
	}
	}
	if (NULL != first_not_zeroed)
	if (NULL != first_not_zeroed)
		*first_not_zeroed = grp;
		*first_not_zeroed = grp;

	ext4_free_blocks_count_set(sbi->s_es,
				   EXT4_C2B(sbi, ext4_count_free_clusters(sb)));
	sbi->s_es->s_free_inodes_count =cpu_to_le32(ext4_count_free_inodes(sb));
	return 1;
	return 1;
}
}


@@ -3883,13 +3879,6 @@ static int ext4_fill_super(struct super_block *sb, void *data, int silent)
		ext4_msg(sb, KERN_ERR, "group descriptors corrupted!");
		ext4_msg(sb, KERN_ERR, "group descriptors corrupted!");
		goto failed_mount2;
		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_mount2;
		}


	sbi->s_gdb_count = db_count;
	sbi->s_gdb_count = db_count;
	get_random_bytes(&sbi->s_next_generation, sizeof(u32));
	get_random_bytes(&sbi->s_next_generation, sizeof(u32));
@@ -3902,23 +3891,7 @@ static int ext4_fill_super(struct super_block *sb, void *data, int silent)
	/* Register extent status tree shrinker */
	/* Register extent status tree shrinker */
	ext4_es_register_shrinker(sbi);
	ext4_es_register_shrinker(sbi);


	err = percpu_counter_init(&sbi->s_freeclusters_counter,
	if ((err = percpu_counter_init(&sbi->s_extent_cache_cnt, 0)) != 0) {
			ext4_count_free_clusters(sb));
	if (!err) {
		err = percpu_counter_init(&sbi->s_freeinodes_counter,
				ext4_count_free_inodes(sb));
	}
	if (!err) {
		err = percpu_counter_init(&sbi->s_dirs_counter,
				ext4_count_dirs(sb));
	}
	if (!err) {
		err = percpu_counter_init(&sbi->s_dirtyclusters_counter, 0);
	}
	if (!err) {
		err = percpu_counter_init(&sbi->s_extent_cache_cnt, 0);
	}
	if (err) {
		ext4_msg(sb, KERN_ERR, "insufficient memory");
		ext4_msg(sb, KERN_ERR, "insufficient memory");
		goto failed_mount3;
		goto failed_mount3;
	}
	}
@@ -4022,18 +3995,6 @@ static int ext4_fill_super(struct super_block *sb, void *data, int silent)


	sbi->s_journal->j_commit_callback = ext4_journal_commit_callback;
	sbi->s_journal->j_commit_callback = ext4_journal_commit_callback;


	/*
	 * The journal may have updated the bg summary counts, so we
	 * need to update the global counters.
	 */
	percpu_counter_set(&sbi->s_freeclusters_counter,
			   ext4_count_free_clusters(sb));
	percpu_counter_set(&sbi->s_freeinodes_counter,
			   ext4_count_free_inodes(sb));
	percpu_counter_set(&sbi->s_dirs_counter,
			   ext4_count_dirs(sb));
	percpu_counter_set(&sbi->s_dirtyclusters_counter, 0);

no_journal:
no_journal:
	if (ext4_mballoc_ready) {
	if (ext4_mballoc_ready) {
		sbi->s_mb_cache = ext4_xattr_create_cache(sb->s_id);
		sbi->s_mb_cache = ext4_xattr_create_cache(sb->s_id);
@@ -4141,6 +4102,33 @@ no_journal:
		goto failed_mount5;
		goto failed_mount5;
	}
	}


	block = ext4_count_free_clusters(sb);
	ext4_free_blocks_count_set(sbi->s_es, 
				   EXT4_C2B(sbi, block));
	err = percpu_counter_init(&sbi->s_freeclusters_counter, block);
	if (!err) {
		unsigned long freei = ext4_count_free_inodes(sb);
		sbi->s_es->s_free_inodes_count = cpu_to_le32(freei);
		err = percpu_counter_init(&sbi->s_freeinodes_counter, freei);
	}
	if (!err)
		err = percpu_counter_init(&sbi->s_dirs_counter,
					  ext4_count_dirs(sb));
	if (!err)
		err = percpu_counter_init(&sbi->s_dirtyclusters_counter, 0);
	if (err) {
		ext4_msg(sb, KERN_ERR, "insufficient memory");
		goto failed_mount6;
	}

	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_mount6;
		}

	err = ext4_register_li_request(sb, first_not_zeroed);
	err = ext4_register_li_request(sb, first_not_zeroed);
	if (err)
	if (err)
		goto failed_mount6;
		goto failed_mount6;
@@ -4215,6 +4203,12 @@ failed_mount7:
	ext4_unregister_li_request(sb);
	ext4_unregister_li_request(sb);
failed_mount6:
failed_mount6:
	ext4_mb_release(sb);
	ext4_mb_release(sb);
	if (sbi->s_flex_groups)
		ext4_kvfree(sbi->s_flex_groups);
	percpu_counter_destroy(&sbi->s_freeclusters_counter);
	percpu_counter_destroy(&sbi->s_freeinodes_counter);
	percpu_counter_destroy(&sbi->s_dirs_counter);
	percpu_counter_destroy(&sbi->s_dirtyclusters_counter);
failed_mount5:
failed_mount5:
	ext4_ext_release(sb);
	ext4_ext_release(sb);
	ext4_release_system_zone(sb);
	ext4_release_system_zone(sb);
@@ -4233,12 +4227,6 @@ failed_mount_wq:
failed_mount3:
failed_mount3:
	ext4_es_unregister_shrinker(sbi);
	ext4_es_unregister_shrinker(sbi);
	del_timer_sync(&sbi->s_err_report);
	del_timer_sync(&sbi->s_err_report);
	if (sbi->s_flex_groups)
		ext4_kvfree(sbi->s_flex_groups);
	percpu_counter_destroy(&sbi->s_freeclusters_counter);
	percpu_counter_destroy(&sbi->s_freeinodes_counter);
	percpu_counter_destroy(&sbi->s_dirs_counter);
	percpu_counter_destroy(&sbi->s_dirtyclusters_counter);
	percpu_counter_destroy(&sbi->s_extent_cache_cnt);
	percpu_counter_destroy(&sbi->s_extent_cache_cnt);
	if (sbi->s_mmp_tsk)
	if (sbi->s_mmp_tsk)
		kthread_stop(sbi->s_mmp_tsk);
		kthread_stop(sbi->s_mmp_tsk);
@@ -4556,9 +4544,11 @@ static int ext4_commit_super(struct super_block *sb, int sync)
	else
	else
		es->s_kbytes_written =
		es->s_kbytes_written =
			cpu_to_le64(EXT4_SB(sb)->s_kbytes_written);
			cpu_to_le64(EXT4_SB(sb)->s_kbytes_written);
	if (percpu_counter_initialized(&EXT4_SB(sb)->s_freeclusters_counter))
		ext4_free_blocks_count_set(es,
		ext4_free_blocks_count_set(es,
			EXT4_C2B(EXT4_SB(sb), percpu_counter_sum_positive(
			EXT4_C2B(EXT4_SB(sb), percpu_counter_sum_positive(
				&EXT4_SB(sb)->s_freeclusters_counter)));
				&EXT4_SB(sb)->s_freeclusters_counter)));
	if (percpu_counter_initialized(&EXT4_SB(sb)->s_freeinodes_counter))
		es->s_free_inodes_count =
		es->s_free_inodes_count =
			cpu_to_le32(percpu_counter_sum_positive(
			cpu_to_le32(percpu_counter_sum_positive(
				&EXT4_SB(sb)->s_freeinodes_counter));
				&EXT4_SB(sb)->s_freeinodes_counter));