forked from Minki/linux
ext4: cleanup for compiling mballoc with verification and debugging #defines
This patch allows compiling mballoc with: #define AGGRESSIVE_CHECK #define DOUBLE_CHECK #define MB_DEBUG It fixes: Compilation errors: fs/ext4/mballoc.c: In function '__mb_check_buddy': fs/ext4/mballoc.c:605: error: 'struct ext4_prealloc_space' has no member named 'group_list' fs/ext4/mballoc.c:606: error: 'struct ext4_prealloc_space' has no member named 'pstart' fs/ext4/mballoc.c:608: error: 'struct ext4_prealloc_space' has no member named 'len' Compilation warnings: fs/ext4/mballoc.c: In function 'ext4_mb_normalize_group_request': fs/ext4/mballoc.c:2863: warning: format '%lu' expects type 'long unsigned int', but argument 3 has type 'int' fs/ext4/mballoc.c: In function 'ext4_mb_use_inode_pa': fs/ext4/mballoc.c:3103: warning: format '%lu' expects type 'long unsigned int', but argument 3 has type 'int' Sparse check: fs/ext4/mballoc.c:3818:2: warning: context imbalance in 'ext4_mb_show_ac' - different lock contexts for basic block Signed-off-by: Solofo Ramangalahy <Solofo.Ramangalahy@bull.net> Signed-off-by: Mingming Cao <cmm@us.ibm.com> Signed-off-by: "Theodore Ts'o" <tytso@mit.edu>
This commit is contained in:
parent
c19204b0ae
commit
60bd63d192
@ -896,10 +896,10 @@ static int __mb_check_buddy(struct ext4_buddy *e4b, char *file,
|
|||||||
list_for_each(cur, &grp->bb_prealloc_list) {
|
list_for_each(cur, &grp->bb_prealloc_list) {
|
||||||
ext4_group_t groupnr;
|
ext4_group_t groupnr;
|
||||||
struct ext4_prealloc_space *pa;
|
struct ext4_prealloc_space *pa;
|
||||||
pa = list_entry(cur, struct ext4_prealloc_space, group_list);
|
pa = list_entry(cur, struct ext4_prealloc_space, pa_group_list);
|
||||||
ext4_get_group_no_and_offset(sb, pa->pstart, &groupnr, &k);
|
ext4_get_group_no_and_offset(sb, pa->pa_pstart, &groupnr, &k);
|
||||||
MB_CHECK_ASSERT(groupnr == e4b->bd_group);
|
MB_CHECK_ASSERT(groupnr == e4b->bd_group);
|
||||||
for (i = 0; i < pa->len; i++)
|
for (i = 0; i < pa->pa_len; i++)
|
||||||
MB_CHECK_ASSERT(mb_test_bit(k + i, buddy));
|
MB_CHECK_ASSERT(mb_test_bit(k + i, buddy));
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
@ -3131,7 +3131,7 @@ static void ext4_mb_normalize_group_request(struct ext4_allocation_context *ac)
|
|||||||
ac->ac_g_ex.fe_len = EXT4_SB(sb)->s_stripe;
|
ac->ac_g_ex.fe_len = EXT4_SB(sb)->s_stripe;
|
||||||
else
|
else
|
||||||
ac->ac_g_ex.fe_len = EXT4_SB(sb)->s_mb_group_prealloc;
|
ac->ac_g_ex.fe_len = EXT4_SB(sb)->s_mb_group_prealloc;
|
||||||
mb_debug("#%u: goal %lu blocks for locality group\n",
|
mb_debug("#%u: goal %u blocks for locality group\n",
|
||||||
current->pid, ac->ac_g_ex.fe_len);
|
current->pid, ac->ac_g_ex.fe_len);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3371,7 +3371,7 @@ static void ext4_mb_use_inode_pa(struct ext4_allocation_context *ac,
|
|||||||
BUG_ON(pa->pa_free < len);
|
BUG_ON(pa->pa_free < len);
|
||||||
pa->pa_free -= len;
|
pa->pa_free -= len;
|
||||||
|
|
||||||
mb_debug("use %llu/%lu from inode pa %p\n", start, len, pa);
|
mb_debug("use %llu/%u from inode pa %p\n", start, len, pa);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -4108,7 +4108,7 @@ static void ext4_mb_show_ac(struct ext4_allocation_context *ac)
|
|||||||
printk(KERN_ERR "PA:%lu:%d:%u \n", i,
|
printk(KERN_ERR "PA:%lu:%d:%u \n", i,
|
||||||
start, pa->pa_len);
|
start, pa->pa_len);
|
||||||
}
|
}
|
||||||
ext4_lock_group(sb, i);
|
ext4_unlock_group(sb, i);
|
||||||
|
|
||||||
if (grp->bb_free == 0)
|
if (grp->bb_free == 0)
|
||||||
continue;
|
continue;
|
||||||
|
Loading…
Reference in New Issue
Block a user