Lines Matching refs:eb

28 			      const struct extent_buffer *eb,  in check_extent_in_eb()  argument
38 !btrfs_file_extent_compression(eb, fi) && in check_extent_in_eb()
39 !btrfs_file_extent_encryption(eb, fi) && in check_extent_in_eb()
40 !btrfs_file_extent_other_encoding(eb, fi)) { in check_extent_in_eb()
44 data_offset = btrfs_file_extent_offset(eb, fi); in check_extent_in_eb()
45 data_len = btrfs_file_extent_num_bytes(eb, fi); in check_extent_in_eb()
75 static int find_extent_in_eb(const struct extent_buffer *eb, in find_extent_in_eb() argument
93 nritems = btrfs_header_nritems(eb); in find_extent_in_eb()
95 btrfs_item_key_to_cpu(eb, &key, slot); in find_extent_in_eb()
98 fi = btrfs_item_ptr(eb, slot, struct btrfs_file_extent_item); in find_extent_in_eb()
99 extent_type = btrfs_file_extent_type(eb, fi); in find_extent_in_eb()
103 disk_byte = btrfs_file_extent_disk_bytenr(eb, fi); in find_extent_in_eb()
107 ret = check_extent_in_eb(&key, eb, fi, extent_item_pos, eie, ignore_offset); in find_extent_in_eb()
426 struct extent_buffer *eb; in add_all_parents() local
437 eb = path->nodes[level]; in add_all_parents()
438 ret = ulist_add(parents, eb->start, 0, GFP_NOFS); in add_all_parents()
454 eb = path->nodes[0]; in add_all_parents()
455 if (path->slots[0] >= btrfs_header_nritems(eb) || in add_all_parents()
456 is_shared_data_backref(preftrees, eb->start) || in add_all_parents()
457 ref->root_id != btrfs_header_owner(eb)) { in add_all_parents()
465 eb = path->nodes[0]; in add_all_parents()
468 btrfs_item_key_to_cpu(eb, &key, slot); in add_all_parents()
480 (is_shared_data_backref(preftrees, eb->start) || in add_all_parents()
481 ref->root_id != btrfs_header_owner(eb))) { in add_all_parents()
488 fi = btrfs_item_ptr(eb, slot, struct btrfs_file_extent_item); in add_all_parents()
489 disk_byte = btrfs_file_extent_disk_bytenr(eb, fi); in add_all_parents()
490 data_offset = btrfs_file_extent_offset(eb, fi); in add_all_parents()
500 ret = check_extent_in_eb(&key, eb, fi, in add_all_parents()
508 ret = ulist_add_merge_ptr(parents, eb->start, in add_all_parents()
544 struct extent_buffer *eb; in resolve_indirect_ref() local
624 eb = path->nodes[level]; in resolve_indirect_ref()
625 while (!eb) { in resolve_indirect_ref()
631 eb = path->nodes[level]; in resolve_indirect_ref()
793 struct extent_buffer *eb; in add_missing_keys() local
805 eb = read_tree_block(fs_info, ref->wanted_disk_byte, 0, in add_missing_keys()
807 if (IS_ERR(eb)) { in add_missing_keys()
809 return PTR_ERR(eb); in add_missing_keys()
810 } else if (!extent_buffer_uptodate(eb)) { in add_missing_keys()
812 free_extent_buffer(eb); in add_missing_keys()
816 btrfs_tree_read_lock(eb); in add_missing_keys()
817 if (btrfs_header_level(eb) == 0) in add_missing_keys()
818 btrfs_item_key_to_cpu(eb, &ref->key_for_search, 0); in add_missing_keys()
820 btrfs_node_key_to_cpu(eb, &ref->key_for_search, 0); in add_missing_keys()
822 btrfs_tree_read_unlock(eb); in add_missing_keys()
823 free_extent_buffer(eb); in add_missing_keys()
1368 struct extent_buffer *eb; local
1370 eb = read_tree_block(fs_info, ref->parent, 0,
1372 if (IS_ERR(eb)) {
1373 ret = PTR_ERR(eb);
1375 } else if (!extent_buffer_uptodate(eb)) {
1376 free_extent_buffer(eb);
1382 btrfs_tree_read_lock(eb);
1383 btrfs_set_lock_blocking_read(eb);
1385 ret = find_extent_in_eb(eb, bytenr,
1388 btrfs_tree_read_unlock_blocking(eb);
1389 free_extent_buffer(eb);
1715 struct extent_buffer *eb = eb_in; local
1727 read_extent_buffer(eb, dest + bytes_left,
1729 if (eb != eb_in) {
1731 btrfs_tree_read_unlock_blocking(eb);
1732 free_extent_buffer(eb);
1748 eb = path->nodes[0];
1750 if (eb != eb_in) {
1752 btrfs_set_lock_blocking_read(eb);
1757 iref = btrfs_item_ptr(eb, slot, struct btrfs_inode_ref);
1759 name_len = btrfs_inode_ref_name_len(eb, iref);
1790 const struct extent_buffer *eb; local
1824 eb = path->nodes[0];
1825 item_size = btrfs_item_size_nr(eb, path->slots[0]);
1828 ei = btrfs_item_ptr(eb, path->slots[0], struct btrfs_extent_item);
1829 flags = btrfs_extent_flags(eb, ei);
1859 const struct extent_buffer *eb, argument
1872 flags = btrfs_extent_flags(eb, ei);
1894 *out_type = btrfs_get_extent_inline_ref_type(eb, *out_eiref,
1914 int tree_backref_for_extent(unsigned long *ptr, struct extent_buffer *eb, argument
1926 ret = get_extent_inline_ref(ptr, eb, key, ei, item_size,
1940 *out_root = btrfs_extent_inline_ref_offset(eb, eiref);
1946 *out_level = btrfs_tree_block_level(eb, info);
2109 struct extent_buffer *eb, void *ctx);
2122 struct extent_buffer *eb; local
2142 eb = btrfs_clone_extent_buffer(path->nodes[0]);
2143 if (!eb) {
2150 iref = btrfs_item_ptr(eb, slot, struct btrfs_inode_ref);
2152 for (cur = 0; cur < btrfs_item_size(eb, item); cur += len) {
2153 name_len = btrfs_inode_ref_name_len(eb, iref);
2160 (unsigned long)(iref + 1), eb, ctx);
2166 free_extent_buffer(eb);
2183 struct extent_buffer *eb; local
2201 eb = btrfs_clone_extent_buffer(path->nodes[0]);
2202 if (!eb) {
2208 item_size = btrfs_item_size_nr(eb, slot);
2209 ptr = btrfs_item_ptr_offset(eb, slot);
2216 parent = btrfs_inode_extref_parent(eb, extref);
2217 name_len = btrfs_inode_extref_name_len(eb, extref);
2219 (unsigned long)&extref->name, eb, ctx);
2223 cur_offset += btrfs_inode_extref_name_len(eb, extref);
2226 free_extent_buffer(eb);
2261 struct extent_buffer *eb, void *ctx) argument
2275 name_off, eb, inum, fspath_min, bytes_left);
2491 struct extent_buffer *eb = btrfs_backref_get_eb(iter); local
2510 type = btrfs_extent_inline_ref_type(eb, iref);
2753 struct extent_buffer *eb; local
2803 eb = path->nodes[level];
2804 if (btrfs_node_blockptr(eb, path->slots[level]) != cur->bytenr) {
2838 eb = path->nodes[level];
2839 rb_node = rb_simple_search(&cache->rb_root, eb->start);
2841 upper = btrfs_backref_alloc_node(cache, eb->start,
2849 upper->owner = btrfs_header_owner(eb);
2857 if (btrfs_block_can_be_shared(root, eb))
2882 upper->owner = btrfs_header_owner(eb);
2959 struct extent_buffer *eb; local
2964 eb = btrfs_backref_get_eb(iter);
2973 type = btrfs_get_extent_inline_ref_type(eb, iref,
2980 key.offset = btrfs_extent_inline_ref_offset(eb, iref);