|
@@ -1726,13 +1726,28 @@ out:
|
|
|
static noinline int may_destroy_subvol(struct btrfs_root *root)
|
|
|
{
|
|
|
struct btrfs_path *path;
|
|
|
+ struct btrfs_dir_item *di;
|
|
|
struct btrfs_key key;
|
|
|
+ u64 dir_id;
|
|
|
int ret;
|
|
|
|
|
|
path = btrfs_alloc_path();
|
|
|
if (!path)
|
|
|
return -ENOMEM;
|
|
|
|
|
|
+ /* Make sure this root isn't set as the default subvol */
|
|
|
+ dir_id = btrfs_super_root_dir(root->fs_info->super_copy);
|
|
|
+ di = btrfs_lookup_dir_item(NULL, root->fs_info->tree_root, path,
|
|
|
+ dir_id, "default", 7, 0);
|
|
|
+ if (di && !IS_ERR(di)) {
|
|
|
+ btrfs_dir_item_key_to_cpu(path->nodes[0], di, &key);
|
|
|
+ if (key.objectid == root->root_key.objectid) {
|
|
|
+ ret = -ENOTEMPTY;
|
|
|
+ goto out;
|
|
|
+ }
|
|
|
+ btrfs_release_path(path);
|
|
|
+ }
|
|
|
+
|
|
|
key.objectid = root->root_key.objectid;
|
|
|
key.type = BTRFS_ROOT_REF_KEY;
|
|
|
key.offset = (u64)-1;
|