Commit e37bc39e authored by Matthew Wilcox's avatar Matthew Wilcox Committed by Linus Torvalds

[PATCH] Minor ext2 speedup

Port Andreas Dilger's and Jan Kara's patch for ext3 to ext2.  Also some
whitespace changes to get ext2/ext3 closer in sync.
Signed-off-by: default avatarMatthew Wilcox <matthew@wil.cx>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent 8826b3d3
...@@ -6,7 +6,7 @@ ...@@ -6,7 +6,7 @@
* Laboratoire MASI - Institut Blaise Pascal * Laboratoire MASI - Institut Blaise Pascal
* Universite Pierre et Marie Curie (Paris VI) * Universite Pierre et Marie Curie (Paris VI)
* *
* Enhanced block allocation by Stephen Tweedie (sct@dcs.ed.ac.uk), 1993 * Enhanced block allocation by Stephen Tweedie (sct@redhat.com), 1993
* Big-endian to little-endian byte-swapping/bitmaps by * Big-endian to little-endian byte-swapping/bitmaps by
* David S. Miller (davem@caip.rutgers.edu), 1995 * David S. Miller (davem@caip.rutgers.edu), 1995
*/ */
...@@ -53,8 +53,8 @@ struct ext2_group_desc * ext2_get_group_desc(struct super_block * sb, ...@@ -53,8 +53,8 @@ struct ext2_group_desc * ext2_get_group_desc(struct super_block * sb,
return NULL; return NULL;
} }
group_desc = block_group / EXT2_DESC_PER_BLOCK(sb); group_desc = block_group >> EXT2_DESC_PER_BLOCK_BITS(sb);
offset = block_group % EXT2_DESC_PER_BLOCK(sb); offset = block_group & (EXT2_DESC_PER_BLOCK(sb) - 1);
if (!sbi->s_group_desc[group_desc]) { if (!sbi->s_group_desc[group_desc]) {
ext2_error (sb, "ext2_get_group_desc", ext2_error (sb, "ext2_get_group_desc",
"Group descriptor not loaded - " "Group descriptor not loaded - "
...@@ -236,13 +236,13 @@ void ext2_free_blocks (struct inode * inode, unsigned long block, ...@@ -236,13 +236,13 @@ void ext2_free_blocks (struct inode * inode, unsigned long block,
for (i = 0, group_freed = 0; i < count; i++) { for (i = 0, group_freed = 0; i < count; i++) {
if (!ext2_clear_bit_atomic(sb_bgl_lock(sbi, block_group), if (!ext2_clear_bit_atomic(sb_bgl_lock(sbi, block_group),
bit + i, (void *) bitmap_bh->b_data)) bit + i, bitmap_bh->b_data)) {
ext2_error (sb, "ext2_free_blocks", ext2_error(sb, __FUNCTION__,
"bit already cleared for block %lu", "bit already cleared for block %lu", block + i);
block + i); } else {
else
group_freed++; group_freed++;
} }
}
mark_buffer_dirty(bitmap_bh); mark_buffer_dirty(bitmap_bh);
if (sb->s_flags & MS_SYNCHRONOUS) if (sb->s_flags & MS_SYNCHRONOUS)
...@@ -569,25 +569,24 @@ unsigned long ext2_count_free_blocks (struct super_block * sb) ...@@ -569,25 +569,24 @@ unsigned long ext2_count_free_blocks (struct super_block * sb)
static inline int static inline int
block_in_use(unsigned long block, struct super_block *sb, unsigned char *map) block_in_use(unsigned long block, struct super_block *sb, unsigned char *map)
{ {
return ext2_test_bit ((block - le32_to_cpu(EXT2_SB(sb)->s_es->s_first_data_block)) % return ext2_test_bit ((block -
le32_to_cpu(EXT2_SB(sb)->s_es->s_first_data_block)) %
EXT2_BLOCKS_PER_GROUP(sb), map); EXT2_BLOCKS_PER_GROUP(sb), map);
} }
static inline int test_root(int a, int b) static inline int test_root(int a, int b)
{ {
if (a == 0) int num = b;
return 1;
while (1) { while (a > num)
if (a == 1) num *= b;
return 1; return num == a;
if (a % b)
return 0;
a = a / b;
}
} }
static int ext2_group_sparse(int group) static int ext2_group_sparse(int group)
{ {
if (group <= 1)
return 1;
return (test_root(group, 3) || test_root(group, 5) || return (test_root(group, 3) || test_root(group, 5) ||
test_root(group, 7)); test_root(group, 7));
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment