]> www.infradead.org Git - users/hch/block.git/commitdiff
mmc: switch to blk_mq_alloc_disk mmc-queues
authorChristoph Hellwig <hch@lst.de>
Tue, 15 Jun 2021 11:49:33 +0000 (13:49 +0200)
committerChristoph Hellwig <hch@lst.de>
Tue, 15 Jun 2021 12:02:06 +0000 (14:02 +0200)
Use the blk_mq_alloc_disk to allocate the request_queue and gendisk
together.

Signed-off-by: Christoph Hellwig <hch@lst.de>
drivers/mmc/core/block.c
drivers/mmc/core/queue.c
drivers/mmc/core/queue.h

index 947624e76c33754fb683f5c9aff5a89fef835693..6652e1f1d4b21b8bd54ec61f7a99fbd67f2bc2d4 100644 (file)
@@ -2310,27 +2310,21 @@ static struct mmc_blk_data *mmc_blk_alloc_req(struct mmc_card *card,
         */
        md->read_only = mmc_blk_readonly(card);
 
-       md->disk = alloc_disk(perdev_minors);
-       if (md->disk == NULL) {
-               ret = -ENOMEM;
+       md->disk = mmc_init_queue(&md->queue, card);
+       if (IS_ERR(md->disk)) {
+               ret = PTR_ERR(md->disk);
                goto err_kfree;
        }
 
        INIT_LIST_HEAD(&md->part);
        INIT_LIST_HEAD(&md->rpmbs);
        md->usage = 1;
-
-       ret = mmc_init_queue(&md->queue, card);
-       if (ret)
-               goto err_putdisk;
-
        md->queue.blkdata = md;
 
        md->disk->major = MMC_BLOCK_MAJOR;
        md->disk->first_minor = devidx * perdev_minors;
        md->disk->fops = &mmc_bdops;
        md->disk->private_data = md;
-       md->disk->queue = md->queue.queue;
        md->parent = parent;
        set_disk_ro(md->disk, md->read_only || default_ro);
        md->disk->flags = GENHD_FL_EXT_DEVT;
@@ -2379,8 +2373,6 @@ static struct mmc_blk_data *mmc_blk_alloc_req(struct mmc_card *card,
 
        return md;
 
- err_putdisk:
-       put_disk(md->disk);
  err_kfree:
        kfree(md);
  out:
index d600e0a4a4604fba52b2a8a1a550d0f55ac6c0a0..cc326177763779325560a1e192a990e60ac84c7c 100644 (file)
@@ -424,9 +424,10 @@ static inline bool mmc_merge_capable(struct mmc_host *host)
  *
  * Initialise a MMC card request queue.
  */
-int mmc_init_queue(struct mmc_queue *mq, struct mmc_card *card)
+struct gendisk *mmc_init_queue(struct mmc_queue *mq, struct mmc_card *card)
 {
        struct mmc_host *host = card->host;
+       struct gendisk *disk;
        int ret;
 
        mq->card = card;
@@ -464,26 +465,22 @@ int mmc_init_queue(struct mmc_queue *mq, struct mmc_card *card)
 
        ret = blk_mq_alloc_tag_set(&mq->tag_set);
        if (ret)
-               return ret;
+               return ERR_PTR(ret);
+               
 
-       mq->queue = blk_mq_init_queue(&mq->tag_set);
-       if (IS_ERR(mq->queue)) {
-               ret = PTR_ERR(mq->queue);
-               goto free_tag_set;
+       disk = blk_mq_alloc_disk(&mq->tag_set, mq);
+       if (IS_ERR(disk)) {
+               blk_mq_free_tag_set(&mq->tag_set);
+               return disk;
        }
+       mq->queue = disk->queue;
 
        if (mmc_host_is_spi(host) && host->use_spi_crc)
                blk_queue_flag_set(QUEUE_FLAG_STABLE_WRITES, mq->queue);
-
-       mq->queue->queuedata = mq;
        blk_queue_rq_timeout(mq->queue, 60 * HZ);
 
        mmc_setup_queue(mq, card);
-       return 0;
-
-free_tag_set:
-       blk_mq_free_tag_set(&mq->tag_set);
-       return ret;
+       return disk;
 }
 
 void mmc_queue_suspend(struct mmc_queue *mq)
index 3319d8ab57d0d47f07ea112382345da0c56b273e..9ade3bcbb714e48187ccf23dda1cb9804e42c2ca 100644 (file)
@@ -94,7 +94,7 @@ struct mmc_queue {
        struct work_struct      complete_work;
 };
 
-extern int mmc_init_queue(struct mmc_queue *, struct mmc_card *);
+struct gendisk *mmc_init_queue(struct mmc_queue *mq, struct mmc_card *card);
 extern void mmc_cleanup_queue(struct mmc_queue *);
 extern void mmc_queue_suspend(struct mmc_queue *);
 extern void mmc_queue_resume(struct mmc_queue *);