Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp850607iog; Mon, 13 Jun 2022 14:27:48 -0700 (PDT) X-Google-Smtp-Source: AGRyM1uKO9hngL2dBV8Os2X9Um0//+qkmEWcZpHX+fMtm5YZa69cUiJbKsSV5NSnGbJq9Y7TD4rk X-Received: by 2002:a17:906:2f92:b0:711:cfe6:b117 with SMTP id w18-20020a1709062f9200b00711cfe6b117mr1425515eji.665.1655155668703; Mon, 13 Jun 2022 14:27:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655155668; cv=none; d=google.com; s=arc-20160816; b=VgzcDG8edgzlnC3qLukeXwN/URkMrnSwOfaG8HI85RD9fzjF79YSI/pYPWPgIjvNhf o9ica6Ch1JWuaNrRl3TXpBsnNzZsodvi4PfoVsdm/oe+pPWE9fPykFQ2RbXhHMgGGG1O XVZC4E05Btty540rCpaoK4hgU86hktFHd6luUWrbALQ7MnxThKiC9E+t0YLCw92SzvsS 24yxQPtYcnbm4qwcwqdiAG+2PZXRzloG8AeBXd7zRP+txFVDbEPrXixrhTrOtdIqfYnG IauFVfOOHnkVXWA5mg1ZCqHxX4sjWKl6ExKs16jwSIp8UiMb6NTPfCDKd3NoBdf2o9CK b0Aw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id; bh=8JFSDG9bfvy523Yle+3VKG3rBlHK1/Z69a2oLB31RlU=; b=iWE1f0Ui/YKVZvC/6ADrMRB3t/MgTgy9F11X/n9iionN0+S79VJD30hX1X/qO/XZDC jxWc8hUGyPz78gEtuwPlRArajacQbl9wlcex3HA3W1WbPWXjo/XpqlQmS4SFxDtV+6rK VsY3M6SxIBNVCDDG97+1WuG8NxC5PBN4Jm4AoFg+ah5ylPXVKe3LUX6dX69ijlTZBgND nqChY5ppiKzEQ+8b+ltz4lTeoq+sPqEmclTkk8SngX7pncYsF1nJ2eFxetR9qVyMC4IZ K4e0s2MbKWFhG845w1kYZ+EL+f4rI4TTdHfuuXnTYZeBXhlsEYNDFYLCwvdcS9FcgAxX bAgQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id cr20-20020a170906d55400b0071728eab678si6226833ejc.78.2022.06.13.14.27.26; Mon, 13 Jun 2022 14:27:48 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1352055AbiFMVQA (ORCPT + 65 others); Mon, 13 Jun 2022 17:16:00 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46718 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1351929AbiFMVPv (ORCPT ); Mon, 13 Jun 2022 17:15:51 -0400 Received: from smtp.smtpout.orange.fr (smtp02.smtpout.orange.fr [80.12.242.124]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B9A4143ED3 for ; Mon, 13 Jun 2022 13:57:29 -0700 (PDT) Received: from [192.168.1.18] ([90.11.190.129]) by smtp.orange.fr with ESMTPA id 0r7no7OkDEMbD0r7nog3Oj; Mon, 13 Jun 2022 22:57:28 +0200 X-ME-Helo: [192.168.1.18] X-ME-Auth: YWZlNiIxYWMyZDliZWIzOTcwYTEyYzlhMmU3ZiQ1M2U2MzfzZDfyZTMxZTBkMTYyNDBjNDJlZmQ3ZQ== X-ME-Date: Mon, 13 Jun 2022 22:57:28 +0200 X-ME-IP: 90.11.190.129 Message-ID: Date: Mon, 13 Jun 2022 22:57:25 +0200 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.9.1 Subject: Re: [PATCH v2] p54: Fix an error handling path in p54spi_probe() Content-Language: en-US To: Christian Lamparter Cc: Kalle Valo , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , "John W. Linville" , linux-kernel , kernel-janitors@vger.kernel.org, Christian Lamparter , linux-wireless , Netdev References: <297d2547ff2ee627731662abceeab9dbdaf23231.1655068321.git.christophe.jaillet@wanadoo.fr> From: Christophe JAILLET In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-3.1 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_NONE,RCVD_IN_MSPIKE_H2,SPF_HELO_NONE,SPF_PASS, T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org Le 13/06/2022 à 22:02, Christian Lamparter a écrit : > On Sun, Jun 12, 2022 at 11:12 PM Christophe JAILLET > wrote: >> >> If an error occurs after a successful call to p54spi_request_firmware(), it >> must be undone by a corresponding release_firmware() as already done in >> the error handling path of p54spi_request_firmware() and in the .remove() >> function. >> >> Add the missing call in the error handling path and remove it from >> p54spi_request_firmware() now that it is the responsibility of the caller >> to release the firmawre > > that last word hast a typo: firmware. (maybe Kalle can fix this in post). More or less the same typo twice in a row... _Embarrassed_ > >> Fixes: cd8d3d321285 ("p54spi: p54spi driver") >> Signed-off-by: Christophe JAILLET > Acked-by: Christian Lamparter > (Though, v1 was fine too.) >> --- >> v2: reduce diffstat and take advantage on the fact that release_firmware() >> checks for NULL > > Heh, ok ;) . Now that I see it, the "ret = p54_parse_firmware(...); ... " > could have been replaced with "return p54_parse_firmware(dev, priv->firmware);" > so the p54spi.c could shrink another 5-6 lines. > > I think leaving p54spi_request_firmware() callee to deal with > releasing the firmware > in the error case as well is nicer because it gets rid of a "but in > this case" complexity. Take the one you consider being the best one. If it deserves a v3 to axe some lines of code, I can do it but, as said previously, v1 is for me the cleaner and more future proof. CJ > > (I still have hope for the devres-firmware to hit some day). > > Cheers > Christian > >> --- >> drivers/net/wireless/intersil/p54/p54spi.c | 3 ++- >> 1 file changed, 2 insertions(+), 1 deletion(-) >> >> diff --git a/drivers/net/wireless/intersil/p54/p54spi.c b/drivers/net/wireless/intersil/p54/p54spi.c >> index f99b7ba69fc3..19152fd449ba 100644 >> --- a/drivers/net/wireless/intersil/p54/p54spi.c >> +++ b/drivers/net/wireless/intersil/p54/p54spi.c >> @@ -164,7 +164,7 @@ static int p54spi_request_firmware(struct ieee80211_hw *dev) >> >> ret = p54_parse_firmware(dev, priv->firmware); >> if (ret) { >> - release_firmware(priv->firmware); >> + /* the firmware is released by the caller */ >> return ret; >> } >> >> @@ -659,6 +659,7 @@ static int p54spi_probe(struct spi_device *spi) >> return 0; >> >> err_free_common: >> + release_firmware(priv->firmware); >> free_irq(gpio_to_irq(p54spi_gpio_irq), spi); >> err_free_gpio_irq: >> gpio_free(p54spi_gpio_irq); >> -- >> 2.34.1 >> >