]> www.infradead.org Git - users/hch/block.git/commitdiff
pd: use blk_mq_alloc_disk and blk_cleanup_disk
authorChristoph Hellwig <hch@lst.de>
Tue, 4 May 2021 16:01:47 +0000 (18:01 +0200)
committerChristoph Hellwig <hch@lst.de>
Wed, 2 Jun 2021 05:49:26 +0000 (08:49 +0300)
Use blk_mq_alloc_disk and blk_cleanup_disk to simplify the gendisk and
request_queue allocation.

Signed-off-by: Christoph Hellwig <hch@lst.de>
drivers/block/paride/pd.c

index 828a45ffe0e7d8a41f61d7e722c5786c6fd1e8ef..3b2b8e872beb6e12921d6f77d1eb516fa5f3b3be 100644 (file)
@@ -879,18 +879,6 @@ static void pd_probe_drive(struct pd_unit *disk)
 {
        struct gendisk *p;
 
-       p = alloc_disk(1 << PD_BITS);
-       if (!p)
-               return;
-
-       strcpy(p->disk_name, disk->name);
-       p->fops = &pd_fops;
-       p->major = major;
-       p->first_minor = (disk - pd) << PD_BITS;
-       p->events = DISK_EVENT_MEDIA_CHANGE;
-       disk->gd = p;
-       p->private_data = disk;
-
        memset(&disk->tag_set, 0, sizeof(disk->tag_set));
        disk->tag_set.ops = &pd_mq_ops;
        disk->tag_set.cmd_size = sizeof(struct pd_req);
@@ -903,14 +891,21 @@ static void pd_probe_drive(struct pd_unit *disk)
        if (blk_mq_alloc_tag_set(&disk->tag_set))
                return;
 
-       p->queue = blk_mq_init_queue(&disk->tag_set);
-       if (IS_ERR(p->queue)) {
+       p = blk_mq_alloc_disk(&disk->tag_set, disk);
+       if (!p) {
                blk_mq_free_tag_set(&disk->tag_set);
-               p->queue = NULL;
                return;
        }
+       disk->gd = p;
+
+       strcpy(p->disk_name, disk->name);
+       p->fops = &pd_fops;
+       p->major = major;
+       p->first_minor = (disk - pd) << PD_BITS;
+       p->minors = 1 << PD_BITS;
+       p->events = DISK_EVENT_MEDIA_CHANGE;
+       p->private_data = disk;
 
-       p->queue->queuedata = disk;
        blk_queue_max_hw_sectors(p->queue, cluster);
        blk_queue_bounce_limit(p->queue, BLK_BOUNCE_HIGH);
 
@@ -1019,9 +1014,8 @@ static void __exit pd_exit(void)
                if (p) {
                        disk->gd = NULL;
                        del_gendisk(p);
-                       blk_cleanup_queue(p->queue);
                        blk_mq_free_tag_set(&disk->tag_set);
-                       put_disk(p);
+                       blk_cleanup_disk(p);
                        pi_release(disk->pi);
                }
        }