struct extent_buffer *btrfs_find_create_tree_block(
                                                struct btrfs_fs_info *fs_info,
-                                               u64 bytenr)
+                                               u64 bytenr, u64 owner_root,
+                                               int level)
 {
        if (btrfs_is_testing(fs_info))
                return alloc_test_extent_buffer(fs_info, bytenr);
-       return alloc_extent_buffer(fs_info, bytenr);
+       return alloc_extent_buffer(fs_info, bytenr, owner_root, level);
 }
 
 /*
        struct extent_buffer *buf = NULL;
        int ret;
 
-       buf = btrfs_find_create_tree_block(fs_info, bytenr);
+       buf = btrfs_find_create_tree_block(fs_info, bytenr, owner_root, level);
        if (IS_ERR(buf))
                return buf;
 
 
                                      int level, struct btrfs_key *first_key);
 struct extent_buffer *btrfs_find_create_tree_block(
                                                struct btrfs_fs_info *fs_info,
-                                               u64 bytenr);
+                                               u64 bytenr, u64 owner_root,
+                                               int level);
 void btrfs_clean_tree_block(struct extent_buffer *buf);
 int __cold open_ctree(struct super_block *sb,
               struct btrfs_fs_devices *fs_devices,
 
        struct btrfs_fs_info *fs_info = root->fs_info;
        struct extent_buffer *buf;
 
-       buf = btrfs_find_create_tree_block(fs_info, bytenr);
+       buf = btrfs_find_create_tree_block(fs_info, bytenr, owner, level);
        if (IS_ERR(buf))
                return buf;
 
 
        next = find_extent_buffer(fs_info, bytenr);
        if (!next) {
-               next = btrfs_find_create_tree_block(fs_info, bytenr);
+               next = btrfs_find_create_tree_block(fs_info, bytenr,
+                               root->root_key.objectid, level - 1);
                if (IS_ERR(next))
                        return PTR_ERR(next);
 
 
 #endif
 
 struct extent_buffer *alloc_extent_buffer(struct btrfs_fs_info *fs_info,
-                                         u64 start)
+                                         u64 start, u64 owner_root, int level)
 {
        unsigned long len = fs_info->nodesize;
        int num_pages;
  * btrfs_readahead_tree_block - attempt to readahead a child block
  * @fs_info:   the fs_info
  * @bytenr:    bytenr to read
+ * @owner_root: objectid of the root that owns this eb
  * @gen:       generation for the uptodate check, can be 0
+ * @level:     level for the eb
  *
  * Attempt to readahead a tree block at @bytenr.  If @gen is 0 then we do a
  * normal uptodate check of the eb, without checking the generation.  If we have
  * to read the block we will not block on anything.
  */
 void btrfs_readahead_tree_block(struct btrfs_fs_info *fs_info,
-                               u64 bytenr, u64 gen)
+                               u64 bytenr, u64 owner_root, u64 gen, int level)
 {
        struct extent_buffer *eb;
        int ret;
 
-       eb = btrfs_find_create_tree_block(fs_info, bytenr);
+       eb = btrfs_find_create_tree_block(fs_info, bytenr, owner_root, level);
        if (IS_ERR(eb))
                return;
 
 {
        btrfs_readahead_tree_block(node->fs_info,
                                   btrfs_node_blockptr(node, slot),
-                                  btrfs_node_ptr_generation(node, slot));
+                                  btrfs_header_owner(node),
+                                  btrfs_node_ptr_generation(node, slot),
+                                  btrfs_header_level(node) - 1);
 }
 
 void set_page_extent_mapped(struct page *page);
 
 struct extent_buffer *alloc_extent_buffer(struct btrfs_fs_info *fs_info,
-                                         u64 start);
+                                         u64 start, u64 owner_root, int level);
 struct extent_buffer *__alloc_dummy_extent_buffer(struct btrfs_fs_info *fs_info,
                                                  u64 start, unsigned long len);
 struct extent_buffer *alloc_dummy_extent_buffer(struct btrfs_fs_info *fs_info,
                             int mirror_num);
 void wait_on_extent_buffer_writeback(struct extent_buffer *eb);
 void btrfs_readahead_tree_block(struct btrfs_fs_info *fs_info,
-                               u64 bytenr, u64 gen);
+                               u64 bytenr, u64 owner_root, u64 gen, int level);
 void btrfs_readahead_node_child(struct extent_buffer *node, int slot);
 
 static inline int num_extent_pages(const struct extent_buffer *eb)
 
 }
 
 static int reada_tree_block_flagged(struct btrfs_fs_info *fs_info, u64 bytenr,
-                                   int mirror_num, struct extent_buffer **eb)
+                                   u64 owner_root, int level, int mirror_num,
+                                   struct extent_buffer **eb)
 {
        struct extent_buffer *buf = NULL;
        int ret;
 
-       buf = btrfs_find_create_tree_block(fs_info, bytenr);
+       buf = btrfs_find_create_tree_block(fs_info, bytenr, owner_root, level);
        if (IS_ERR(buf))
                return 0;
 
        logical = re->logical;
 
        atomic_inc(&dev->reada_in_flight);
-       ret = reada_tree_block_flagged(fs_info, logical, mirror_num, &eb);
+       ret = reada_tree_block_flagged(fs_info, logical, re->owner_root,
+                                      re->level, mirror_num, &eb);
        if (ret)
                __readahead_hook(fs_info, re, NULL, ret);
        else if (eb)
 
        /* Kick in readahead for tree blocks with missing keys */
        rbtree_postorder_for_each_entry_safe(block, next, blocks, rb_node) {
                if (!block->key_ready)
-                       btrfs_readahead_tree_block(fs_info, block->bytenr, 0);
+                       btrfs_readahead_tree_block(fs_info, block->bytenr, 0, 0,
+                                                  block->level);
        }
 
        /* Get first keys */
 
                btrfs_node_key_to_cpu(cur, &first_key, path->slots[*level]);
                blocksize = fs_info->nodesize;
 
-               next = btrfs_find_create_tree_block(fs_info, bytenr);
+               next = btrfs_find_create_tree_block(fs_info, bytenr,
+                                                   btrfs_header_owner(cur),
+                                                   *level - 1);
                if (IS_ERR(next))
                        return PTR_ERR(next);
 
 
         * fixed to BTRFS_SUPER_INFO_SIZE. If nodesize > sb size, this will
         * overallocate but we can keep it as-is, only the first page is used.
         */
-       sb = btrfs_find_create_tree_block(fs_info, BTRFS_SUPER_INFO_OFFSET);
+       sb = btrfs_find_create_tree_block(fs_info, BTRFS_SUPER_INFO_OFFSET,
+                                         root->root_key.objectid, 0);
        if (IS_ERR(sb))
                return PTR_ERR(sb);
        set_extent_buffer_uptodate(sb);