|
@@ -558,6 +558,8 @@ static void imx_dma_tx(struct imx_port *sport)
|
|
desc = dmaengine_prep_slave_sg(chan, sgl, sport->dma_tx_nents,
|
|
desc = dmaengine_prep_slave_sg(chan, sgl, sport->dma_tx_nents,
|
|
DMA_MEM_TO_DEV, DMA_PREP_INTERRUPT);
|
|
DMA_MEM_TO_DEV, DMA_PREP_INTERRUPT);
|
|
if (!desc) {
|
|
if (!desc) {
|
|
|
|
+ dma_unmap_sg(dev, sgl, sport->dma_tx_nents,
|
|
|
|
+ DMA_TO_DEVICE);
|
|
dev_err(dev, "We cannot prepare for the TX slave dma!\n");
|
|
dev_err(dev, "We cannot prepare for the TX slave dma!\n");
|
|
return;
|
|
return;
|
|
}
|
|
}
|
|
@@ -947,6 +949,7 @@ static int start_rx_dma(struct imx_port *sport)
|
|
desc = dmaengine_prep_slave_sg(chan, sgl, 1, DMA_DEV_TO_MEM,
|
|
desc = dmaengine_prep_slave_sg(chan, sgl, 1, DMA_DEV_TO_MEM,
|
|
DMA_PREP_INTERRUPT);
|
|
DMA_PREP_INTERRUPT);
|
|
if (!desc) {
|
|
if (!desc) {
|
|
|
|
+ dma_unmap_sg(dev, sgl, 1, DMA_FROM_DEVICE);
|
|
dev_err(dev, "We cannot prepare for the RX slave dma!\n");
|
|
dev_err(dev, "We cannot prepare for the RX slave dma!\n");
|
|
return -EINVAL;
|
|
return -EINVAL;
|
|
}
|
|
}
|