struct iomap_swapfile_info *isi = data;
        int error;
 
+       /* No inline data. */
+       if (iomap->flags & IOMAP_F_DATA_INLINE) {
+               pr_err("swapon: file is inline\n");
+               return -EINVAL;
+       }
+
        /* Skip holes. */
        if (iomap->type == IOMAP_HOLE)
                goto out;
 
-       /* Only one bdev per swap file. */
-       if (iomap->bdev != isi->sis->bdev)
-               goto err;
-
        /* Only real or unwritten extents. */
-       if (iomap->type != IOMAP_MAPPED && iomap->type != IOMAP_UNWRITTEN)
-               goto err;
+       if (iomap->type != IOMAP_MAPPED && iomap->type != IOMAP_UNWRITTEN) {
+               pr_err("swapon: file has unallocated extents\n");
+               return -EINVAL;
+       }
 
-       /* No uncommitted metadata or shared blocks or inline data. */
-       if (iomap->flags & (IOMAP_F_DIRTY | IOMAP_F_SHARED |
-                           IOMAP_F_DATA_INLINE))
-               goto err;
+       /* No uncommitted metadata or shared blocks. */
+       if (iomap->flags & IOMAP_F_DIRTY) {
+               pr_err("swapon: file is not committed\n");
+               return -EINVAL;
+       }
+       if (iomap->flags & IOMAP_F_SHARED) {
+               pr_err("swapon: file has shared extents\n");
+               return -EINVAL;
+       }
 
-       /* No null physical addresses. */
-       if (iomap->addr == IOMAP_NULL_ADDR)
-               goto err;
+       /* Only one bdev per swap file. */
+       if (iomap->bdev != isi->sis->bdev) {
+               pr_err("swapon: file is on multiple devices\n");
+               return -EINVAL;
+       }
 
        if (isi->iomap.length == 0) {
                /* No accumulated extent, so just store it. */
        }
 out:
        return count;
-err:
-       pr_err("swapon: file cannot be used for swap\n");
-       return -EINVAL;
 }
 
 /*