]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
octeontx2-af: CGX: fix bitmap leaks
authorBo Sun <bo@mboxify.com>
Fri, 6 Feb 2026 13:09:24 +0000 (21:09 +0800)
committerSasha Levin <sashal@kernel.org>
Wed, 4 Mar 2026 12:21:27 +0000 (07:21 -0500)
[ Upstream commit 3def995c4ede842adf509c410e92d09a0cedc965 ]

The RX/TX flow-control bitmaps (rx_fc_pfvf_bmap and tx_fc_pfvf_bmap)
are allocated by cgx_lmac_init() but never freed in cgx_lmac_exit().
Unbinding and rebinding the driver therefore triggers kmemleak:

    unreferenced object (size 16):
        backtrace:
          rvu_alloc_bitmap
          cgx_probe

Free both bitmaps during teardown.

Fixes: e740003874ed ("octeontx2-af: Flow control resource management")
Cc: stable@vger.kernel.org
Signed-off-by: Bo Sun <bo@mboxify.com>
Reviewed-by: Vadim Fedorenko <vadim.fedorenko@linux.dev>
Reviewed-by: Jijie Shao <shaojijie@huawei.com>
Link: https://patch.msgid.link/20260206130925.1087588-2-bo@mboxify.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/net/ethernet/marvell/octeontx2/af/cgx.c

index ec0e11c77cbf20f2e2211059f04d0765500a2455..81b55f1416e0d7a1f7c9282613cb42195e3b9ecc 100644 (file)
@@ -1823,6 +1823,8 @@ static int cgx_lmac_exit(struct cgx *cgx)
                cgx->mac_ops->mac_pause_frm_config(cgx, lmac->lmac_id, false);
                cgx_configure_interrupt(cgx, lmac, lmac->lmac_id, true);
                kfree(lmac->mac_to_index_bmap.bmap);
+               rvu_free_bitmap(&lmac->rx_fc_pfvf_bmap);
+               rvu_free_bitmap(&lmac->tx_fc_pfvf_bmap);
                kfree(lmac->name);
                kfree(lmac);
        }