btrfs_node_key(buf, &disk_key, 0);
 
        cow = btrfs_alloc_tree_block(trans, root, 0, new_root_objectid,
-                       &disk_key, level, buf->start, 0, BTRFS_NESTING_NORMAL);
+                                    &disk_key, level, buf->start, 0,
+                                    BTRFS_NESTING_NEW_ROOT);
        if (IS_ERR(cow))
                return PTR_ERR(cow);
 
 
        c = alloc_tree_block_no_bg_flush(trans, root, 0, &lower_key, level,
                                         root->node->start, 0,
-                                        BTRFS_NESTING_NORMAL);
+                                        BTRFS_NESTING_NEW_ROOT);
        if (IS_ERR(c))
                return PTR_ERR(c);
 
 
         */
        BTRFS_NESTING_SPLIT,
 
+       /*
+        * When promoting a new block to a root we need to have a special
+        * subclass so we don't confuse lockdep, as it will appear that we are
+        * locking a higher level node before a lower level one.  Copying also
+        * has this problem as it appears we're locking the same block again
+        * when we make a snapshot of an existing root.
+        */
+       BTRFS_NESTING_NEW_ROOT,
+
        /*
         * We are limited to MAX_LOCKDEP_SUBLCLASSES number of subclasses, so
         * add this in here and add a static_assert to keep us from going over