Commit 4a46ba36 authored by Laxman Dewangan's avatar Laxman Dewangan Committed by Vinod Koul

dma: tegra: fix residual calculation for cyclic case

In cyclic mode of DMA, the byte transferred can be more
than the requested size and in this case, calculating
residuals based on the current position of DMA transfer to
bytes requested i.e. bytes required to transfer to reach
bytes requested from current DMA position.
Signed-off-by: default avatarLaxman Dewangan <ldewangan@nvidia.com>
Acked-by: default avatarStephen Warren <swarren@wwwdotorg.org>
Signed-off-by: default avatarVinod Koul <vinod.koul@linux.intel.com>
parent 46fb3f8e
...@@ -731,6 +731,7 @@ static enum dma_status tegra_dma_tx_status(struct dma_chan *dc, ...@@ -731,6 +731,7 @@ static enum dma_status tegra_dma_tx_status(struct dma_chan *dc,
struct tegra_dma_sg_req *sg_req; struct tegra_dma_sg_req *sg_req;
enum dma_status ret; enum dma_status ret;
unsigned long flags; unsigned long flags;
unsigned int residual;
spin_lock_irqsave(&tdc->lock, flags); spin_lock_irqsave(&tdc->lock, flags);
...@@ -744,9 +745,10 @@ static enum dma_status tegra_dma_tx_status(struct dma_chan *dc, ...@@ -744,9 +745,10 @@ static enum dma_status tegra_dma_tx_status(struct dma_chan *dc,
/* Check on wait_ack desc status */ /* Check on wait_ack desc status */
list_for_each_entry(dma_desc, &tdc->free_dma_desc, node) { list_for_each_entry(dma_desc, &tdc->free_dma_desc, node) {
if (dma_desc->txd.cookie == cookie) { if (dma_desc->txd.cookie == cookie) {
dma_set_residue(txstate, residual = dma_desc->bytes_requested -
dma_desc->bytes_requested - (dma_desc->bytes_transferred %
dma_desc->bytes_transferred); dma_desc->bytes_requested);
dma_set_residue(txstate, residual);
ret = dma_desc->dma_status; ret = dma_desc->dma_status;
spin_unlock_irqrestore(&tdc->lock, flags); spin_unlock_irqrestore(&tdc->lock, flags);
return ret; return ret;
...@@ -757,9 +759,10 @@ static enum dma_status tegra_dma_tx_status(struct dma_chan *dc, ...@@ -757,9 +759,10 @@ static enum dma_status tegra_dma_tx_status(struct dma_chan *dc,
list_for_each_entry(sg_req, &tdc->pending_sg_req, node) { list_for_each_entry(sg_req, &tdc->pending_sg_req, node) {
dma_desc = sg_req->dma_desc; dma_desc = sg_req->dma_desc;
if (dma_desc->txd.cookie == cookie) { if (dma_desc->txd.cookie == cookie) {
dma_set_residue(txstate, residual = dma_desc->bytes_requested -
dma_desc->bytes_requested - (dma_desc->bytes_transferred %
dma_desc->bytes_transferred); dma_desc->bytes_requested);
dma_set_residue(txstate, residual);
ret = dma_desc->dma_status; ret = dma_desc->dma_status;
spin_unlock_irqrestore(&tdc->lock, flags); spin_unlock_irqrestore(&tdc->lock, flags);
return ret; return 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