diff options
author | Eric Sandeen <sandeen@redhat.com> | 2008-04-29 08:11:12 -0400 |
---|---|---|
committer | Theodore Ts'o <tytso@mit.edu> | 2008-04-29 08:11:12 -0400 |
commit | 4ddfef7b41aebbbede73f361cb938800ba3072dc (patch) | |
tree | c4d0b722424220a02af393b7be7298e456ba4954 | |
parent | 5cdd7b2d7716a7ed7d6dc7588e2d015f04d46640 (diff) |
ext4: reduce mballoc stack usage with noinline_for_stack
mballoc.c is a whole lot of static functions, which gcc seems to
really like to inline.
With the changes below, on x86, I can at least get from:
432 ext4_mb_new_blocks
240 ext4_mb_free_blocks
208 ext4_mb_discard_group_preallocations
188 ext4_mb_seq_groups_show
164 ext4_mb_init_cache
152 ext4_mb_release_inode_pa
136 ext4_mb_seq_history_show
...
to
220 ext4_mb_free_blocks
188 ext4_mb_seq_groups_show
176 ext4_mb_regular_allocator
164 ext4_mb_init_cache
156 ext4_mb_new_blocks
152 ext4_mb_release_inode_pa
136 ext4_mb_seq_history_show
124 ext4_mb_release_group_pa
...
which still has some big functions in there, but not 432 bytes!
Signed-off-by: Eric Sandeen <sandeen@redhat.com>
Signed-off-by: Mingming Cao <cmm@us.ibm.com>
Signed-off-by: "Theodore Ts'o" <tytso@mit.edu>
-rw-r--r-- | fs/ext4/mballoc.c | 45 |
1 files changed, 29 insertions, 16 deletions
diff --git a/fs/ext4/mballoc.c b/fs/ext4/mballoc.c index 9d57695de746..66e1451f64e7 100644 --- a/fs/ext4/mballoc.c +++ b/fs/ext4/mballoc.c | |||
@@ -1168,8 +1168,9 @@ out: | |||
1168 | return err; | 1168 | return err; |
1169 | } | 1169 | } |
1170 | 1170 | ||
1171 | static int ext4_mb_load_buddy(struct super_block *sb, ext4_group_t group, | 1171 | static noinline_for_stack int |
1172 | struct ext4_buddy *e4b) | 1172 | ext4_mb_load_buddy(struct super_block *sb, ext4_group_t group, |
1173 | struct ext4_buddy *e4b) | ||
1173 | { | 1174 | { |
1174 | struct ext4_sb_info *sbi = EXT4_SB(sb); | 1175 | struct ext4_sb_info *sbi = EXT4_SB(sb); |
1175 | struct inode *inode = sbi->s_buddy_cache; | 1176 | struct inode *inode = sbi->s_buddy_cache; |
@@ -1965,7 +1966,8 @@ static int ext4_mb_good_group(struct ext4_allocation_context *ac, | |||
1965 | return 0; | 1966 | return 0; |
1966 | } | 1967 | } |
1967 | 1968 | ||
1968 | static int ext4_mb_regular_allocator(struct ext4_allocation_context *ac) | 1969 | static noinline_for_stack int |
1970 | ext4_mb_regular_allocator(struct ext4_allocation_context *ac) | ||
1969 | { | 1971 | { |
1970 | ext4_group_t group; | 1972 | ext4_group_t group; |
1971 | ext4_group_t i; | 1973 | ext4_group_t i; |
@@ -2465,7 +2467,8 @@ static void ext4_mb_history_init(struct super_block *sb) | |||
2465 | /* if we can't allocate history, then we simple won't use it */ | 2467 | /* if we can't allocate history, then we simple won't use it */ |
2466 | } | 2468 | } |
2467 | 2469 | ||
2468 | static void ext4_mb_store_history(struct ext4_allocation_context *ac) | 2470 | static noinline_for_stack void |
2471 | ext4_mb_store_history(struct ext4_allocation_context *ac) | ||
2469 | { | 2472 | { |
2470 | struct ext4_sb_info *sbi = EXT4_SB(ac->ac_sb); | 2473 | struct ext4_sb_info *sbi = EXT4_SB(ac->ac_sb); |
2471 | struct ext4_mb_history h; | 2474 | struct ext4_mb_history h; |
@@ -2801,7 +2804,8 @@ int ext4_mb_release(struct super_block *sb) | |||
2801 | return 0; | 2804 | return 0; |
2802 | } | 2805 | } |
2803 | 2806 | ||
2804 | static void ext4_mb_free_committed_blocks(struct super_block *sb) | 2807 | static noinline_for_stack void |
2808 | ext4_mb_free_committed_blocks(struct super_block *sb) | ||
2805 | { | 2809 | { |
2806 | struct ext4_sb_info *sbi = EXT4_SB(sb); | 2810 | struct ext4_sb_info *sbi = EXT4_SB(sb); |
2807 | int err; | 2811 | int err; |
@@ -3021,7 +3025,8 @@ void exit_ext4_mballoc(void) | |||
3021 | * Check quota and mark choosed space (ac->ac_b_ex) non-free in bitmaps | 3025 | * Check quota and mark choosed space (ac->ac_b_ex) non-free in bitmaps |
3022 | * Returns 0 if success or error code | 3026 | * Returns 0 if success or error code |
3023 | */ | 3027 | */ |
3024 | static int ext4_mb_mark_diskspace_used(struct ext4_allocation_context *ac, | 3028 | static noinline_for_stack int |
3029 | ext4_mb_mark_diskspace_used(struct ext4_allocation_context *ac, | ||
3025 | handle_t *handle) | 3030 | handle_t *handle) |
3026 | { | 3031 | { |
3027 | struct buffer_head *bitmap_bh = NULL; | 3032 | struct buffer_head *bitmap_bh = NULL; |
@@ -3138,7 +3143,8 @@ static void ext4_mb_normalize_group_request(struct ext4_allocation_context *ac) | |||
3138 | * Normalization means making request better in terms of | 3143 | * Normalization means making request better in terms of |
3139 | * size and alignment | 3144 | * size and alignment |
3140 | */ | 3145 | */ |
3141 | static void ext4_mb_normalize_request(struct ext4_allocation_context *ac, | 3146 | static noinline_for_stack void |
3147 | ext4_mb_normalize_request(struct ext4_allocation_context *ac, | ||
3142 | struct ext4_allocation_request *ar) | 3148 | struct ext4_allocation_request *ar) |
3143 | { | 3149 | { |
3144 | int bsbits, max; | 3150 | int bsbits, max; |
@@ -3404,7 +3410,8 @@ static void ext4_mb_use_group_pa(struct ext4_allocation_context *ac, | |||
3404 | /* | 3410 | /* |
3405 | * search goal blocks in preallocated space | 3411 | * search goal blocks in preallocated space |
3406 | */ | 3412 | */ |
3407 | static int ext4_mb_use_preallocated(struct ext4_allocation_context *ac) | 3413 | static noinline_for_stack int |
3414 | ext4_mb_use_preallocated(struct ext4_allocation_context *ac) | ||
3408 | { | 3415 | { |
3409 | struct ext4_inode_info *ei = EXT4_I(ac->ac_inode); | 3416 | struct ext4_inode_info *ei = EXT4_I(ac->ac_inode); |
3410 | struct ext4_locality_group *lg; | 3417 | struct ext4_locality_group *lg; |
@@ -3571,7 +3578,8 @@ static void ext4_mb_put_pa(struct ext4_allocation_context *ac, | |||
3571 | /* | 3578 | /* |
3572 | * creates new preallocated space for given inode | 3579 | * creates new preallocated space for given inode |
3573 | */ | 3580 | */ |
3574 | static int ext4_mb_new_inode_pa(struct ext4_allocation_context *ac) | 3581 | static noinline_for_stack int |
3582 | ext4_mb_new_inode_pa(struct ext4_allocation_context *ac) | ||
3575 | { | 3583 | { |
3576 | struct super_block *sb = ac->ac_sb; | 3584 | struct super_block *sb = ac->ac_sb; |
3577 | struct ext4_prealloc_space *pa; | 3585 | struct ext4_prealloc_space *pa; |
@@ -3658,7 +3666,8 @@ static int ext4_mb_new_inode_pa(struct ext4_allocation_context *ac) | |||
3658 | /* | 3666 | /* |
3659 | * creates new preallocated space for locality group inodes belongs to | 3667 | * creates new preallocated space for locality group inodes belongs to |
3660 | */ | 3668 | */ |
3661 | static int ext4_mb_new_group_pa(struct ext4_allocation_context *ac) | 3669 | static noinline_for_stack int |
3670 | ext4_mb_new_group_pa(struct ext4_allocation_context *ac) | ||
3662 | { | 3671 | { |
3663 | struct super_block *sb = ac->ac_sb; | 3672 | struct super_block *sb = ac->ac_sb; |
3664 | struct ext4_locality_group *lg; | 3673 | struct ext4_locality_group *lg; |
@@ -3731,8 +3740,8 @@ static int ext4_mb_new_preallocation(struct ext4_allocation_context *ac) | |||
3731 | * the caller MUST hold group/inode locks. | 3740 | * the caller MUST hold group/inode locks. |
3732 | * TODO: optimize the case when there are no in-core structures yet | 3741 | * TODO: optimize the case when there are no in-core structures yet |
3733 | */ | 3742 | */ |
3734 | static int ext4_mb_release_inode_pa(struct ext4_buddy *e4b, | 3743 | static noinline_for_stack int |
3735 | struct buffer_head *bitmap_bh, | 3744 | ext4_mb_release_inode_pa(struct ext4_buddy *e4b, struct buffer_head *bitmap_bh, |
3736 | struct ext4_prealloc_space *pa) | 3745 | struct ext4_prealloc_space *pa) |
3737 | { | 3746 | { |
3738 | struct ext4_allocation_context *ac; | 3747 | struct ext4_allocation_context *ac; |
@@ -3803,7 +3812,8 @@ static int ext4_mb_release_inode_pa(struct ext4_buddy *e4b, | |||
3803 | return err; | 3812 | return err; |
3804 | } | 3813 | } |
3805 | 3814 | ||
3806 | static int ext4_mb_release_group_pa(struct ext4_buddy *e4b, | 3815 | static noinline_for_stack int |
3816 | ext4_mb_release_group_pa(struct ext4_buddy *e4b, | ||
3807 | struct ext4_prealloc_space *pa) | 3817 | struct ext4_prealloc_space *pa) |
3808 | { | 3818 | { |
3809 | struct ext4_allocation_context *ac; | 3819 | struct ext4_allocation_context *ac; |
@@ -3845,7 +3855,8 @@ static int ext4_mb_release_group_pa(struct ext4_buddy *e4b, | |||
3845 | * - how many do we discard | 3855 | * - how many do we discard |
3846 | * 1) how many requested | 3856 | * 1) how many requested |
3847 | */ | 3857 | */ |
3848 | static int ext4_mb_discard_group_preallocations(struct super_block *sb, | 3858 | static noinline_for_stack int |
3859 | ext4_mb_discard_group_preallocations(struct super_block *sb, | ||
3849 | ext4_group_t group, int needed) | 3860 | ext4_group_t group, int needed) |
3850 | { | 3861 | { |
3851 | struct ext4_group_info *grp = ext4_get_group_info(sb, group); | 3862 | struct ext4_group_info *grp = ext4_get_group_info(sb, group); |
@@ -4167,7 +4178,8 @@ static void ext4_mb_group_or_file(struct ext4_allocation_context *ac) | |||
4167 | mutex_lock(&ac->ac_lg->lg_mutex); | 4178 | mutex_lock(&ac->ac_lg->lg_mutex); |
4168 | } | 4179 | } |
4169 | 4180 | ||
4170 | static int ext4_mb_initialize_context(struct ext4_allocation_context *ac, | 4181 | static noinline_for_stack int |
4182 | ext4_mb_initialize_context(struct ext4_allocation_context *ac, | ||
4171 | struct ext4_allocation_request *ar) | 4183 | struct ext4_allocation_request *ar) |
4172 | { | 4184 | { |
4173 | struct super_block *sb = ar->inode->i_sb; | 4185 | struct super_block *sb = ar->inode->i_sb; |
@@ -4398,7 +4410,8 @@ static void ext4_mb_poll_new_transaction(struct super_block *sb, | |||
4398 | ext4_mb_free_committed_blocks(sb); | 4410 | ext4_mb_free_committed_blocks(sb); |
4399 | } | 4411 | } |
4400 | 4412 | ||
4401 | static int ext4_mb_free_metadata(handle_t *handle, struct ext4_buddy *e4b, | 4413 | static noinline_for_stack int |
4414 | ext4_mb_free_metadata(handle_t *handle, struct ext4_buddy *e4b, | ||
4402 | ext4_group_t group, ext4_grpblk_t block, int count) | 4415 | ext4_group_t group, ext4_grpblk_t block, int count) |
4403 | { | 4416 | { |
4404 | struct ext4_group_info *db = e4b->bd_info; | 4417 | struct ext4_group_info *db = e4b->bd_info; |