diff options
author | Bartlomiej Zolnierkiewicz <[email protected]> | 2012-11-08 10:02:07 +0000 |
---|---|---|
committer | Vinod Koul <[email protected]> | 2013-01-07 22:05:11 -0800 |
commit | 2cbe7feba1ac521b5668609c35b94536bbbcd52f (patch) | |
tree | 70373963c3c6f3ee91ad073a5f987d36de4e8175 | |
parent | e239345f642e6a255d0ba1e3d92c2f9ec5a44fbe (diff) |
dmaengine: add cpu_relax() to busy-loop in dma_sync_wait()
Removal of the busy-loop from dma_sync_wait() is not a trivial
task so just add cpu_relax() to the loop for now.
Cc: Vinod Koul <[email protected]>
Cc: Tomasz Figa <[email protected]>
Signed-off-by: Bartlomiej Zolnierkiewicz <[email protected]>
Signed-off-by: Kyungmin Park <[email protected]>
Signed-off-by: Dan Williams <[email protected]>
-rw-r--r-- | drivers/dma/dmaengine.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/drivers/dma/dmaengine.c b/drivers/dma/dmaengine.c index d37cf95987b6..242b8c0a3de8 100644 --- a/drivers/dma/dmaengine.c +++ b/drivers/dma/dmaengine.c @@ -267,7 +267,10 @@ enum dma_status dma_sync_wait(struct dma_chan *chan, dma_cookie_t cookie) pr_err("%s: timeout!\n", __func__); return DMA_ERROR; } - } while (status == DMA_IN_PROGRESS); + if (status != DMA_IN_PROGRESS) + break; + cpu_relax(); + } while (1); return status; } |