diff options
| author | Sage Weil <sage@inktank.com> | 2013-08-15 11:11:45 -0700 | 
|---|---|---|
| committer | Sage Weil <sage@inktank.com> | 2013-08-15 11:11:45 -0700 | 
| commit | ee3e542fec6e69bc9fb668698889a37d93950ddf (patch) | |
| tree | e74ee766a4764769ef1d3d45d266b4dea64101d3 /fs/ext4/balloc.c | |
| parent | fe2a801b50c0bb8039d627e5ae1fec249d10ff39 (diff) | |
| parent | f1d6e17f540af37bb1891480143669ba7636c4cf (diff) | |
Merge remote-tracking branch 'linus/master' into testing
Diffstat (limited to 'fs/ext4/balloc.c')
| -rw-r--r-- | fs/ext4/balloc.c | 18 | 
1 files changed, 11 insertions, 7 deletions
| diff --git a/fs/ext4/balloc.c b/fs/ext4/balloc.c index d0f13eada0ed..ddd715e42a5c 100644 --- a/fs/ext4/balloc.c +++ b/fs/ext4/balloc.c @@ -38,8 +38,8 @@ ext4_group_t ext4_get_group_number(struct super_block *sb,  	ext4_group_t group;  	if (test_opt2(sb, STD_GROUP_SIZE)) -		group = (le32_to_cpu(EXT4_SB(sb)->s_es->s_first_data_block) + -			 block) >> +		group = (block - +			 le32_to_cpu(EXT4_SB(sb)->s_es->s_first_data_block)) >>  			(EXT4_BLOCK_SIZE_BITS(sb) + EXT4_CLUSTER_BITS(sb) + 3);  	else  		ext4_get_group_no_and_offset(sb, block, &group, NULL); @@ -682,11 +682,15 @@ ext4_fsblk_t ext4_count_free_clusters(struct super_block *sb)  static inline int test_root(ext4_group_t a, int b)  { -	int num = b; - -	while (a > num) -		num *= b; -	return num == a; +	while (1) { +		if (a < b) +			return 0; +		if (a == b) +			return 1; +		if ((a % b) != 0) +			return 0; +		a = a / b; +	}  }  static int ext4_group_sparse(ext4_group_t group) | 
