Received: by 2002:a05:7412:6592:b0:d7:7d3a:4fe2 with SMTP id m18csp871042rdg; Fri, 11 Aug 2023 02:31:04 -0700 (PDT) X-Google-Smtp-Source: AGHT+IFMf/Y+ETo2sVGxVWs6w7f/56Fgw9p6prbWPWjorjiikZFTk7rtROYMecE23mtcxvVd4ZiL X-Received: by 2002:a17:902:d4c3:b0:1b6:b703:36f8 with SMTP id o3-20020a170902d4c300b001b6b70336f8mr1893356plg.25.1691746264148; Fri, 11 Aug 2023 02:31:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1691746264; cv=none; d=google.com; s=arc-20160816; b=VGaFJRfSFU6Mlsp6fQrlV7B1zkZyP/V9ii5i+HmeTIsjKuspfvKjNf4OJEjJS3dNuy 3Tzu8DG9cwAbLmSIyeN42LYq7mcGJDfDJ9sNtgFfEZHS/MEZeQ7yHdYvYFnmrZRrQuFz GGz2fQ1jCMIhtrKdQLLI93UnVbiaaHro/S2VMJaZ49fyI4ZytEoVw/PdcLa4YxzMDKxu MszlrOTwy0i2nfSdspSYJrTtrbRuj+uS/dqb1shz2stcVaT/y7pbfuR9otGXP3G9/yzP fdH+6hW4DcJ6NALN+ECb82HjHK0TjA+tSJQqidZ7i+tDjZdUkRKDk8z0mhruvrLIMuC2 1hTA== 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=ZLHGajSNMaaBeKT2GRlFtqPgOeUjK99n10bcDrnHd2k=; fh=vmy4+VYp31eXcFPDiGFPRKmO3bKn49jEkIJwbeEP4DE=; b=bld350sjQEHxcm5KSLb3vIab+c6yx3YmGJ2gR2aCz/VqIHAcxwFhw5NHcxKLXHh7tN pRf3o265eCYNyvwMB5e9knYH4XarGA9Rn7ndUgiXacm2yXoXDeaJ32NFPzlMvl32x7LT XllfpBd5GAE1Oe+74qOFgxry+H7+sGRTHkvHCir4MVgj3VmAY9e3CK8ED6mdqS8gPk6R TEt+UIrVDGacM8mG2nyklbl7RDKgsew2HQCol4uMScZMGC0JWk49LMyESg92adNpDKmc 6kR2Ly0kG1MmFCXG1oab5nueoOCofZEroVr2DewaYw23xPapzOKVuie4Jg8c8xV0z3az WgvQ== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id u6-20020a170902e80600b001b84c7d4716si3248482plg.32.2023.08.11.02.30.51; Fri, 11 Aug 2023 02:31:04 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234096AbjHKJXG (ORCPT + 99 others); Fri, 11 Aug 2023 05:23:06 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44394 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229835AbjHKJXF (ORCPT ); Fri, 11 Aug 2023 05:23:05 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 8DCE2C5 for ; Fri, 11 Aug 2023 02:23:04 -0700 (PDT) Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id B560ED75; Fri, 11 Aug 2023 02:23:46 -0700 (PDT) Received: from [10.163.54.13] (unknown [10.163.54.13]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id D47E03F59C; Fri, 11 Aug 2023 02:22:56 -0700 (PDT) Message-ID: <32017de8-7b92-a88f-0bf6-da1dfe3a7f7d@arm.com> Date: Fri, 11 Aug 2023 14:52:53 +0530 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.13.0 Subject: Re: [PATCH] coresight: etm4x: Ensure valid drvdata and clock before clk_put() Content-Language: en-US To: Suzuki K Poulose , James Clark , linux-arm-kernel@lists.infradead.org Cc: Mike Leach , coresight@lists.linaro.org, linux-kernel@vger.kernel.org, Dan Carpenter References: <20230811062738.1066787-1-anshuman.khandual@arm.com> <07b0dabb-5409-9ba8-543f-aeecafe083e9@arm.com> <72960b11-9e35-a259-3ea6-bae91ff94838@arm.com> From: Anshuman Khandual In-Reply-To: <72960b11-9e35-a259-3ea6-bae91ff94838@arm.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-5.2 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_MED,SPF_HELO_NONE,SPF_NONE,URIBL_BLOCKED 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 8/11/23 14:39, Suzuki K Poulose wrote: > On 11/08/2023 09:39, James Clark wrote: >> >> >> On 11/08/2023 07:27, Anshuman Khandual wrote: >>> This validates 'drvdata' and 'drvdata->pclk' clock before calling clk_put() >>> in etm4_remove_platform_dev(). The problem was detected using Smatch static >>> checker as reported. >>> >>> Cc: Suzuki K Poulose >>> Cc: Mike Leach >>> Cc: James Clark >>> Cc: coresight@lists.linaro.org >>> Cc: linux-arm-kernel@lists.infradead.org >>> Cc: linux-kernel@vger.kernel.org >>> Reported-by: Dan Carpenter >>> Closes: https://lists.linaro.org/archives/list/coresight@lists.linaro.org/thread/G4N6P4OXELPLLQSNU3GU2MR4LOLRXRMJ/ >>> Signed-off-by: Anshuman Khandual >>> --- >>> This applies on coresight-next >>> >>>   drivers/hwtracing/coresight/coresight-etm4x-core.c | 2 +- >>>   1 file changed, 1 insertion(+), 1 deletion(-) >>> >>> diff --git a/drivers/hwtracing/coresight/coresight-etm4x-core.c b/drivers/hwtracing/coresight/coresight-etm4x-core.c >>> index 703b6fcbb6a5..eb412ce302cc 100644 >>> --- a/drivers/hwtracing/coresight/coresight-etm4x-core.c >>> +++ b/drivers/hwtracing/coresight/coresight-etm4x-core.c >>> @@ -2269,7 +2269,7 @@ static int __exit etm4_remove_platform_dev(struct platform_device *pdev) >>>           etm4_remove_dev(drvdata); >>>       pm_runtime_disable(&pdev->dev); >>>   -    if (drvdata->pclk) >>> +    if (drvdata && drvdata->pclk && !IS_ERR(drvdata->pclk)) >>>           clk_put(drvdata->pclk); >>>         return 0; >> >> It could be !IS_ERR_OR_NULL(drvdata->pclk), but I wouldn't bother >> changing it at this point. > > +1, please could we have that. Someone else will run a code scanner and > send a patch later. Given this is straight and easy change, lets do it > in the first place. But we already have a drvdata->pclk validation check before IS_ERR(). Would not _OR_NULL be redundant ?