Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp254282pxj; Fri, 28 May 2021 03:14:24 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzwassaEGafzJwVL/A9WihLPUlP2QBDsbNWPQ3O1U7fpRrRoaOtnwVnlzbBONd2hpVxQZQe X-Received: by 2002:a17:906:1305:: with SMTP id w5mr8190904ejb.404.1622196863865; Fri, 28 May 2021 03:14:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1622196863; cv=none; d=google.com; s=arc-20160816; b=W3KJuwPClCg682JGfxgyS7T7lZMtpc42WywB/mXXRinWUeNc12zB2bDRWbBxFKgzx5 X174XBzArGs/UyvAN3OZ71dtoPo+7RDpBwZTV6PcNO1KjN2z0Y4Ak69xkbbrEjQYZTdn PcpJcuFhhJdSvVhFuJ6/yeS3QtqsQwXPZGS3MD6SizM13Rg4am7isNuulZduQi3f1piE rsLD2clSPshDlu1tGz67WUB+EZQPKU0Uj68eh3CsM+kqHvgjHCRXU3b7h2xnVfJ6E3tU MmvLEKVqgKEb24NS08BAXR9hpeK29ydYjJvUKRECzjROpA3X8j7i7pYMNLI0kd2rcc4u KhFw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date; bh=4knqlxn0HbrwmWMWgpiwHB0Vb1MoORTCgI05WDm4Esg=; b=w0Hme1N3eT7fhDibda1qd6zurqu2m3i9JdJFttsbQvmjvrHU1GuNWiGC+nWALrjxfc UReU+ZUcqrrq52XqgNeSV3zbh949HHOmgsgY0LxW6QBA/aSEAuvGAC8v6t44YrmAdZHN U/dkkFE9imxGcODgPplT+JhskSqrHERadFqi4VQQkW4evAOjnidLxzhT6JrYMZrgsAoG qTe6sq2vj16rF2DGpHjxAMUdYfQuco5aRehk2cKBmqW8He2qpXXaIbjOmbcW3f9qyArO m88kav+SHuf7s1BNaUcR/+dDr6Hea+QDpG7X2ajOOdSpfTh+VVCrlHsI8MqWk0xByyXH CCfQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id kl18si4820009ejc.160.2021.05.28.03.13.59; Fri, 28 May 2021 03:14:23 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236444AbhE1KMd (ORCPT + 99 others); Fri, 28 May 2021 06:12:33 -0400 Received: from jabberwock.ucw.cz ([46.255.230.98]:34412 "EHLO jabberwock.ucw.cz" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235672AbhE1KMd (ORCPT ); Fri, 28 May 2021 06:12:33 -0400 Received: by jabberwock.ucw.cz (Postfix, from userid 1017) id 12C441C0B76; Fri, 28 May 2021 12:10:58 +0200 (CEST) Date: Fri, 28 May 2021 12:10:57 +0200 From: Pavel Machek To: Andy Shevchenko Cc: Andy Shevchenko , Amireddy Mallikarjuna reddy , Linus Walleij , Marek =?iso-8859-1?Q?Beh=FAn?= , Abanoub Sameh , Dan Murphy , Krzysztof Kozlowski , linux-leds@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v1 21/28] leds: lm3697: Make error handling more robust Message-ID: <20210528101057.GH2209@amd> References: <20210510095045.3299382-1-andy.shevchenko@gmail.com> <20210510095045.3299382-22-andy.shevchenko@gmail.com> MIME-Version: 1.0 Content-Type: multipart/signed; micalg=pgp-sha1; protocol="application/pgp-signature"; boundary="ZPDwMsyfds7q4mrK" Content-Disposition: inline In-Reply-To: <20210510095045.3299382-22-andy.shevchenko@gmail.com> User-Agent: Mutt/1.5.23 (2014-03-12) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org --ZPDwMsyfds7q4mrK Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Content-Transfer-Encoding: quoted-printable On Mon 2021-05-10 12:50:38, Andy Shevchenko wrote: > It's easy to miss necessary clean up, e.g. firmware node reference counti= ng, > during error path in ->probe(). Make it more robust by moving to a single > point of return. >=20 > Signed-off-by: Andy Shevchenko You are now putting the handle even in the success case. Is that right? Pavel > --- > drivers/leds/leds-lm3697.c | 5 +---- > 1 file changed, 1 insertion(+), 4 deletions(-) >=20 > diff --git a/drivers/leds/leds-lm3697.c b/drivers/leds/leds-lm3697.c > index 9d35dd2a9bf0..6262ae69591e 100644 > --- a/drivers/leds/leds-lm3697.c > +++ b/drivers/leds/leds-lm3697.c > @@ -224,14 +224,12 @@ static int lm3697_probe_dt(struct lm3697 *priv) > ret =3D fwnode_property_read_u32(child, "reg", &control_bank); > if (ret) { > dev_err(dev, "reg property missing\n"); > - fwnode_handle_put(child); > goto child_out; > } > =20 > if (control_bank > LM3697_CONTROL_B) { > dev_err(dev, "reg property is invalid\n"); > ret =3D -EINVAL; > - fwnode_handle_put(child); > goto child_out; > } > =20 > @@ -262,7 +260,6 @@ static int lm3697_probe_dt(struct lm3697 *priv) > led->num_leds); > if (ret) { > dev_err(dev, "led-sources property missing\n"); > - fwnode_handle_put(child); > goto child_out; > } > =20 > @@ -287,7 +284,6 @@ static int lm3697_probe_dt(struct lm3697 *priv) > &init_data); > if (ret) { > dev_err(dev, "led register err: %d\n", ret); > - fwnode_handle_put(child); > goto child_out; > } > =20 > @@ -295,6 +291,7 @@ static int lm3697_probe_dt(struct lm3697 *priv) > } > =20 > child_out: > + fwnode_handle_put(child); > return ret; > } > =20 --=20 http://www.livejournal.com/~pavelmachek --ZPDwMsyfds7q4mrK Content-Type: application/pgp-signature; name="signature.asc" Content-Description: Digital signature -----BEGIN PGP SIGNATURE----- Version: GnuPG v1 iEYEARECAAYFAmCwwbEACgkQMOfwapXb+vLAGgCfYJHx7B9rkKtDWSxAKk4A4L7W YxAAoJtkYxIhFPHHBvh+Hpy4kJoHy3+D =C3z8 -----END PGP SIGNATURE----- --ZPDwMsyfds7q4mrK--