if (*cow_ret == buf)
                unlock_orig = 1;
 
-       btrfs_assert_tree_locked(buf);
+       btrfs_assert_tree_write_locked(buf);
 
        WARN_ON(test_bit(BTRFS_ROOT_SHAREABLE, &root->state) &&
                trans->transid != fs_info->running_transaction->transid);
        int ret;
 
        BUG_ON(!path->nodes[level]);
-       btrfs_assert_tree_locked(path->nodes[level]);
+       btrfs_assert_tree_write_locked(path->nodes[level]);
        lower = path->nodes[level];
        nritems = btrfs_header_nritems(lower);
        BUG_ON(slot > nritems);
        if (slot >= btrfs_header_nritems(upper) - 1)
                return 1;
 
-       btrfs_assert_tree_locked(path->nodes[1]);
+       btrfs_assert_tree_write_locked(path->nodes[1]);
 
        right = btrfs_read_node_slot(upper, slot + 1);
        /*
        if (right_nritems == 0)
                return 1;
 
-       btrfs_assert_tree_locked(path->nodes[1]);
+       btrfs_assert_tree_write_locked(path->nodes[1]);
 
        left = btrfs_read_node_slot(path->nodes[1], slot - 1);
        /*
 
                BUG_ON(!eb);
                BUG_ON(!test_bit(EXTENT_BUFFER_DIRTY, &eb->bflags));
                BUG_ON(!atomic_read(&eb->refs));
-               btrfs_assert_tree_locked(eb);
+               btrfs_assert_tree_write_locked(eb);
                return __set_page_dirty_nobuffers(page);
        }
        ASSERT(PagePrivate(page) && page->private);
                ASSERT(eb);
                ASSERT(test_bit(EXTENT_BUFFER_DIRTY, &eb->bflags));
                ASSERT(atomic_read(&eb->refs));
-               btrfs_assert_tree_locked(eb);
+               btrfs_assert_tree_write_locked(eb);
                free_extent_buffer(eb);
 
                cur_bit += (fs_info->nodesize >> fs_info->sectorsize_bits);
        struct btrfs_fs_info *fs_info = buf->fs_info;
        if (btrfs_header_generation(buf) ==
            fs_info->running_transaction->transid) {
-               btrfs_assert_tree_locked(buf);
+               btrfs_assert_tree_write_locked(buf);
 
                if (test_and_clear_bit(EXTENT_BUFFER_DIRTY, &buf->bflags)) {
                        percpu_counter_add_batch(&fs_info->dirty_metadata_bytes,
        if (unlikely(test_bit(EXTENT_BUFFER_UNMAPPED, &buf->bflags)))
                return;
 #endif
-       btrfs_assert_tree_locked(buf);
+       btrfs_assert_tree_write_locked(buf);
        if (transid != fs_info->generation)
                WARN(1, KERN_CRIT "btrfs transid mismatch buffer %llu, found %llu running %llu\n",
                        buf->start, transid, fs_info->generation);
 
                return -ENOMEM;
        }
 
-       btrfs_assert_tree_locked(parent);
+       btrfs_assert_tree_write_locked(parent);
        parent_level = btrfs_header_level(parent);
        atomic_inc(&parent->refs);
        path->nodes[parent_level] = parent;
        path->slots[parent_level] = btrfs_header_nritems(parent);
 
-       btrfs_assert_tree_locked(node);
+       btrfs_assert_tree_write_locked(node);
        level = btrfs_header_level(node);
        path->nodes[level] = node;
        path->slots[level] = 0;
 
 struct extent_buffer *btrfs_read_lock_root_node(struct btrfs_root *root);
 
 #ifdef CONFIG_BTRFS_DEBUG
-static inline void btrfs_assert_tree_locked(struct extent_buffer *eb) {
-       lockdep_assert_held(&eb->lock);
+static inline void btrfs_assert_tree_write_locked(struct extent_buffer *eb)
+{
+       lockdep_assert_held_write(&eb->lock);
 }
 #else
-static inline void btrfs_assert_tree_locked(struct extent_buffer *eb) { }
+static inline void btrfs_assert_tree_write_locked(struct extent_buffer *eb) { }
 #endif
 
 void btrfs_unlock_up_safe(struct btrfs_path *path, int level);
 
                 * matches our target xattr, so lets check.
                 */
                ret = 0;
-               btrfs_assert_tree_locked(path->nodes[0]);
+               btrfs_assert_tree_write_locked(path->nodes[0]);
                di = btrfs_match_dir_item_name(fs_info, path, name, name_len);
                if (!di && !(flags & XATTR_REPLACE)) {
                        ret = -ENOSPC;