mmc: sh_mmcif: Fix DMA slave address configuration
authorLaurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
Tue, 15 Jul 2014 22:45:12 +0000 (00:45 +0200)
committerUlf Hansson <ulf.hansson@linaro.org>
Sat, 26 Jul 2014 09:38:19 +0000 (11:38 +0200)
Commit e5a233cb647d749de2f188477c9a54b94d90477f ("mmc: sh_mmcif:
Factorize DMA channel request and configuration code") incorrectly
set the destination address for both slave channels instead of setting
the source address for the receive channel. Fix that.

Signed-off-by: Laurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
drivers/mmc/host/sh_mmcif.c

index 0289b4ecccb3974d5993f0bb4c4bfa9877b99c4a..863d21ee4a2f187a1227a8a0d8ca0a165245b4a3 100644 (file)
@@ -386,7 +386,7 @@ sh_mmcif_request_dma_one(struct sh_mmcif_host *host,
                         struct sh_mmcif_plat_data *pdata,
                         enum dma_transfer_direction direction)
 {
-       struct dma_slave_config cfg;
+       struct dma_slave_config cfg = { 0, };
        struct dma_chan *chan;
        unsigned int slave_id;
        struct resource *res;
@@ -417,8 +417,12 @@ sh_mmcif_request_dma_one(struct sh_mmcif_host *host,
        /* In the OF case the driver will get the slave ID from the DT */
        cfg.slave_id = slave_id;
        cfg.direction = direction;
-       cfg.dst_addr = res->start + MMCIF_CE_DATA;
-       cfg.src_addr = 0;
+
+       if (direction == DMA_DEV_TO_MEM)
+               cfg.src_addr = res->start + MMCIF_CE_DATA;
+       else
+               cfg.dst_addr = res->start + MMCIF_CE_DATA;
+
        ret = dmaengine_slave_config(chan, &cfg);
        if (ret < 0) {
                dma_release_channel(chan);