Received: by 2002:a05:6358:9144:b0:117:f937:c515 with SMTP id r4csp4408754rwr; Sun, 23 Apr 2023 05:16:58 -0700 (PDT) X-Google-Smtp-Source: AKy350ZipCKNmtgSxYW2B/mcWMfSqMFrE7i4SXb8PLYX5uq1t9fLfGaoht3Clv5zvX4hAAgKYIoi X-Received: by 2002:a17:902:ea0d:b0:1a6:3ba2:c896 with SMTP id s13-20020a170902ea0d00b001a63ba2c896mr13345409plg.3.1682252218333; Sun, 23 Apr 2023 05:16:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1682252218; cv=none; d=google.com; s=arc-20160816; b=P89zjeni8I1CmhDxxWt8fc556BSP/JLeYbuGpeU6bVv26FvpD+Vbw5fvtCiCromzKO djoZxpVoZkh3Vm7I77al/yTFOT5rktJ2tQSg9+FALEb7/y8HnZUIAV45DpQiYG7pfl8P iBsiZHev2CzfXmWd/EJwq0bknXCVfZsX4mJa8NXJTccpx7sqXVXRKabnz1O1s3WTj9WU SouIQvErxdCLqdp+Sz4w9jwZ5fDRQJovLLUHB76k4CO4qg5LA6g8lYviWiFCxy0Ui/Lh /oHC2zbf0g1d/Feyf7zt6cZk9ZkqCW3+a/hn5ma1uq2DEgHKCSN1Hp8jOiUe3VYjqiTA 5nHQ== 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:subject:user-agent:mime-version:date:message-id; bh=uXvTkZp1N6+CrxK74mao+t5vVxaamtGTsuU+Xv7X07E=; b=GsL/l9tDNPZYU7KsYc+eGgJy0FqMfWznAj+cLjhPXcPqu/m/2j6D6qlk0JnxYrohQo aPxQ5qRXVMrIfD8o0MLUBDoVugoZNc9fHxBKRliyqIyoSus+vmK7zwFwmBLSKMFFLcbo Ry8i48+2rSpD64WUObeh66IvJatLBwC+L8MvKIl6vixacHa4pJBKmby5CY7SFyz+84zk iDmgLwVTNjY3U6dhkQvaJPanJDrjqP7bXgP3r07rUU77xVy7ctInEjwEpLN4ehLD4CR+ Q/36dUkZSg5e8FpenMuGz6bFyKp0drsb1/hZIRsG+BdB9kzo4VNKjCD8ClD35zz2AVJb 7dqw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-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 u12-20020a17090341cc00b001a664075202si9528495ple.542.2023.04.23.05.16.46; Sun, 23 Apr 2023 05:16:58 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-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-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229959AbjDWMDt (ORCPT + 99 others); Sun, 23 Apr 2023 08:03:49 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41662 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229477AbjDWMDq (ORCPT ); Sun, 23 Apr 2023 08:03:46 -0400 Received: from hust.edu.cn (mail.hust.edu.cn [202.114.0.240]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 3DF63E66; Sun, 23 Apr 2023 05:03:43 -0700 (PDT) Received: from [192.168.1.10] ([183.94.69.5]) (user=dzm91@hust.edu.cn mech=PLAIN bits=0) by mx1.hust.edu.cn with ESMTP id 33NC1Y2W012811-33NC1Y2X012811 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128 verify=NO); Sun, 23 Apr 2023 20:01:34 +0800 Message-ID: <54c3b7f7-20da-f42e-6bef-f462246fd3ee@hust.edu.cn> Date: Sun, 23 Apr 2023 20:01:29 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:102.0) Gecko/20100101 Thunderbird/102.10.0 Subject: Re: [PATCH v2] iio: adc: mxs-lradc: fix the order of two cleanup operations To: Jonathan Cameron , Jiakai Luo Cc: Lars-Peter Clausen , Shawn Guo , Sascha Hauer , Pengutronix Kernel Team , Fabio Estevam , NXP Linux Team , Ksenija Stanojevic , Lee Jones , Marek Vasut , hust-os-kernel-patches@googlegroups.com, linux-iio@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org References: <20230417024745.59614-1-jkluo@hust.edu.cn> <20230423115049.1c73600f@jic23-huawei> From: Dongliang Mu In-Reply-To: <20230423115049.1c73600f@jic23-huawei> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-FEAS-AUTH-USER: dzm91@hust.edu.cn X-Spam-Status: No, score=-4.1 required=5.0 tests=BAYES_00,NICE_REPLY_A, SPF_HELO_PASS,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham 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-kernel@vger.kernel.org On 2023/4/23 18:50, Jonathan Cameron wrote: > On Sun, 16 Apr 2023 19:47:45 -0700 > Jiakai Luo wrote: > >> Smatch reports: >> drivers/iio/adc/mxs-lradc-adc.c:766 mxs_lradc_adc_probe() warn: >> missing unwind goto? >> >> the order of three init operation: >> 1.mxs_lradc_adc_trigger_init >> 2.iio_triggered_buffer_setup >> 3.mxs_lradc_adc_hw_init >> >> thus, the order of three cleanup operation should be: >> 1.mxs_lradc_adc_hw_stop >> 2.iio_triggered_buffer_cleanup >> 3.mxs_lradc_adc_trigger_remove >> >> we exchange the order of two cleanup operations, >> introducing the following differences: >> 1.if mxs_lradc_adc_trigger_init fails, returns directly; >> 2.if trigger_init succeeds but iio_triggered_buffer_setup fails, >> goto err_trig and remove the trigger. >> >> In addition, we also reorder the unwind that goes on in the >> remove() callback to match the new ordering. >> >> Fixes: 6dd112b9f85e ("iio: adc: mxs-lradc: Add support for ADC driver") >> Signed-off-by: Jiakai Luo >> Reviewed-by: Dongliang Mu > If resending please state why. I'm guessing on this occasion it was because > you realised a fresh thread is expected for a new patch. > > Also, even if you are just amending the patch description, please increase > the version number so that we can be sure we are looking at latest version. > > I already picked it from the earlier posting and this appears unchanged > so all's well that ends well! > > Jonathan Hi JC, Jiakai originally would like to send a reminder about his patch, but mistakenly sent a v2 version. Please ignore this v2 version since this version is the same with v1 version. Sorry for the mistake. > >> --- >> The issue is found by static analysis and remains untested. >> --- >> drivers/iio/adc/mxs-lradc-adc.c | 10 +++++----- >> 1 file changed, 5 insertions(+), 5 deletions(-) >> >> diff --git a/drivers/iio/adc/mxs-lradc-adc.c b/drivers/iio/adc/mxs-lradc-adc.c >> index bca79a93cbe4..85882509b7d9 100644 >> --- a/drivers/iio/adc/mxs-lradc-adc.c >> +++ b/drivers/iio/adc/mxs-lradc-adc.c >> @@ -757,13 +757,13 @@ static int mxs_lradc_adc_probe(struct platform_device *pdev) >> >> ret = mxs_lradc_adc_trigger_init(iio); >> if (ret) >> - goto err_trig; >> + return ret; >> >> ret = iio_triggered_buffer_setup(iio, &iio_pollfunc_store_time, >> &mxs_lradc_adc_trigger_handler, >> &mxs_lradc_adc_buffer_ops); >> if (ret) >> - return ret; >> + goto err_trig; >> >> adc->vref_mv = mxs_lradc_adc_vref_mv[lradc->soc]; >> >> @@ -801,9 +801,9 @@ static int mxs_lradc_adc_probe(struct platform_device *pdev) >> >> err_dev: >> mxs_lradc_adc_hw_stop(adc); >> - mxs_lradc_adc_trigger_remove(iio); >> -err_trig: >> iio_triggered_buffer_cleanup(iio); >> +err_trig: >> + mxs_lradc_adc_trigger_remove(iio); >> return ret; >> } >> >> @@ -814,8 +814,8 @@ static int mxs_lradc_adc_remove(struct platform_device *pdev) >> >> iio_device_unregister(iio); >> mxs_lradc_adc_hw_stop(adc); >> - mxs_lradc_adc_trigger_remove(iio); >> iio_triggered_buffer_cleanup(iio); >> + mxs_lradc_adc_trigger_remove(iio); >> >> return 0; >> }