diff options
Diffstat (limited to 'fs/ext4/extents.c')
| -rw-r--r-- | fs/ext4/extents.c | 20 |
1 files changed, 8 insertions, 12 deletions
diff --git a/fs/ext4/extents.c b/fs/ext4/extents.c index 377309c1af65..06328d3e5717 100644 --- a/fs/ext4/extents.c +++ b/fs/ext4/extents.c | |||
| @@ -401,9 +401,9 @@ static int ext4_valid_extent_entries(struct inode *inode, | |||
| 401 | return 1; | 401 | return 1; |
| 402 | } | 402 | } |
| 403 | 403 | ||
| 404 | static int __ext4_ext_check(const char *function, struct inode *inode, | 404 | static int __ext4_ext_check(const char *function, unsigned int line, |
| 405 | struct ext4_extent_header *eh, | 405 | struct inode *inode, struct ext4_extent_header *eh, |
| 406 | int depth) | 406 | int depth) |
| 407 | { | 407 | { |
| 408 | const char *error_msg; | 408 | const char *error_msg; |
| 409 | int max = 0; | 409 | int max = 0; |
| @@ -436,7 +436,7 @@ static int __ext4_ext_check(const char *function, struct inode *inode, | |||
| 436 | return 0; | 436 | return 0; |
| 437 | 437 | ||
| 438 | corrupted: | 438 | corrupted: |
| 439 | ext4_error_inode(function, inode, | 439 | ext4_error_inode(inode, function, line, 0, |
| 440 | "bad header/extent: %s - magic %x, " | 440 | "bad header/extent: %s - magic %x, " |
| 441 | "entries %u, max %u(%u), depth %u(%u)", | 441 | "entries %u, max %u(%u), depth %u(%u)", |
| 442 | error_msg, le16_to_cpu(eh->eh_magic), | 442 | error_msg, le16_to_cpu(eh->eh_magic), |
| @@ -447,7 +447,7 @@ corrupted: | |||
| 447 | } | 447 | } |
| 448 | 448 | ||
| 449 | #define ext4_ext_check(inode, eh, depth) \ | 449 | #define ext4_ext_check(inode, eh, depth) \ |
| 450 | __ext4_ext_check(__func__, inode, eh, depth) | 450 | __ext4_ext_check(__func__, __LINE__, inode, eh, depth) |
| 451 | 451 | ||
| 452 | int ext4_ext_check_inode(struct inode *inode) | 452 | int ext4_ext_check_inode(struct inode *inode) |
| 453 | { | 453 | { |
| @@ -1083,7 +1083,6 @@ static int ext4_ext_grow_indepth(handle_t *handle, struct inode *inode, | |||
| 1083 | { | 1083 | { |
| 1084 | struct ext4_ext_path *curp = path; | 1084 | struct ext4_ext_path *curp = path; |
| 1085 | struct ext4_extent_header *neh; | 1085 | struct ext4_extent_header *neh; |
| 1086 | struct ext4_extent_idx *fidx; | ||
| 1087 | struct buffer_head *bh; | 1086 | struct buffer_head *bh; |
| 1088 | ext4_fsblk_t newblock; | 1087 | ext4_fsblk_t newblock; |
| 1089 | int err = 0; | 1088 | int err = 0; |
| @@ -1144,10 +1143,10 @@ static int ext4_ext_grow_indepth(handle_t *handle, struct inode *inode, | |||
| 1144 | ext4_idx_store_pblock(curp->p_idx, newblock); | 1143 | ext4_idx_store_pblock(curp->p_idx, newblock); |
| 1145 | 1144 | ||
| 1146 | neh = ext_inode_hdr(inode); | 1145 | neh = ext_inode_hdr(inode); |
| 1147 | fidx = EXT_FIRST_INDEX(neh); | ||
| 1148 | ext_debug("new root: num %d(%d), lblock %d, ptr %llu\n", | 1146 | ext_debug("new root: num %d(%d), lblock %d, ptr %llu\n", |
| 1149 | le16_to_cpu(neh->eh_entries), le16_to_cpu(neh->eh_max), | 1147 | le16_to_cpu(neh->eh_entries), le16_to_cpu(neh->eh_max), |
| 1150 | le32_to_cpu(fidx->ei_block), idx_pblock(fidx)); | 1148 | le32_to_cpu(EXT_FIRST_INDEX(neh)->ei_block), |
| 1149 | idx_pblock(EXT_FIRST_INDEX(neh))); | ||
| 1151 | 1150 | ||
| 1152 | neh->eh_depth = cpu_to_le16(path->p_depth + 1); | 1151 | neh->eh_depth = cpu_to_le16(path->p_depth + 1); |
| 1153 | err = ext4_ext_dirty(handle, inode, curp); | 1152 | err = ext4_ext_dirty(handle, inode, curp); |
| @@ -2937,7 +2936,7 @@ fix_extent_len: | |||
| 2937 | * One of more index blocks maybe needed if the extent tree grow after | 2936 | * One of more index blocks maybe needed if the extent tree grow after |
| 2938 | * the unintialized extent split. To prevent ENOSPC occur at the IO | 2937 | * the unintialized extent split. To prevent ENOSPC occur at the IO |
| 2939 | * complete, we need to split the uninitialized extent before DIO submit | 2938 | * complete, we need to split the uninitialized extent before DIO submit |
| 2940 | * the IO. The uninitilized extent called at this time will be split | 2939 | * the IO. The uninitialized extent called at this time will be split |
| 2941 | * into three uninitialized extent(at most). After IO complete, the part | 2940 | * into three uninitialized extent(at most). After IO complete, the part |
| 2942 | * being filled will be convert to initialized by the end_io callback function | 2941 | * being filled will be convert to initialized by the end_io callback function |
| 2943 | * via ext4_convert_unwritten_extents(). | 2942 | * via ext4_convert_unwritten_extents(). |
| @@ -2954,7 +2953,6 @@ static int ext4_split_unwritten_extents(handle_t *handle, | |||
| 2954 | struct ext4_extent *ex1 = NULL; | 2953 | struct ext4_extent *ex1 = NULL; |
| 2955 | struct ext4_extent *ex2 = NULL; | 2954 | struct ext4_extent *ex2 = NULL; |
| 2956 | struct ext4_extent *ex3 = NULL; | 2955 | struct ext4_extent *ex3 = NULL; |
| 2957 | struct ext4_extent_header *eh; | ||
| 2958 | ext4_lblk_t ee_block, eof_block; | 2956 | ext4_lblk_t ee_block, eof_block; |
| 2959 | unsigned int allocated, ee_len, depth; | 2957 | unsigned int allocated, ee_len, depth; |
| 2960 | ext4_fsblk_t newblock; | 2958 | ext4_fsblk_t newblock; |
| @@ -2971,7 +2969,6 @@ static int ext4_split_unwritten_extents(handle_t *handle, | |||
| 2971 | eof_block = map->m_lblk + map->m_len; | 2969 | eof_block = map->m_lblk + map->m_len; |
| 2972 | 2970 | ||
| 2973 | depth = ext_depth(inode); | 2971 | depth = ext_depth(inode); |
| 2974 | eh = path[depth].p_hdr; | ||
| 2975 | ex = path[depth].p_ext; | 2972 | ex = path[depth].p_ext; |
| 2976 | ee_block = le32_to_cpu(ex->ee_block); | 2973 | ee_block = le32_to_cpu(ex->ee_block); |
| 2977 | ee_len = ext4_ext_get_actual_len(ex); | 2974 | ee_len = ext4_ext_get_actual_len(ex); |
| @@ -3058,7 +3055,6 @@ static int ext4_split_unwritten_extents(handle_t *handle, | |||
| 3058 | err = PTR_ERR(path); | 3055 | err = PTR_ERR(path); |
| 3059 | goto out; | 3056 | goto out; |
| 3060 | } | 3057 | } |
| 3061 | eh = path[depth].p_hdr; | ||
| 3062 | ex = path[depth].p_ext; | 3058 | ex = path[depth].p_ext; |
| 3063 | if (ex2 != &newex) | 3059 | if (ex2 != &newex) |
| 3064 | ex2 = ex; | 3060 | ex2 = ex; |
