goto out;
        }
  
 +      vol_args->name[BTRFS_PATH_NAME_MAX] = '\0';
        mutex_lock(&root->fs_info->volume_mutex);
-       ret = btrfs_rm_device(root, vol_args->name);
+       ret = btrfs_rm_device(root, vol_args->name, 0);
        mutex_unlock(&root->fs_info->volume_mutex);
 -      atomic_set(&root->fs_info->mutually_exclusive_operation_running, 0);
  
        if (!ret)
                btrfs_info(root->fs_info, "disk deleted %s",vol_args->name);
 
  
        btrfs_sysfs_rm_device_link(fs_info->fs_devices, tgtdev);
  
 -      if (tgtdev->bdev) {
 -              btrfs_scratch_superblocks(tgtdev->bdev, tgtdev->name->str);
 +      if (tgtdev->bdev)
                fs_info->fs_devices->open_devices--;
 -      }
 +
        fs_info->fs_devices->num_devices--;
  
-       next_device = list_entry(fs_info->fs_devices->devices.next,
-                                struct btrfs_device, dev_list);
-       if (tgtdev->bdev == fs_info->sb->s_bdev)
-               fs_info->sb->s_bdev = next_device->bdev;
-       if (tgtdev->bdev == fs_info->fs_devices->latest_bdev)
-               fs_info->fs_devices->latest_bdev = next_device->bdev;
+       btrfs_assign_next_active_device(fs_info, tgtdev, NULL);
+ 
        list_del_rcu(&tgtdev->dev_list);
  
 -      call_rcu(&tgtdev->rcu, free_device);
 -
        mutex_unlock(&fs_info->fs_devices->device_list_mutex);
        mutex_unlock(&uuid_mutex);
 +
 +      /*
 +       * The update_dev_time() with in btrfs_scratch_superblocks()
 +       * may lead to a call to btrfs_show_devname() which will try
 +       * to hold device_list_mutex. And here this device
 +       * is already out of device list, so we don't have to hold
 +       * the device_list_mutex lock.
 +       */
 +      btrfs_scratch_superblocks(tgtdev->bdev, tgtdev->name->str);
 +      call_rcu(&tgtdev->rcu, free_device);
  }
  
  static int btrfs_find_device_by_path(struct btrfs_root *root, char *device_path,