Commit 9c6e02ea authored by Kaiwei Liu's avatar Kaiwei Liu Committed by Vinod Koul

dmaengine: sprd: add dma mask interface in probe

In the probe of DMA, the default addressing range is 32 bits,
while the actual DMA hardware addressing range used is 36 bits.
So add dma_set_mask_and_coherent function to match DMA
addressing range.
Signed-off-by: default avatarKaiwei Liu <kaiwei.liu@unisoc.com>
Reviewed-by: default avatarBaolin Wang <baolin.wang@linux.alibaba.com>
Link: https://lore.kernel.org/r/20230919073801.25054-1-kaiwei.liu@unisoc.comSigned-off-by: default avatarVinod Koul <vkoul@kernel.org>
parent a04bbeaa
...@@ -1117,6 +1117,15 @@ static int sprd_dma_probe(struct platform_device *pdev) ...@@ -1117,6 +1117,15 @@ static int sprd_dma_probe(struct platform_device *pdev)
u32 chn_count; u32 chn_count;
int ret, i; int ret, i;
ret = dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(36));
if (ret) {
ret = dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(32));
if (ret) {
dev_err(&pdev->dev, "unable to set coherent mask to 32\n");
return ret;
}
}
/* Parse new and deprecated dma-channels properties */ /* Parse new and deprecated dma-channels properties */
ret = device_property_read_u32(&pdev->dev, "dma-channels", &chn_count); ret = device_property_read_u32(&pdev->dev, "dma-channels", &chn_count);
if (ret) if (ret)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment