提交 5c601aba 编写于 作者: J Joel Becker

ocfs2: Get inode out of ocfs2_rotate_subtree_root_right().

Pass the ocfs2_extent_list down through ocfs2_rotate_tree_right() and
get rid of struct inode in ocfs2_rotate_subtree_root_right().
Signed-off-by: NJoel Becker <joel.becker@oracle.com>
上级 4619c73e
...@@ -2062,8 +2062,8 @@ static void ocfs2_complete_edge_insert(handle_t *handle, ...@@ -2062,8 +2062,8 @@ static void ocfs2_complete_edge_insert(handle_t *handle,
mlog_errno(ret); mlog_errno(ret);
} }
static int ocfs2_rotate_subtree_right(struct inode *inode, static int ocfs2_rotate_subtree_right(handle_t *handle,
handle_t *handle, struct ocfs2_extent_tree *et,
struct ocfs2_path *left_path, struct ocfs2_path *left_path,
struct ocfs2_path *right_path, struct ocfs2_path *right_path,
int subtree_index) int subtree_index)
...@@ -2079,10 +2079,10 @@ static int ocfs2_rotate_subtree_right(struct inode *inode, ...@@ -2079,10 +2079,10 @@ static int ocfs2_rotate_subtree_right(struct inode *inode,
left_el = path_leaf_el(left_path); left_el = path_leaf_el(left_path);
if (left_el->l_next_free_rec != left_el->l_count) { if (left_el->l_next_free_rec != left_el->l_count) {
ocfs2_error(inode->i_sb, ocfs2_error(ocfs2_metadata_cache_get_super(et->et_ci),
"Inode %llu has non-full interior leaf node %llu" "Inode %llu has non-full interior leaf node %llu"
"(next free = %u)", "(next free = %u)",
(unsigned long long)OCFS2_I(inode)->ip_blkno, (unsigned long long)ocfs2_metadata_cache_owner(et->et_ci),
(unsigned long long)left_leaf_bh->b_blocknr, (unsigned long long)left_leaf_bh->b_blocknr,
le16_to_cpu(left_el->l_next_free_rec)); le16_to_cpu(left_el->l_next_free_rec));
return -EROFS; return -EROFS;
...@@ -2098,7 +2098,7 @@ static int ocfs2_rotate_subtree_right(struct inode *inode, ...@@ -2098,7 +2098,7 @@ static int ocfs2_rotate_subtree_right(struct inode *inode,
root_bh = left_path->p_node[subtree_index].bh; root_bh = left_path->p_node[subtree_index].bh;
BUG_ON(root_bh != right_path->p_node[subtree_index].bh); BUG_ON(root_bh != right_path->p_node[subtree_index].bh);
ret = ocfs2_path_bh_journal_access(handle, INODE_CACHE(inode), right_path, ret = ocfs2_path_bh_journal_access(handle, et->et_ci, right_path,
subtree_index); subtree_index);
if (ret) { if (ret) {
mlog_errno(ret); mlog_errno(ret);
...@@ -2106,14 +2106,14 @@ static int ocfs2_rotate_subtree_right(struct inode *inode, ...@@ -2106,14 +2106,14 @@ static int ocfs2_rotate_subtree_right(struct inode *inode,
} }
for(i = subtree_index + 1; i < path_num_items(right_path); i++) { for(i = subtree_index + 1; i < path_num_items(right_path); i++) {
ret = ocfs2_path_bh_journal_access(handle, INODE_CACHE(inode), ret = ocfs2_path_bh_journal_access(handle, et->et_ci,
right_path, i); right_path, i);
if (ret) { if (ret) {
mlog_errno(ret); mlog_errno(ret);
goto out; goto out;
} }
ret = ocfs2_path_bh_journal_access(handle, INODE_CACHE(inode), ret = ocfs2_path_bh_journal_access(handle, et->et_ci,
left_path, i); left_path, i);
if (ret) { if (ret) {
mlog_errno(ret); mlog_errno(ret);
...@@ -2127,7 +2127,7 @@ static int ocfs2_rotate_subtree_right(struct inode *inode, ...@@ -2127,7 +2127,7 @@ static int ocfs2_rotate_subtree_right(struct inode *inode,
/* This is a code error, not a disk corruption. */ /* This is a code error, not a disk corruption. */
mlog_bug_on_msg(!right_el->l_next_free_rec, "Inode %llu: Rotate fails " mlog_bug_on_msg(!right_el->l_next_free_rec, "Inode %llu: Rotate fails "
"because rightmost leaf block %llu is empty\n", "because rightmost leaf block %llu is empty\n",
(unsigned long long)OCFS2_I(inode)->ip_blkno, (unsigned long long)ocfs2_metadata_cache_owner(et->et_ci),
(unsigned long long)right_leaf_bh->b_blocknr); (unsigned long long)right_leaf_bh->b_blocknr);
ocfs2_create_empty_extent(right_el); ocfs2_create_empty_extent(right_el);
...@@ -2325,8 +2325,8 @@ static int ocfs2_leftmost_rec_contains(struct ocfs2_extent_list *el, u32 cpos) ...@@ -2325,8 +2325,8 @@ static int ocfs2_leftmost_rec_contains(struct ocfs2_extent_list *el, u32 cpos)
* *ret_left_path will contain a valid path which can be passed to * *ret_left_path will contain a valid path which can be passed to
* ocfs2_insert_path(). * ocfs2_insert_path().
*/ */
static int ocfs2_rotate_tree_right(struct inode *inode, static int ocfs2_rotate_tree_right(struct inode *inode, handle_t *handle,
handle_t *handle, struct ocfs2_extent_tree *et,
enum ocfs2_split_type split, enum ocfs2_split_type split,
u32 insert_cpos, u32 insert_cpos,
struct ocfs2_path *right_path, struct ocfs2_path *right_path,
...@@ -2335,6 +2335,7 @@ static int ocfs2_rotate_tree_right(struct inode *inode, ...@@ -2335,6 +2335,7 @@ static int ocfs2_rotate_tree_right(struct inode *inode,
int ret, start, orig_credits = handle->h_buffer_credits; int ret, start, orig_credits = handle->h_buffer_credits;
u32 cpos; u32 cpos;
struct ocfs2_path *left_path = NULL; struct ocfs2_path *left_path = NULL;
struct super_block *sb = ocfs2_metadata_cache_get_super(et->et_ci);
*ret_left_path = NULL; *ret_left_path = NULL;
...@@ -2345,7 +2346,7 @@ static int ocfs2_rotate_tree_right(struct inode *inode, ...@@ -2345,7 +2346,7 @@ static int ocfs2_rotate_tree_right(struct inode *inode,
goto out; goto out;
} }
ret = ocfs2_find_cpos_for_left_leaf(inode->i_sb, right_path, &cpos); ret = ocfs2_find_cpos_for_left_leaf(sb, right_path, &cpos);
if (ret) { if (ret) {
mlog_errno(ret); mlog_errno(ret);
goto out; goto out;
...@@ -2383,7 +2384,7 @@ static int ocfs2_rotate_tree_right(struct inode *inode, ...@@ -2383,7 +2384,7 @@ static int ocfs2_rotate_tree_right(struct inode *inode,
mlog(0, "Rotating a tree: ins. cpos: %u, left path cpos: %u\n", mlog(0, "Rotating a tree: ins. cpos: %u, left path cpos: %u\n",
insert_cpos, cpos); insert_cpos, cpos);
ret = ocfs2_find_path(INODE_CACHE(inode), left_path, cpos); ret = ocfs2_find_path(et->et_ci, left_path, cpos);
if (ret) { if (ret) {
mlog_errno(ret); mlog_errno(ret);
goto out; goto out;
...@@ -2391,10 +2392,11 @@ static int ocfs2_rotate_tree_right(struct inode *inode, ...@@ -2391,10 +2392,11 @@ static int ocfs2_rotate_tree_right(struct inode *inode,
mlog_bug_on_msg(path_leaf_bh(left_path) == mlog_bug_on_msg(path_leaf_bh(left_path) ==
path_leaf_bh(right_path), path_leaf_bh(right_path),
"Inode %lu: error during insert of %u " "Owner %llu: error during insert of %u "
"(left path cpos %u) results in two identical " "(left path cpos %u) results in two identical "
"paths ending at %llu\n", "paths ending at %llu\n",
inode->i_ino, insert_cpos, cpos, (unsigned long long)ocfs2_metadata_cache_owner(et->et_ci),
insert_cpos, cpos,
(unsigned long long) (unsigned long long)
path_leaf_bh(left_path)->b_blocknr); path_leaf_bh(left_path)->b_blocknr);
...@@ -2434,7 +2436,7 @@ static int ocfs2_rotate_tree_right(struct inode *inode, ...@@ -2434,7 +2436,7 @@ static int ocfs2_rotate_tree_right(struct inode *inode,
goto out; goto out;
} }
ret = ocfs2_rotate_subtree_right(inode, handle, left_path, ret = ocfs2_rotate_subtree_right(handle, et, left_path,
right_path, start); right_path, start);
if (ret) { if (ret) {
mlog_errno(ret); mlog_errno(ret);
...@@ -2466,8 +2468,7 @@ static int ocfs2_rotate_tree_right(struct inode *inode, ...@@ -2466,8 +2468,7 @@ static int ocfs2_rotate_tree_right(struct inode *inode,
*/ */
ocfs2_mv_path(right_path, left_path); ocfs2_mv_path(right_path, left_path);
ret = ocfs2_find_cpos_for_left_leaf(inode->i_sb, right_path, ret = ocfs2_find_cpos_for_left_leaf(sb, right_path, &cpos);
&cpos);
if (ret) { if (ret) {
mlog_errno(ret); mlog_errno(ret);
goto out; goto out;
...@@ -4268,7 +4269,7 @@ static int ocfs2_do_insert_extent(struct inode *inode, ...@@ -4268,7 +4269,7 @@ static int ocfs2_do_insert_extent(struct inode *inode,
* can wind up skipping both of these two special cases... * can wind up skipping both of these two special cases...
*/ */
if (rotate) { if (rotate) {
ret = ocfs2_rotate_tree_right(inode, handle, type->ins_split, ret = ocfs2_rotate_tree_right(inode, handle, et, type->ins_split,
le32_to_cpu(insert_rec->e_cpos), le32_to_cpu(insert_rec->e_cpos),
right_path, &left_path); right_path, &left_path);
if (ret) { if (ret) {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册