|
@@ -207,11 +207,6 @@ static ext4_fsblk_t ext4_find_near(struct inode *inode, Indirect *ind)
|
|
struct ext4_inode_info *ei = EXT4_I(inode);
|
|
struct ext4_inode_info *ei = EXT4_I(inode);
|
|
__le32 *start = ind->bh ? (__le32 *) ind->bh->b_data : ei->i_data;
|
|
__le32 *start = ind->bh ? (__le32 *) ind->bh->b_data : ei->i_data;
|
|
__le32 *p;
|
|
__le32 *p;
|
|
- ext4_fsblk_t bg_start;
|
|
|
|
- ext4_fsblk_t last_block;
|
|
|
|
- ext4_grpblk_t colour;
|
|
|
|
- ext4_group_t block_group;
|
|
|
|
- int flex_size = ext4_flex_bg_size(EXT4_SB(inode->i_sb));
|
|
|
|
|
|
|
|
/* Try to find previous block */
|
|
/* Try to find previous block */
|
|
for (p = ind->p - 1; p >= start; p--) {
|
|
for (p = ind->p - 1; p >= start; p--) {
|
|
@@ -227,28 +222,7 @@ static ext4_fsblk_t ext4_find_near(struct inode *inode, Indirect *ind)
|
|
* It is going to be referred to from the inode itself? OK, just put it
|
|
* It is going to be referred to from the inode itself? OK, just put it
|
|
* into the same cylinder group then.
|
|
* into the same cylinder group then.
|
|
*/
|
|
*/
|
|
- block_group = ei->i_block_group;
|
|
|
|
- if (flex_size >= EXT4_FLEX_SIZE_DIR_ALLOC_SCHEME) {
|
|
|
|
- block_group &= ~(flex_size-1);
|
|
|
|
- if (S_ISREG(inode->i_mode))
|
|
|
|
- block_group++;
|
|
|
|
- }
|
|
|
|
- bg_start = ext4_group_first_block_no(inode->i_sb, block_group);
|
|
|
|
- last_block = ext4_blocks_count(EXT4_SB(inode->i_sb)->s_es) - 1;
|
|
|
|
-
|
|
|
|
- /*
|
|
|
|
- * If we are doing delayed allocation, we don't need take
|
|
|
|
- * colour into account.
|
|
|
|
- */
|
|
|
|
- if (test_opt(inode->i_sb, DELALLOC))
|
|
|
|
- return bg_start;
|
|
|
|
-
|
|
|
|
- if (bg_start + EXT4_BLOCKS_PER_GROUP(inode->i_sb) <= last_block)
|
|
|
|
- colour = (current->pid % 16) *
|
|
|
|
- (EXT4_BLOCKS_PER_GROUP(inode->i_sb) / 16);
|
|
|
|
- else
|
|
|
|
- colour = (current->pid % 16) * ((last_block - bg_start) / 16);
|
|
|
|
- return bg_start + colour;
|
|
|
|
|
|
+ return ext4_inode_to_goal_block(inode);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
/**
|