Merge tag 'dma-mapping-5.14' of git://git.infradead.org/users/hch/dma-mapping
[linux-2.6-block.git] / drivers / block / amiflop.c
index 9e2d0c6a3877213c56ccf048f34a10a5cd93367c..8b1714021498c39f9d34d0fba4c139955cc001ad 100644 (file)
@@ -1781,15 +1781,13 @@ static int fd_alloc_disk(int drive, int system)
 {
        struct gendisk *disk;
 
-       disk = alloc_disk(1);
-       if (!disk)
-               goto out;
-       disk->queue = blk_mq_init_queue(&unit[drive].tag_set);
-       if (IS_ERR(disk->queue))
-               goto out_put_disk;
+       disk = blk_mq_alloc_disk(&unit[drive].tag_set, NULL);
+       if (IS_ERR(disk))
+               return PTR_ERR(disk);
 
        disk->major = FLOPPY_MAJOR;
        disk->first_minor = drive + system;
+       disk->minors = 1;
        disk->fops = &floppy_fops;
        disk->events = DISK_EVENT_MEDIA_CHANGE;
        if (system)
@@ -1802,12 +1800,6 @@ static int fd_alloc_disk(int drive, int system)
        unit[drive].gendisk[system] = disk;
        add_disk(disk);
        return 0;
-
-out_put_disk:
-       disk->queue = NULL;
-       put_disk(disk);
-out:
-       return -ENOMEM;
 }
 
 static int fd_alloc_drive(int drive)