]> git.droids-corp.org - dpdk.git/commitdiff
dma/idxd: fix partial freeing in PCI close
authorKevin Laatz <kevin.laatz@intel.com>
Mon, 4 Jul 2022 15:27:50 +0000 (16:27 +0100)
committerThomas Monjalon <thomas@monjalon.net>
Tue, 5 Jul 2022 19:34:38 +0000 (21:34 +0200)
During PCI device close, any allocated memory needs to be free'd.
Currently, one of the free's is being called on an incorrect idxd_dmadev
struct member, namely 'batch_idx_ring'.

At device creation, memory is allocated for both 'batch_comp_ring' and
'batch_idx_ring' simultaneously. Calling free only on 'batch_idx_ring'
meant the first half of this memory was not being free'd, leading to the
memleak.

This patch fixes this memleak by calling free on 'batch_comp_ring' which
will free the memory for both rings.

Fixes: 9449330a8458 ("dma/idxd: create dmadev instances on PCI probe")
Cc: stable@dpdk.org
Signed-off-by: Kevin Laatz <kevin.laatz@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
drivers/dma/idxd/idxd_pci.c

index fb618d34b635653d22907a2815c67b3c451ac036..2c3b01cd2bfeb80b6b7b6a8fd5a32b6665123479 100644 (file)
@@ -130,7 +130,7 @@ idxd_pci_dev_close(struct rte_dma_dev *dev)
 
        /* free device memory */
        IDXD_PMD_DEBUG("Freeing device driver memory");
-       rte_free(idxd->batch_idx_ring);
+       rte_free(idxd->batch_comp_ring);
        rte_free(idxd->desc_ring);
 
        /* if this is the last WQ on the device, disable the device and free