Received: by 2002:a05:6358:9144:b0:117:f937:c515 with SMTP id r4csp8540794rwr; Thu, 11 May 2023 02:46:36 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ52cipOXhmdWLt13oNGZ+ozVfeoFMO7uFw4Z1evNc2djla2D/XGvPYYBRTnPxJboS7DtBOm X-Received: by 2002:a05:6a00:2e8f:b0:63d:254a:3900 with SMTP id fd15-20020a056a002e8f00b0063d254a3900mr27621909pfb.5.1683798396176; Thu, 11 May 2023 02:46:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1683798396; cv=none; d=google.com; s=arc-20160816; b=arGKukTa3wt61MRDZlDyDWpJQR8f28PeO5cip4NyGAFwhqkx8yWWH/u/X0OkYPteIp 9FnkQXryfUu/S3YMrBiUGJv5VNgimceZAh1PdwTl6y8BzYAbJZuxhmmzTIdjAOgk73Ns 7ScFvERARO38t17e0/YD4gq7aC9PYng4o17y5mJDXuq24x6p5GDh24jXO/OT3p4Qq5a2 1pS7UtbamFCPKtBXKeGg8kvRimlm6xmr3NfnVJPicl0kRWcwiLncRAaqPil4CLMyLTUo v2aQhdtua78sDE1ZVfwil+8h2ALYW79ev65ogZ3STu8r98AQdp59WMHccQQMg5Zrl+fM gZzg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:date:subject:cc:to:from :dkim-signature; bh=Vap+41/PY6pXzbjKvr9Q+3GpaSZ82N/7BpF/0fTMCj8=; b=0OLZPsYKG8cC8jToaCxq5ACSiUmsT5ynXdUzQxnpX5snq+lqMphoclD00Y6U+d5D2z t+YYGjaoF1EegIuNetw29ZCmFc5gK+D4+EHyLDd2G+voAt/wQeKEqNmdeFcV1+rGHs4s HocFGhc4Xr25wNsB0cPDkTxs/mgZxRjyVwbWlFScMb45KoJyfE2lIzfHjS23NgRl+3Ui SXZ3PmsYgAnGDeKULAY+QQPfIOCfzskPxYgciPMHRH7GBIhPgXItbkU343G4DoO4Dbb/ CdTPbYJ3cfy/kxftd8CpRa/9ReNEM0RkO/eSHWCF9tC4byryADXC2K6/ygu/++PlZppX xypQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@dh-electronics.com header.s=dhelectronicscom header.b="b5Zw/J+g"; 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=pass (p=REJECT sp=REJECT dis=NONE) header.from=dh-electronics.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id p184-20020a6229c1000000b00643b2b72c87si2191228pfp.24.2023.05.11.02.46.22; Thu, 11 May 2023 02:46:36 -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; dkim=pass header.i=@dh-electronics.com header.s=dhelectronicscom header.b="b5Zw/J+g"; 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=pass (p=REJECT sp=REJECT dis=NONE) header.from=dh-electronics.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237701AbjEKJfs (ORCPT + 99 others); Thu, 11 May 2023 05:35:48 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56568 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237740AbjEKJff (ORCPT ); Thu, 11 May 2023 05:35:35 -0400 X-Greylist: delayed 584 seconds by postgrey-1.37 at lindbergh.monkeyblade.net; Thu, 11 May 2023 02:35:31 PDT Received: from mx4.securetransport.de (mx4.securetransport.de [178.254.6.145]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 1D71A8A47; Thu, 11 May 2023 02:35:30 -0700 (PDT) Received: from mail.dh-electronics.com (unknown [77.24.89.57]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mx4.securetransport.de (Postfix) with ESMTPSA id 1D35E720163; Thu, 11 May 2023 11:25:03 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=dh-electronics.com; s=dhelectronicscom; t=1683797104; bh=Vap+41/PY6pXzbjKvr9Q+3GpaSZ82N/7BpF/0fTMCj8=; h=From:To:CC:Subject:Date:From; b=b5Zw/J+gzTB7D2sT7mNE7AoYe2Uk9/Km4o+WPa4OQ3QQT2XYC5mIsJRaAvH5uEuaZ FFHkEiViLqdOs/g0FaEHRgYcGcnTAvcJJUa+QG1AN9qFLCF548kFKEez634W9d5Kc3 7vTG2I3d70yPFy+F/m8n0AtmOCaPox/te72scJ1KbWL60+CYxJQEzMs9d81Co+qpDq qYOlaizCvU6WIBGxasuJK11YzANyzQcFW6/Wq8GUVP9U35T37FoZPKePtkDez37iQv GQKB37YvMZvVHsV+ZMTII6+NasY8+YKC92zc6X6KpN1iY3Dj4EYVabUlS4mHPEByux zKyximx+Zdt+w== Received: from DHPWEX01.DH-ELECTRONICS.ORG (10.64.2.30) by DHPWEX01.DH-ELECTRONICS.ORG (10.64.2.30) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1118.26; Thu, 11 May 2023 11:25:02 +0200 Received: from localhost.localdomain (172.16.51.5) by DHPWEX01.DH-ELECTRONICS.ORG (10.64.2.30) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1118.26 via Frontend Transport; Thu, 11 May 2023 11:25:01 +0200 From: Christoph Niedermaier To: CC: Christoph Niedermaier , Viresh Kumar , "Rafael J. Wysocki" , Shawn Guo , Marek Vasut , Fabio Estevam , NXP Linux Team , "open list:CPU FREQUENCY SCALING FRAMEWORK" , open list Subject: [PATCH] cpufreq: imx6q: Disable only available frequencies Date: Thu, 11 May 2023 11:23:34 +0200 Message-ID: <20230511092334.3017-1-cniedermaier@dh-electronics.com> X-Mailer: git-send-email 2.11.0 X-klartext: yes MIME-Version: 1.0 Content-Type: text/plain X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,SPF_HELO_NONE,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 In the example in Documentation/power/opp.rst, an availability check is present before disabling a specific frequency. If a frequency isn't available, the warning of a failed disabling of a non-existent frequency is misleading. Therefore, check the availability of the frequency in a separate inline function before disabling it. Signed-off-by: Christoph Niedermaier --- Cc: Viresh Kumar Cc: "Rafael J. Wysocki" Cc: Shawn Guo Cc: Marek Vasut Cc: Fabio Estevam Cc: NXP Linux Team Cc: linux-pm@vger.kernel.org (open list:CPU FREQUENCY SCALING FRAMEWORK) Cc: linux-kernel@vger.kernel.org (open list) To: linux-arm-kernel@lists.infradead.org --- drivers/cpufreq/imx6q-cpufreq.c | 27 +++++++++++++++++++++------ 1 file changed, 21 insertions(+), 6 deletions(-) diff --git a/drivers/cpufreq/imx6q-cpufreq.c b/drivers/cpufreq/imx6q-cpufreq.c index 48e1772e98fd..4e2d2bc47aba 100644 --- a/drivers/cpufreq/imx6q-cpufreq.c +++ b/drivers/cpufreq/imx6q-cpufreq.c @@ -209,6 +209,21 @@ static struct cpufreq_driver imx6q_cpufreq_driver = { .suspend = cpufreq_generic_suspend, }; +static inline int disable_freq_if_available(struct device *dev, + unsigned long freq) +{ + struct dev_pm_opp *opp; + int ret = 0; + + opp = dev_pm_opp_find_freq_exact(dev, freq, true); + if (!IS_ERR(opp)) { + dev_pm_opp_put(opp); + ret = dev_pm_opp_disable(dev, freq); + } + + return ret; +} + #define OCOTP_CFG3 0x440 #define OCOTP_CFG3_SPEED_SHIFT 16 #define OCOTP_CFG3_SPEED_1P2GHZ 0x3 @@ -254,16 +269,16 @@ static int imx6q_opp_check_speed_grading(struct device *dev) val &= 0x3; if (val < OCOTP_CFG3_SPEED_996MHZ) - if (dev_pm_opp_disable(dev, 996000000)) + if (disable_freq_if_available(dev, 996000000)) dev_warn(dev, "failed to disable 996MHz OPP\n"); if (of_machine_is_compatible("fsl,imx6q") || of_machine_is_compatible("fsl,imx6qp")) { if (val != OCOTP_CFG3_SPEED_852MHZ) - if (dev_pm_opp_disable(dev, 852000000)) + if (disable_freq_if_available(dev, 852000000)) dev_warn(dev, "failed to disable 852MHz OPP\n"); if (val != OCOTP_CFG3_SPEED_1P2GHZ) - if (dev_pm_opp_disable(dev, 1200000000)) + if (disable_freq_if_available(dev, 1200000000)) dev_warn(dev, "failed to disable 1.2GHz OPP\n"); } @@ -318,17 +333,17 @@ static int imx6ul_opp_check_speed_grading(struct device *dev) if (of_machine_is_compatible("fsl,imx6ul")) { if (val != OCOTP_CFG3_6UL_SPEED_696MHZ) - if (dev_pm_opp_disable(dev, 696000000)) + if (disable_freq_if_available(dev, 696000000)) dev_warn(dev, "failed to disable 696MHz OPP\n"); } if (of_machine_is_compatible("fsl,imx6ull")) { if (val != OCOTP_CFG3_6ULL_SPEED_792MHZ) - if (dev_pm_opp_disable(dev, 792000000)) + if (disable_freq_if_available(dev, 792000000)) dev_warn(dev, "failed to disable 792MHz OPP\n"); if (val != OCOTP_CFG3_6ULL_SPEED_900MHZ) - if (dev_pm_opp_disable(dev, 900000000)) + if (disable_freq_if_available(dev, 900000000)) dev_warn(dev, "failed to disable 900MHz OPP\n"); } -- 2.11.0