net: stmmac: fix possible memory leak in stmmac_dvr_probe()
authorGaosheng Cui <cuigaosheng1@huawei.com>
Wed, 7 Dec 2022 08:34:13 +0000 (16:34 +0800)
committerDavid S. Miller <davem@davemloft.net>
Fri, 9 Dec 2022 10:51:38 +0000 (10:51 +0000)
The bitmap_free() should be called to free priv->af_xdp_zc_qps
when create_singlethread_workqueue() fails, otherwise there will
be a memory leak, so we add the err path error_wq_init to fix it.

Fixes: bba2556efad6 ("net: stmmac: Enable RX via AF_XDP zero-copy")
Signed-off-by: Gaosheng Cui <cuigaosheng1@huawei.com>
Reviewed-by: Leon Romanovsky <leonro@nvidia.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/stmicro/stmmac/stmmac_main.c

index 23ec0a9..b978d05 100644 (file)
@@ -7097,7 +7097,7 @@ int stmmac_dvr_probe(struct device *device,
        priv->wq = create_singlethread_workqueue("stmmac_wq");
        if (!priv->wq) {
                dev_err(priv->device, "failed to create workqueue\n");
-               return -ENOMEM;
+               goto error_wq_init;
        }
 
        INIT_WORK(&priv->service_task, stmmac_service_task);
@@ -7325,6 +7325,7 @@ error_mdio_register:
        stmmac_napi_del(ndev);
 error_hw_init:
        destroy_workqueue(priv->wq);
+error_wq_init:
        bitmap_free(priv->af_xdp_zc_qps);
 
        return ret;