mmc: renesas_sdhi_internal_dmac: clean up the code for dma complete
authorYoshihiro Shimoda <yoshihiro.shimoda.uh@renesas.com>
Thu, 21 May 2020 07:01:05 +0000 (16:01 +0900)
committerUlf Hansson <ulf.hansson@linaro.org>
Mon, 13 Jul 2020 10:18:24 +0000 (12:18 +0200)
To add end() operation in the future, clean the code of
renesas_sdhi_internal_dmac_complete_tasklet_fn(). No behavior change.

Signed-off-by: Yoshihiro Shimoda <yoshihiro.shimoda.uh@renesas.com>
Link: https://lore.kernel.org/r/1590044466-28372-3-git-send-email-yoshihiro.shimoda.uh@renesas.com
Tested-by: Wolfram Sang <wsa+renesas@sang-engineering.com>
Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
drivers/mmc/host/renesas_sdhi_internal_dmac.c

index 47ac53e..201b8ed 100644 (file)
@@ -229,15 +229,12 @@ static void renesas_sdhi_internal_dmac_issue_tasklet_fn(unsigned long arg)
                                            DTRAN_CTRL_DM_START);
 }
 
-static void renesas_sdhi_internal_dmac_complete_tasklet_fn(unsigned long arg)
+static bool renesas_sdhi_internal_dmac_complete(struct tmio_mmc_host *host)
 {
-       struct tmio_mmc_host *host = (struct tmio_mmc_host *)arg;
        enum dma_data_direction dir;
 
-       spin_lock_irq(&host->lock);
-
        if (!host->data)
-               goto out;
+               return false;
 
        if (host->data->flags & MMC_DATA_READ)
                dir = DMA_FROM_DEVICE;
@@ -250,6 +247,17 @@ static void renesas_sdhi_internal_dmac_complete_tasklet_fn(unsigned long arg)
        if (dir == DMA_FROM_DEVICE)
                clear_bit(SDHI_INTERNAL_DMAC_RX_IN_USE, &global_flags);
 
+       return true;
+}
+
+static void renesas_sdhi_internal_dmac_complete_tasklet_fn(unsigned long arg)
+{
+       struct tmio_mmc_host *host = (struct tmio_mmc_host *)arg;
+
+       spin_lock_irq(&host->lock);
+       if (!renesas_sdhi_internal_dmac_complete(host))
+               goto out;
+
        tmio_mmc_do_data_irq(host);
 out:
        spin_unlock_irq(&host->lock);