> -----Original Message----- > From: Intel-wired-lan <intel-wired-lan-boun...@osuosl.org> On Behalf Of > Gui-Dong Han > Sent: Tuesday, September 3, 2024 5:19 PM > To: Nguyen, Anthony L <anthony.l.ngu...@intel.com>; Kitszel, Przemyslaw > <przemyslaw.kits...@intel.com>; da...@davemloft.net; eduma...@google.com; > k...@kernel.org; pab...@redhat.com > Cc: net...@vger.kernel.org; linux-ker...@vger.kernel.org; > sta...@vger.kernel.org; Gui-Dong Han <hanguidon...@outlook.com>; > baijiaju1...@gmail.com; intel-wired-...@lists.osuosl.org > Subject: [Intel-wired-lan] [PATCH v2] ice: Fix improper handling of refcount > in ice_dpll_init_rclk_pins() > > This patch addresses a reference count handling issue in the > ice_dpll_init_rclk_pins() function. The function calls ice_dpll_get_pins(), > which increments the reference count of the relevant resources. However, if > the condition WARN_ON((!vsi || !vsi->netdev)) is met, the function currently > returns an error without properly releasing the > resources acquired by > ice_dpll_get_pins(), leading to a reference count leak. > > To resolve this, the check has been moved to the top of the function. This > ensures that the function verifies the state before any resources are > acquired, avoiding the need for additional resource management in the error > path. > > This bug was identified by an experimental static analysis tool developed by > our team. The tool specializes in analyzing reference count operations and > detecting potential issues where resources are not properly managed. > In this case, the tool flagged the missing release operation as a potential > problem, which led to the development of this patch. > > Fixes: d7999f5ea64b ("ice: implement dpll interface to control cgu") > Cc: sta...@vger.kernel.org > Signed-off-by: Gui-Dong Han <hanguidon...@outlook.com> > --- > v2: > * In this patch v2, the check for vsi and vsi->netdev has been moved to the > top of the function to simplify error handling and avoid the need for > resource unwinding. > Thanks to Simon Horman for suggesting this improvement. > --- > drivers/net/ethernet/intel/ice/ice_dpll.c | 4 ++-- > 1 file changed, 2 insertions(+), 2 deletions(-) >
Tested-by: Pucha Himasekhar Reddy <himasekharx.reddy.pu...@intel.com> (A Contingent worker at Intel)