diff options
author | Joel Becker <joel.becker@oracle.com> | 2009-02-13 06:41:26 -0500 |
---|---|---|
committer | Joel Becker <joel.becker@oracle.com> | 2009-09-04 19:08:10 -0400 |
commit | dbdcf6a48a40e6c9d7081393d793c4f1c5bb4fcf (patch) | |
tree | d50b179dbbe1a62ea98a0b65ecf33c9a86d906b0 /fs/ocfs2/alloc.c | |
parent | cbee7e1a6a1a2a3d6eda1f76ffc38a3ed3eeb6cc (diff) |
ocfs2: ocfs2_remove_extent() no longer needs struct inode.
One more generic btree function that is isolated from struct inode.
Signed-off-by: Joel Becker <joel.becker@oracle.com>
Diffstat (limited to 'fs/ocfs2/alloc.c')
-rw-r--r-- | fs/ocfs2/alloc.c | 40 |
1 files changed, 21 insertions, 19 deletions
diff --git a/fs/ocfs2/alloc.c b/fs/ocfs2/alloc.c index 29095e155949..bfead609f76c 100644 --- a/fs/ocfs2/alloc.c +++ b/fs/ocfs2/alloc.c | |||
@@ -5198,8 +5198,8 @@ out: | |||
5198 | return ret; | 5198 | return ret; |
5199 | } | 5199 | } |
5200 | 5200 | ||
5201 | static int ocfs2_split_tree(struct inode *inode, struct ocfs2_extent_tree *et, | 5201 | static int ocfs2_split_tree(handle_t *handle, struct ocfs2_extent_tree *et, |
5202 | handle_t *handle, struct ocfs2_path *path, | 5202 | struct ocfs2_path *path, |
5203 | int index, u32 new_range, | 5203 | int index, u32 new_range, |
5204 | struct ocfs2_alloc_context *meta_ac) | 5204 | struct ocfs2_alloc_context *meta_ac) |
5205 | { | 5205 | { |
@@ -5216,7 +5216,8 @@ static int ocfs2_split_tree(struct inode *inode, struct ocfs2_extent_tree *et, | |||
5216 | */ | 5216 | */ |
5217 | el = path_leaf_el(path); | 5217 | el = path_leaf_el(path); |
5218 | rec = &el->l_recs[index]; | 5218 | rec = &el->l_recs[index]; |
5219 | ocfs2_make_right_split_rec(inode->i_sb, &split_rec, new_range, rec); | 5219 | ocfs2_make_right_split_rec(ocfs2_metadata_cache_get_super(et->et_ci), |
5220 | &split_rec, new_range, rec); | ||
5220 | 5221 | ||
5221 | depth = path->p_tree_depth; | 5222 | depth = path->p_tree_depth; |
5222 | if (depth > 0) { | 5223 | if (depth > 0) { |
@@ -5424,9 +5425,9 @@ out: | |||
5424 | return ret; | 5425 | return ret; |
5425 | } | 5426 | } |
5426 | 5427 | ||
5427 | int ocfs2_remove_extent(struct inode *inode, | 5428 | int ocfs2_remove_extent(handle_t *handle, |
5428 | struct ocfs2_extent_tree *et, | 5429 | struct ocfs2_extent_tree *et, |
5429 | u32 cpos, u32 len, handle_t *handle, | 5430 | u32 cpos, u32 len, |
5430 | struct ocfs2_alloc_context *meta_ac, | 5431 | struct ocfs2_alloc_context *meta_ac, |
5431 | struct ocfs2_cached_dealloc_ctxt *dealloc) | 5432 | struct ocfs2_cached_dealloc_ctxt *dealloc) |
5432 | { | 5433 | { |
@@ -5458,10 +5459,11 @@ int ocfs2_remove_extent(struct inode *inode, | |||
5458 | el = path_leaf_el(path); | 5459 | el = path_leaf_el(path); |
5459 | index = ocfs2_search_extent_list(el, cpos); | 5460 | index = ocfs2_search_extent_list(el, cpos); |
5460 | if (index == -1 || index >= le16_to_cpu(el->l_next_free_rec)) { | 5461 | if (index == -1 || index >= le16_to_cpu(el->l_next_free_rec)) { |
5461 | ocfs2_error(inode->i_sb, | 5462 | ocfs2_error(ocfs2_metadata_cache_get_super(et->et_ci), |
5462 | "Inode %llu has an extent at cpos %u which can no " | 5463 | "Owner %llu has an extent at cpos %u which can no " |
5463 | "longer be found.\n", | 5464 | "longer be found.\n", |
5464 | (unsigned long long)OCFS2_I(inode)->ip_blkno, cpos); | 5465 | (unsigned long long)ocfs2_metadata_cache_owner(et->et_ci), |
5466 | cpos); | ||
5465 | ret = -EROFS; | 5467 | ret = -EROFS; |
5466 | goto out; | 5468 | goto out; |
5467 | } | 5469 | } |
@@ -5488,9 +5490,10 @@ int ocfs2_remove_extent(struct inode *inode, | |||
5488 | 5490 | ||
5489 | BUG_ON(cpos < le32_to_cpu(rec->e_cpos) || trunc_range > rec_range); | 5491 | BUG_ON(cpos < le32_to_cpu(rec->e_cpos) || trunc_range > rec_range); |
5490 | 5492 | ||
5491 | mlog(0, "Inode %llu, remove (cpos %u, len %u). Existing index %d " | 5493 | mlog(0, "Owner %llu, remove (cpos %u, len %u). Existing index %d " |
5492 | "(cpos %u, len %u)\n", | 5494 | "(cpos %u, len %u)\n", |
5493 | (unsigned long long)OCFS2_I(inode)->ip_blkno, cpos, len, index, | 5495 | (unsigned long long)ocfs2_metadata_cache_owner(et->et_ci), |
5496 | cpos, len, index, | ||
5494 | le32_to_cpu(rec->e_cpos), ocfs2_rec_clusters(el, rec)); | 5497 | le32_to_cpu(rec->e_cpos), ocfs2_rec_clusters(el, rec)); |
5495 | 5498 | ||
5496 | if (le32_to_cpu(rec->e_cpos) == cpos || rec_range == trunc_range) { | 5499 | if (le32_to_cpu(rec->e_cpos) == cpos || rec_range == trunc_range) { |
@@ -5501,7 +5504,7 @@ int ocfs2_remove_extent(struct inode *inode, | |||
5501 | goto out; | 5504 | goto out; |
5502 | } | 5505 | } |
5503 | } else { | 5506 | } else { |
5504 | ret = ocfs2_split_tree(inode, et, handle, path, index, | 5507 | ret = ocfs2_split_tree(handle, et, path, index, |
5505 | trunc_range, meta_ac); | 5508 | trunc_range, meta_ac); |
5506 | if (ret) { | 5509 | if (ret) { |
5507 | mlog_errno(ret); | 5510 | mlog_errno(ret); |
@@ -5523,9 +5526,9 @@ int ocfs2_remove_extent(struct inode *inode, | |||
5523 | el = path_leaf_el(path); | 5526 | el = path_leaf_el(path); |
5524 | index = ocfs2_search_extent_list(el, cpos); | 5527 | index = ocfs2_search_extent_list(el, cpos); |
5525 | if (index == -1 || index >= le16_to_cpu(el->l_next_free_rec)) { | 5528 | if (index == -1 || index >= le16_to_cpu(el->l_next_free_rec)) { |
5526 | ocfs2_error(inode->i_sb, | 5529 | ocfs2_error(ocfs2_metadata_cache_get_super(et->et_ci), |
5527 | "Inode %llu: split at cpos %u lost record.", | 5530 | "Owner %llu: split at cpos %u lost record.", |
5528 | (unsigned long long)OCFS2_I(inode)->ip_blkno, | 5531 | (unsigned long long)ocfs2_metadata_cache_owner(et->et_ci), |
5529 | cpos); | 5532 | cpos); |
5530 | ret = -EROFS; | 5533 | ret = -EROFS; |
5531 | goto out; | 5534 | goto out; |
@@ -5539,10 +5542,10 @@ int ocfs2_remove_extent(struct inode *inode, | |||
5539 | rec_range = le32_to_cpu(rec->e_cpos) + | 5542 | rec_range = le32_to_cpu(rec->e_cpos) + |
5540 | ocfs2_rec_clusters(el, rec); | 5543 | ocfs2_rec_clusters(el, rec); |
5541 | if (rec_range != trunc_range) { | 5544 | if (rec_range != trunc_range) { |
5542 | ocfs2_error(inode->i_sb, | 5545 | ocfs2_error(ocfs2_metadata_cache_get_super(et->et_ci), |
5543 | "Inode %llu: error after split at cpos %u" | 5546 | "Owner %llu: error after split at cpos %u" |
5544 | "trunc len %u, existing record is (%u,%u)", | 5547 | "trunc len %u, existing record is (%u,%u)", |
5545 | (unsigned long long)OCFS2_I(inode)->ip_blkno, | 5548 | (unsigned long long)ocfs2_metadata_cache_owner(et->et_ci), |
5546 | cpos, len, le32_to_cpu(rec->e_cpos), | 5549 | cpos, len, le32_to_cpu(rec->e_cpos), |
5547 | ocfs2_rec_clusters(el, rec)); | 5550 | ocfs2_rec_clusters(el, rec)); |
5548 | ret = -EROFS; | 5551 | ret = -EROFS; |
@@ -5607,8 +5610,7 @@ int ocfs2_remove_btree_range(struct inode *inode, | |||
5607 | vfs_dq_free_space_nodirty(inode, | 5610 | vfs_dq_free_space_nodirty(inode, |
5608 | ocfs2_clusters_to_bytes(inode->i_sb, len)); | 5611 | ocfs2_clusters_to_bytes(inode->i_sb, len)); |
5609 | 5612 | ||
5610 | ret = ocfs2_remove_extent(inode, et, cpos, len, handle, meta_ac, | 5613 | ret = ocfs2_remove_extent(handle, et, cpos, len, meta_ac, dealloc); |
5611 | dealloc); | ||
5612 | if (ret) { | 5614 | if (ret) { |
5613 | mlog_errno(ret); | 5615 | mlog_errno(ret); |
5614 | goto out_commit; | 5616 | goto out_commit; |