if (ret && ret != -ENOENT)
                        goto out;
 
+               /*
+                * The path must have a locked leaf from the extent tree where
+                * the extent item for our extent is located, in case it exists,
+                * or where it should be located in case it doesn't exist yet
+                * because it's new and its delayed ref was not yet flushed.
+                * We need to lock the delayed ref head at check_delayed_ref(),
+                * if one exists, while holding the leaf locked in order to not
+                * race with delayed ref flushing, missing references and
+                * incorrectly reporting that the extent is not shared.
+                */
+               if (IS_ENABLED(CONFIG_BTRFS_ASSERT)) {
+                       struct extent_buffer *leaf = path->nodes[0];
+
+                       ASSERT(leaf != NULL);
+                       btrfs_assert_tree_read_locked(leaf);
+
+                       if (ret != -ENOENT) {
+                               struct btrfs_key key;
+
+                               btrfs_item_key_to_cpu(leaf, &key, path->slots[0]);
+                               ASSERT(key.objectid == bytenr);
+                               ASSERT(key.type == BTRFS_EXTENT_ITEM_KEY);
+                       }
+               }
+
                ret = check_delayed_ref(inode, path, offset, bytenr);
        } while (ret == -EAGAIN && !path->nowait);
 
 
 {
        lockdep_assert_held_write(&eb->lock);
 }
+static inline void btrfs_assert_tree_read_locked(struct extent_buffer *eb)
+{
+       lockdep_assert_held_read(&eb->lock);
+}
 #else
 static inline void btrfs_assert_tree_write_locked(struct extent_buffer *eb) { }
+static inline void btrfs_assert_tree_read_locked(struct extent_buffer *eb) { }
 #endif
 
 void btrfs_unlock_up_safe(struct btrfs_path *path, int level);