dmaengine: xilinx_dma: Freeup active list based on descriptor completion bit
AXIDMA IP in SG mode sets completion bit to 1 when the transfer is completed. Read this bit to move descriptor from active list to the done list. This feature is needed when interrupt delay timeout and IRQThreshold is enabled i.e Dly_IrqEn is triggered w/o completing interrupt threshold. Signed-off-by: Radhey Shyam Pandey <radhey.shyam.pandey@amd.com> Link: https://lore.kernel.org/r/1691387509-2113129-6-git-send-email-radhey.shyam.pandey@amd.com Signed-off-by: Vinod Koul <vkoul@kernel.org>
This commit is contained in:
parent
491e9d4096
commit
7bcdaa6581
@ -177,6 +177,7 @@
|
||||
#define XILINX_DMA_CR_COALESCE_SHIFT 16
|
||||
#define XILINX_DMA_BD_SOP BIT(27)
|
||||
#define XILINX_DMA_BD_EOP BIT(26)
|
||||
#define XILINX_DMA_BD_COMP_MASK BIT(31)
|
||||
#define XILINX_DMA_COALESCE_MAX 255
|
||||
#define XILINX_DMA_NUM_DESCS 512
|
||||
#define XILINX_DMA_NUM_APP_WORDS 5
|
||||
@ -1708,6 +1709,14 @@ static void xilinx_dma_complete_descriptor(struct xilinx_dma_chan *chan)
|
||||
return;
|
||||
|
||||
list_for_each_entry_safe(desc, next, &chan->active_list, node) {
|
||||
if (chan->xdev->dma_config->dmatype == XDMA_TYPE_AXIDMA) {
|
||||
struct xilinx_axidma_tx_segment *seg;
|
||||
|
||||
seg = list_last_entry(&desc->segments,
|
||||
struct xilinx_axidma_tx_segment, node);
|
||||
if (!(seg->hw.status & XILINX_DMA_BD_COMP_MASK) && chan->has_sg)
|
||||
break;
|
||||
}
|
||||
if (chan->has_sg && chan->xdev->dma_config->dmatype !=
|
||||
XDMA_TYPE_VDMA)
|
||||
desc->residue = xilinx_dma_get_residue(chan, desc);
|
||||
|
Loading…
x
Reference in New Issue
Block a user