return ERR_CAST(page);
 
        super = page_address(page);
-       if (btrfs_super_bytenr(super) != bytenr ||
-                   btrfs_super_magic(super) != BTRFS_MAGIC) {
+       if (btrfs_super_magic(super) != BTRFS_MAGIC) {
+               btrfs_release_disk_super(super);
+               return ERR_PTR(-ENODATA);
+       }
+
+       if (btrfs_super_bytenr(super) != bytenr) {
                btrfs_release_disk_super(super);
                return ERR_PTR(-EINVAL);
        }
 
 {
        struct btrfs_device *device;
        struct btrfs_device *latest_dev = NULL;
+       struct btrfs_device *tmp_device;
 
        flags |= FMODE_EXCL;
 
-       list_for_each_entry(device, &fs_devices->devices, dev_list) {
-               /* Just open everything we can; ignore failures here */
-               if (btrfs_open_one_device(fs_devices, device, flags, holder))
-                       continue;
+       list_for_each_entry_safe(device, tmp_device, &fs_devices->devices,
+                                dev_list) {
+               int ret;
 
-               if (!latest_dev ||
-                   device->generation > latest_dev->generation)
+               ret = btrfs_open_one_device(fs_devices, device, flags, holder);
+               if (ret == 0 &&
+                   (!latest_dev || device->generation > latest_dev->generation)) {
                        latest_dev = device;
+               } else if (ret == -ENODATA) {
+                       fs_devices->num_devices--;
+                       list_del(&device->dev_list);
+                       btrfs_free_device(device);
+               }
        }
        if (fs_devices->open_devices == 0)
                return -EINVAL;