aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/mmc/host/atmel-mci.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/mmc/host/atmel-mci.c')
-rw-r--r--drivers/mmc/host/atmel-mci.c24
1 files changed, 16 insertions, 8 deletions
diff --git a/drivers/mmc/host/atmel-mci.c b/drivers/mmc/host/atmel-mci.c
index fcfe1eb5acc8..3ba865ddebc4 100644
--- a/drivers/mmc/host/atmel-mci.c
+++ b/drivers/mmc/host/atmel-mci.c
@@ -24,6 +24,7 @@
24#include <linux/seq_file.h> 24#include <linux/seq_file.h>
25#include <linux/slab.h> 25#include <linux/slab.h>
26#include <linux/stat.h> 26#include <linux/stat.h>
27#include <linux/types.h>
27 28
28#include <linux/mmc/host.h> 29#include <linux/mmc/host.h>
29#include <linux/mmc/sdio.h> 30#include <linux/mmc/sdio.h>
@@ -173,6 +174,7 @@ struct atmel_mci {
173 174
174 struct atmel_mci_dma dma; 175 struct atmel_mci_dma dma;
175 struct dma_chan *data_chan; 176 struct dma_chan *data_chan;
177 struct dma_slave_config dma_conf;
176 178
177 u32 cmd_status; 179 u32 cmd_status;
178 u32 data_status; 180 u32 data_status;
@@ -863,15 +865,16 @@ atmci_prepare_data_dma(struct atmel_mci *host, struct mmc_data *data)
863 865
864 if (data->flags & MMC_DATA_READ) { 866 if (data->flags & MMC_DATA_READ) {
865 direction = DMA_FROM_DEVICE; 867 direction = DMA_FROM_DEVICE;
866 slave_dirn = DMA_DEV_TO_MEM; 868 host->dma_conf.direction = slave_dirn = DMA_DEV_TO_MEM;
867 } else { 869 } else {
868 direction = DMA_TO_DEVICE; 870 direction = DMA_TO_DEVICE;
869 slave_dirn = DMA_MEM_TO_DEV; 871 host->dma_conf.direction = slave_dirn = DMA_MEM_TO_DEV;
870 } 872 }
871 873
872 sglen = dma_map_sg(chan->device->dev, data->sg, 874 sglen = dma_map_sg(chan->device->dev, data->sg,
873 data->sg_len, direction); 875 data->sg_len, direction);
874 876
877 dmaengine_slave_config(chan, &host->dma_conf);
875 desc = chan->device->device_prep_slave_sg(chan, 878 desc = chan->device->device_prep_slave_sg(chan,
876 data->sg, sglen, slave_dirn, 879 data->sg, sglen, slave_dirn,
877 DMA_PREP_INTERRUPT | DMA_CTRL_ACK); 880 DMA_PREP_INTERRUPT | DMA_CTRL_ACK);
@@ -1957,22 +1960,27 @@ static void atmci_configure_dma(struct atmel_mci *host)
1957 if (pdata && find_slave_dev(pdata->dma_slave)) { 1960 if (pdata && find_slave_dev(pdata->dma_slave)) {
1958 dma_cap_mask_t mask; 1961 dma_cap_mask_t mask;
1959 1962
1960 setup_dma_addr(pdata->dma_slave,
1961 host->mapbase + ATMCI_TDR,
1962 host->mapbase + ATMCI_RDR);
1963
1964 /* Try to grab a DMA channel */ 1963 /* Try to grab a DMA channel */
1965 dma_cap_zero(mask); 1964 dma_cap_zero(mask);
1966 dma_cap_set(DMA_SLAVE, mask); 1965 dma_cap_set(DMA_SLAVE, mask);
1967 host->dma.chan = 1966 host->dma.chan =
1968 dma_request_channel(mask, atmci_filter, pdata->dma_slave); 1967 dma_request_channel(mask, atmci_filter, pdata->dma_slave);
1969 } 1968 }
1970 if (!host->dma.chan) 1969 if (!host->dma.chan) {
1971 dev_notice(&host->pdev->dev, "DMA not available, using PIO\n"); 1970 dev_notice(&host->pdev->dev, "DMA not available, using PIO\n");
1972 else 1971 } else {
1973 dev_info(&host->pdev->dev, 1972 dev_info(&host->pdev->dev,
1974 "Using %s for DMA transfers\n", 1973 "Using %s for DMA transfers\n",
1975 dma_chan_name(host->dma.chan)); 1974 dma_chan_name(host->dma.chan));
1975
1976 host->dma_conf.src_addr = host->mapbase + ATMCI_RDR;
1977 host->dma_conf.src_addr_width = DMA_SLAVE_BUSWIDTH_4_BYTES;
1978 host->dma_conf.src_maxburst = 1;
1979 host->dma_conf.dst_addr = host->mapbase + ATMCI_TDR;
1980 host->dma_conf.dst_addr_width = DMA_SLAVE_BUSWIDTH_4_BYTES;
1981 host->dma_conf.dst_maxburst = 1;
1982 host->dma_conf.device_fc = false;
1983 }
1976} 1984}
1977 1985
1978static inline unsigned int atmci_get_version(struct atmel_mci *host) 1986static inline unsigned int atmci_get_version(struct atmel_mci *host)