mmc: queue: Factor out mmc_queue_alloc_bounce_bufs()
authorAdrian Hunter <adrian.hunter@intel.com>
Tue, 29 Nov 2016 10:09:11 +0000 (12:09 +0200)
committerUlf Hansson <ulf.hansson@linaro.org>
Mon, 5 Dec 2016 09:31:04 +0000 (10:31 +0100)
In preparation for supporting a queue of requests, factor out
mmc_queue_alloc_bounce_bufs().

Signed-off-by: Adrian Hunter <adrian.hunter@intel.com>
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Reviewed-by: Harjani Ritesh <riteshh@codeaurora.org>
[Ulf: Fixed compiler warning]
Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
drivers/mmc/card/queue.c

index 010888d8d97c230874948d350e51056cd4f1cc4d..cca143afd12ff6eece3584ccc17ddf5b1dce9f29 100644 (file)
@@ -186,6 +186,33 @@ static void mmc_queue_setup_discard(struct request_queue *q,
                queue_flag_set_unlocked(QUEUE_FLAG_SECERASE, q);
 }
 
+#ifdef CONFIG_MMC_BLOCK_BOUNCE
+static bool mmc_queue_alloc_bounce_bufs(struct mmc_queue *mq,
+                                       unsigned int bouncesz)
+{
+       struct mmc_queue_req *mqrq_cur = mq->mqrq_cur;
+       struct mmc_queue_req *mqrq_prev = mq->mqrq_prev;
+
+       mqrq_cur->bounce_buf = kmalloc(bouncesz, GFP_KERNEL);
+       if (!mqrq_cur->bounce_buf) {
+               pr_warn("%s: unable to allocate bounce cur buffer\n",
+                       mmc_card_name(mq->card));
+               return false;
+       }
+
+       mqrq_prev->bounce_buf = kmalloc(bouncesz, GFP_KERNEL);
+       if (!mqrq_prev->bounce_buf) {
+               pr_warn("%s: unable to allocate bounce prev buffer\n",
+                       mmc_card_name(mq->card));
+               kfree(mqrq_cur->bounce_buf);
+               mqrq_cur->bounce_buf = NULL;
+               return false;
+       }
+
+       return true;
+}
+#endif
+
 /**
  * mmc_init_queue - initialise a queue structure.
  * @mq: mmc queue
@@ -235,24 +262,8 @@ int mmc_init_queue(struct mmc_queue *mq, struct mmc_card *card,
                if (bouncesz > (host->max_blk_count * 512))
                        bouncesz = host->max_blk_count * 512;
 
-               if (bouncesz > 512) {
-                       mqrq_cur->bounce_buf = kmalloc(bouncesz, GFP_KERNEL);
-                       if (!mqrq_cur->bounce_buf) {
-                               pr_warn("%s: unable to allocate bounce cur buffer\n",
-                                       mmc_card_name(card));
-                       } else {
-                               mqrq_prev->bounce_buf =
-                                               kmalloc(bouncesz, GFP_KERNEL);
-                               if (!mqrq_prev->bounce_buf) {
-                                       pr_warn("%s: unable to allocate bounce prev buffer\n",
-                                               mmc_card_name(card));
-                                       kfree(mqrq_cur->bounce_buf);
-                                       mqrq_cur->bounce_buf = NULL;
-                               }
-                       }
-               }
-
-               if (mqrq_cur->bounce_buf && mqrq_prev->bounce_buf) {
+               if (bouncesz > 512 &&
+                   mmc_queue_alloc_bounce_bufs(mq, bouncesz)) {
                        blk_queue_bounce_limit(mq->queue, BLK_BOUNCE_ANY);
                        blk_queue_max_hw_sectors(mq->queue, bouncesz / 512);
                        blk_queue_max_segments(mq->queue, bouncesz / 512);