]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
ice: dpll: fix memory leak in ice_dpll_init_info error paths
authorZhaoJinming <zhaojinming@uniontech.com>
Fri, 29 May 2026 05:37:33 +0000 (13:37 +0800)
committerTony Nguyen <anthony.l.nguyen@intel.com>
Mon, 22 Jun 2026 21:44:50 +0000 (14:44 -0700)
Several error return paths in ice_dpll_init_info() directly return
without freeing previously allocated resources, causing memory leaks:

- When de->input_prio allocation fails, d->inputs is leaked
- When dp->input_prio allocation fails, d->inputs and de->input_prio
  are leaked
- When ice_get_cgu_rclk_pin_info() fails, all previously allocated
  inputs/outputs/input_prio are leaked
- When ice_dpll_init_pins_info(RCLK_INPUT) fails, same resources
  are leaked

Fix this by jumping to the deinit_info label which properly calls
ice_dpll_deinit_info() to free all allocated resources.

Fixes: d7999f5ea64b ("ice: implement dpll interface to control cgu")
Signed-off-by: ZhaoJinming <zhaojinming@uniontech.com>
Reviewed-by: Aleksandr Loktionov <aleksandr.loktionov@intel.com>
Tested-by: Rinitha S <sx.rinitha@intel.com> (A Contingent worker at Intel)
Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com>
drivers/net/ethernet/intel/ice/ice_dpll.c

index 3876ee7255ac2d44103c42d45359d7376ab2bc09..30c3a4db7d611cb21cd77eb9cb898b9ebcbb5c40 100644 (file)
@@ -4752,12 +4752,16 @@ static int ice_dpll_init_info(struct ice_pf *pf, bool cgu)
 
        alloc_size = sizeof(*de->input_prio) * d->num_inputs;
        de->input_prio = kzalloc(alloc_size, GFP_KERNEL);
-       if (!de->input_prio)
-               return -ENOMEM;
+       if (!de->input_prio) {
+               ret = -ENOMEM;
+               goto deinit_info;
+       }
 
        dp->input_prio = kzalloc(alloc_size, GFP_KERNEL);
-       if (!dp->input_prio)
-               return -ENOMEM;
+       if (!dp->input_prio) {
+               ret = -ENOMEM;
+               goto deinit_info;
+       }
 
        ret = ice_dpll_init_pins_info(pf, ICE_DPLL_PIN_TYPE_INPUT);
        if (ret)
@@ -4782,12 +4786,12 @@ static int ice_dpll_init_info(struct ice_pf *pf, bool cgu)
        ret = ice_get_cgu_rclk_pin_info(&pf->hw, &d->base_rclk_idx,
                                        &pf->dplls.rclk.num_parents);
        if (ret)
-               return ret;
+               goto deinit_info;
        for (i = 0; i < pf->dplls.rclk.num_parents; i++)
                pf->dplls.rclk.parent_idx[i] = d->base_rclk_idx + i;
        ret = ice_dpll_init_pins_info(pf, ICE_DPLL_PIN_TYPE_RCLK_INPUT);
        if (ret)
-               return ret;
+               goto deinit_info;
        de->mode = DPLL_MODE_AUTOMATIC;
        dp->mode = DPLL_MODE_AUTOMATIC;