]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
dmaengine: idxd: Flush all pending descriptors
authorVinicius Costa Gomes <vinicius.gomes@intel.com>
Wed, 21 Jan 2026 18:34:31 +0000 (10:34 -0800)
committerVinod Koul <vkoul@kernel.org>
Wed, 25 Feb 2026 11:09:18 +0000 (16:39 +0530)
When used as a dmaengine, the DMA "core" might ask the driver to
terminate all pending requests, when that happens, flush all pending
descriptors.

In this context, flush means removing the requests from the pending
lists, so even if they are completed after, the user is not notified.

Reviewed-by: Dave Jiang <dave.jiang@intel.com>
Signed-off-by: Vinicius Costa Gomes <vinicius.gomes@intel.com>
Link: https://patch.msgid.link/20260121-idxd-fix-flr-on-kernel-queues-v3-v3-5-7ed70658a9d1@intel.com
Signed-off-by: Vinod Koul <vkoul@kernel.org>
drivers/dma/idxd/dma.c

index dbecd699237e3ac5a73b49ed2097a897abc9a043..e4f9788aa63515a0f647a335b106895318b1704d 100644 (file)
@@ -194,6 +194,15 @@ static void idxd_dma_release(struct dma_device *device)
        kfree(idxd_dma);
 }
 
+static int idxd_dma_terminate_all(struct dma_chan *c)
+{
+       struct idxd_wq *wq = to_idxd_wq(c);
+
+       idxd_wq_flush_descs(wq);
+
+       return 0;
+}
+
 int idxd_register_dma_device(struct idxd_device *idxd)
 {
        struct idxd_dma_dev *idxd_dma;
@@ -224,6 +233,7 @@ int idxd_register_dma_device(struct idxd_device *idxd)
        dma->device_issue_pending = idxd_dma_issue_pending;
        dma->device_alloc_chan_resources = idxd_dma_alloc_chan_resources;
        dma->device_free_chan_resources = idxd_dma_free_chan_resources;
+       dma->device_terminate_all = idxd_dma_terminate_all;
 
        rc = dma_async_device_register(dma);
        if (rc < 0) {