diff options
-rw-r--r-- | fs/btrfs/ctree.c | 28 | ||||
-rw-r--r-- | fs/btrfs/ctree.h | 2 | ||||
-rw-r--r-- | fs/btrfs/dir-item.c | 2 | ||||
-rw-r--r-- | fs/btrfs/extent-tree.c | 44 | ||||
-rw-r--r-- | fs/btrfs/file-item.c | 12 | ||||
-rw-r--r-- | fs/btrfs/file.c | 12 | ||||
-rw-r--r-- | fs/btrfs/free-space-cache.c | 14 | ||||
-rw-r--r-- | fs/btrfs/inode.c | 34 | ||||
-rw-r--r-- | fs/btrfs/ioctl.c | 12 | ||||
-rw-r--r-- | fs/btrfs/relocation.c | 30 | ||||
-rw-r--r-- | fs/btrfs/root-tree.c | 10 | ||||
-rw-r--r-- | fs/btrfs/tree-defrag.c | 2 | ||||
-rw-r--r-- | fs/btrfs/tree-log.c | 98 | ||||
-rw-r--r-- | fs/btrfs/volumes.c | 16 | ||||
-rw-r--r-- | fs/btrfs/xattr.c | 4 |
15 files changed, 160 insertions, 160 deletions
diff --git a/fs/btrfs/ctree.c b/fs/btrfs/ctree.c index a36c87db4dc4..fad8f23d70f0 100644 --- a/fs/btrfs/ctree.c +++ b/fs/btrfs/ctree.c | |||
@@ -107,7 +107,7 @@ void btrfs_free_path(struct btrfs_path *p) | |||
107 | { | 107 | { |
108 | if (!p) | 108 | if (!p) |
109 | return; | 109 | return; |
110 | btrfs_release_path(NULL, p); | 110 | btrfs_release_path(p); |
111 | kmem_cache_free(btrfs_path_cachep, p); | 111 | kmem_cache_free(btrfs_path_cachep, p); |
112 | } | 112 | } |
113 | 113 | ||
@@ -117,7 +117,7 @@ void btrfs_free_path(struct btrfs_path *p) | |||
117 | * | 117 | * |
118 | * It is safe to call this on paths that no locks or extent buffers held. | 118 | * It is safe to call this on paths that no locks or extent buffers held. |
119 | */ | 119 | */ |
120 | noinline void btrfs_release_path(struct btrfs_root *root, struct btrfs_path *p) | 120 | noinline void btrfs_release_path(struct btrfs_path *p) |
121 | { | 121 | { |
122 | int i; | 122 | int i; |
123 | 123 | ||
@@ -1328,7 +1328,7 @@ static noinline int reada_for_balance(struct btrfs_root *root, | |||
1328 | ret = -EAGAIN; | 1328 | ret = -EAGAIN; |
1329 | 1329 | ||
1330 | /* release the whole path */ | 1330 | /* release the whole path */ |
1331 | btrfs_release_path(root, path); | 1331 | btrfs_release_path(path); |
1332 | 1332 | ||
1333 | /* read the blocks */ | 1333 | /* read the blocks */ |
1334 | if (block1) | 1334 | if (block1) |
@@ -1475,7 +1475,7 @@ read_block_for_search(struct btrfs_trans_handle *trans, | |||
1475 | return 0; | 1475 | return 0; |
1476 | } | 1476 | } |
1477 | free_extent_buffer(tmp); | 1477 | free_extent_buffer(tmp); |
1478 | btrfs_release_path(NULL, p); | 1478 | btrfs_release_path(p); |
1479 | return -EIO; | 1479 | return -EIO; |
1480 | } | 1480 | } |
1481 | } | 1481 | } |
@@ -1494,7 +1494,7 @@ read_block_for_search(struct btrfs_trans_handle *trans, | |||
1494 | if (p->reada) | 1494 | if (p->reada) |
1495 | reada_for_search(root, p, level, slot, key->objectid); | 1495 | reada_for_search(root, p, level, slot, key->objectid); |
1496 | 1496 | ||
1497 | btrfs_release_path(NULL, p); | 1497 | btrfs_release_path(p); |
1498 | 1498 | ||
1499 | ret = -EAGAIN; | 1499 | ret = -EAGAIN; |
1500 | tmp = read_tree_block(root, blocknr, blocksize, 0); | 1500 | tmp = read_tree_block(root, blocknr, blocksize, 0); |
@@ -1563,7 +1563,7 @@ setup_nodes_for_search(struct btrfs_trans_handle *trans, | |||
1563 | } | 1563 | } |
1564 | b = p->nodes[level]; | 1564 | b = p->nodes[level]; |
1565 | if (!b) { | 1565 | if (!b) { |
1566 | btrfs_release_path(NULL, p); | 1566 | btrfs_release_path(p); |
1567 | goto again; | 1567 | goto again; |
1568 | } | 1568 | } |
1569 | BUG_ON(btrfs_header_nritems(b) == 1); | 1569 | BUG_ON(btrfs_header_nritems(b) == 1); |
@@ -1753,7 +1753,7 @@ done: | |||
1753 | if (!p->leave_spinning) | 1753 | if (!p->leave_spinning) |
1754 | btrfs_set_path_blocking(p); | 1754 | btrfs_set_path_blocking(p); |
1755 | if (ret < 0) | 1755 | if (ret < 0) |
1756 | btrfs_release_path(root, p); | 1756 | btrfs_release_path(p); |
1757 | return ret; | 1757 | return ret; |
1758 | } | 1758 | } |
1759 | 1759 | ||
@@ -3026,7 +3026,7 @@ static noinline int setup_leaf_for_split(struct btrfs_trans_handle *trans, | |||
3026 | struct btrfs_file_extent_item); | 3026 | struct btrfs_file_extent_item); |
3027 | extent_len = btrfs_file_extent_num_bytes(leaf, fi); | 3027 | extent_len = btrfs_file_extent_num_bytes(leaf, fi); |
3028 | } | 3028 | } |
3029 | btrfs_release_path(root, path); | 3029 | btrfs_release_path(path); |
3030 | 3030 | ||
3031 | path->keep_locks = 1; | 3031 | path->keep_locks = 1; |
3032 | path->search_for_split = 1; | 3032 | path->search_for_split = 1; |
@@ -3948,7 +3948,7 @@ int btrfs_prev_leaf(struct btrfs_root *root, struct btrfs_path *path) | |||
3948 | else | 3948 | else |
3949 | return 1; | 3949 | return 1; |
3950 | 3950 | ||
3951 | btrfs_release_path(root, path); | 3951 | btrfs_release_path(path); |
3952 | ret = btrfs_search_slot(NULL, root, &key, path, 0, 0); | 3952 | ret = btrfs_search_slot(NULL, root, &key, path, 0, 0); |
3953 | if (ret < 0) | 3953 | if (ret < 0) |
3954 | return ret; | 3954 | return ret; |
@@ -4072,7 +4072,7 @@ find_next_key: | |||
4072 | sret = btrfs_find_next_key(root, path, min_key, level, | 4072 | sret = btrfs_find_next_key(root, path, min_key, level, |
4073 | cache_only, min_trans); | 4073 | cache_only, min_trans); |
4074 | if (sret == 0) { | 4074 | if (sret == 0) { |
4075 | btrfs_release_path(root, path); | 4075 | btrfs_release_path(path); |
4076 | goto again; | 4076 | goto again; |
4077 | } else { | 4077 | } else { |
4078 | goto out; | 4078 | goto out; |
@@ -4151,7 +4151,7 @@ next: | |||
4151 | btrfs_node_key_to_cpu(c, &cur_key, slot); | 4151 | btrfs_node_key_to_cpu(c, &cur_key, slot); |
4152 | 4152 | ||
4153 | orig_lowest = path->lowest_level; | 4153 | orig_lowest = path->lowest_level; |
4154 | btrfs_release_path(root, path); | 4154 | btrfs_release_path(path); |
4155 | path->lowest_level = level; | 4155 | path->lowest_level = level; |
4156 | ret = btrfs_search_slot(NULL, root, &cur_key, path, | 4156 | ret = btrfs_search_slot(NULL, root, &cur_key, path, |
4157 | 0, 0); | 4157 | 0, 0); |
@@ -4228,7 +4228,7 @@ int btrfs_next_leaf(struct btrfs_root *root, struct btrfs_path *path) | |||
4228 | again: | 4228 | again: |
4229 | level = 1; | 4229 | level = 1; |
4230 | next = NULL; | 4230 | next = NULL; |
4231 | btrfs_release_path(root, path); | 4231 | btrfs_release_path(path); |
4232 | 4232 | ||
4233 | path->keep_locks = 1; | 4233 | path->keep_locks = 1; |
4234 | 4234 | ||
@@ -4284,7 +4284,7 @@ again: | |||
4284 | goto again; | 4284 | goto again; |
4285 | 4285 | ||
4286 | if (ret < 0) { | 4286 | if (ret < 0) { |
4287 | btrfs_release_path(root, path); | 4287 | btrfs_release_path(path); |
4288 | goto done; | 4288 | goto done; |
4289 | } | 4289 | } |
4290 | 4290 | ||
@@ -4323,7 +4323,7 @@ again: | |||
4323 | goto again; | 4323 | goto again; |
4324 | 4324 | ||
4325 | if (ret < 0) { | 4325 | if (ret < 0) { |
4326 | btrfs_release_path(root, path); | 4326 | btrfs_release_path(path); |
4327 | goto done; | 4327 | goto done; |
4328 | } | 4328 | } |
4329 | 4329 | ||
diff --git a/fs/btrfs/ctree.h b/fs/btrfs/ctree.h index b5433bbe7516..3f301f05099d 100644 --- a/fs/btrfs/ctree.h +++ b/fs/btrfs/ctree.h | |||
@@ -2290,7 +2290,7 @@ int btrfs_realloc_node(struct btrfs_trans_handle *trans, | |||
2290 | struct btrfs_root *root, struct extent_buffer *parent, | 2290 | struct btrfs_root *root, struct extent_buffer *parent, |
2291 | int start_slot, int cache_only, u64 *last_ret, | 2291 | int start_slot, int cache_only, u64 *last_ret, |
2292 | struct btrfs_key *progress); | 2292 | struct btrfs_key *progress); |
2293 | void btrfs_release_path(struct btrfs_root *root, struct btrfs_path *p); | 2293 | void btrfs_release_path(struct btrfs_path *p); |
2294 | struct btrfs_path *btrfs_alloc_path(void); | 2294 | struct btrfs_path *btrfs_alloc_path(void); |
2295 | void btrfs_free_path(struct btrfs_path *p); | 2295 | void btrfs_free_path(struct btrfs_path *p); |
2296 | void btrfs_set_path_blocking(struct btrfs_path *p); | 2296 | void btrfs_set_path_blocking(struct btrfs_path *p); |
diff --git a/fs/btrfs/dir-item.c b/fs/btrfs/dir-item.c index c62f02f6ae69..ab8afed671a0 100644 --- a/fs/btrfs/dir-item.c +++ b/fs/btrfs/dir-item.c | |||
@@ -172,7 +172,7 @@ second_insert: | |||
172 | ret = 0; | 172 | ret = 0; |
173 | goto out_free; | 173 | goto out_free; |
174 | } | 174 | } |
175 | btrfs_release_path(root, path); | 175 | btrfs_release_path(path); |
176 | 176 | ||
177 | btrfs_set_key_type(&key, BTRFS_DIR_INDEX_KEY); | 177 | btrfs_set_key_type(&key, BTRFS_DIR_INDEX_KEY); |
178 | key.offset = index; | 178 | key.offset = index; |
diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c index 6a3d53783d55..a160f11465f8 100644 --- a/fs/btrfs/extent-tree.c +++ b/fs/btrfs/extent-tree.c | |||
@@ -379,7 +379,7 @@ again: | |||
379 | break; | 379 | break; |
380 | 380 | ||
381 | caching_ctl->progress = last; | 381 | caching_ctl->progress = last; |
382 | btrfs_release_path(extent_root, path); | 382 | btrfs_release_path(path); |
383 | up_read(&fs_info->extent_commit_sem); | 383 | up_read(&fs_info->extent_commit_sem); |
384 | mutex_unlock(&caching_ctl->mutex); | 384 | mutex_unlock(&caching_ctl->mutex); |
385 | if (btrfs_transaction_in_commit(fs_info)) | 385 | if (btrfs_transaction_in_commit(fs_info)) |
@@ -754,7 +754,7 @@ again: | |||
754 | atomic_inc(&head->node.refs); | 754 | atomic_inc(&head->node.refs); |
755 | spin_unlock(&delayed_refs->lock); | 755 | spin_unlock(&delayed_refs->lock); |
756 | 756 | ||
757 | btrfs_release_path(root->fs_info->extent_root, path); | 757 | btrfs_release_path(path); |
758 | 758 | ||
759 | mutex_lock(&head->mutex); | 759 | mutex_lock(&head->mutex); |
760 | mutex_unlock(&head->mutex); | 760 | mutex_unlock(&head->mutex); |
@@ -934,7 +934,7 @@ static int convert_extent_item_v0(struct btrfs_trans_handle *trans, | |||
934 | break; | 934 | break; |
935 | } | 935 | } |
936 | } | 936 | } |
937 | btrfs_release_path(root, path); | 937 | btrfs_release_path(path); |
938 | 938 | ||
939 | if (owner < BTRFS_FIRST_FREE_OBJECTID) | 939 | if (owner < BTRFS_FIRST_FREE_OBJECTID) |
940 | new_size += sizeof(*bi); | 940 | new_size += sizeof(*bi); |
@@ -1042,7 +1042,7 @@ again: | |||
1042 | return 0; | 1042 | return 0; |
1043 | #ifdef BTRFS_COMPAT_EXTENT_TREE_V0 | 1043 | #ifdef BTRFS_COMPAT_EXTENT_TREE_V0 |
1044 | key.type = BTRFS_EXTENT_REF_V0_KEY; | 1044 | key.type = BTRFS_EXTENT_REF_V0_KEY; |
1045 | btrfs_release_path(root, path); | 1045 | btrfs_release_path(path); |
1046 | ret = btrfs_search_slot(trans, root, &key, path, -1, 1); | 1046 | ret = btrfs_search_slot(trans, root, &key, path, -1, 1); |
1047 | if (ret < 0) { | 1047 | if (ret < 0) { |
1048 | err = ret; | 1048 | err = ret; |
@@ -1080,7 +1080,7 @@ again: | |||
1080 | if (match_extent_data_ref(leaf, ref, root_objectid, | 1080 | if (match_extent_data_ref(leaf, ref, root_objectid, |
1081 | owner, offset)) { | 1081 | owner, offset)) { |
1082 | if (recow) { | 1082 | if (recow) { |
1083 | btrfs_release_path(root, path); | 1083 | btrfs_release_path(path); |
1084 | goto again; | 1084 | goto again; |
1085 | } | 1085 | } |
1086 | err = 0; | 1086 | err = 0; |
@@ -1141,7 +1141,7 @@ static noinline int insert_extent_data_ref(struct btrfs_trans_handle *trans, | |||
1141 | if (match_extent_data_ref(leaf, ref, root_objectid, | 1141 | if (match_extent_data_ref(leaf, ref, root_objectid, |
1142 | owner, offset)) | 1142 | owner, offset)) |
1143 | break; | 1143 | break; |
1144 | btrfs_release_path(root, path); | 1144 | btrfs_release_path(path); |
1145 | key.offset++; | 1145 | key.offset++; |
1146 | ret = btrfs_insert_empty_item(trans, root, path, &key, | 1146 | ret = btrfs_insert_empty_item(trans, root, path, &key, |
1147 | size); | 1147 | size); |
@@ -1167,7 +1167,7 @@ static noinline int insert_extent_data_ref(struct btrfs_trans_handle *trans, | |||
1167 | btrfs_mark_buffer_dirty(leaf); | 1167 | btrfs_mark_buffer_dirty(leaf); |
1168 | ret = 0; | 1168 | ret = 0; |
1169 | fail: | 1169 | fail: |
1170 | btrfs_release_path(root, path); | 1170 | btrfs_release_path(path); |
1171 | return ret; | 1171 | return ret; |
1172 | } | 1172 | } |
1173 | 1173 | ||
@@ -1293,7 +1293,7 @@ static noinline int lookup_tree_block_ref(struct btrfs_trans_handle *trans, | |||
1293 | ret = -ENOENT; | 1293 | ret = -ENOENT; |
1294 | #ifdef BTRFS_COMPAT_EXTENT_TREE_V0 | 1294 | #ifdef BTRFS_COMPAT_EXTENT_TREE_V0 |
1295 | if (ret == -ENOENT && parent) { | 1295 | if (ret == -ENOENT && parent) { |
1296 | btrfs_release_path(root, path); | 1296 | btrfs_release_path(path); |
1297 | key.type = BTRFS_EXTENT_REF_V0_KEY; | 1297 | key.type = BTRFS_EXTENT_REF_V0_KEY; |
1298 | ret = btrfs_search_slot(trans, root, &key, path, -1, 1); | 1298 | ret = btrfs_search_slot(trans, root, &key, path, -1, 1); |
1299 | if (ret > 0) | 1299 | if (ret > 0) |
@@ -1322,7 +1322,7 @@ static noinline int insert_tree_block_ref(struct btrfs_trans_handle *trans, | |||
1322 | } | 1322 | } |
1323 | 1323 | ||
1324 | ret = btrfs_insert_empty_item(trans, root, path, &key, 0); | 1324 | ret = btrfs_insert_empty_item(trans, root, path, &key, 0); |
1325 | btrfs_release_path(root, path); | 1325 | btrfs_release_path(path); |
1326 | return ret; | 1326 | return ret; |
1327 | } | 1327 | } |
1328 | 1328 | ||
@@ -1608,7 +1608,7 @@ static int lookup_extent_backref(struct btrfs_trans_handle *trans, | |||
1608 | if (ret != -ENOENT) | 1608 | if (ret != -ENOENT) |
1609 | return ret; | 1609 | return ret; |
1610 | 1610 | ||
1611 | btrfs_release_path(root, path); | 1611 | btrfs_release_path(path); |
1612 | *ref_ret = NULL; | 1612 | *ref_ret = NULL; |
1613 | 1613 | ||
1614 | if (owner < BTRFS_FIRST_FREE_OBJECTID) { | 1614 | if (owner < BTRFS_FIRST_FREE_OBJECTID) { |
@@ -1862,7 +1862,7 @@ static int __btrfs_inc_extent_ref(struct btrfs_trans_handle *trans, | |||
1862 | __run_delayed_extent_op(extent_op, leaf, item); | 1862 | __run_delayed_extent_op(extent_op, leaf, item); |
1863 | 1863 | ||
1864 | btrfs_mark_buffer_dirty(leaf); | 1864 | btrfs_mark_buffer_dirty(leaf); |
1865 | btrfs_release_path(root->fs_info->extent_root, path); | 1865 | btrfs_release_path(path); |
1866 | 1866 | ||
1867 | path->reada = 1; | 1867 | path->reada = 1; |
1868 | path->leave_spinning = 1; | 1868 | path->leave_spinning = 1; |
@@ -2361,7 +2361,7 @@ static noinline int check_delayed_ref(struct btrfs_trans_handle *trans, | |||
2361 | atomic_inc(&head->node.refs); | 2361 | atomic_inc(&head->node.refs); |
2362 | spin_unlock(&delayed_refs->lock); | 2362 | spin_unlock(&delayed_refs->lock); |
2363 | 2363 | ||
2364 | btrfs_release_path(root->fs_info->extent_root, path); | 2364 | btrfs_release_path(path); |
2365 | 2365 | ||
2366 | mutex_lock(&head->mutex); | 2366 | mutex_lock(&head->mutex); |
2367 | mutex_unlock(&head->mutex); | 2367 | mutex_unlock(&head->mutex); |
@@ -2732,7 +2732,7 @@ static int write_one_cache_group(struct btrfs_trans_handle *trans, | |||
2732 | bi = btrfs_item_ptr_offset(leaf, path->slots[0]); | 2732 | bi = btrfs_item_ptr_offset(leaf, path->slots[0]); |
2733 | write_extent_buffer(leaf, &cache->item, bi, sizeof(cache->item)); | 2733 | write_extent_buffer(leaf, &cache->item, bi, sizeof(cache->item)); |
2734 | btrfs_mark_buffer_dirty(leaf); | 2734 | btrfs_mark_buffer_dirty(leaf); |
2735 | btrfs_release_path(extent_root, path); | 2735 | btrfs_release_path(path); |
2736 | fail: | 2736 | fail: |
2737 | if (ret) | 2737 | if (ret) |
2738 | return ret; | 2738 | return ret; |
@@ -2785,7 +2785,7 @@ again: | |||
2785 | inode = lookup_free_space_inode(root, block_group, path); | 2785 | inode = lookup_free_space_inode(root, block_group, path); |
2786 | if (IS_ERR(inode) && PTR_ERR(inode) != -ENOENT) { | 2786 | if (IS_ERR(inode) && PTR_ERR(inode) != -ENOENT) { |
2787 | ret = PTR_ERR(inode); | 2787 | ret = PTR_ERR(inode); |
2788 | btrfs_release_path(root, path); | 2788 | btrfs_release_path(path); |
2789 | goto out; | 2789 | goto out; |
2790 | } | 2790 | } |
2791 | 2791 | ||
@@ -2854,7 +2854,7 @@ again: | |||
2854 | out_put: | 2854 | out_put: |
2855 | iput(inode); | 2855 | iput(inode); |
2856 | out_free: | 2856 | out_free: |
2857 | btrfs_release_path(root, path); | 2857 | btrfs_release_path(path); |
2858 | out: | 2858 | out: |
2859 | spin_lock(&block_group->lock); | 2859 | spin_lock(&block_group->lock); |
2860 | block_group->disk_cache_state = dcs; | 2860 | block_group->disk_cache_state = dcs; |
@@ -4541,7 +4541,7 @@ static int __btrfs_free_extent(struct btrfs_trans_handle *trans, | |||
4541 | NULL, refs_to_drop, | 4541 | NULL, refs_to_drop, |
4542 | is_data); | 4542 | is_data); |
4543 | BUG_ON(ret); | 4543 | BUG_ON(ret); |
4544 | btrfs_release_path(extent_root, path); | 4544 | btrfs_release_path(path); |
4545 | path->leave_spinning = 1; | 4545 | path->leave_spinning = 1; |
4546 | 4546 | ||
4547 | key.objectid = bytenr; | 4547 | key.objectid = bytenr; |
@@ -4580,7 +4580,7 @@ static int __btrfs_free_extent(struct btrfs_trans_handle *trans, | |||
4580 | owner_objectid, 0); | 4580 | owner_objectid, 0); |
4581 | BUG_ON(ret < 0); | 4581 | BUG_ON(ret < 0); |
4582 | 4582 | ||
4583 | btrfs_release_path(extent_root, path); | 4583 | btrfs_release_path(path); |
4584 | path->leave_spinning = 1; | 4584 | path->leave_spinning = 1; |
4585 | 4585 | ||
4586 | key.objectid = bytenr; | 4586 | key.objectid = bytenr; |
@@ -4650,7 +4650,7 @@ static int __btrfs_free_extent(struct btrfs_trans_handle *trans, | |||
4650 | ret = btrfs_del_items(trans, extent_root, path, path->slots[0], | 4650 | ret = btrfs_del_items(trans, extent_root, path, path->slots[0], |
4651 | num_to_del); | 4651 | num_to_del); |
4652 | BUG_ON(ret); | 4652 | BUG_ON(ret); |
4653 | btrfs_release_path(extent_root, path); | 4653 | btrfs_release_path(path); |
4654 | 4654 | ||
4655 | if (is_data) { | 4655 | if (is_data) { |
4656 | ret = btrfs_del_csums(trans, root, bytenr, num_bytes); | 4656 | ret = btrfs_del_csums(trans, root, bytenr, num_bytes); |
@@ -6480,7 +6480,7 @@ int btrfs_drop_snapshot(struct btrfs_root *root, | |||
6480 | trans->block_rsv = block_rsv; | 6480 | trans->block_rsv = block_rsv; |
6481 | } | 6481 | } |
6482 | } | 6482 | } |
6483 | btrfs_release_path(root, path); | 6483 | btrfs_release_path(path); |
6484 | BUG_ON(err); | 6484 | BUG_ON(err); |
6485 | 6485 | ||
6486 | ret = btrfs_del_root(trans, tree_root, &root->root_key); | 6486 | ret = btrfs_del_root(trans, tree_root, &root->root_key); |
@@ -8580,7 +8580,7 @@ int btrfs_read_block_groups(struct btrfs_root *root) | |||
8580 | memcpy(&cache->key, &found_key, sizeof(found_key)); | 8580 | memcpy(&cache->key, &found_key, sizeof(found_key)); |
8581 | 8581 | ||
8582 | key.objectid = found_key.objectid + found_key.offset; | 8582 | key.objectid = found_key.objectid + found_key.offset; |
8583 | btrfs_release_path(root, path); | 8583 | btrfs_release_path(path); |
8584 | cache->flags = btrfs_block_group_flags(&cache->item); | 8584 | cache->flags = btrfs_block_group_flags(&cache->item); |
8585 | cache->sectorsize = root->sectorsize; | 8585 | cache->sectorsize = root->sectorsize; |
8586 | 8586 | ||
@@ -8802,12 +8802,12 @@ int btrfs_remove_block_group(struct btrfs_trans_handle *trans, | |||
8802 | if (ret < 0) | 8802 | if (ret < 0) |
8803 | goto out; | 8803 | goto out; |
8804 | if (ret > 0) | 8804 | if (ret > 0) |
8805 | btrfs_release_path(tree_root, path); | 8805 | btrfs_release_path(path); |
8806 | if (ret == 0) { | 8806 | if (ret == 0) { |
8807 | ret = btrfs_del_item(trans, tree_root, path); | 8807 | ret = btrfs_del_item(trans, tree_root, path); |
8808 | if (ret) | 8808 | if (ret) |
8809 | goto out; | 8809 | goto out; |
8810 | btrfs_release_path(tree_root, path); | 8810 | btrfs_release_path(path); |
8811 | } | 8811 | } |
8812 | 8812 | ||
8813 | spin_lock(&root->fs_info->block_group_cache_lock); | 8813 | spin_lock(&root->fs_info->block_group_cache_lock); |
diff --git a/fs/btrfs/file-item.c b/fs/btrfs/file-item.c index a6a9d4e8b491..f47e43d855aa 100644 --- a/fs/btrfs/file-item.c +++ b/fs/btrfs/file-item.c | |||
@@ -193,7 +193,7 @@ static int __btrfs_lookup_bio_sums(struct btrfs_root *root, | |||
193 | u32 item_size; | 193 | u32 item_size; |
194 | 194 | ||
195 | if (item) | 195 | if (item) |
196 | btrfs_release_path(root, path); | 196 | btrfs_release_path(path); |
197 | item = btrfs_lookup_csum(NULL, root->fs_info->csum_root, | 197 | item = btrfs_lookup_csum(NULL, root->fs_info->csum_root, |
198 | path, disk_bytenr, 0); | 198 | path, disk_bytenr, 0); |
199 | if (IS_ERR(item)) { | 199 | if (IS_ERR(item)) { |
@@ -213,7 +213,7 @@ static int __btrfs_lookup_bio_sums(struct btrfs_root *root, | |||
213 | (unsigned long long)offset); | 213 | (unsigned long long)offset); |
214 | } | 214 | } |
215 | item = NULL; | 215 | item = NULL; |
216 | btrfs_release_path(root, path); | 216 | btrfs_release_path(path); |
217 | goto found; | 217 | goto found; |
218 | } | 218 | } |
219 | btrfs_item_key_to_cpu(path->nodes[0], &found_key, | 219 | btrfs_item_key_to_cpu(path->nodes[0], &found_key, |
@@ -631,7 +631,7 @@ int btrfs_del_csums(struct btrfs_trans_handle *trans, | |||
631 | if (key.offset < bytenr) | 631 | if (key.offset < bytenr) |
632 | break; | 632 | break; |
633 | } | 633 | } |
634 | btrfs_release_path(root, path); | 634 | btrfs_release_path(path); |
635 | } | 635 | } |
636 | out: | 636 | out: |
637 | btrfs_free_path(path); | 637 | btrfs_free_path(path); |
@@ -722,7 +722,7 @@ again: | |||
722 | * at this point, we know the tree has an item, but it isn't big | 722 | * at this point, we know the tree has an item, but it isn't big |
723 | * enough yet to put our csum in. Grow it | 723 | * enough yet to put our csum in. Grow it |
724 | */ | 724 | */ |
725 | btrfs_release_path(root, path); | 725 | btrfs_release_path(path); |
726 | ret = btrfs_search_slot(trans, root, &file_key, path, | 726 | ret = btrfs_search_slot(trans, root, &file_key, path, |
727 | csum_size, 1); | 727 | csum_size, 1); |
728 | if (ret < 0) | 728 | if (ret < 0) |
@@ -766,7 +766,7 @@ again: | |||
766 | } | 766 | } |
767 | 767 | ||
768 | insert: | 768 | insert: |
769 | btrfs_release_path(root, path); | 769 | btrfs_release_path(path); |
770 | csum_offset = 0; | 770 | csum_offset = 0; |
771 | if (found_next) { | 771 | if (found_next) { |
772 | u64 tmp = total_bytes + root->sectorsize; | 772 | u64 tmp = total_bytes + root->sectorsize; |
@@ -850,7 +850,7 @@ next_sector: | |||
850 | } | 850 | } |
851 | btrfs_mark_buffer_dirty(path->nodes[0]); | 851 | btrfs_mark_buffer_dirty(path->nodes[0]); |
852 | if (total_bytes < sums->len) { | 852 | if (total_bytes < sums->len) { |
853 | btrfs_release_path(root, path); | 853 | btrfs_release_path(path); |
854 | cond_resched(); | 854 | cond_resched(); |
855 | goto again; | 855 | goto again; |
856 | } | 856 | } |
diff --git a/fs/btrfs/file.c b/fs/btrfs/file.c index 80eabe85409a..566bdf298ea8 100644 --- a/fs/btrfs/file.c +++ b/fs/btrfs/file.c | |||
@@ -376,7 +376,7 @@ next_slot: | |||
376 | 376 | ||
377 | search_start = max(key.offset, start); | 377 | search_start = max(key.offset, start); |
378 | if (recow) { | 378 | if (recow) { |
379 | btrfs_release_path(root, path); | 379 | btrfs_release_path(path); |
380 | continue; | 380 | continue; |
381 | } | 381 | } |
382 | 382 | ||
@@ -393,7 +393,7 @@ next_slot: | |||
393 | ret = btrfs_duplicate_item(trans, root, path, | 393 | ret = btrfs_duplicate_item(trans, root, path, |
394 | &new_key); | 394 | &new_key); |
395 | if (ret == -EAGAIN) { | 395 | if (ret == -EAGAIN) { |
396 | btrfs_release_path(root, path); | 396 | btrfs_release_path(path); |
397 | continue; | 397 | continue; |
398 | } | 398 | } |
399 | if (ret < 0) | 399 | if (ret < 0) |
@@ -516,7 +516,7 @@ next_slot: | |||
516 | del_nr = 0; | 516 | del_nr = 0; |
517 | del_slot = 0; | 517 | del_slot = 0; |
518 | 518 | ||
519 | btrfs_release_path(root, path); | 519 | btrfs_release_path(path); |
520 | continue; | 520 | continue; |
521 | } | 521 | } |
522 | 522 | ||
@@ -681,7 +681,7 @@ again: | |||
681 | new_key.offset = split; | 681 | new_key.offset = split; |
682 | ret = btrfs_duplicate_item(trans, root, path, &new_key); | 682 | ret = btrfs_duplicate_item(trans, root, path, &new_key); |
683 | if (ret == -EAGAIN) { | 683 | if (ret == -EAGAIN) { |
684 | btrfs_release_path(root, path); | 684 | btrfs_release_path(path); |
685 | goto again; | 685 | goto again; |
686 | } | 686 | } |
687 | BUG_ON(ret < 0); | 687 | BUG_ON(ret < 0); |
@@ -721,7 +721,7 @@ again: | |||
721 | inode->i_ino, bytenr, orig_offset, | 721 | inode->i_ino, bytenr, orig_offset, |
722 | &other_start, &other_end)) { | 722 | &other_start, &other_end)) { |
723 | if (recow) { | 723 | if (recow) { |
724 | btrfs_release_path(root, path); | 724 | btrfs_release_path(path); |
725 | goto again; | 725 | goto again; |
726 | } | 726 | } |
727 | extent_end = other_end; | 727 | extent_end = other_end; |
@@ -738,7 +738,7 @@ again: | |||
738 | inode->i_ino, bytenr, orig_offset, | 738 | inode->i_ino, bytenr, orig_offset, |
739 | &other_start, &other_end)) { | 739 | &other_start, &other_end)) { |
740 | if (recow) { | 740 | if (recow) { |
741 | btrfs_release_path(root, path); | 741 | btrfs_release_path(path); |
742 | goto again; | 742 | goto again; |
743 | } | 743 | } |
744 | key.offset = other_start; | 744 | key.offset = other_start; |
diff --git a/fs/btrfs/free-space-cache.c b/fs/btrfs/free-space-cache.c index d06abe20a729..48fafcb85b0e 100644 --- a/fs/btrfs/free-space-cache.c +++ b/fs/btrfs/free-space-cache.c | |||
@@ -61,7 +61,7 @@ struct inode *lookup_free_space_inode(struct btrfs_root *root, | |||
61 | if (ret < 0) | 61 | if (ret < 0) |
62 | return ERR_PTR(ret); | 62 | return ERR_PTR(ret); |
63 | if (ret > 0) { | 63 | if (ret > 0) { |
64 | btrfs_release_path(root, path); | 64 | btrfs_release_path(path); |
65 | return ERR_PTR(-ENOENT); | 65 | return ERR_PTR(-ENOENT); |
66 | } | 66 | } |
67 | 67 | ||
@@ -70,7 +70,7 @@ struct inode *lookup_free_space_inode(struct btrfs_root *root, | |||
70 | struct btrfs_free_space_header); | 70 | struct btrfs_free_space_header); |
71 | btrfs_free_space_key(leaf, header, &disk_key); | 71 | btrfs_free_space_key(leaf, header, &disk_key); |
72 | btrfs_disk_key_to_cpu(&location, &disk_key); | 72 | btrfs_disk_key_to_cpu(&location, &disk_key); |
73 | btrfs_release_path(root, path); | 73 | btrfs_release_path(path); |
74 | 74 | ||
75 | inode = btrfs_iget(root->fs_info->sb, &location, root, NULL); | 75 | inode = btrfs_iget(root->fs_info->sb, &location, root, NULL); |
76 | if (!inode) | 76 | if (!inode) |
@@ -134,7 +134,7 @@ int create_free_space_inode(struct btrfs_root *root, | |||
134 | btrfs_set_inode_block_group(leaf, inode_item, | 134 | btrfs_set_inode_block_group(leaf, inode_item, |
135 | block_group->key.objectid); | 135 | block_group->key.objectid); |
136 | btrfs_mark_buffer_dirty(leaf); | 136 | btrfs_mark_buffer_dirty(leaf); |
137 | btrfs_release_path(root, path); | 137 | btrfs_release_path(path); |
138 | 138 | ||
139 | key.objectid = BTRFS_FREE_SPACE_OBJECTID; | 139 | key.objectid = BTRFS_FREE_SPACE_OBJECTID; |
140 | key.offset = block_group->key.objectid; | 140 | key.offset = block_group->key.objectid; |
@@ -143,7 +143,7 @@ int create_free_space_inode(struct btrfs_root *root, | |||
143 | ret = btrfs_insert_empty_item(trans, root, path, &key, | 143 | ret = btrfs_insert_empty_item(trans, root, path, &key, |
144 | sizeof(struct btrfs_free_space_header)); | 144 | sizeof(struct btrfs_free_space_header)); |
145 | if (ret < 0) { | 145 | if (ret < 0) { |
146 | btrfs_release_path(root, path); | 146 | btrfs_release_path(path); |
147 | return ret; | 147 | return ret; |
148 | } | 148 | } |
149 | leaf = path->nodes[0]; | 149 | leaf = path->nodes[0]; |
@@ -152,7 +152,7 @@ int create_free_space_inode(struct btrfs_root *root, | |||
152 | memset_extent_buffer(leaf, 0, (unsigned long)header, sizeof(*header)); | 152 | memset_extent_buffer(leaf, 0, (unsigned long)header, sizeof(*header)); |
153 | btrfs_set_free_space_key(leaf, header, &disk_key); | 153 | btrfs_set_free_space_key(leaf, header, &disk_key); |
154 | btrfs_mark_buffer_dirty(leaf); | 154 | btrfs_mark_buffer_dirty(leaf); |
155 | btrfs_release_path(root, path); | 155 | btrfs_release_path(path); |
156 | 156 | ||
157 | return 0; | 157 | return 0; |
158 | } | 158 | } |
@@ -822,7 +822,7 @@ int btrfs_write_out_cache(struct btrfs_root *root, | |||
822 | EXTENT_DIRTY | EXTENT_DELALLOC | | 822 | EXTENT_DIRTY | EXTENT_DELALLOC | |
823 | EXTENT_DO_ACCOUNTING, 0, 0, NULL, | 823 | EXTENT_DO_ACCOUNTING, 0, 0, NULL, |
824 | GFP_NOFS); | 824 | GFP_NOFS); |
825 | btrfs_release_path(root, path); | 825 | btrfs_release_path(path); |
826 | goto out_free; | 826 | goto out_free; |
827 | } | 827 | } |
828 | } | 828 | } |
@@ -832,7 +832,7 @@ int btrfs_write_out_cache(struct btrfs_root *root, | |||
832 | btrfs_set_free_space_bitmaps(leaf, header, bitmaps); | 832 | btrfs_set_free_space_bitmaps(leaf, header, bitmaps); |
833 | btrfs_set_free_space_generation(leaf, header, trans->transid); | 833 | btrfs_set_free_space_generation(leaf, header, trans->transid); |
834 | btrfs_mark_buffer_dirty(leaf); | 834 | btrfs_mark_buffer_dirty(leaf); |
835 | btrfs_release_path(root, path); | 835 | btrfs_release_path(path); |
836 | 836 | ||
837 | ret = 1; | 837 | ret = 1; |
838 | 838 | ||
diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c index 26f4d56cf049..2840989737b7 100644 --- a/fs/btrfs/inode.c +++ b/fs/btrfs/inode.c | |||
@@ -1164,7 +1164,7 @@ out_check: | |||
1164 | goto next_slot; | 1164 | goto next_slot; |
1165 | } | 1165 | } |
1166 | 1166 | ||
1167 | btrfs_release_path(root, path); | 1167 | btrfs_release_path(path); |
1168 | if (cow_start != (u64)-1) { | 1168 | if (cow_start != (u64)-1) { |
1169 | ret = cow_file_range(inode, locked_page, cow_start, | 1169 | ret = cow_file_range(inode, locked_page, cow_start, |
1170 | found_key.offset - 1, page_started, | 1170 | found_key.offset - 1, page_started, |
@@ -1222,7 +1222,7 @@ out_check: | |||
1222 | if (cur_offset > end) | 1222 | if (cur_offset > end) |
1223 | break; | 1223 | break; |
1224 | } | 1224 | } |
1225 | btrfs_release_path(root, path); | 1225 | btrfs_release_path(path); |
1226 | 1226 | ||
1227 | if (cur_offset <= end && cow_start == (u64)-1) | 1227 | if (cur_offset <= end && cow_start == (u64)-1) |
1228 | cow_start = cur_offset; | 1228 | cow_start = cur_offset; |
@@ -2346,7 +2346,7 @@ int btrfs_orphan_cleanup(struct btrfs_root *root) | |||
2346 | break; | 2346 | break; |
2347 | 2347 | ||
2348 | /* release the path since we're done with it */ | 2348 | /* release the path since we're done with it */ |
2349 | btrfs_release_path(root, path); | 2349 | btrfs_release_path(path); |
2350 | 2350 | ||
2351 | /* | 2351 | /* |
2352 | * this is where we are basically btrfs_lookup, without the | 2352 | * this is where we are basically btrfs_lookup, without the |
@@ -2712,7 +2712,7 @@ static int __btrfs_unlink_inode(struct btrfs_trans_handle *trans, | |||
2712 | ret = btrfs_delete_one_dir_name(trans, root, path, di); | 2712 | ret = btrfs_delete_one_dir_name(trans, root, path, di); |
2713 | if (ret) | 2713 | if (ret) |
2714 | goto err; | 2714 | goto err; |
2715 | btrfs_release_path(root, path); | 2715 | btrfs_release_path(path); |
2716 | 2716 | ||
2717 | ret = btrfs_del_inode_ref(trans, root, name, name_len, | 2717 | ret = btrfs_del_inode_ref(trans, root, name, name_len, |
2718 | inode->i_ino, | 2718 | inode->i_ino, |
@@ -2735,7 +2735,7 @@ static int __btrfs_unlink_inode(struct btrfs_trans_handle *trans, | |||
2735 | goto err; | 2735 | goto err; |
2736 | } | 2736 | } |
2737 | ret = btrfs_delete_one_dir_name(trans, root, path, di); | 2737 | ret = btrfs_delete_one_dir_name(trans, root, path, di); |
2738 | btrfs_release_path(root, path); | 2738 | btrfs_release_path(path); |
2739 | 2739 | ||
2740 | ret = btrfs_del_inode_ref_in_log(trans, root, name, name_len, | 2740 | ret = btrfs_del_inode_ref_in_log(trans, root, name, name_len, |
2741 | inode, dir->i_ino); | 2741 | inode, dir->i_ino); |
@@ -2862,7 +2862,7 @@ static struct btrfs_trans_handle *__unlink_start_trans(struct inode *dir, | |||
2862 | } else { | 2862 | } else { |
2863 | check_link = 0; | 2863 | check_link = 0; |
2864 | } | 2864 | } |
2865 | btrfs_release_path(root, path); | 2865 | btrfs_release_path(path); |
2866 | 2866 | ||
2867 | ret = btrfs_lookup_inode(trans, root, path, | 2867 | ret = btrfs_lookup_inode(trans, root, path, |
2868 | &BTRFS_I(inode)->location, 0); | 2868 | &BTRFS_I(inode)->location, 0); |
@@ -2876,7 +2876,7 @@ static struct btrfs_trans_handle *__unlink_start_trans(struct inode *dir, | |||
2876 | } else { | 2876 | } else { |
2877 | check_link = 0; | 2877 | check_link = 0; |
2878 | } | 2878 | } |
2879 | btrfs_release_path(root, path); | 2879 | btrfs_release_path(path); |
2880 | 2880 | ||
2881 | if (ret == 0 && S_ISREG(inode->i_mode)) { | 2881 | if (ret == 0 && S_ISREG(inode->i_mode)) { |
2882 | ret = btrfs_lookup_file_extent(trans, root, path, | 2882 | ret = btrfs_lookup_file_extent(trans, root, path, |
@@ -2888,7 +2888,7 @@ static struct btrfs_trans_handle *__unlink_start_trans(struct inode *dir, | |||
2888 | BUG_ON(ret == 0); | 2888 | BUG_ON(ret == 0); |
2889 | if (check_path_shared(root, path)) | 2889 | if (check_path_shared(root, path)) |
2890 | goto out; | 2890 | goto out; |
2891 | btrfs_release_path(root, path); | 2891 | btrfs_release_path(path); |
2892 | } | 2892 | } |
2893 | 2893 | ||
2894 | if (!check_link) { | 2894 | if (!check_link) { |
@@ -2909,7 +2909,7 @@ static struct btrfs_trans_handle *__unlink_start_trans(struct inode *dir, | |||
2909 | err = 0; | 2909 | err = 0; |
2910 | goto out; | 2910 | goto out; |
2911 | } | 2911 | } |
2912 | btrfs_release_path(root, path); | 2912 | btrfs_release_path(path); |
2913 | 2913 | ||
2914 | ref = btrfs_lookup_inode_ref(trans, root, path, | 2914 | ref = btrfs_lookup_inode_ref(trans, root, path, |
2915 | dentry->d_name.name, dentry->d_name.len, | 2915 | dentry->d_name.name, dentry->d_name.len, |
@@ -2922,7 +2922,7 @@ static struct btrfs_trans_handle *__unlink_start_trans(struct inode *dir, | |||
2922 | if (check_path_shared(root, path)) | 2922 | if (check_path_shared(root, path)) |
2923 | goto out; | 2923 | goto out; |
2924 | index = btrfs_inode_ref_index(path->nodes[0], ref); | 2924 | index = btrfs_inode_ref_index(path->nodes[0], ref); |
2925 | btrfs_release_path(root, path); | 2925 | btrfs_release_path(path); |
2926 | 2926 | ||
2927 | di = btrfs_lookup_dir_index_item(trans, root, path, dir->i_ino, index, | 2927 | di = btrfs_lookup_dir_index_item(trans, root, path, dir->i_ino, index, |
2928 | dentry->d_name.name, dentry->d_name.len, 0); | 2928 | dentry->d_name.name, dentry->d_name.len, 0); |
@@ -3013,7 +3013,7 @@ int btrfs_unlink_subvol(struct btrfs_trans_handle *trans, | |||
3013 | WARN_ON(key.type != BTRFS_ROOT_ITEM_KEY || key.objectid != objectid); | 3013 | WARN_ON(key.type != BTRFS_ROOT_ITEM_KEY || key.objectid != objectid); |
3014 | ret = btrfs_delete_one_dir_name(trans, root, path, di); | 3014 | ret = btrfs_delete_one_dir_name(trans, root, path, di); |
3015 | BUG_ON(ret); | 3015 | BUG_ON(ret); |
3016 | btrfs_release_path(root, path); | 3016 | btrfs_release_path(path); |
3017 | 3017 | ||
3018 | ret = btrfs_del_root_ref(trans, root->fs_info->tree_root, | 3018 | ret = btrfs_del_root_ref(trans, root->fs_info->tree_root, |
3019 | objectid, root->root_key.objectid, | 3019 | objectid, root->root_key.objectid, |
@@ -3026,7 +3026,7 @@ int btrfs_unlink_subvol(struct btrfs_trans_handle *trans, | |||
3026 | 3026 | ||
3027 | leaf = path->nodes[0]; | 3027 | leaf = path->nodes[0]; |
3028 | btrfs_item_key_to_cpu(leaf, &key, path->slots[0]); | 3028 | btrfs_item_key_to_cpu(leaf, &key, path->slots[0]); |
3029 | btrfs_release_path(root, path); | 3029 | btrfs_release_path(path); |
3030 | index = key.offset; | 3030 | index = key.offset; |
3031 | } | 3031 | } |
3032 | 3032 | ||
@@ -3039,7 +3039,7 @@ int btrfs_unlink_subvol(struct btrfs_trans_handle *trans, | |||
3039 | WARN_ON(key.type != BTRFS_ROOT_ITEM_KEY || key.objectid != objectid); | 3039 | WARN_ON(key.type != BTRFS_ROOT_ITEM_KEY || key.objectid != objectid); |
3040 | ret = btrfs_delete_one_dir_name(trans, root, path, di); | 3040 | ret = btrfs_delete_one_dir_name(trans, root, path, di); |
3041 | BUG_ON(ret); | 3041 | BUG_ON(ret); |
3042 | btrfs_release_path(root, path); | 3042 | btrfs_release_path(path); |
3043 | 3043 | ||
3044 | btrfs_i_size_write(dir, dir->i_size - name_len * 2); | 3044 | btrfs_i_size_write(dir, dir->i_size - name_len * 2); |
3045 | dir->i_mtime = dir->i_ctime = CURRENT_TIME; | 3045 | dir->i_mtime = dir->i_ctime = CURRENT_TIME; |
@@ -3477,7 +3477,7 @@ delete: | |||
3477 | BUG_ON(ret); | 3477 | BUG_ON(ret); |
3478 | pending_del_nr = 0; | 3478 | pending_del_nr = 0; |
3479 | } | 3479 | } |
3480 | btrfs_release_path(root, path); | 3480 | btrfs_release_path(path); |
3481 | goto search_again; | 3481 | goto search_again; |
3482 | } else { | 3482 | } else { |
3483 | path->slots[0]--; | 3483 | path->slots[0]--; |
@@ -3899,7 +3899,7 @@ static int fixup_tree_root_location(struct btrfs_root *root, | |||
3899 | if (ret) | 3899 | if (ret) |
3900 | goto out; | 3900 | goto out; |
3901 | 3901 | ||
3902 | btrfs_release_path(root->fs_info->tree_root, path); | 3902 | btrfs_release_path(path); |
3903 | 3903 | ||
3904 | new_root = btrfs_read_fs_root_no_name(root->fs_info, location); | 3904 | new_root = btrfs_read_fs_root_no_name(root->fs_info, location); |
3905 | if (IS_ERR(new_root)) { | 3905 | if (IS_ERR(new_root)) { |
@@ -5223,7 +5223,7 @@ again: | |||
5223 | kunmap(page); | 5223 | kunmap(page); |
5224 | free_extent_map(em); | 5224 | free_extent_map(em); |
5225 | em = NULL; | 5225 | em = NULL; |
5226 | btrfs_release_path(root, path); | 5226 | btrfs_release_path(path); |
5227 | trans = btrfs_join_transaction(root, 1); | 5227 | trans = btrfs_join_transaction(root, 1); |
5228 | if (IS_ERR(trans)) | 5228 | if (IS_ERR(trans)) |
5229 | return ERR_CAST(trans); | 5229 | return ERR_CAST(trans); |
@@ -5249,7 +5249,7 @@ not_found_em: | |||
5249 | em->block_start = EXTENT_MAP_HOLE; | 5249 | em->block_start = EXTENT_MAP_HOLE; |
5250 | set_bit(EXTENT_FLAG_VACANCY, &em->flags); | 5250 | set_bit(EXTENT_FLAG_VACANCY, &em->flags); |
5251 | insert: | 5251 | insert: |
5252 | btrfs_release_path(root, path); | 5252 | btrfs_release_path(path); |
5253 | if (em->start > start || extent_map_end(em) <= start) { | 5253 | if (em->start > start || extent_map_end(em) <= start) { |
5254 | printk(KERN_ERR "Btrfs: bad extent! em: [%llu %llu] passed " | 5254 | printk(KERN_ERR "Btrfs: bad extent! em: [%llu %llu] passed " |
5255 | "[%llu %llu]\n", (unsigned long long)em->start, | 5255 | "[%llu %llu]\n", (unsigned long long)em->start, |
diff --git a/fs/btrfs/ioctl.c b/fs/btrfs/ioctl.c index ffb48d6c5433..d11fc6548e15 100644 --- a/fs/btrfs/ioctl.c +++ b/fs/btrfs/ioctl.c | |||
@@ -1396,7 +1396,7 @@ static noinline int search_ioctl(struct inode *inode, | |||
1396 | } | 1396 | } |
1397 | ret = copy_to_sk(root, path, &key, sk, args->buf, | 1397 | ret = copy_to_sk(root, path, &key, sk, args->buf, |
1398 | &sk_offset, &num_found); | 1398 | &sk_offset, &num_found); |
1399 | btrfs_release_path(root, path); | 1399 | btrfs_release_path(path); |
1400 | if (ret || num_found >= sk->nr_items) | 1400 | if (ret || num_found >= sk->nr_items) |
1401 | break; | 1401 | break; |
1402 | 1402 | ||
@@ -1503,7 +1503,7 @@ static noinline int btrfs_search_path_in_tree(struct btrfs_fs_info *info, | |||
1503 | if (key.offset == BTRFS_FIRST_FREE_OBJECTID) | 1503 | if (key.offset == BTRFS_FIRST_FREE_OBJECTID) |
1504 | break; | 1504 | break; |
1505 | 1505 | ||
1506 | btrfs_release_path(root, path); | 1506 | btrfs_release_path(path); |
1507 | key.objectid = key.offset; | 1507 | key.objectid = key.offset; |
1508 | key.offset = (u64)-1; | 1508 | key.offset = (u64)-1; |
1509 | dirid = key.objectid; | 1509 | dirid = key.objectid; |
@@ -1982,7 +1982,7 @@ static noinline long btrfs_ioctl_clone(struct file *file, unsigned long srcfd, | |||
1982 | datal = btrfs_file_extent_ram_bytes(leaf, | 1982 | datal = btrfs_file_extent_ram_bytes(leaf, |
1983 | extent); | 1983 | extent); |
1984 | } | 1984 | } |
1985 | btrfs_release_path(root, path); | 1985 | btrfs_release_path(path); |
1986 | 1986 | ||
1987 | if (key.offset + datal <= off || | 1987 | if (key.offset + datal <= off || |
1988 | key.offset >= off+len) | 1988 | key.offset >= off+len) |
@@ -2092,7 +2092,7 @@ static noinline long btrfs_ioctl_clone(struct file *file, unsigned long srcfd, | |||
2092 | } | 2092 | } |
2093 | 2093 | ||
2094 | btrfs_mark_buffer_dirty(leaf); | 2094 | btrfs_mark_buffer_dirty(leaf); |
2095 | btrfs_release_path(root, path); | 2095 | btrfs_release_path(path); |
2096 | 2096 | ||
2097 | inode->i_mtime = inode->i_ctime = CURRENT_TIME; | 2097 | inode->i_mtime = inode->i_ctime = CURRENT_TIME; |
2098 | 2098 | ||
@@ -2113,12 +2113,12 @@ static noinline long btrfs_ioctl_clone(struct file *file, unsigned long srcfd, | |||
2113 | btrfs_end_transaction(trans, root); | 2113 | btrfs_end_transaction(trans, root); |
2114 | } | 2114 | } |
2115 | next: | 2115 | next: |
2116 | btrfs_release_path(root, path); | 2116 | btrfs_release_path(path); |
2117 | key.offset++; | 2117 | key.offset++; |
2118 | } | 2118 | } |
2119 | ret = 0; | 2119 | ret = 0; |
2120 | out: | 2120 | out: |
2121 | btrfs_release_path(root, path); | 2121 | btrfs_release_path(path); |
2122 | unlock_extent(&BTRFS_I(src)->io_tree, off, off+len, GFP_NOFS); | 2122 | unlock_extent(&BTRFS_I(src)->io_tree, off, off+len, GFP_NOFS); |
2123 | out_unlock: | 2123 | out_unlock: |
2124 | mutex_unlock(&src->i_mutex); | 2124 | mutex_unlock(&src->i_mutex); |
diff --git a/fs/btrfs/relocation.c b/fs/btrfs/relocation.c index 2097a88f60aa..f7b799b151aa 100644 --- a/fs/btrfs/relocation.c +++ b/fs/btrfs/relocation.c | |||
@@ -961,7 +961,7 @@ again: | |||
961 | lower = upper; | 961 | lower = upper; |
962 | upper = NULL; | 962 | upper = NULL; |
963 | } | 963 | } |
964 | btrfs_release_path(root, path2); | 964 | btrfs_release_path(path2); |
965 | next: | 965 | next: |
966 | if (ptr < end) { | 966 | if (ptr < end) { |
967 | ptr += btrfs_extent_inline_ref_size(key.type); | 967 | ptr += btrfs_extent_inline_ref_size(key.type); |
@@ -974,7 +974,7 @@ next: | |||
974 | if (ptr >= end) | 974 | if (ptr >= end) |
975 | path1->slots[0]++; | 975 | path1->slots[0]++; |
976 | } | 976 | } |
977 | btrfs_release_path(rc->extent_root, path1); | 977 | btrfs_release_path(path1); |
978 | 978 | ||
979 | cur->checked = 1; | 979 | cur->checked = 1; |
980 | WARN_ON(exist); | 980 | WARN_ON(exist); |
@@ -1749,7 +1749,7 @@ again: | |||
1749 | 1749 | ||
1750 | btrfs_node_key_to_cpu(path->nodes[level], &key, | 1750 | btrfs_node_key_to_cpu(path->nodes[level], &key, |
1751 | path->slots[level]); | 1751 | path->slots[level]); |
1752 | btrfs_release_path(src, path); | 1752 | btrfs_release_path(path); |
1753 | 1753 | ||
1754 | path->lowest_level = level; | 1754 | path->lowest_level = level; |
1755 | ret = btrfs_search_slot(trans, src, &key, path, 0, 1); | 1755 | ret = btrfs_search_slot(trans, src, &key, path, 0, 1); |
@@ -2496,7 +2496,7 @@ static int do_relocation(struct btrfs_trans_handle *trans, | |||
2496 | path->locks[upper->level] = 0; | 2496 | path->locks[upper->level] = 0; |
2497 | 2497 | ||
2498 | slot = path->slots[upper->level]; | 2498 | slot = path->slots[upper->level]; |
2499 | btrfs_release_path(NULL, path); | 2499 | btrfs_release_path(path); |
2500 | } else { | 2500 | } else { |
2501 | ret = btrfs_bin_search(upper->eb, key, upper->level, | 2501 | ret = btrfs_bin_search(upper->eb, key, upper->level, |
2502 | &slot); | 2502 | &slot); |
@@ -2737,7 +2737,7 @@ static int relocate_tree_block(struct btrfs_trans_handle *trans, | |||
2737 | } else { | 2737 | } else { |
2738 | path->lowest_level = node->level; | 2738 | path->lowest_level = node->level; |
2739 | ret = btrfs_search_slot(trans, root, key, path, 0, 1); | 2739 | ret = btrfs_search_slot(trans, root, key, path, 0, 1); |
2740 | btrfs_release_path(root, path); | 2740 | btrfs_release_path(path); |
2741 | if (ret > 0) | 2741 | if (ret > 0) |
2742 | ret = 0; | 2742 | ret = 0; |
2743 | } | 2743 | } |
@@ -3119,7 +3119,7 @@ static int add_tree_block(struct reloc_control *rc, | |||
3119 | #endif | 3119 | #endif |
3120 | } | 3120 | } |
3121 | 3121 | ||
3122 | btrfs_release_path(rc->extent_root, path); | 3122 | btrfs_release_path(path); |
3123 | 3123 | ||
3124 | BUG_ON(level == -1); | 3124 | BUG_ON(level == -1); |
3125 | 3125 | ||
@@ -3505,7 +3505,7 @@ int add_data_references(struct reloc_control *rc, | |||
3505 | } | 3505 | } |
3506 | path->slots[0]++; | 3506 | path->slots[0]++; |
3507 | } | 3507 | } |
3508 | btrfs_release_path(rc->extent_root, path); | 3508 | btrfs_release_path(path); |
3509 | if (err) | 3509 | if (err) |
3510 | free_block_list(blocks); | 3510 | free_block_list(blocks); |
3511 | return err; | 3511 | return err; |
@@ -3568,7 +3568,7 @@ next: | |||
3568 | EXTENT_DIRTY); | 3568 | EXTENT_DIRTY); |
3569 | 3569 | ||
3570 | if (ret == 0 && start <= key.objectid) { | 3570 | if (ret == 0 && start <= key.objectid) { |
3571 | btrfs_release_path(rc->extent_root, path); | 3571 | btrfs_release_path(path); |
3572 | rc->search_start = end + 1; | 3572 | rc->search_start = end + 1; |
3573 | } else { | 3573 | } else { |
3574 | rc->search_start = key.objectid + key.offset; | 3574 | rc->search_start = key.objectid + key.offset; |
@@ -3576,7 +3576,7 @@ next: | |||
3576 | return 0; | 3576 | return 0; |
3577 | } | 3577 | } |
3578 | } | 3578 | } |
3579 | btrfs_release_path(rc->extent_root, path); | 3579 | btrfs_release_path(path); |
3580 | return ret; | 3580 | return ret; |
3581 | } | 3581 | } |
3582 | 3582 | ||
@@ -3713,7 +3713,7 @@ restart: | |||
3713 | flags = BTRFS_EXTENT_FLAG_DATA; | 3713 | flags = BTRFS_EXTENT_FLAG_DATA; |
3714 | 3714 | ||
3715 | if (path_change) { | 3715 | if (path_change) { |
3716 | btrfs_release_path(rc->extent_root, path); | 3716 | btrfs_release_path(path); |
3717 | 3717 | ||
3718 | path->search_commit_root = 1; | 3718 | path->search_commit_root = 1; |
3719 | path->skip_locking = 1; | 3719 | path->skip_locking = 1; |
@@ -3736,7 +3736,7 @@ restart: | |||
3736 | (flags & BTRFS_EXTENT_FLAG_DATA)) { | 3736 | (flags & BTRFS_EXTENT_FLAG_DATA)) { |
3737 | ret = add_data_references(rc, &key, path, &blocks); | 3737 | ret = add_data_references(rc, &key, path, &blocks); |
3738 | } else { | 3738 | } else { |
3739 | btrfs_release_path(rc->extent_root, path); | 3739 | btrfs_release_path(path); |
3740 | ret = 0; | 3740 | ret = 0; |
3741 | } | 3741 | } |
3742 | if (ret < 0) { | 3742 | if (ret < 0) { |
@@ -3799,7 +3799,7 @@ restart: | |||
3799 | } | 3799 | } |
3800 | } | 3800 | } |
3801 | 3801 | ||
3802 | btrfs_release_path(rc->extent_root, path); | 3802 | btrfs_release_path(path); |
3803 | clear_extent_bits(&rc->processed_blocks, 0, (u64)-1, EXTENT_DIRTY, | 3803 | clear_extent_bits(&rc->processed_blocks, 0, (u64)-1, EXTENT_DIRTY, |
3804 | GFP_NOFS); | 3804 | GFP_NOFS); |
3805 | 3805 | ||
@@ -3867,7 +3867,7 @@ static int __insert_orphan_inode(struct btrfs_trans_handle *trans, | |||
3867 | btrfs_set_inode_flags(leaf, item, BTRFS_INODE_NOCOMPRESS | | 3867 | btrfs_set_inode_flags(leaf, item, BTRFS_INODE_NOCOMPRESS | |
3868 | BTRFS_INODE_PREALLOC); | 3868 | BTRFS_INODE_PREALLOC); |
3869 | btrfs_mark_buffer_dirty(leaf); | 3869 | btrfs_mark_buffer_dirty(leaf); |
3870 | btrfs_release_path(root, path); | 3870 | btrfs_release_path(path); |
3871 | out: | 3871 | out: |
3872 | btrfs_free_path(path); | 3872 | btrfs_free_path(path); |
3873 | return ret; | 3873 | return ret; |
@@ -4109,7 +4109,7 @@ int btrfs_recover_relocation(struct btrfs_root *root) | |||
4109 | } | 4109 | } |
4110 | leaf = path->nodes[0]; | 4110 | leaf = path->nodes[0]; |
4111 | btrfs_item_key_to_cpu(leaf, &key, path->slots[0]); | 4111 | btrfs_item_key_to_cpu(leaf, &key, path->slots[0]); |
4112 | btrfs_release_path(root->fs_info->tree_root, path); | 4112 | btrfs_release_path(path); |
4113 | 4113 | ||
4114 | if (key.objectid != BTRFS_TREE_RELOC_OBJECTID || | 4114 | if (key.objectid != BTRFS_TREE_RELOC_OBJECTID || |
4115 | key.type != BTRFS_ROOT_ITEM_KEY) | 4115 | key.type != BTRFS_ROOT_ITEM_KEY) |
@@ -4141,7 +4141,7 @@ int btrfs_recover_relocation(struct btrfs_root *root) | |||
4141 | 4141 | ||
4142 | key.offset--; | 4142 | key.offset--; |
4143 | } | 4143 | } |
4144 | btrfs_release_path(root->fs_info->tree_root, path); | 4144 | btrfs_release_path(path); |
4145 | 4145 | ||
4146 | if (list_empty(&reloc_roots)) | 4146 | if (list_empty(&reloc_roots)) |
4147 | goto out; | 4147 | goto out; |
diff --git a/fs/btrfs/root-tree.c b/fs/btrfs/root-tree.c index 6928bff62daa..59a94c1d9815 100644 --- a/fs/btrfs/root-tree.c +++ b/fs/btrfs/root-tree.c | |||
@@ -57,7 +57,7 @@ again: | |||
57 | btrfs_item_key_to_cpu(path->nodes[0], &search_key, path->slots[0]); | 57 | btrfs_item_key_to_cpu(path->nodes[0], &search_key, path->slots[0]); |
58 | if (search_key.type != BTRFS_ROOT_ITEM_KEY) { | 58 | if (search_key.type != BTRFS_ROOT_ITEM_KEY) { |
59 | search_key.offset++; | 59 | search_key.offset++; |
60 | btrfs_release_path(root, path); | 60 | btrfs_release_path(path); |
61 | goto again; | 61 | goto again; |
62 | } | 62 | } |
63 | ret = 0; | 63 | ret = 0; |
@@ -230,7 +230,7 @@ again: | |||
230 | 230 | ||
231 | memcpy(&found_key, &key, sizeof(key)); | 231 | memcpy(&found_key, &key, sizeof(key)); |
232 | key.offset++; | 232 | key.offset++; |
233 | btrfs_release_path(root, path); | 233 | btrfs_release_path(path); |
234 | dead_root = | 234 | dead_root = |
235 | btrfs_read_fs_root_no_radix(root->fs_info->tree_root, | 235 | btrfs_read_fs_root_no_radix(root->fs_info->tree_root, |
236 | &found_key); | 236 | &found_key); |
@@ -292,7 +292,7 @@ int btrfs_find_orphan_roots(struct btrfs_root *tree_root) | |||
292 | } | 292 | } |
293 | 293 | ||
294 | btrfs_item_key_to_cpu(leaf, &key, path->slots[0]); | 294 | btrfs_item_key_to_cpu(leaf, &key, path->slots[0]); |
295 | btrfs_release_path(tree_root, path); | 295 | btrfs_release_path(path); |
296 | 296 | ||
297 | if (key.objectid != BTRFS_ORPHAN_OBJECTID || | 297 | if (key.objectid != BTRFS_ORPHAN_OBJECTID || |
298 | key.type != BTRFS_ORPHAN_ITEM_KEY) | 298 | key.type != BTRFS_ORPHAN_ITEM_KEY) |
@@ -390,7 +390,7 @@ again: | |||
390 | err = -ENOENT; | 390 | err = -ENOENT; |
391 | 391 | ||
392 | if (key.type == BTRFS_ROOT_BACKREF_KEY) { | 392 | if (key.type == BTRFS_ROOT_BACKREF_KEY) { |
393 | btrfs_release_path(tree_root, path); | 393 | btrfs_release_path(path); |
394 | key.objectid = ref_id; | 394 | key.objectid = ref_id; |
395 | key.type = BTRFS_ROOT_REF_KEY; | 395 | key.type = BTRFS_ROOT_REF_KEY; |
396 | key.offset = root_id; | 396 | key.offset = root_id; |
@@ -463,7 +463,7 @@ again: | |||
463 | btrfs_mark_buffer_dirty(leaf); | 463 | btrfs_mark_buffer_dirty(leaf); |
464 | 464 | ||
465 | if (key.type == BTRFS_ROOT_BACKREF_KEY) { | 465 | if (key.type == BTRFS_ROOT_BACKREF_KEY) { |
466 | btrfs_release_path(tree_root, path); | 466 | btrfs_release_path(path); |
467 | key.objectid = ref_id; | 467 | key.objectid = ref_id; |
468 | key.type = BTRFS_ROOT_REF_KEY; | 468 | key.type = BTRFS_ROOT_REF_KEY; |
469 | key.offset = root_id; | 469 | key.offset = root_id; |
diff --git a/fs/btrfs/tree-defrag.c b/fs/btrfs/tree-defrag.c index 992ab425599d..3b580ee8ab1d 100644 --- a/fs/btrfs/tree-defrag.c +++ b/fs/btrfs/tree-defrag.c | |||
@@ -97,7 +97,7 @@ int btrfs_defrag_leaves(struct btrfs_trans_handle *trans, | |||
97 | ret = 0; | 97 | ret = 0; |
98 | goto out; | 98 | goto out; |
99 | } | 99 | } |
100 | btrfs_release_path(root, path); | 100 | btrfs_release_path(path); |
101 | wret = btrfs_search_slot(trans, root, &key, path, 0, 1); | 101 | wret = btrfs_search_slot(trans, root, &key, path, 0, 1); |
102 | 102 | ||
103 | if (wret < 0) { | 103 | if (wret < 0) { |
diff --git a/fs/btrfs/tree-log.c b/fs/btrfs/tree-log.c index d5313d63f967..c599e8c2a53c 100644 --- a/fs/btrfs/tree-log.c +++ b/fs/btrfs/tree-log.c | |||
@@ -333,13 +333,13 @@ static noinline int overwrite_item(struct btrfs_trans_handle *trans, | |||
333 | goto insert; | 333 | goto insert; |
334 | 334 | ||
335 | if (item_size == 0) { | 335 | if (item_size == 0) { |
336 | btrfs_release_path(root, path); | 336 | btrfs_release_path(path); |
337 | return 0; | 337 | return 0; |
338 | } | 338 | } |
339 | dst_copy = kmalloc(item_size, GFP_NOFS); | 339 | dst_copy = kmalloc(item_size, GFP_NOFS); |
340 | src_copy = kmalloc(item_size, GFP_NOFS); | 340 | src_copy = kmalloc(item_size, GFP_NOFS); |
341 | if (!dst_copy || !src_copy) { | 341 | if (!dst_copy || !src_copy) { |
342 | btrfs_release_path(root, path); | 342 | btrfs_release_path(path); |
343 | kfree(dst_copy); | 343 | kfree(dst_copy); |
344 | kfree(src_copy); | 344 | kfree(src_copy); |
345 | return -ENOMEM; | 345 | return -ENOMEM; |
@@ -361,13 +361,13 @@ static noinline int overwrite_item(struct btrfs_trans_handle *trans, | |||
361 | * sync | 361 | * sync |
362 | */ | 362 | */ |
363 | if (ret == 0) { | 363 | if (ret == 0) { |
364 | btrfs_release_path(root, path); | 364 | btrfs_release_path(path); |
365 | return 0; | 365 | return 0; |
366 | } | 366 | } |
367 | 367 | ||
368 | } | 368 | } |
369 | insert: | 369 | insert: |
370 | btrfs_release_path(root, path); | 370 | btrfs_release_path(path); |
371 | /* try to insert the key into the destination tree */ | 371 | /* try to insert the key into the destination tree */ |
372 | ret = btrfs_insert_empty_item(trans, root, path, | 372 | ret = btrfs_insert_empty_item(trans, root, path, |
373 | key, item_size); | 373 | key, item_size); |
@@ -438,7 +438,7 @@ insert: | |||
438 | } | 438 | } |
439 | no_copy: | 439 | no_copy: |
440 | btrfs_mark_buffer_dirty(path->nodes[0]); | 440 | btrfs_mark_buffer_dirty(path->nodes[0]); |
441 | btrfs_release_path(root, path); | 441 | btrfs_release_path(path); |
442 | return 0; | 442 | return 0; |
443 | } | 443 | } |
444 | 444 | ||
@@ -544,11 +544,11 @@ static noinline int replay_one_extent(struct btrfs_trans_handle *trans, | |||
544 | * we don't have to do anything | 544 | * we don't have to do anything |
545 | */ | 545 | */ |
546 | if (memcmp(&cmp1, &cmp2, sizeof(cmp1)) == 0) { | 546 | if (memcmp(&cmp1, &cmp2, sizeof(cmp1)) == 0) { |
547 | btrfs_release_path(root, path); | 547 | btrfs_release_path(path); |
548 | goto out; | 548 | goto out; |
549 | } | 549 | } |
550 | } | 550 | } |
551 | btrfs_release_path(root, path); | 551 | btrfs_release_path(path); |
552 | 552 | ||
553 | saved_nbytes = inode_get_bytes(inode); | 553 | saved_nbytes = inode_get_bytes(inode); |
554 | /* drop any overlapping extents */ | 554 | /* drop any overlapping extents */ |
@@ -600,7 +600,7 @@ static noinline int replay_one_extent(struct btrfs_trans_handle *trans, | |||
600 | key->objectid, offset, &ins); | 600 | key->objectid, offset, &ins); |
601 | BUG_ON(ret); | 601 | BUG_ON(ret); |
602 | } | 602 | } |
603 | btrfs_release_path(root, path); | 603 | btrfs_release_path(path); |
604 | 604 | ||
605 | if (btrfs_file_extent_compression(eb, item)) { | 605 | if (btrfs_file_extent_compression(eb, item)) { |
606 | csum_start = ins.objectid; | 606 | csum_start = ins.objectid; |
@@ -629,7 +629,7 @@ static noinline int replay_one_extent(struct btrfs_trans_handle *trans, | |||
629 | kfree(sums); | 629 | kfree(sums); |
630 | } | 630 | } |
631 | } else { | 631 | } else { |
632 | btrfs_release_path(root, path); | 632 | btrfs_release_path(path); |
633 | } | 633 | } |
634 | } else if (found_type == BTRFS_FILE_EXTENT_INLINE) { | 634 | } else if (found_type == BTRFS_FILE_EXTENT_INLINE) { |
635 | /* inline extents are easy, we just overwrite them */ | 635 | /* inline extents are easy, we just overwrite them */ |
@@ -675,7 +675,7 @@ static noinline int drop_one_dir_item(struct btrfs_trans_handle *trans, | |||
675 | return -ENOMEM; | 675 | return -ENOMEM; |
676 | 676 | ||
677 | read_extent_buffer(leaf, name, (unsigned long)(di + 1), name_len); | 677 | read_extent_buffer(leaf, name, (unsigned long)(di + 1), name_len); |
678 | btrfs_release_path(root, path); | 678 | btrfs_release_path(path); |
679 | 679 | ||
680 | inode = read_one_inode(root, location.objectid); | 680 | inode = read_one_inode(root, location.objectid); |
681 | BUG_ON(!inode); | 681 | BUG_ON(!inode); |
@@ -713,7 +713,7 @@ static noinline int inode_in_dir(struct btrfs_root *root, | |||
713 | goto out; | 713 | goto out; |
714 | } else | 714 | } else |
715 | goto out; | 715 | goto out; |
716 | btrfs_release_path(root, path); | 716 | btrfs_release_path(path); |
717 | 717 | ||
718 | di = btrfs_lookup_dir_item(NULL, root, path, dirid, name, name_len, 0); | 718 | di = btrfs_lookup_dir_item(NULL, root, path, dirid, name, name_len, 0); |
719 | if (di && !IS_ERR(di)) { | 719 | if (di && !IS_ERR(di)) { |
@@ -724,7 +724,7 @@ static noinline int inode_in_dir(struct btrfs_root *root, | |||
724 | goto out; | 724 | goto out; |
725 | match = 1; | 725 | match = 1; |
726 | out: | 726 | out: |
727 | btrfs_release_path(root, path); | 727 | btrfs_release_path(path); |
728 | return match; | 728 | return match; |
729 | } | 729 | } |
730 | 730 | ||
@@ -884,7 +884,7 @@ again: | |||
884 | if (!backref_in_log(log, key, victim_name, | 884 | if (!backref_in_log(log, key, victim_name, |
885 | victim_name_len)) { | 885 | victim_name_len)) { |
886 | btrfs_inc_nlink(inode); | 886 | btrfs_inc_nlink(inode); |
887 | btrfs_release_path(root, path); | 887 | btrfs_release_path(path); |
888 | 888 | ||
889 | ret = btrfs_unlink_inode(trans, root, dir, | 889 | ret = btrfs_unlink_inode(trans, root, dir, |
890 | inode, victim_name, | 890 | inode, victim_name, |
@@ -901,7 +901,7 @@ again: | |||
901 | */ | 901 | */ |
902 | search_done = 1; | 902 | search_done = 1; |
903 | } | 903 | } |
904 | btrfs_release_path(root, path); | 904 | btrfs_release_path(path); |
905 | 905 | ||
906 | insert: | 906 | insert: |
907 | /* insert our name */ | 907 | /* insert our name */ |
@@ -922,7 +922,7 @@ out: | |||
922 | BUG_ON(ret); | 922 | BUG_ON(ret); |
923 | 923 | ||
924 | out_nowrite: | 924 | out_nowrite: |
925 | btrfs_release_path(root, path); | 925 | btrfs_release_path(path); |
926 | iput(dir); | 926 | iput(dir); |
927 | iput(inode); | 927 | iput(inode); |
928 | return 0; | 928 | return 0; |
@@ -999,9 +999,9 @@ static noinline int fixup_inode_link_count(struct btrfs_trans_handle *trans, | |||
999 | if (key.offset == 0) | 999 | if (key.offset == 0) |
1000 | break; | 1000 | break; |
1001 | key.offset--; | 1001 | key.offset--; |
1002 | btrfs_release_path(root, path); | 1002 | btrfs_release_path(path); |
1003 | } | 1003 | } |
1004 | btrfs_release_path(root, path); | 1004 | btrfs_release_path(path); |
1005 | if (nlink != inode->i_nlink) { | 1005 | if (nlink != inode->i_nlink) { |
1006 | inode->i_nlink = nlink; | 1006 | inode->i_nlink = nlink; |
1007 | btrfs_update_inode(trans, root, inode); | 1007 | btrfs_update_inode(trans, root, inode); |
@@ -1052,7 +1052,7 @@ static noinline int fixup_inode_link_counts(struct btrfs_trans_handle *trans, | |||
1052 | ret = btrfs_del_item(trans, root, path); | 1052 | ret = btrfs_del_item(trans, root, path); |
1053 | BUG_ON(ret); | 1053 | BUG_ON(ret); |
1054 | 1054 | ||
1055 | btrfs_release_path(root, path); | 1055 | btrfs_release_path(path); |
1056 | inode = read_one_inode(root, key.offset); | 1056 | inode = read_one_inode(root, key.offset); |
1057 | BUG_ON(!inode); | 1057 | BUG_ON(!inode); |
1058 | 1058 | ||
@@ -1068,7 +1068,7 @@ static noinline int fixup_inode_link_counts(struct btrfs_trans_handle *trans, | |||
1068 | */ | 1068 | */ |
1069 | key.offset = (u64)-1; | 1069 | key.offset = (u64)-1; |
1070 | } | 1070 | } |
1071 | btrfs_release_path(root, path); | 1071 | btrfs_release_path(path); |
1072 | return 0; | 1072 | return 0; |
1073 | } | 1073 | } |
1074 | 1074 | ||
@@ -1096,7 +1096,7 @@ static noinline int link_to_fixup_dir(struct btrfs_trans_handle *trans, | |||
1096 | 1096 | ||
1097 | ret = btrfs_insert_empty_item(trans, root, path, &key, 0); | 1097 | ret = btrfs_insert_empty_item(trans, root, path, &key, 0); |
1098 | 1098 | ||
1099 | btrfs_release_path(root, path); | 1099 | btrfs_release_path(path); |
1100 | if (ret == 0) { | 1100 | if (ret == 0) { |
1101 | btrfs_inc_nlink(inode); | 1101 | btrfs_inc_nlink(inode); |
1102 | btrfs_update_inode(trans, root, inode); | 1102 | btrfs_update_inode(trans, root, inode); |
@@ -1192,7 +1192,7 @@ static noinline int replay_one_name(struct btrfs_trans_handle *trans, | |||
1192 | exists = 1; | 1192 | exists = 1; |
1193 | else | 1193 | else |
1194 | exists = 0; | 1194 | exists = 0; |
1195 | btrfs_release_path(root, path); | 1195 | btrfs_release_path(path); |
1196 | 1196 | ||
1197 | if (key->type == BTRFS_DIR_ITEM_KEY) { | 1197 | if (key->type == BTRFS_DIR_ITEM_KEY) { |
1198 | dst_di = btrfs_lookup_dir_item(trans, root, path, key->objectid, | 1198 | dst_di = btrfs_lookup_dir_item(trans, root, path, key->objectid, |
@@ -1236,13 +1236,13 @@ static noinline int replay_one_name(struct btrfs_trans_handle *trans, | |||
1236 | if (key->type == BTRFS_DIR_INDEX_KEY) | 1236 | if (key->type == BTRFS_DIR_INDEX_KEY) |
1237 | goto insert; | 1237 | goto insert; |
1238 | out: | 1238 | out: |
1239 | btrfs_release_path(root, path); | 1239 | btrfs_release_path(path); |
1240 | kfree(name); | 1240 | kfree(name); |
1241 | iput(dir); | 1241 | iput(dir); |
1242 | return 0; | 1242 | return 0; |
1243 | 1243 | ||
1244 | insert: | 1244 | insert: |
1245 | btrfs_release_path(root, path); | 1245 | btrfs_release_path(path); |
1246 | ret = insert_one_name(trans, root, path, key->objectid, key->offset, | 1246 | ret = insert_one_name(trans, root, path, key->objectid, key->offset, |
1247 | name, name_len, log_type, &log_key); | 1247 | name, name_len, log_type, &log_key); |
1248 | 1248 | ||
@@ -1363,7 +1363,7 @@ next: | |||
1363 | *end_ret = found_end; | 1363 | *end_ret = found_end; |
1364 | ret = 0; | 1364 | ret = 0; |
1365 | out: | 1365 | out: |
1366 | btrfs_release_path(root, path); | 1366 | btrfs_release_path(path); |
1367 | return ret; | 1367 | return ret; |
1368 | } | 1368 | } |
1369 | 1369 | ||
@@ -1428,8 +1428,8 @@ again: | |||
1428 | } | 1428 | } |
1429 | if (IS_ERR_OR_NULL(log_di)) { | 1429 | if (IS_ERR_OR_NULL(log_di)) { |
1430 | btrfs_dir_item_key_to_cpu(eb, di, &location); | 1430 | btrfs_dir_item_key_to_cpu(eb, di, &location); |
1431 | btrfs_release_path(root, path); | 1431 | btrfs_release_path(path); |
1432 | btrfs_release_path(log, log_path); | 1432 | btrfs_release_path(log_path); |
1433 | inode = read_one_inode(root, location.objectid); | 1433 | inode = read_one_inode(root, location.objectid); |
1434 | BUG_ON(!inode); | 1434 | BUG_ON(!inode); |
1435 | 1435 | ||
@@ -1453,7 +1453,7 @@ again: | |||
1453 | ret = 0; | 1453 | ret = 0; |
1454 | goto out; | 1454 | goto out; |
1455 | } | 1455 | } |
1456 | btrfs_release_path(log, log_path); | 1456 | btrfs_release_path(log_path); |
1457 | kfree(name); | 1457 | kfree(name); |
1458 | 1458 | ||
1459 | ptr = (unsigned long)(di + 1); | 1459 | ptr = (unsigned long)(di + 1); |
@@ -1461,8 +1461,8 @@ again: | |||
1461 | } | 1461 | } |
1462 | ret = 0; | 1462 | ret = 0; |
1463 | out: | 1463 | out: |
1464 | btrfs_release_path(root, path); | 1464 | btrfs_release_path(path); |
1465 | btrfs_release_path(log, log_path); | 1465 | btrfs_release_path(log_path); |
1466 | return ret; | 1466 | return ret; |
1467 | } | 1467 | } |
1468 | 1468 | ||
@@ -1550,7 +1550,7 @@ again: | |||
1550 | break; | 1550 | break; |
1551 | dir_key.offset = found_key.offset + 1; | 1551 | dir_key.offset = found_key.offset + 1; |
1552 | } | 1552 | } |
1553 | btrfs_release_path(root, path); | 1553 | btrfs_release_path(path); |
1554 | if (range_end == (u64)-1) | 1554 | if (range_end == (u64)-1) |
1555 | break; | 1555 | break; |
1556 | range_start = range_end + 1; | 1556 | range_start = range_end + 1; |
@@ -1561,11 +1561,11 @@ next_type: | |||
1561 | if (key_type == BTRFS_DIR_LOG_ITEM_KEY) { | 1561 | if (key_type == BTRFS_DIR_LOG_ITEM_KEY) { |
1562 | key_type = BTRFS_DIR_LOG_INDEX_KEY; | 1562 | key_type = BTRFS_DIR_LOG_INDEX_KEY; |
1563 | dir_key.type = BTRFS_DIR_INDEX_KEY; | 1563 | dir_key.type = BTRFS_DIR_INDEX_KEY; |
1564 | btrfs_release_path(root, path); | 1564 | btrfs_release_path(path); |
1565 | goto again; | 1565 | goto again; |
1566 | } | 1566 | } |
1567 | out: | 1567 | out: |
1568 | btrfs_release_path(root, path); | 1568 | btrfs_release_path(path); |
1569 | btrfs_free_path(log_path); | 1569 | btrfs_free_path(log_path); |
1570 | iput(dir); | 1570 | iput(dir); |
1571 | return ret; | 1571 | return ret; |
@@ -2225,7 +2225,7 @@ int btrfs_del_dir_entries_in_log(struct btrfs_trans_handle *trans, | |||
2225 | bytes_del += name_len; | 2225 | bytes_del += name_len; |
2226 | BUG_ON(ret); | 2226 | BUG_ON(ret); |
2227 | } | 2227 | } |
2228 | btrfs_release_path(log, path); | 2228 | btrfs_release_path(path); |
2229 | di = btrfs_lookup_dir_index_item(trans, log, path, dir->i_ino, | 2229 | di = btrfs_lookup_dir_index_item(trans, log, path, dir->i_ino, |
2230 | index, name, name_len, -1); | 2230 | index, name, name_len, -1); |
2231 | if (IS_ERR(di)) { | 2231 | if (IS_ERR(di)) { |
@@ -2247,7 +2247,7 @@ int btrfs_del_dir_entries_in_log(struct btrfs_trans_handle *trans, | |||
2247 | key.objectid = dir->i_ino; | 2247 | key.objectid = dir->i_ino; |
2248 | key.offset = 0; | 2248 | key.offset = 0; |
2249 | key.type = BTRFS_INODE_ITEM_KEY; | 2249 | key.type = BTRFS_INODE_ITEM_KEY; |
2250 | btrfs_release_path(log, path); | 2250 | btrfs_release_path(path); |
2251 | 2251 | ||
2252 | ret = btrfs_search_slot(trans, log, &key, path, 0, 1); | 2252 | ret = btrfs_search_slot(trans, log, &key, path, 0, 1); |
2253 | if (ret < 0) { | 2253 | if (ret < 0) { |
@@ -2269,7 +2269,7 @@ int btrfs_del_dir_entries_in_log(struct btrfs_trans_handle *trans, | |||
2269 | btrfs_mark_buffer_dirty(path->nodes[0]); | 2269 | btrfs_mark_buffer_dirty(path->nodes[0]); |
2270 | } else | 2270 | } else |
2271 | ret = 0; | 2271 | ret = 0; |
2272 | btrfs_release_path(log, path); | 2272 | btrfs_release_path(path); |
2273 | } | 2273 | } |
2274 | fail: | 2274 | fail: |
2275 | btrfs_free_path(path); | 2275 | btrfs_free_path(path); |
@@ -2344,7 +2344,7 @@ static noinline int insert_dir_log_key(struct btrfs_trans_handle *trans, | |||
2344 | struct btrfs_dir_log_item); | 2344 | struct btrfs_dir_log_item); |
2345 | btrfs_set_dir_log_end(path->nodes[0], item, last_offset); | 2345 | btrfs_set_dir_log_end(path->nodes[0], item, last_offset); |
2346 | btrfs_mark_buffer_dirty(path->nodes[0]); | 2346 | btrfs_mark_buffer_dirty(path->nodes[0]); |
2347 | btrfs_release_path(log, path); | 2347 | btrfs_release_path(path); |
2348 | return 0; | 2348 | return 0; |
2349 | } | 2349 | } |
2350 | 2350 | ||
@@ -2393,10 +2393,10 @@ static noinline int log_dir_items(struct btrfs_trans_handle *trans, | |||
2393 | min_key.objectid = inode->i_ino; | 2393 | min_key.objectid = inode->i_ino; |
2394 | min_key.type = key_type; | 2394 | min_key.type = key_type; |
2395 | min_key.offset = (u64)-1; | 2395 | min_key.offset = (u64)-1; |
2396 | btrfs_release_path(root, path); | 2396 | btrfs_release_path(path); |
2397 | ret = btrfs_search_slot(NULL, root, &min_key, path, 0, 0); | 2397 | ret = btrfs_search_slot(NULL, root, &min_key, path, 0, 0); |
2398 | if (ret < 0) { | 2398 | if (ret < 0) { |
2399 | btrfs_release_path(root, path); | 2399 | btrfs_release_path(path); |
2400 | return ret; | 2400 | return ret; |
2401 | } | 2401 | } |
2402 | ret = btrfs_previous_item(root, path, inode->i_ino, key_type); | 2402 | ret = btrfs_previous_item(root, path, inode->i_ino, key_type); |
@@ -2432,7 +2432,7 @@ static noinline int log_dir_items(struct btrfs_trans_handle *trans, | |||
2432 | } | 2432 | } |
2433 | } | 2433 | } |
2434 | } | 2434 | } |
2435 | btrfs_release_path(root, path); | 2435 | btrfs_release_path(path); |
2436 | 2436 | ||
2437 | /* find the first key from this transaction again */ | 2437 | /* find the first key from this transaction again */ |
2438 | ret = btrfs_search_slot(NULL, root, &min_key, path, 0, 0); | 2438 | ret = btrfs_search_slot(NULL, root, &min_key, path, 0, 0); |
@@ -2490,8 +2490,8 @@ static noinline int log_dir_items(struct btrfs_trans_handle *trans, | |||
2490 | } | 2490 | } |
2491 | } | 2491 | } |
2492 | done: | 2492 | done: |
2493 | btrfs_release_path(root, path); | 2493 | btrfs_release_path(path); |
2494 | btrfs_release_path(log, dst_path); | 2494 | btrfs_release_path(dst_path); |
2495 | 2495 | ||
2496 | if (err == 0) { | 2496 | if (err == 0) { |
2497 | *last_offset_ret = last_offset; | 2497 | *last_offset_ret = last_offset; |
@@ -2588,9 +2588,9 @@ static int drop_objectid_items(struct btrfs_trans_handle *trans, | |||
2588 | 2588 | ||
2589 | ret = btrfs_del_item(trans, log, path); | 2589 | ret = btrfs_del_item(trans, log, path); |
2590 | BUG_ON(ret); | 2590 | BUG_ON(ret); |
2591 | btrfs_release_path(log, path); | 2591 | btrfs_release_path(path); |
2592 | } | 2592 | } |
2593 | btrfs_release_path(log, path); | 2593 | btrfs_release_path(path); |
2594 | return ret; | 2594 | return ret; |
2595 | } | 2595 | } |
2596 | 2596 | ||
@@ -2696,7 +2696,7 @@ static noinline int copy_items(struct btrfs_trans_handle *trans, | |||
2696 | } | 2696 | } |
2697 | 2697 | ||
2698 | btrfs_mark_buffer_dirty(dst_path->nodes[0]); | 2698 | btrfs_mark_buffer_dirty(dst_path->nodes[0]); |
2699 | btrfs_release_path(log, dst_path); | 2699 | btrfs_release_path(dst_path); |
2700 | kfree(ins_data); | 2700 | kfree(ins_data); |
2701 | 2701 | ||
2702 | /* | 2702 | /* |
@@ -2845,7 +2845,7 @@ next_slot: | |||
2845 | } | 2845 | } |
2846 | ins_nr = 0; | 2846 | ins_nr = 0; |
2847 | } | 2847 | } |
2848 | btrfs_release_path(root, path); | 2848 | btrfs_release_path(path); |
2849 | 2849 | ||
2850 | if (min_key.offset < (u64)-1) | 2850 | if (min_key.offset < (u64)-1) |
2851 | min_key.offset++; | 2851 | min_key.offset++; |
@@ -2868,8 +2868,8 @@ next_slot: | |||
2868 | } | 2868 | } |
2869 | WARN_ON(ins_nr); | 2869 | WARN_ON(ins_nr); |
2870 | if (inode_only == LOG_INODE_ALL && S_ISDIR(inode->i_mode)) { | 2870 | if (inode_only == LOG_INODE_ALL && S_ISDIR(inode->i_mode)) { |
2871 | btrfs_release_path(root, path); | 2871 | btrfs_release_path(path); |
2872 | btrfs_release_path(log, dst_path); | 2872 | btrfs_release_path(dst_path); |
2873 | ret = log_directory_changes(trans, root, inode, path, dst_path); | 2873 | ret = log_directory_changes(trans, root, inode, path, dst_path); |
2874 | if (ret) { | 2874 | if (ret) { |
2875 | err = ret; | 2875 | err = ret; |
@@ -3136,7 +3136,7 @@ again: | |||
3136 | } | 3136 | } |
3137 | btrfs_item_key_to_cpu(path->nodes[0], &found_key, | 3137 | btrfs_item_key_to_cpu(path->nodes[0], &found_key, |
3138 | path->slots[0]); | 3138 | path->slots[0]); |
3139 | btrfs_release_path(log_root_tree, path); | 3139 | btrfs_release_path(path); |
3140 | if (found_key.objectid != BTRFS_TREE_LOG_OBJECTID) | 3140 | if (found_key.objectid != BTRFS_TREE_LOG_OBJECTID) |
3141 | break; | 3141 | break; |
3142 | 3142 | ||
@@ -3171,7 +3171,7 @@ again: | |||
3171 | if (found_key.offset == 0) | 3171 | if (found_key.offset == 0) |
3172 | break; | 3172 | break; |
3173 | } | 3173 | } |
3174 | btrfs_release_path(log_root_tree, path); | 3174 | btrfs_release_path(path); |
3175 | 3175 | ||
3176 | /* step one is to pin it all, step two is to replay just inodes */ | 3176 | /* step one is to pin it all, step two is to replay just inodes */ |
3177 | if (wc.pin) { | 3177 | if (wc.pin) { |
diff --git a/fs/btrfs/volumes.c b/fs/btrfs/volumes.c index 76acd1d235e4..e21130d3f98a 100644 --- a/fs/btrfs/volumes.c +++ b/fs/btrfs/volumes.c | |||
@@ -1475,7 +1475,7 @@ next_slot: | |||
1475 | goto error; | 1475 | goto error; |
1476 | leaf = path->nodes[0]; | 1476 | leaf = path->nodes[0]; |
1477 | btrfs_item_key_to_cpu(leaf, &key, path->slots[0]); | 1477 | btrfs_item_key_to_cpu(leaf, &key, path->slots[0]); |
1478 | btrfs_release_path(root, path); | 1478 | btrfs_release_path(path); |
1479 | continue; | 1479 | continue; |
1480 | } | 1480 | } |
1481 | 1481 | ||
@@ -1947,7 +1947,7 @@ again: | |||
1947 | chunk = btrfs_item_ptr(leaf, path->slots[0], | 1947 | chunk = btrfs_item_ptr(leaf, path->slots[0], |
1948 | struct btrfs_chunk); | 1948 | struct btrfs_chunk); |
1949 | chunk_type = btrfs_chunk_type(leaf, chunk); | 1949 | chunk_type = btrfs_chunk_type(leaf, chunk); |
1950 | btrfs_release_path(chunk_root, path); | 1950 | btrfs_release_path(path); |
1951 | 1951 | ||
1952 | if (chunk_type & BTRFS_BLOCK_GROUP_SYSTEM) { | 1952 | if (chunk_type & BTRFS_BLOCK_GROUP_SYSTEM) { |
1953 | ret = btrfs_relocate_chunk(chunk_root, chunk_tree, | 1953 | ret = btrfs_relocate_chunk(chunk_root, chunk_tree, |
@@ -2065,7 +2065,7 @@ int btrfs_balance(struct btrfs_root *dev_root) | |||
2065 | if (found_key.offset == 0) | 2065 | if (found_key.offset == 0) |
2066 | break; | 2066 | break; |
2067 | 2067 | ||
2068 | btrfs_release_path(chunk_root, path); | 2068 | btrfs_release_path(path); |
2069 | ret = btrfs_relocate_chunk(chunk_root, | 2069 | ret = btrfs_relocate_chunk(chunk_root, |
2070 | chunk_root->root_key.objectid, | 2070 | chunk_root->root_key.objectid, |
2071 | found_key.objectid, | 2071 | found_key.objectid, |
@@ -2137,7 +2137,7 @@ again: | |||
2137 | goto done; | 2137 | goto done; |
2138 | if (ret) { | 2138 | if (ret) { |
2139 | ret = 0; | 2139 | ret = 0; |
2140 | btrfs_release_path(root, path); | 2140 | btrfs_release_path(path); |
2141 | break; | 2141 | break; |
2142 | } | 2142 | } |
2143 | 2143 | ||
@@ -2146,7 +2146,7 @@ again: | |||
2146 | btrfs_item_key_to_cpu(l, &key, path->slots[0]); | 2146 | btrfs_item_key_to_cpu(l, &key, path->slots[0]); |
2147 | 2147 | ||
2148 | if (key.objectid != device->devid) { | 2148 | if (key.objectid != device->devid) { |
2149 | btrfs_release_path(root, path); | 2149 | btrfs_release_path(path); |
2150 | break; | 2150 | break; |
2151 | } | 2151 | } |
2152 | 2152 | ||
@@ -2154,14 +2154,14 @@ again: | |||
2154 | length = btrfs_dev_extent_length(l, dev_extent); | 2154 | length = btrfs_dev_extent_length(l, dev_extent); |
2155 | 2155 | ||
2156 | if (key.offset + length <= new_size) { | 2156 | if (key.offset + length <= new_size) { |
2157 | btrfs_release_path(root, path); | 2157 | btrfs_release_path(path); |
2158 | break; | 2158 | break; |
2159 | } | 2159 | } |
2160 | 2160 | ||
2161 | chunk_tree = btrfs_dev_extent_chunk_tree(l, dev_extent); | 2161 | chunk_tree = btrfs_dev_extent_chunk_tree(l, dev_extent); |
2162 | chunk_objectid = btrfs_dev_extent_chunk_objectid(l, dev_extent); | 2162 | chunk_objectid = btrfs_dev_extent_chunk_objectid(l, dev_extent); |
2163 | chunk_offset = btrfs_dev_extent_chunk_offset(l, dev_extent); | 2163 | chunk_offset = btrfs_dev_extent_chunk_offset(l, dev_extent); |
2164 | btrfs_release_path(root, path); | 2164 | btrfs_release_path(path); |
2165 | 2165 | ||
2166 | ret = btrfs_relocate_chunk(root, chunk_tree, chunk_objectid, | 2166 | ret = btrfs_relocate_chunk(root, chunk_tree, chunk_objectid, |
2167 | chunk_offset); | 2167 | chunk_offset); |
@@ -3813,7 +3813,7 @@ again: | |||
3813 | } | 3813 | } |
3814 | if (key.objectid == BTRFS_DEV_ITEMS_OBJECTID) { | 3814 | if (key.objectid == BTRFS_DEV_ITEMS_OBJECTID) { |
3815 | key.objectid = 0; | 3815 | key.objectid = 0; |
3816 | btrfs_release_path(root, path); | 3816 | btrfs_release_path(path); |
3817 | goto again; | 3817 | goto again; |
3818 | } | 3818 | } |
3819 | ret = 0; | 3819 | ret = 0; |
diff --git a/fs/btrfs/xattr.c b/fs/btrfs/xattr.c index cfd660550ded..4ca88d1e18e2 100644 --- a/fs/btrfs/xattr.c +++ b/fs/btrfs/xattr.c | |||
@@ -120,13 +120,13 @@ static int do_setxattr(struct btrfs_trans_handle *trans, | |||
120 | 120 | ||
121 | ret = btrfs_delete_one_dir_name(trans, root, path, di); | 121 | ret = btrfs_delete_one_dir_name(trans, root, path, di); |
122 | BUG_ON(ret); | 122 | BUG_ON(ret); |
123 | btrfs_release_path(root, path); | 123 | btrfs_release_path(path); |
124 | 124 | ||
125 | /* if we don't have a value then we are removing the xattr */ | 125 | /* if we don't have a value then we are removing the xattr */ |
126 | if (!value) | 126 | if (!value) |
127 | goto out; | 127 | goto out; |
128 | } else { | 128 | } else { |
129 | btrfs_release_path(root, path); | 129 | btrfs_release_path(path); |
130 | 130 | ||
131 | if (flags & XATTR_REPLACE) { | 131 | if (flags & XATTR_REPLACE) { |
132 | /* we couldn't find the attr to replace */ | 132 | /* we couldn't find the attr to replace */ |