Commit 7ac10c7d authored by Vikas Gupta's avatar Vikas Gupta Committed by David S. Miller

bnxt_en: Fix possible memory leak in bnxt_rdma_aux_device_init()

If ulp = kzalloc() fails, the allocated edev will leak because it is
not properly assigned and the cleanup path will not be able to free it.
Fix it by assigning it properly immediately after allocation.

Fixes: 30343221 ("bnxt_en: Remove runtime interrupt vector allocation")
Reviewed-by: default avatarAndy Gospodarek <andrew.gospodarek@broadcom.com>
Signed-off-by: default avatarVikas Gupta <vikas.gupta@broadcom.com>
Signed-off-by: default avatarMichael Chan <michael.chan@broadcom.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 58effa34
...@@ -392,12 +392,13 @@ void bnxt_rdma_aux_device_init(struct bnxt *bp) ...@@ -392,12 +392,13 @@ void bnxt_rdma_aux_device_init(struct bnxt *bp)
if (!edev) if (!edev)
goto aux_dev_uninit; goto aux_dev_uninit;
aux_priv->edev = edev;
ulp = kzalloc(sizeof(*ulp), GFP_KERNEL); ulp = kzalloc(sizeof(*ulp), GFP_KERNEL);
if (!ulp) if (!ulp)
goto aux_dev_uninit; goto aux_dev_uninit;
edev->ulp_tbl = ulp; edev->ulp_tbl = ulp;
aux_priv->edev = edev;
bp->edev = edev; bp->edev = edev;
bnxt_set_edev_info(edev, bp); bnxt_set_edev_info(edev, bp);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment