]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
dmaengine: Add missing cleanup on module unload
authorGuenter Roeck <linux@roeck-us.net>
Mon, 20 Oct 2025 17:04:22 +0000 (10:04 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 23 Oct 2025 14:20:48 +0000 (16:20 +0200)
Upstream commit b7cb9a034305 ("dmaengine: idxd: Fix refcount underflow
on module unload") fixes a refcount underflow by replacing the call to
idxd_cleanup() in the remove function with direct cleanup calls. That works
fine upstream. However, upstream removed support for IOMMU_DEV_FEAT_IOPF,
which is still supported in v6.12.y. The backport of commit b7cb9a034305
into v6.12.y misses the call to disable it. This results in a warning
backtrace when unloading and reloading the module.

WARNING: CPU: 0 PID: 665849 at drivers/pci/ats.c:337 pci_reset_pri+0x4c/0x60
...
RIP: 0010:pci_reset_pri+0xa7/0x130

Add the missing cleanup call to fix the problem.

Fixes: ce81905bec91 ("dmaengine: idxd: Fix refcount underflow on module unload")
Cc: Yi Sun <yi.sun@intel.com>
Cc: Shuai Xue <xueshuai@linux.alibaba.com>
Cc: Dave Jiang <dave.jiang@intel.com>
Cc: Vinicius Costa Gomes <vinicius.gomes@intel.com>
Cc: Vinod Koul <vkoul@kernel.org>
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
Acked-by: Vinicius Costa Gomes <vinicius.gomes@intel.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/dma/idxd/init.c

index 74a83203181d6fdf51e7e9045e6d5636250a6088..e55136bb525e2cd0e2456b3cfde9cdd3cf26b548 100644 (file)
@@ -923,6 +923,8 @@ static void idxd_remove(struct pci_dev *pdev)
        idxd_cleanup_interrupts(idxd);
        if (device_pasid_enabled(idxd))
                idxd_disable_system_pasid(idxd);
+       if (device_user_pasid_enabled(idxd))
+               idxd_disable_sva(idxd->pdev);
        pci_iounmap(pdev, idxd->reg_base);
        put_device(idxd_confdev(idxd));
        pci_disable_device(pdev);