|
@@ -664,12 +664,13 @@ static irqreturn_t rspi_irq(int irq, void *_sr)
|
|
|
static int rspi_request_dma(struct rspi_data *rspi,
|
|
|
struct platform_device *pdev)
|
|
|
{
|
|
|
+ struct resource *res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
|
|
|
struct rspi_plat_data *rspi_pd = pdev->dev.platform_data;
|
|
|
dma_cap_mask_t mask;
|
|
|
struct dma_slave_config cfg;
|
|
|
int ret;
|
|
|
|
|
|
- if (!rspi_pd)
|
|
|
+ if (!res || !rspi_pd)
|
|
|
return 0; /* The driver assumes no error. */
|
|
|
|
|
|
rspi->dma_width_16bit = rspi_pd->dma_width_16bit;
|
|
@@ -683,6 +684,8 @@ static int rspi_request_dma(struct rspi_data *rspi,
|
|
|
if (rspi->chan_rx) {
|
|
|
cfg.slave_id = rspi_pd->dma_rx_id;
|
|
|
cfg.direction = DMA_DEV_TO_MEM;
|
|
|
+ cfg.dst_addr = 0;
|
|
|
+ cfg.src_addr = res->start + RSPI_SPDR;
|
|
|
ret = dmaengine_slave_config(rspi->chan_rx, &cfg);
|
|
|
if (!ret)
|
|
|
dev_info(&pdev->dev, "Use DMA when rx.\n");
|
|
@@ -698,6 +701,8 @@ static int rspi_request_dma(struct rspi_data *rspi,
|
|
|
if (rspi->chan_tx) {
|
|
|
cfg.slave_id = rspi_pd->dma_tx_id;
|
|
|
cfg.direction = DMA_MEM_TO_DEV;
|
|
|
+ cfg.dst_addr = res->start + RSPI_SPDR;
|
|
|
+ cfg.src_addr = 0;
|
|
|
ret = dmaengine_slave_config(rspi->chan_tx, &cfg);
|
|
|
if (!ret)
|
|
|
dev_info(&pdev->dev, "Use DMA when tx\n");
|