From patchwork Tue Apr 18 11:34:54 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Sumit Gupta X-Patchwork-Id: 13215499 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id F25F2C6FD18 for ; Tue, 18 Apr 2023 11:35:42 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231144AbjDRLfl (ORCPT ); Tue, 18 Apr 2023 07:35:41 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44802 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230202AbjDRLfl (ORCPT ); Tue, 18 Apr 2023 07:35:41 -0400 Received: from NAM11-CO1-obe.outbound.protection.outlook.com (mail-co1nam11on2074.outbound.protection.outlook.com [40.107.220.74]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A0055469E; Tue, 18 Apr 2023 04:35:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=DUNj5vumTytZRKOpmSaSVogDvqhgo7dJEYMDFXBaiVgNn0xMyk4/Gh4yPbNLMnFBmeg7R5rA1Mcyt5eKRsUhPBIkgi3I7WdJ7Hd+ZXYW1YJMG/AEvgSmje399FoZlt4Tpwr3Po77FzkMnSNeVDCRPxXcRVfygpA/uevz1NlMd3mg21ikMG/YnSHke+bBcv4q4z6ozuVm7xEsXFyvGI6P7/vEluuvKrxBjK5BUm31Lcyw3o22NPv77aQaoGE5ur+uA6NQZNytBN2kGmae7ID68evTNveXPND/PB7i6lIRjS26bGV5rf2K3LtpJ2x4r4YVlK60gi62doJbtNeQxKeUUw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=1qjly0cb5gRUnOWUNdQ4IjiJI21JtUnruafD2gDYLuA=; b=UODfieqaYNExSNOzTUkktAR6ky8Etid/WTDF1XjPg8fpCpybmap4sJ0kwFNSSPGpPh/ooveJWUvJI5k59l9+yhCMWkEl4tYnBdbtvgYfcgNN3FJ/RTrwJJJiHTR8CEaMqET4vaR75wVSEOLpahOUjlzgG+IOVEkCRrkD/CXXVtePTd0jgEGhcM6bdLT1enD1dMQKln7DrdW3flBaecuhm/ObeCxI6vSHG2rUkiEFLej2WSVwH+DzRcdSp64m5rUkcYa56l0+p8LZirZU5AgiZ1ERP1dahTp+BHj0U2jBSlS+tLFVo3YKGH2I89ts/enWXP0Km8/RRQj39G5mTVnYKw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 216.228.118.232) smtp.rcpttodomain=linaro.org smtp.mailfrom=nvidia.com; dmarc=pass (p=reject sp=reject pct=100) action=none header.from=nvidia.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=Nvidia.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=1qjly0cb5gRUnOWUNdQ4IjiJI21JtUnruafD2gDYLuA=; b=j6E/LajpyFTMm38SRu+plmFgxLkRnZpnVknBGDEcUM3hbvSUmZATLhk2lKgtgeUyUp/mH2E0gp/ZQTzOkGIl268nLnP61+zVox+gRmeSUUbnW9KG/rdhcI3pbNnxm/J7DkhpJC4TmDexc8NTE32yjVx6a5ntpAmaCG6EDaeu1yqJJ0kBzEcVmgXznEDPE9auZXED8lm/UmaEr5D1viW6KtEAv6AfaTeYv3jk0StJkt9lNvqbq+Jt7xgx6qWvw/VGA+Ublv6a3JzeTRWcMJ/2yw4a9Ew9xdsYfcqIfjHGvF7FHV8ifSNvjiTBO/9HLZO2xDaqTNupthLRFSWtjSpCGw== Received: from BN9PR03CA0347.namprd03.prod.outlook.com (2603:10b6:408:f6::22) by DS7PR12MB8323.namprd12.prod.outlook.com (2603:10b6:8:ec::19) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6298.45; Tue, 18 Apr 2023 11:35:37 +0000 Received: from BN8NAM11FT007.eop-nam11.prod.protection.outlook.com (2603:10b6:408:f6:cafe::1e) by BN9PR03CA0347.outlook.office365.com (2603:10b6:408:f6::22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6298.46 via Frontend Transport; Tue, 18 Apr 2023 11:35:37 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 216.228.118.232) smtp.mailfrom=nvidia.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=nvidia.com; Received-SPF: Pass (protection.outlook.com: domain of nvidia.com designates 216.228.118.232 as permitted sender) receiver=protection.outlook.com; client-ip=216.228.118.232; helo=mail.nvidia.com; pr=C Received: from mail.nvidia.com (216.228.118.232) by BN8NAM11FT007.mail.protection.outlook.com (10.13.177.109) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6319.20 via Frontend Transport; Tue, 18 Apr 2023 11:35:36 +0000 Received: from drhqmail203.nvidia.com (10.126.190.182) by mail.nvidia.com (10.127.129.5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.5; Tue, 18 Apr 2023 04:35:33 -0700 Received: from drhqmail202.nvidia.com (10.126.190.181) by drhqmail203.nvidia.com (10.126.190.182) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.37; Tue, 18 Apr 2023 04:35:32 -0700 Received: from sumitg-l4t.nvidia.com (10.127.8.10) by mail.nvidia.com (10.126.190.181) with Microsoft SMTP Server id 15.2.986.37 via Frontend Transport; Tue, 18 Apr 2023 04:35:28 -0700 From: Sumit Gupta To: , , , , , , , CC: , , , , , , , , , , , Subject: [Patch 1/6] cpufreq: use correct unit when verify cur freq Date: Tue, 18 Apr 2023 17:04:54 +0530 Message-ID: <20230418113459.12860-2-sumitg@nvidia.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20230418113459.12860-1-sumitg@nvidia.com> References: <20230418113459.12860-1-sumitg@nvidia.com> X-NVConfidentiality: public MIME-Version: 1.0 X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: BN8NAM11FT007:EE_|DS7PR12MB8323:EE_ X-MS-Office365-Filtering-Correlation-Id: 8705403d-37c3-4767-d523-08db400107b5 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: WE4LURFlPF93VDBtRL0ZceYPfGn2eNRuv5MkCyrV9BJJLG7XvH/p/HHiSwKXBs5iDoME8CgP+O+DYoGE/44Wj4xCnpYr0DffzLAAdSBA7E9srRD3IiYopprfAG9FFfcGUhCxjv99g+TtHrGE7WyZwQF4tJcZMlanxCDmnAnXb/EtDmXrejEVZ/bnK/dtXPvMfKb07o7Ile3BAmiX0jmJes9EB35WDlh3SqUr4WL0tW4QkVwk/tOZBc7mRb5C7ol65drWy87cLIptz2sFS2nU6jUqbTqB7jyoGD7pexVRpV+ShBr/b+jUnYHakNpepTUTgpGPqNBHdLpzizd1dG2orvajHXiUMZSKmb3aOohTP/JLaMQYBeRHIgPqZVt5ZwRk+eNihBKWYIxzwcVdmRK0hwv9mrZ6rnNp1WTA5bDPquMhvn01MzVGqXIDKE1tEcjN7JilfoCpslLsT0BWyTKtXXS7Ej/xLGg11yLoyuqblN64yaPYA1bBua6DhlFym/KwCfHufoiWc6o1SsPOr3g/y009kHo5jssihVJS1v/Oe6osfVldu9Vm0ki6wPxWHTVdPAJAPQHU6jdDxvwSma88lGc1VxiVfwp1V88RVsYriahPy7J4Ok+Czwp/HseZvrlSgxUD3nIF2Z6raYDCIjoYG89S2V9uZxHFYUY4JBB6BFl4gbiXEkmBjdPPFKxH3UA633oiKLYpS7510PNyQBe0gMc6QUQqjnDvXXhh74kk5WbnnE4YgbPUSFOdpBlXQi4G9LMYuTVbOo6lx6++2jExSEx0SltwT1/JPayd6dLEgts= X-Forefront-Antispam-Report: CIP:216.228.118.232;CTRY:US;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:mail.nvidia.com;PTR:dc7edge1.nvidia.com;CAT:NONE;SFS:(13230028)(4636009)(39860400002)(376002)(346002)(136003)(396003)(451199021)(40470700004)(46966006)(36840700001)(356005)(82740400003)(7696005)(7636003)(34020700004)(6666004)(40460700003)(110136005)(54906003)(2906002)(478600001)(40480700001)(83380400001)(426003)(336012)(47076005)(107886003)(186003)(2616005)(26005)(82310400005)(36860700001)(36756003)(4326008)(5660300002)(70586007)(316002)(7416002)(15650500001)(1076003)(70206006)(86362001)(41300700001)(8676002)(8936002);DIR:OUT;SFP:1101; X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 18 Apr 2023 11:35:36.9684 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 8705403d-37c3-4767-d523-08db400107b5 X-MS-Exchange-CrossTenant-Id: 43083d15-7273-40c1-b7db-39efd9ccc17a X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=43083d15-7273-40c1-b7db-39efd9ccc17a;Ip=[216.228.118.232];Helo=[mail.nvidia.com] X-MS-Exchange-CrossTenant-AuthSource: BN8NAM11FT007.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: DS7PR12MB8323 Precedence: bulk List-ID: X-Mailing-List: linux-pm@vger.kernel.org From: Sanjay Chandrashekara cpufreq_verify_current_freq checks if the frequency returned by the hardware has a slight delta with the valid frequency value last set and returns "policy->cur" if the delta is within "1 MHz". In the comparison, "policy->cur" is in "kHz" but it's compared against HZ_PER_MHZ. So, the comparison range becomes "1 GHz". Fix this by comparing against KHZ_PER_MHZ instead of HZ_PER_MHZ. Fixes: f55ae08c8987 ("cpufreq: Avoid unnecessary frequency updates due to mismatch") Signed-off-by: Sanjay Chandrashekara [ sumit gupta: Commit message update ] Signed-off-by: Sumit Gupta --- drivers/cpufreq/cpufreq.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/cpufreq/cpufreq.c b/drivers/cpufreq/cpufreq.c index 8b0509f89f1b..6b52ebe5a890 100644 --- a/drivers/cpufreq/cpufreq.c +++ b/drivers/cpufreq/cpufreq.c @@ -1732,7 +1732,7 @@ static unsigned int cpufreq_verify_current_freq(struct cpufreq_policy *policy, b * MHz. In such cases it is better to avoid getting into * unnecessary frequency updates. */ - if (abs(policy->cur - new_freq) < HZ_PER_MHZ) + if (abs(policy->cur - new_freq) < KHZ_PER_MHZ) return policy->cur; cpufreq_out_of_sync(policy, new_freq); From patchwork Tue Apr 18 11:34:55 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Sumit Gupta X-Patchwork-Id: 13215500 X-Patchwork-Delegate: viresh.linux@gmail.com Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 0C29EC77B78 for ; Tue, 18 Apr 2023 11:35:57 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230202AbjDRLfz (ORCPT ); Tue, 18 Apr 2023 07:35:55 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45102 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229627AbjDRLfy (ORCPT ); Tue, 18 Apr 2023 07:35:54 -0400 Received: from NAM12-MW2-obe.outbound.protection.outlook.com (mail-mw2nam12on2060.outbound.protection.outlook.com [40.107.244.60]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 9FB337DA9; Tue, 18 Apr 2023 04:35:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=UqOZ0vQ4BrQSf7TlrxXBruqNmERlapYetcFKN9aSXNOcEWEb0tLXHWSwWj1Y6FpgZf9WaO7j1eOCOnSEyhpU/7obzth29X6oARM3jGUi9ddZt/ggieQRCN7mMFFSNwzqm+HaTV0mdVUaTfrabIgxQ5tUhul8CAhnfDStPPLA/bvU3+MJOvgBECt8ZnE4c5vwY43cU1YLMdXBBU2DESmDZopScuyegdRnCgg3VI4UlwqTvdDM4y+o9fxxV1EPUWl0SwgJoQugSUT5I1ytil7nppDAl6YEJwZRv1rdGa3yGigZLNiHO+VVoX/QNGN3/AzxC5DKaMDq0kNAoOUSR+LprQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=+Y653bwi3M5aOq9x8QWV3YqXHIBfbVcGhKhc8M8w/8g=; b=RcK7hXxojjDWv2+jA8hYgOP0Dp0oBMVR0n7yNnF/9jUarkHJuEMZgqSwrYiifRzMpW0fdicopxFwo38EUVAbivgfapShs7G+0lzV6uFKFMsbvDbqYwM3X+dCOwlIdhbi/Hw6SXGZIX78ZVETJZrYyDNQIbrQhAFHO/lcLIGwhtHNUqM6L+HBQtX7g1vmBDimWdUSmY+DXgGPV0erTFtOfUyi5d+i2TkK3i20Lc7TaPaIuPbssH76MBkr8TQ8By1ZiIHS0gOktqc3nxzkfL4YK6biKsiGOWTS3fbY6r7AyfKcYfuG3sMw7/EZZ0zpP0CpbdYLnU8MY7VJ7OYRjhdhYw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 216.228.118.233) smtp.rcpttodomain=linaro.org smtp.mailfrom=nvidia.com; dmarc=pass (p=reject sp=reject pct=100) action=none header.from=nvidia.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=Nvidia.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=+Y653bwi3M5aOq9x8QWV3YqXHIBfbVcGhKhc8M8w/8g=; b=H/UU0CtaeATeaefAd2T0aUPQm2/X85o7N3kWXgkuNse/qnJMVITUW6FIuXflsa+WjYo2+ugGJIv76zUpZovparhpLLcGj7qShkbeoKsnRgrHqWvWZRLuoYORsdIY4qPVl7GjM8HgU89K0mHKDmRAS14b7HfqNAvCIae6SM7KbkxYQmeZiC/CJsiOPrx2oZU7w8utVWARmA96OgaBG9T3JcvEG9ulLqMmBC9wSzTgO3Fra8EumVpc3dI6uXWC45OuBmrI29NJ07s2x1iaAWe+Pyx/6fse2he61v7BUBoXc0vCFkL+AO/fic2Cfjt/NifoyfvDtvtOYl6WT2hgIk3k4A== Received: from DM6PR17CA0009.namprd17.prod.outlook.com (2603:10b6:5:1b3::22) by PH7PR12MB6539.namprd12.prod.outlook.com (2603:10b6:510:1f0::14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6298.45; Tue, 18 Apr 2023 11:35:45 +0000 Received: from DM6NAM11FT003.eop-nam11.prod.protection.outlook.com (2603:10b6:5:1b3:cafe::c6) by DM6PR17CA0009.outlook.office365.com (2603:10b6:5:1b3::22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6319.20 via Frontend Transport; Tue, 18 Apr 2023 11:35:45 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 216.228.118.233) smtp.mailfrom=nvidia.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=nvidia.com; Received-SPF: Pass (protection.outlook.com: domain of nvidia.com designates 216.228.118.233 as permitted sender) receiver=protection.outlook.com; client-ip=216.228.118.233; helo=mail.nvidia.com; pr=C Received: from mail.nvidia.com (216.228.118.233) by DM6NAM11FT003.mail.protection.outlook.com (10.13.173.162) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6319.20 via Frontend Transport; Tue, 18 Apr 2023 11:35:45 +0000 Received: from drhqmail201.nvidia.com (10.126.190.180) by mail.nvidia.com (10.127.129.6) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.5; Tue, 18 Apr 2023 04:35:43 -0700 Received: from drhqmail202.nvidia.com (10.126.190.181) by drhqmail201.nvidia.com (10.126.190.180) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.37; Tue, 18 Apr 2023 04:35:43 -0700 Received: from sumitg-l4t.nvidia.com (10.127.8.10) by mail.nvidia.com (10.126.190.181) with Microsoft SMTP Server id 15.2.986.37 via Frontend Transport; Tue, 18 Apr 2023 04:35:38 -0700 From: Sumit Gupta To: , , , , , , , CC: , , , , , , , , , , , Subject: [Patch 2/6] cpufreq: CPPC: make workaround apply code generic Date: Tue, 18 Apr 2023 17:04:55 +0530 Message-ID: <20230418113459.12860-3-sumitg@nvidia.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20230418113459.12860-1-sumitg@nvidia.com> References: <20230418113459.12860-1-sumitg@nvidia.com> X-NVConfidentiality: public MIME-Version: 1.0 X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DM6NAM11FT003:EE_|PH7PR12MB6539:EE_ X-MS-Office365-Filtering-Correlation-Id: 860a25bf-206c-438f-9a87-08db40010c9d X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 1yVfHm6lv8xr9aQ/Sfn64LGzjgZG/y2HD7cYhiMYMf1RvKJk/uk6pqwD1rraRUasHr/pu/uwPid7vvga/rMckFn1jI/BpxkOXPjJmcHEs7Fm7iV7FXKRXk2Xyp1mlEknq09dLLWpHRWMNohjkULT0lwlIfc3qPfl2OKwlT8jgRu/yLBu42sOOoq6y0o9CeyIsjmUznM0bRHPiEZjmtbZZ7gMx/F6aQZG1EJyOo3Us8Gz2aXymcQliU042ya1GRhjO9QzOo0LH9dN/3akRW2K9Y2YD/zgf49cKKXq6ocMZN5bnnBtbPUD/7utDhY4DiT7qxZeSLY4ZdgbohOsFFq8LoRwKzCdpsBmoYG/hGcyfiMQoDcSqqkc/qz3BDNlOVq7KOAxnxoYXzQ9pHd3ZjQvQjdnnuXqtAFM8V3vFxn2Eg/EWOgGevAM4B0rd4mm1M6cbN+PePgAQSeNs0hBB+qeQ+8XB2RZbx3CC5om7XN6phUXKoCvZNdBShaV2h+ehHjZ3D84GXeuVaA5Wf/yTOaodENruzVYss+HOIyS04+4NQ2FqnmzhvnvVf1Q4Ea/2nI0JbA9+RuT3sd69hDQSKcUve9is/0Sz/yoJuox53yJpYJCMzayUA4ddNC4ltBYMZkiUHOyVX+GGhVkkx+boMGWmoe1B/SLa2Ou2wuUERmeK+4LXEZyXe+JOqa1d3SyVFRa5qbAvQCCUO2qLVHYC4r3EskMqoJgcqydd+hKqR6uwO8a0Ck5kmF1HCw8Nt7MS+Tg90830/Us6+ZBf4O8bKY53LdTWGjU/nCbB28DscipbCG8SoO19KYikzCrqT98Up0S X-Forefront-Antispam-Report: CIP:216.228.118.233;CTRY:US;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:mail.nvidia.com;PTR:dc7edge2.nvidia.com;CAT:NONE;SFS:(13230028)(4636009)(396003)(136003)(346002)(376002)(39860400002)(451199021)(40470700004)(36840700001)(46966006)(7416002)(426003)(5660300002)(82310400005)(2616005)(336012)(47076005)(83380400001)(356005)(86362001)(186003)(26005)(7636003)(107886003)(82740400003)(1076003)(34020700004)(36860700001)(8936002)(8676002)(110136005)(54906003)(478600001)(40480700001)(6666004)(7696005)(41300700001)(316002)(40460700003)(36756003)(70206006)(4326008)(70586007)(2906002)(41533002);DIR:OUT;SFP:1101; X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 18 Apr 2023 11:35:45.2451 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 860a25bf-206c-438f-9a87-08db40010c9d X-MS-Exchange-CrossTenant-Id: 43083d15-7273-40c1-b7db-39efd9ccc17a X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=43083d15-7273-40c1-b7db-39efd9ccc17a;Ip=[216.228.118.233];Helo=[mail.nvidia.com] X-MS-Exchange-CrossTenant-AuthSource: DM6NAM11FT003.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: PH7PR12MB6539 Precedence: bulk List-ID: X-Mailing-List: linux-pm@vger.kernel.org Expand the code which applies SoC workarounds to make it generic and easy to reuse. Signed-off-by: Sumit Gupta --- drivers/cpufreq/cppc_cpufreq.c | 19 +++++++++++++++---- 1 file changed, 15 insertions(+), 4 deletions(-) diff --git a/drivers/cpufreq/cppc_cpufreq.c b/drivers/cpufreq/cppc_cpufreq.c index 022e3555407c..15c2cbb7a50e 100644 --- a/drivers/cpufreq/cppc_cpufreq.c +++ b/drivers/cpufreq/cppc_cpufreq.c @@ -43,10 +43,13 @@ static LIST_HEAD(cpu_data_list); static bool boost_supported; +static void cppc_check_hisi_workaround(void); + struct cppc_workaround_oem_info { char oem_id[ACPI_OEM_ID_SIZE + 1]; char oem_table_id[ACPI_OEM_TABLE_ID_SIZE + 1]; u32 oem_revision; + void (*apply_wa_func)(void); }; static struct cppc_workaround_oem_info wa_info[] = { @@ -54,10 +57,12 @@ static struct cppc_workaround_oem_info wa_info[] = { .oem_id = "HISI ", .oem_table_id = "HIP07 ", .oem_revision = 0, + .apply_wa_func = cppc_check_hisi_workaround, }, { .oem_id = "HISI ", .oem_table_id = "HIP08 ", .oem_revision = 0, + .apply_wa_func = cppc_check_hisi_workaround, } }; @@ -938,6 +943,13 @@ static unsigned int hisi_cppc_cpufreq_get_rate(unsigned int cpu) } static void cppc_check_hisi_workaround(void) +{ + /* Overwrite the get() callback */ + cppc_cpufreq_driver.get = hisi_cppc_cpufreq_get_rate; + fie_disabled = FIE_DISABLED; +} + +static void cppc_apply_workarounds(void) { struct acpi_table_header *tbl; acpi_status status = AE_OK; @@ -951,9 +963,8 @@ static void cppc_check_hisi_workaround(void) if (!memcmp(wa_info[i].oem_id, tbl->oem_id, ACPI_OEM_ID_SIZE) && !memcmp(wa_info[i].oem_table_id, tbl->oem_table_id, ACPI_OEM_TABLE_ID_SIZE) && wa_info[i].oem_revision == tbl->oem_revision) { - /* Overwrite the get() callback */ - cppc_cpufreq_driver.get = hisi_cppc_cpufreq_get_rate; - fie_disabled = FIE_DISABLED; + /* call work around function which matched from the table */ + wa_info[i].apply_wa_func(); break; } } @@ -968,7 +979,7 @@ static int __init cppc_cpufreq_init(void) if (!acpi_cpc_valid()) return -ENODEV; - cppc_check_hisi_workaround(); + cppc_apply_workarounds(); cppc_freq_invariance_init(); populate_efficiency_class(); From patchwork Tue Apr 18 11:34:56 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Sumit Gupta X-Patchwork-Id: 13215501 X-Patchwork-Delegate: viresh.linux@gmail.com Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 48F31C77B76 for ; Tue, 18 Apr 2023 11:36:24 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229721AbjDRLgW (ORCPT ); Tue, 18 Apr 2023 07:36:22 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45610 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229640AbjDRLgV (ORCPT ); Tue, 18 Apr 2023 07:36:21 -0400 Received: from NAM11-BN8-obe.outbound.protection.outlook.com (mail-bn8nam11on2041.outbound.protection.outlook.com [40.107.236.41]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7317B49D9; Tue, 18 Apr 2023 04:36:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=YHyneTFzgVhES651ixyh+5Qle9Zz8qT2H+nPcQG+5xnCtnr6RHu3t3gvFkjDXXnWlvtS2FKXGCj7WXREvpCkm4j4GtdXqlCs28reyAnyjzXEdPkGU7x9x82GU7PS/NlkgYS54t0DuwKISqL0N/1BubeHSyefKfUECcW17LBxDpguM87WmS9uFIykljr2biiDDdj9p6naPVN/15flDKkgvNhZaQxmU01iEXfdKSEdNqU1P3H1HbSWtMb8lx39krar9dmgAzqaAgYFTX7v8TBOY4bZttAEAdHhgk3yNrUmGM0FsGbPUyXvAMxZxlLZ8Y3+KJV1Xc17Q2DSwcN64hVG8g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=9k+bEkt5RDqztAdxzqxHIwHzJm6hMa7GABcVPzZ3aBI=; b=b719Mgjc0Mn7yb704pvIoaaM8SAchbGCuka54CHX1UBoCPF2NIDvxdmKrLfenDHfYHX4FIhDrs0krmMHELy6orhT45ygIwDMu0Vl8C3U9ijFcqsszJ2zhNGZ6iIjxdkEAcNpZw2+Tr5T7P++Z2zizMah159Zr6LTPAHfb7dnfA1kM7BVlt5lRdPWtHypZKUcyI4Q5UDcMQMrNjlWZGcsySH8FNShK81fxdivF0xiHNMBCJYY3pjZu4UsrvJo49PXAwoq6KSUn5Z/6z/6elz8LxMJRgqeUdv2wJyiOj/5AuWKbpS79MDapJuL7dwebVIbt/QFogecxaBwsIhMvgMq4w== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 216.228.118.232) smtp.rcpttodomain=linaro.org smtp.mailfrom=nvidia.com; dmarc=pass (p=reject sp=reject pct=100) action=none header.from=nvidia.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=Nvidia.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=9k+bEkt5RDqztAdxzqxHIwHzJm6hMa7GABcVPzZ3aBI=; b=Uaq9CLrR7cpGv/sshFHgKJMe4R/W1129ET85gzNBVCt+17w6b1NuCSj0s2ncpAhjzFE5TiSFJyWmeIMcXbzK5j8NmL2pTbI4rb8gnojXFBjlkL8L7aF7wB0+GOncQD1wNTv2od8L2+dNT7EK5MpewZQ4fLUGa2aVdS09nxIGebVy+tmV7fKUGrxmE84O0x+jOcM8+BGQx4pGjJa9xm2gok4Hy2psSkcYqiFGJTc53fZjqBF+JNmPm3/bQC24ZpiXV107qbhmn7IjHAE38ExFfS0WEkkaRAjFfGIsqjorqiKLerOW0ah1uTVxTB7HmBN5iznui0duTcWf93mYmx//LA== Received: from BN0PR02CA0060.namprd02.prod.outlook.com (2603:10b6:408:e5::35) by DS0PR12MB7677.namprd12.prod.outlook.com (2603:10b6:8:136::13) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6298.45; Tue, 18 Apr 2023 11:36:06 +0000 Received: from BN8NAM11FT050.eop-nam11.prod.protection.outlook.com (2603:10b6:408:e5:cafe::18) by BN0PR02CA0060.outlook.office365.com (2603:10b6:408:e5::35) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6298.47 via Frontend Transport; Tue, 18 Apr 2023 11:36:06 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 216.228.118.232) smtp.mailfrom=nvidia.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=nvidia.com; Received-SPF: Pass (protection.outlook.com: domain of nvidia.com designates 216.228.118.232 as permitted sender) receiver=protection.outlook.com; client-ip=216.228.118.232; helo=mail.nvidia.com; pr=C Received: from mail.nvidia.com (216.228.118.232) by BN8NAM11FT050.mail.protection.outlook.com (10.13.177.5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6319.20 via Frontend Transport; Tue, 18 Apr 2023 11:36:05 +0000 Received: from drhqmail201.nvidia.com (10.126.190.180) by mail.nvidia.com (10.127.129.5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.5; Tue, 18 Apr 2023 04:35:54 -0700 Received: from drhqmail202.nvidia.com (10.126.190.181) by drhqmail201.nvidia.com (10.126.190.180) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.37; Tue, 18 Apr 2023 04:35:53 -0700 Received: from sumitg-l4t.nvidia.com (10.127.8.10) by mail.nvidia.com (10.126.190.181) with Microsoft SMTP Server id 15.2.986.37 via Frontend Transport; Tue, 18 Apr 2023 04:35:48 -0700 From: Sumit Gupta To: , , , , , , , CC: , , , , , , , , , , , Subject: [Patch 3/6] irqchip/gicv3: Export arm_smccc_get_soc_id_xx funcs Date: Tue, 18 Apr 2023 17:04:56 +0530 Message-ID: <20230418113459.12860-4-sumitg@nvidia.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20230418113459.12860-1-sumitg@nvidia.com> References: <20230418113459.12860-1-sumitg@nvidia.com> X-NVConfidentiality: public MIME-Version: 1.0 X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: BN8NAM11FT050:EE_|DS0PR12MB7677:EE_ X-MS-Office365-Filtering-Correlation-Id: 9f8ab61c-bcb5-4082-8f5c-08db400118f4 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: uAxee32bW8mTzQtRktY3rVzZLGKRQDTL8RTKxlyOMqZtZWpwQuAn0iu1rIiRc+rF4P8chJESto3dGr+8rXuF3UaZceuDnwopJqvD0DeteaaBu7iLxZ0hHLr69wzul+ejhYm2jpycfqqwy58IWeBrYopl1avq91FYFkce+Lqz1c2jbdOv8LzDw2ee54CquldtHstTG0R+GdOqQOHhHtwDk+RegcArdng3EDbHcaoZCVPlNXtxkoRma0I8KmxwdChf/OV0/EEIVUTqfKzCTa4T0TNQvEcekiGZRJA/drspTmnukntYfNfX5wmhrcJzANES4wTamyfWPM8rTTkJnImSZ5T7xU+tpUeL2MzOfsqIPrgxFmLFQap/5/ZEbxfd3bpDBIuY9ecLZUfP7Skzru5U8Aq3ZlX301VuHjOQ1ENOX7ET6DqpM3HsNWNnt+x+JVpKRGFLTuAP4SOCYRVFzAM/CFtoOzwEpQF527esyhTFux2/Cml6VATOcfWRxIMHCbrsPp8Z4q0nPnks7wolYwAJf6LGTJyPLtZHGw34m1y/kpF3pOcm+VpqKWVNO2ghpuFw+huI5iNTHEfxtypTGKpiBNCVydfDBoqpXUm6G9BiCRgEPijywOicmi/839B5LRIhiLbfybL/TaKI0EUdMsBGdxLX0R1kLYKQudKAl6Aqn70ZfQKe4NYBXvV+OgKww9/RSxl4xu1b4JoNLW8LbAZp8Km0Cy2VXGBBpMcipvgDa4uQjVBNEIDspP0j0g9GqG5sgEAPGTbGpqZpNSiIUHi95HcPg+Vmg3PTRaxy+gliLMI= X-Forefront-Antispam-Report: CIP:216.228.118.232;CTRY:US;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:mail.nvidia.com;PTR:dc7edge1.nvidia.com;CAT:NONE;SFS:(13230028)(4636009)(376002)(396003)(39860400002)(136003)(346002)(451199021)(40470700004)(36840700001)(46966006)(26005)(1076003)(186003)(40460700003)(41300700001)(107886003)(82310400005)(110136005)(34020700004)(54906003)(40480700001)(86362001)(426003)(336012)(47076005)(2616005)(4326008)(316002)(70586007)(70206006)(36860700001)(4744005)(2906002)(7416002)(8676002)(8936002)(6666004)(7696005)(7636003)(82740400003)(356005)(36756003)(5660300002)(478600001);DIR:OUT;SFP:1101; X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 18 Apr 2023 11:36:05.9007 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 9f8ab61c-bcb5-4082-8f5c-08db400118f4 X-MS-Exchange-CrossTenant-Id: 43083d15-7273-40c1-b7db-39efd9ccc17a X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=43083d15-7273-40c1-b7db-39efd9ccc17a;Ip=[216.228.118.232];Helo=[mail.nvidia.com] X-MS-Exchange-CrossTenant-AuthSource: BN8NAM11FT050.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: DS0PR12MB7677 Precedence: bulk List-ID: X-Mailing-List: linux-pm@vger.kernel.org Export arm_smccc_get_soc_id_version() function which is needed in CPPC_CPUFREQ to check and apply workaround for Tegra241 SoC. Also, exporting arm_smccc_get_soc_id_revision() function as it might be needed in future. Signed-off-by: Sumit Gupta --- drivers/firmware/smccc/smccc.c | 2 ++ 1 file changed, 2 insertions(+) diff --git a/drivers/firmware/smccc/smccc.c b/drivers/firmware/smccc/smccc.c index db818f9dcb8e..b4224da46988 100644 --- a/drivers/firmware/smccc/smccc.c +++ b/drivers/firmware/smccc/smccc.c @@ -64,11 +64,13 @@ s32 arm_smccc_get_soc_id_version(void) { return smccc_soc_id_version; } +EXPORT_SYMBOL_GPL(arm_smccc_get_soc_id_version); s32 arm_smccc_get_soc_id_revision(void) { return smccc_soc_id_revision; } +EXPORT_SYMBOL_GPL(arm_smccc_get_soc_id_revision); static int __init smccc_devices_init(void) { From patchwork Tue Apr 18 11:34:57 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Sumit Gupta X-Patchwork-Id: 13215502 X-Patchwork-Delegate: viresh.linux@gmail.com Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 790D5C77B78 for ; Tue, 18 Apr 2023 11:36:28 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231356AbjDRLg1 (ORCPT ); Tue, 18 Apr 2023 07:36:27 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45660 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231327AbjDRLg0 (ORCPT ); Tue, 18 Apr 2023 07:36:26 -0400 Received: from NAM10-DM6-obe.outbound.protection.outlook.com (mail-dm6nam10on20602.outbound.protection.outlook.com [IPv6:2a01:111:f400:7e88::602]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C960A55AC; Tue, 18 Apr 2023 04:36:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=m7j80QvTpbCdzEWc1UH+ALqGlvCqJgcqeis5U2QORgcs6ajXdp2aOgjJO9gLTy+ny29b9ksKwDodINCm2kjHKtk4CvmULM188jVNGC2PHImv27oPeAlocVfoXAt8c+17VgnGLL+z3PEheuPvBuoNXRFv7f/3R5hfyqPStASurZxUbBWqvpl4AD/NAvaCJTBVonDWUnmiTk9B8k/JfqloS4DjDbk/RawCUEO1fO16zdRT1XM/0ay7ItpnRM/Jp0EPvrDkGa+BOj7hDX2ePE1ElBRnP4gi62sMMGyJs0Sb9CdYFK1APJBBFJRC9p0Ey0RkYx6o7qkZynbJ2rlKx2gqVQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=5ykCwYzo+l/9NAsygK+a1+QKJV6mGzFqPf5shfdBEvo=; b=GSniakyKnppGVKgdDYVXA2P73PuUBzlz9Q+WYSJjc3C7Fk6NOSUdFIcrLO5BBCTvqdguNmwec9B3GUDjWgFI9saqyJoej4AY9q8HXmpWeEwsseGF6zoGLaTxaZgx1lZS8nGk8ZO9MqvxsBCEbudFhu5t6uoGot0+C6ng8GEqdjeA1UQfOjp+ox1spznQTnEcXCfTcEmFmtBBMGq7nnWlTt/Nx6tqFL4dK4RQyEa2LBidoeInZKGUKZ0aGB3Fw+NGrx8Hbc0f0/bv6nbfyy20DiOBquze6qsfkGH88Hct+Rsur9pNf7XhBtCUxLBcOm6MeHKHdymB5eTuo7FX4SIw2A== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 216.228.118.232) smtp.rcpttodomain=linaro.org smtp.mailfrom=nvidia.com; dmarc=pass (p=reject sp=reject pct=100) action=none header.from=nvidia.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=Nvidia.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=5ykCwYzo+l/9NAsygK+a1+QKJV6mGzFqPf5shfdBEvo=; b=m7uMPR8dYCpUpuv8TP7jP/VHVRI+Eq2OGcnyMhsnEWx7RGXW684EjPqhFrnhqHdhDA74+UrGxi3emcmBcP2VEhE615fcaOC4/UNGdGb+CJ+vyFLi73mrGD+6WUgxkjKJ006BP76Xx6U5tvt9iTyNWOijSj4wnsvzhl6JHUzsBgfEz4tLWNy9T1v6/NbtqVf/DnPgCnPgWj0wDtyq1mmqrBZTUuQbua6F9Ue+rtFDbMjveoEzvRVa5ZeEAzG0fCg8j5dbpFwNSYYSd9A3LrVNvWQTnpp6oPJIq/8nKnXFf8Dwz9XnmUDqB11F9b3CxUZzsFG3vAXTz0iiXBYtSmO47A== Received: from BN0PR02CA0032.namprd02.prod.outlook.com (2603:10b6:408:e5::7) by IA1PR12MB8239.namprd12.prod.outlook.com (2603:10b6:208:3f7::19) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6298.30; Tue, 18 Apr 2023 11:36:09 +0000 Received: from BN8NAM11FT050.eop-nam11.prod.protection.outlook.com (2603:10b6:408:e5:cafe::1b) by BN0PR02CA0032.outlook.office365.com (2603:10b6:408:e5::7) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6298.47 via Frontend Transport; Tue, 18 Apr 2023 11:36:09 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 216.228.118.232) smtp.mailfrom=nvidia.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=nvidia.com; Received-SPF: Pass (protection.outlook.com: domain of nvidia.com designates 216.228.118.232 as permitted sender) receiver=protection.outlook.com; client-ip=216.228.118.232; helo=mail.nvidia.com; pr=C Received: from mail.nvidia.com (216.228.118.232) by BN8NAM11FT050.mail.protection.outlook.com (10.13.177.5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6319.20 via Frontend Transport; Tue, 18 Apr 2023 11:36:08 +0000 Received: from drhqmail201.nvidia.com (10.126.190.180) by mail.nvidia.com (10.127.129.5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.5; Tue, 18 Apr 2023 04:36:00 -0700 Received: from drhqmail202.nvidia.com (10.126.190.181) by drhqmail201.nvidia.com (10.126.190.180) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.37; Tue, 18 Apr 2023 04:35:59 -0700 Received: from sumitg-l4t.nvidia.com (10.127.8.10) by mail.nvidia.com (10.126.190.181) with Microsoft SMTP Server id 15.2.986.37 via Frontend Transport; Tue, 18 Apr 2023 04:35:55 -0700 From: Sumit Gupta To: , , , , , , , CC: , , , , , , , , , , , Subject: [Patch 4/6] cpufreq: CPPC: update sampling window for Tegra241 Date: Tue, 18 Apr 2023 17:04:57 +0530 Message-ID: <20230418113459.12860-5-sumitg@nvidia.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20230418113459.12860-1-sumitg@nvidia.com> References: <20230418113459.12860-1-sumitg@nvidia.com> X-NVConfidentiality: public MIME-Version: 1.0 X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: BN8NAM11FT050:EE_|IA1PR12MB8239:EE_ X-MS-Office365-Filtering-Correlation-Id: 54dba8fa-0b4a-42e6-60db-08db40011a93 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: sWLzIF/dyzrTctyvfFqGYEVvgHqq+rU8VXEL/gvNkUDM1zYvB/K5q+WB1048aHyLxX/GFNgnL1jyv2UP1D5S1x86aK0FRWOiCRSYXUR1MSphhTW74Zdxu/PlRR8Z5TdqlwcXt0MBYGCvctR2cDLH3iM95u0jzPHtOWH2ynzk8YsQ0rqvBtLvhDpGuhhZV7K2zul1hKSIH/ZDMlbkrZQUGxThNjG2nSQ0t0Vixv3FuhI3OS3DsKurLSLK60AX++7GmeoIynlpoReE7KeFQf1283+e8Hfnt3Pvh6cyp811sEPFbbtxgVz+uFVFRtbqKT/jR44D5N4mICeoUFjgxfF32SxRwCIT+ZlL57krFthKdt/cFho56QJHlG3H7xu8P0oBpHosMDInAoTCc5xNVJlTzOyJvR1zwkW7DVZqKXwMP/LD5Lt/0oKeBZPb5TGm2QjZLyVv1uqCtt3Er93Ulj6Z8zYv6d/9OyspvBwnir+QocwDoLpP1bZ/A8UK1gvucD/MRh0AIGLfuP1z42AoqKrCUqzlJaNg92hVNXvzJugHw8yhP0ze/rH6wBqAEw1+TKGgg1DrcoUH7eS7YMJ5w+gVfn81v1054465mJCglw1TSXfN8Oaf53wDM9VYJ0kj+pRISJwmgvrb5+l909L+kVXjeiGMGsgOaPX2wC4qIKvqFmUNCMoOBRe6ooe8eH2lIyWwsu9WRIPRhgEhZfUR5DYqjp7oeqiRTEaLbtmqTEuauX3UCp/HXwrdvYB6QP7lrfAOGIEKGOtpTxcwoogSO3B4kHkHLmT/AUu9wEraRQ0i9Mk= X-Forefront-Antispam-Report: CIP:216.228.118.232;CTRY:US;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:mail.nvidia.com;PTR:dc7edge1.nvidia.com;CAT:NONE;SFS:(13230028)(4636009)(396003)(39860400002)(376002)(346002)(136003)(451199021)(36840700001)(46966006)(40470700004)(36756003)(54906003)(110136005)(4326008)(316002)(70586007)(70206006)(478600001)(7696005)(40480700001)(82310400005)(8936002)(8676002)(5660300002)(41300700001)(2906002)(7416002)(82740400003)(34020700004)(356005)(86362001)(7636003)(426003)(336012)(2616005)(1076003)(26005)(107886003)(186003)(40460700003)(36860700001)(47076005)(83380400001);DIR:OUT;SFP:1101; X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 18 Apr 2023 11:36:08.6037 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 54dba8fa-0b4a-42e6-60db-08db40011a93 X-MS-Exchange-CrossTenant-Id: 43083d15-7273-40c1-b7db-39efd9ccc17a X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=43083d15-7273-40c1-b7db-39efd9ccc17a;Ip=[216.228.118.232];Helo=[mail.nvidia.com] X-MS-Exchange-CrossTenant-AuthSource: BN8NAM11FT050.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: IA1PR12MB8239 Precedence: bulk List-ID: X-Mailing-List: linux-pm@vger.kernel.org In Tegra241, the Activity Monitor Unit's (AMU) constant counter (i.e. reference clock counter) increment happens in bursts and not incremented in the steps of one. For example reference counter may increment by '0x20' every '32' periods of ARM periphclk. This quantization of the reference counter is a source of error when reconstructing the frequency from the AMU counter data. To fix, increase the observation time interval so the error percentage becomes less. Signed-off-by: Sumit Gupta --- drivers/cpufreq/cppc_cpufreq.c | 29 ++++++++++++++++++++++++++++- 1 file changed, 28 insertions(+), 1 deletion(-) diff --git a/drivers/cpufreq/cppc_cpufreq.c b/drivers/cpufreq/cppc_cpufreq.c index 15c2cbb7a50e..5e6a132a525e 100644 --- a/drivers/cpufreq/cppc_cpufreq.c +++ b/drivers/cpufreq/cppc_cpufreq.c @@ -43,12 +43,17 @@ static LIST_HEAD(cpu_data_list); static bool boost_supported; +/* default 2usec delay between sampling */ +static unsigned int sampling_delay_us = 2; + static void cppc_check_hisi_workaround(void); +static void cppc_nvidia_workaround(void); struct cppc_workaround_oem_info { char oem_id[ACPI_OEM_ID_SIZE + 1]; char oem_table_id[ACPI_OEM_TABLE_ID_SIZE + 1]; u32 oem_revision; + u32 smcc_soc_id; void (*apply_wa_func)(void); }; @@ -63,6 +68,10 @@ static struct cppc_workaround_oem_info wa_info[] = { .oem_table_id = "HIP08 ", .oem_revision = 0, .apply_wa_func = cppc_check_hisi_workaround, + }, { + .oem_id = "NVIDIA", + .smcc_soc_id = 0x036b0241, /* JEP106 code for NVIDIA T241 chip (036b:0241) */ + .apply_wa_func = cppc_nvidia_workaround, } }; @@ -856,7 +865,7 @@ static unsigned int cppc_cpufreq_get_rate(unsigned int cpu) if (ret) return ret; - udelay(2); /* 2usec delay between sampling */ + udelay(sampling_delay_us); ret = cppc_get_perf_ctrs(cpu, &fb_ctrs_t1); if (ret) @@ -942,6 +951,11 @@ static unsigned int hisi_cppc_cpufreq_get_rate(unsigned int cpu) return cppc_cpufreq_perf_to_khz(cpu_data, desired_perf); } +static void cppc_nvidia_workaround(void) +{ + sampling_delay_us = 25; +} + static void cppc_check_hisi_workaround(void) { /* Overwrite the get() callback */ @@ -953,8 +967,21 @@ static void cppc_apply_workarounds(void) { struct acpi_table_header *tbl; acpi_status status = AE_OK; + s32 soc_id; int i; +#ifdef CONFIG_HAVE_ARM_SMCCC_DISCOVERY + for (i = 0; i < ARRAY_SIZE(wa_info); i++) { + if (wa_info[i].smcc_soc_id) { + soc_id = arm_smccc_get_soc_id_version(); + if (wa_info[i].smcc_soc_id == soc_id) { + wa_info[i].apply_wa_func(); + return; + } + } + } +#endif + status = acpi_get_table(ACPI_SIG_PCCT, 0, &tbl); if (ACPI_FAILURE(status) || !tbl) return; From patchwork Tue Apr 18 11:34:58 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Sumit Gupta X-Patchwork-Id: 13215503 X-Patchwork-Delegate: viresh.linux@gmail.com Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id D3200C77B76 for ; Tue, 18 Apr 2023 11:36:39 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231420AbjDRLgi (ORCPT ); Tue, 18 Apr 2023 07:36:38 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45952 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231472AbjDRLgf (ORCPT ); Tue, 18 Apr 2023 07:36:35 -0400 Received: from NAM10-DM6-obe.outbound.protection.outlook.com (mail-dm6nam10on2057.outbound.protection.outlook.com [40.107.93.57]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E9E7976AF; Tue, 18 Apr 2023 04:36:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=ChN8CQRlZigFgOSF+gy/4OuKzzzpqYHGcWxsK/DhW0e39WIPoUqo4w5vRpxydX85RNkjpathOBbJ+JFLXzlrvQFzMJAOZfgl3zAGbo05ZEI0yKDw12HAMy9qmbF0R/O0K0L0fsSSg8+lHTEHC4SmhYllcg6hf+V+dQAku7Ci519L1Xa5w7JKDa6XsSXNG4NFr/r9ebuUHfVREh0ZcuRJX/3bIRQQbct0Q58xc/icgARmrqKlB/L+TgxWTvBsjPqx19ABW7KDjdQ/O0pyiBPkAHYw6IeXwUsgBCs91df2zFNLceex0S/+8RO6uUrLr0ajxMxhGefKM+8aNRr2ZCcqMQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=/rahqSi0lxKjo4ecE7XdMLzWetALNSJxu0JOZbNFBoU=; b=FFbKNjSq4334oNq1JrCGCu3zpifc8QbvJNraXzepXsZ2jZc+r8zsKF/JhcvQ7Nj30PzkiZP6xt3z1X69BlLBoLGF6SH4z8ti50M9a+owX/ZgWEybbAsV4UHvbIie1Pi4NnZZoco0LNZ0zCMLQwHc+3WRYkViTtOx9/O6dmPKf96j7YElZhn5NG21KZuXplvdvbgMLOOTbnMkDxpxzAvPI0fmT0T+Y9q7IrP0cGQbPV2498s4S3Ee0Iv+ZV4XE48pX6uu0PU70dIXRCyVUy1Ve0q0MH7lFtTDbxzlZo9hUTT9dc1E4S+i/VSIcjYBSXIFKZ5Nm0Ej+OOnLPgTY2eBRA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 216.228.118.233) smtp.rcpttodomain=linaro.org smtp.mailfrom=nvidia.com; dmarc=pass (p=reject sp=reject pct=100) action=none header.from=nvidia.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=Nvidia.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=/rahqSi0lxKjo4ecE7XdMLzWetALNSJxu0JOZbNFBoU=; b=DNNYZXYbeOeoBXsgBX4Py2NaVMsoMcjFn0Xz1G55woI3Fqi9GQAgRnAX/pFkSc+5zBz/HFS5jKBxZphzsKZHjTXUQEj6BthQwX6vmbj4wB5UHsTJT83hV+Gtbt/jPbqiWbbv3BUyRqTisy2iXXFWM62hRsI4x0c0aUjFIB/jm3AS8bt8fdXD83KNuGFZIWOZxI4g/WippnwWNhfnuY0nLi7BSgW94+Ich0GmCosLonblf7gdF1FStGBZVqS7SUCTd8kFlVDoHVcxN9KDt9B5Gl0xV07AquMQp3ntiNEDytcbMZ8652rOSxQ5UZ9895LBA0pvsWyZlN705ArsytgaCg== Received: from DM6PR06CA0102.namprd06.prod.outlook.com (2603:10b6:5:336::35) by PH8PR12MB6914.namprd12.prod.outlook.com (2603:10b6:510:1cb::21) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6298.45; Tue, 18 Apr 2023 11:36:14 +0000 Received: from DM6NAM11FT033.eop-nam11.prod.protection.outlook.com (2603:10b6:5:336:cafe::bf) by DM6PR06CA0102.outlook.office365.com (2603:10b6:5:336::35) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6319.20 via Frontend Transport; Tue, 18 Apr 2023 11:36:14 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 216.228.118.233) smtp.mailfrom=nvidia.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=nvidia.com; Received-SPF: Pass (protection.outlook.com: domain of nvidia.com designates 216.228.118.233 as permitted sender) receiver=protection.outlook.com; client-ip=216.228.118.233; helo=mail.nvidia.com; pr=C Received: from mail.nvidia.com (216.228.118.233) by DM6NAM11FT033.mail.protection.outlook.com (10.13.172.221) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6319.20 via Frontend Transport; Tue, 18 Apr 2023 11:36:14 +0000 Received: from drhqmail201.nvidia.com (10.126.190.180) by mail.nvidia.com (10.127.129.6) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.5; Tue, 18 Apr 2023 04:36:12 -0700 Received: from drhqmail202.nvidia.com (10.126.190.181) by drhqmail201.nvidia.com (10.126.190.180) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.37; Tue, 18 Apr 2023 04:36:11 -0700 Received: from sumitg-l4t.nvidia.com (10.127.8.10) by mail.nvidia.com (10.126.190.181) with Microsoft SMTP Server id 15.2.986.37 via Frontend Transport; Tue, 18 Apr 2023 04:36:07 -0700 From: Sumit Gupta To: , , , , , , , CC: , , , , , , , , , , , Subject: [Patch 5/6] arm64: cpufeature: Export get_cpu_with_amu_feat func Date: Tue, 18 Apr 2023 17:04:58 +0530 Message-ID: <20230418113459.12860-6-sumitg@nvidia.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20230418113459.12860-1-sumitg@nvidia.com> References: <20230418113459.12860-1-sumitg@nvidia.com> X-NVConfidentiality: public MIME-Version: 1.0 X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DM6NAM11FT033:EE_|PH8PR12MB6914:EE_ X-MS-Office365-Filtering-Correlation-Id: 1831378e-dd9b-4a39-b9e7-08db40011df0 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: JlnWLich6hJsPjApHLubZ3Z0GUiKAZ5DFIbbjpfNIMt/oPjW5PJHJmZf1aL/4DdmqoSq99oOHdLpd6vIPnFcy4LPmFGQsAZG7dtW1+h4xG2RUJtMJbNd3n3qRCMJjJgnKtn7/bCsC1nnbwoZo84yamRaQ6cHCtD3RV+YtZOzUmtjrxzn4wkqFCdsySePg67zJ+tW6RdhkGd9rByDCExCGeXilCLw2cfzv290qqdgXENhXNmOopPArSShDzeRMTs6W1gVCVtRm8rYZDYZVxKfP21cujtxzFp2XCkdiZF8s8iJuO/dDpchZ+327zrgcz6H7AZ0qfI2K6iTlwNZUcuYFo7j8qRXPNcVZF29qjF8Yem6yPbog31DD3cNgoy+nkrJH0vSb7UyPrC5ak3iZ75zDmSgJuI7qOhcEy8b8z5Foq1hLqRnHNl3+PUrdZZSItqLRPT5QjNOnt3fQla/vwmxSqAbU2p5jVdb7C1ZHE3BaTaD4WkU2ergSjlWEFlexejFblcunz1CKUrAL5dkP1ZqRDHusv4qz6fE4YQwqW+4rVEIOA7QV4TG0GgzRat0KmOH9ptlcmHQsh/pZU1/UROJMaPwGoM3PU9Zg4qAB4B+6gySDuZFlJrBapojfbLse8ivCoNaTj/Z9agmxifFrkc3PJIvChZSfdhsBDRDcEmRewt5u+HcrNk8Cc5Z5smfL2IvjeMSfd/oYM4lB3Bea+hqb33kyIEIj2E9JIQCymIVN0LM68U5NTToKsu3ykHD7Q+NcTOyPf+U1wd7gCjr1bIS53ow/m87m7/8jIhC6+F7lhs= X-Forefront-Antispam-Report: CIP:216.228.118.233;CTRY:US;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:mail.nvidia.com;PTR:dc7edge2.nvidia.com;CAT:NONE;SFS:(13230028)(4636009)(376002)(396003)(136003)(39860400002)(346002)(451199021)(46966006)(36840700001)(40470700004)(36756003)(4326008)(110136005)(54906003)(316002)(70586007)(70206006)(7696005)(478600001)(6666004)(41300700001)(5660300002)(82310400005)(8676002)(8936002)(40480700001)(2906002)(7416002)(4744005)(34020700004)(82740400003)(86362001)(356005)(426003)(2616005)(336012)(107886003)(40460700003)(1076003)(26005)(186003)(36860700001)(47076005)(7636003);DIR:OUT;SFP:1101; X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 18 Apr 2023 11:36:14.3267 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 1831378e-dd9b-4a39-b9e7-08db40011df0 X-MS-Exchange-CrossTenant-Id: 43083d15-7273-40c1-b7db-39efd9ccc17a X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=43083d15-7273-40c1-b7db-39efd9ccc17a;Ip=[216.228.118.233];Helo=[mail.nvidia.com] X-MS-Exchange-CrossTenant-AuthSource: DM6NAM11FT033.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: PH8PR12MB6914 Precedence: bulk List-ID: X-Mailing-List: linux-pm@vger.kernel.org Export the get_cpu_with_amu_feat() function for use by "cppc_cpufreq" to check if any CPU implements ARM's Activity Monitor Unit (AMU). If AMU is available, then for re-constructing the current CPU freq from its counters, queue work on target CPU to read the counters in a single call instead of reading them in separate smp calls. Signed-off-by: Sumit Gupta --- arch/arm64/kernel/cpufeature.c | 1 + 1 file changed, 1 insertion(+) diff --git a/arch/arm64/kernel/cpufeature.c b/arch/arm64/kernel/cpufeature.c index d9345e9c0226..ec31da7043eb 100644 --- a/arch/arm64/kernel/cpufeature.c +++ b/arch/arm64/kernel/cpufeature.c @@ -1917,6 +1917,7 @@ int get_cpu_with_amu_feat(void) { return cpumask_any(&amu_cpus); } +EXPORT_SYMBOL_GPL(get_cpu_with_amu_feat); static void cpu_amu_enable(struct arm64_cpu_capabilities const *cap) { From patchwork Tue Apr 18 11:34:59 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Sumit Gupta X-Patchwork-Id: 13215504 X-Patchwork-Delegate: viresh.linux@gmail.com Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 64901C77B7D for ; Tue, 18 Apr 2023 11:36:42 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231496AbjDRLgk (ORCPT ); Tue, 18 Apr 2023 07:36:40 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46008 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231455AbjDRLgg (ORCPT ); Tue, 18 Apr 2023 07:36:36 -0400 Received: from NAM10-DM6-obe.outbound.protection.outlook.com (mail-dm6nam10on2067.outbound.protection.outlook.com [40.107.93.67]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 42C0B49DB; Tue, 18 Apr 2023 04:36:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=BGqeI3Tkak1vucWq3OxDxA+OJSoKJq4oxzbybBP+RWW+8OYBCOeelD6zhHiOKSZikRHhemJpgCZQEQUPID6Vz4Dxc4RTbGPMI+3rbbG+fzr/CNV4IgTEgz/b4RlzpUPq/hCl7AEGfn/uAOWA0X36BiZjvXZEAt4s/goHkoy9LcSqvBGIGwBwQgyGgF5/e+jbfmzJkxqCkXy9Z414VosMPaOmdnsozMa7+d+tF+tfQQ281YE7zA+e4sme4PhQPcL4WZteuW2HggS++jyN0uwTLS7uWoCU5gAHiAbb/zmxtwArPPq7HEBk36Dc/mcZzadDpqyV8HPCyO9QgAOxaaL3uQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=bUt+6/5XC1OaGh7iuH+Z/LJrw1UWkzVE+H6FlLwW0qM=; b=d6ophGo0qBZMOGTjZ4HN8e+oPTATAbKEFkCagPHNsNlkEPRhc9wDjdLTHrW7UNe/h5utnf9eBB0fJ7wIWgPcZm2l68dfSoJkthUGYZcok9OZ/UB/r5OCSW3iSVf4/A+RZ1EUVZZzOLX/ww2ezK/hxEMFLs3uxTeiQeIJevuF/2soDSk+87FaQ1ppgErcMi/Lq15YtJemhiaHvGLitCokRezrR27LmUZWX/nsyi0fp8sggy484NQ+2RrskC5xK2FBH9E/anzxnp1tlKooeBsFHHXxp8BoF7/UlPK9HmVo26siBf28dNpenauUseGxdb5HUVofO1GSCeDjyelBWy1UIQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 216.228.118.233) smtp.rcpttodomain=linaro.org smtp.mailfrom=nvidia.com; dmarc=pass (p=reject sp=reject pct=100) action=none header.from=nvidia.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=Nvidia.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=bUt+6/5XC1OaGh7iuH+Z/LJrw1UWkzVE+H6FlLwW0qM=; b=fMSo8o/B7PGSC5yo1eNmmxCIFHq+8gtfxJno1y7HGw9oWw8pEeXoYkLrBdIBVG93f3I3TJG2ZfiYMHjXOZYY21nSz3+f7Fbs2kZRcxLB8J/FQDo3V1oBWjmkGI4o47pFMoA7jMNC5dAA1XlGGl8pXE3ObR26JmKWh7S8OKcuGT3KANl2mZvvmqNzxqhV5eMDgquOqH9XrUTZ7q8NJZ8LqnDgoeFKUThaJZnu7MeR/gmr8gmukMAhPIhdGucI8lBgGZ3GYPiOWI5vdd96ENIo20/5GwbXGMGnozIfPX/WnuEf68xFQ1VjIl0CA+GezClPi8EqXeuHnaGrXGgKMVQAnw== Received: from DM5PR07CA0101.namprd07.prod.outlook.com (2603:10b6:4:ae::30) by DS7PR12MB5767.namprd12.prod.outlook.com (2603:10b6:8:76::22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6319.20; Tue, 18 Apr 2023 11:36:23 +0000 Received: from DM6NAM11FT098.eop-nam11.prod.protection.outlook.com (2603:10b6:4:ae:cafe::58) by DM5PR07CA0101.outlook.office365.com (2603:10b6:4:ae::30) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6319.20 via Frontend Transport; Tue, 18 Apr 2023 11:36:23 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 216.228.118.233) smtp.mailfrom=nvidia.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=nvidia.com; Received-SPF: Pass (protection.outlook.com: domain of nvidia.com designates 216.228.118.233 as permitted sender) receiver=protection.outlook.com; client-ip=216.228.118.233; helo=mail.nvidia.com; pr=C Received: from mail.nvidia.com (216.228.118.233) by DM6NAM11FT098.mail.protection.outlook.com (10.13.173.61) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.6319.20 via Frontend Transport; Tue, 18 Apr 2023 11:36:23 +0000 Received: from drhqmail203.nvidia.com (10.126.190.182) by mail.nvidia.com (10.127.129.6) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.5; Tue, 18 Apr 2023 04:36:18 -0700 Received: from drhqmail202.nvidia.com (10.126.190.181) by drhqmail203.nvidia.com (10.126.190.182) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.37; Tue, 18 Apr 2023 04:36:18 -0700 Received: from sumitg-l4t.nvidia.com (10.127.8.10) by mail.nvidia.com (10.126.190.181) with Microsoft SMTP Server id 15.2.986.37 via Frontend Transport; Tue, 18 Apr 2023 04:36:13 -0700 From: Sumit Gupta To: , , , , , , , CC: , , , , , , , , , , , Subject: [Patch 6/6] cpufreq: CPPC: use wq to read amu counters on target cpu Date: Tue, 18 Apr 2023 17:04:59 +0530 Message-ID: <20230418113459.12860-7-sumitg@nvidia.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20230418113459.12860-1-sumitg@nvidia.com> References: <20230418113459.12860-1-sumitg@nvidia.com> X-NVConfidentiality: public MIME-Version: 1.0 X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DM6NAM11FT098:EE_|DS7PR12MB5767:EE_ X-MS-Office365-Filtering-Correlation-Id: 9409800e-d1b8-4413-9990-08db4001233d X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: v/J4rRkBFY9ugXe3zIplEb2pH+4QT+tdN/F+xAZ75WLxCTJGcl1e3cB7QDMMCXifetWXg5TDltKry2WxECRubPP/GqZ73FpnDefL8WS30AfrDDSHcUcEpIv3LWAwDUyd9+hK3UMcsdWn1kzcOYpaUkq+DcKnreGHJ8I+YWEAr4UGV20XuyWd7tmfqyj267QbL3zgG69UDveeOejK3cDiER5t2cSuyzw92BG70mVap3QvuwAmWq4GGaV8nVxAz9bL2CsdkvX7aXyGy5y8zryw507hu4TJTvgDb/3LO7yHN5od7kv3EowZWofymOhDhiRhwciMS0YvaJyHw8cNhdDKWoCV/IKqx6Q4wNG7VI7EtJZlMETn3QUCNfjEfxbpaIb4AQ82tnktz+5UZLjLTI2WybB3uIzvTj3uVqIanOlw1er4BlMOsB/ASPBcC3uY2gFM+fX46OT0sCuChIi4QtSYBW6Ss6dPwYvqXvdoq4Wv9qyf9P5nQmVJFI1lXimD7yzZYeATmmLZf27vFx5GqgCO22S874tmSm3ltBp7PH8ssVkPiZ3+Lo3h3D4pbFFFIEe/K+EnuG9D9ETEPPstyTjvx4ESfsMeKvz0FV8Phgs5fRcE2mf9LUMfl4W1R247dm5wScBPY9+jAeJ4/wPAoJzBRYMxN+R3T77WFQ5IzM2u4H+YrIPHAAcSivcrmBg8GveyjwlP43w1O7daInQnuGs/hzMagpKYCjwHQWSqG7WTZdV7UOyI897nqgRQ/H052oJ0iOkHWRYBVZ5AAJv7deLZRdZHIEP+ZT5/AM6UnUVv7A4= X-Forefront-Antispam-Report: CIP:216.228.118.233;CTRY:US;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:mail.nvidia.com;PTR:dc7edge2.nvidia.com;CAT:NONE;SFS:(13230028)(4636009)(376002)(136003)(396003)(346002)(39860400002)(451199021)(40470700004)(36840700001)(46966006)(2906002)(34020700004)(2616005)(36860700001)(40460700003)(478600001)(6666004)(86362001)(82310400005)(26005)(1076003)(107886003)(7696005)(186003)(36756003)(40480700001)(426003)(336012)(41300700001)(82740400003)(356005)(7636003)(54906003)(8936002)(8676002)(47076005)(110136005)(316002)(70586007)(70206006)(83380400001)(4326008)(5660300002)(7416002);DIR:OUT;SFP:1101; X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 18 Apr 2023 11:36:23.2191 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 9409800e-d1b8-4413-9990-08db4001233d X-MS-Exchange-CrossTenant-Id: 43083d15-7273-40c1-b7db-39efd9ccc17a X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=43083d15-7273-40c1-b7db-39efd9ccc17a;Ip=[216.228.118.233];Helo=[mail.nvidia.com] X-MS-Exchange-CrossTenant-AuthSource: DM6NAM11FT098.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: DS7PR12MB5767 Precedence: bulk List-ID: X-Mailing-List: linux-pm@vger.kernel.org ARM cores which implement the Activity Monitor Unit (AMU) use Functional Fixed Hardware (FFH) to map AMU counters to Delivered_Counter and Reference_Counter registers. Each sysreg is read separately with a smp_call_function_single call. So, total four IPI's are used, one per register. Due to this, the AMU's core counter and constant counter sampling can happen at a non-consistent time interval if an IPI is handled late. This results in unstable frequency value from "cpuinfo_cur_req" node sometimes. To fix, queue work on target CPU to read all counters synchronously in sequence. This helps to remove the inter-IPI latency and make sure that both the counters are sampled at a close time interval. Without this change we observed that the re-generated value of CPU Frequency from AMU counters sometimes deviates by ~25% as the counters are read at non-determenistic time. Currently, kept the change specific to Tegra241. It can be applied to other SoC's having AMU if same issue is observed. Signed-off-by: Sumit Gupta --- drivers/cpufreq/cppc_cpufreq.c | 53 +++++++++++++++++++++++++++------- 1 file changed, 43 insertions(+), 10 deletions(-) diff --git a/drivers/cpufreq/cppc_cpufreq.c b/drivers/cpufreq/cppc_cpufreq.c index 5e6a132a525e..52b93ac6225e 100644 --- a/drivers/cpufreq/cppc_cpufreq.c +++ b/drivers/cpufreq/cppc_cpufreq.c @@ -46,6 +46,8 @@ static bool boost_supported; /* default 2usec delay between sampling */ static unsigned int sampling_delay_us = 2; +static bool get_rate_use_wq; + static void cppc_check_hisi_workaround(void); static void cppc_nvidia_workaround(void); @@ -99,6 +101,12 @@ struct cppc_freq_invariance { static DEFINE_PER_CPU(struct cppc_freq_invariance, cppc_freq_inv); static struct kthread_worker *kworker_fie; +struct feedback_ctrs { + u32 cpu; + struct cppc_perf_fb_ctrs fb_ctrs_t0; + struct cppc_perf_fb_ctrs fb_ctrs_t1; +}; + static unsigned int hisi_cppc_cpufreq_get_rate(unsigned int cpu); static int cppc_perf_from_fbctrs(struct cppc_cpudata *cpu_data, struct cppc_perf_fb_ctrs *fb_ctrs_t0, @@ -851,28 +859,44 @@ static int cppc_perf_from_fbctrs(struct cppc_cpudata *cpu_data, return (reference_perf * delta_delivered) / delta_reference; } +static int cppc_get_perf_ctrs_sync(void *fb_ctrs) +{ + struct feedback_ctrs *ctrs = fb_ctrs; + int ret; + + ret = cppc_get_perf_ctrs(ctrs->cpu, &(ctrs->fb_ctrs_t0)); + if (ret) + return ret; + + udelay(sampling_delay_us); + + ret = cppc_get_perf_ctrs(ctrs->cpu, &(ctrs->fb_ctrs_t1)); + if (ret) + return ret; + + return ret; +} + static unsigned int cppc_cpufreq_get_rate(unsigned int cpu) { - struct cppc_perf_fb_ctrs fb_ctrs_t0 = {0}, fb_ctrs_t1 = {0}; struct cpufreq_policy *policy = cpufreq_cpu_get(cpu); struct cppc_cpudata *cpu_data = policy->driver_data; + struct feedback_ctrs fb_ctrs = {0}; u64 delivered_perf; int ret; cpufreq_cpu_put(policy); + fb_ctrs.cpu = cpu; - ret = cppc_get_perf_ctrs(cpu, &fb_ctrs_t0); - if (ret) - return ret; - - udelay(sampling_delay_us); - - ret = cppc_get_perf_ctrs(cpu, &fb_ctrs_t1); + if (get_rate_use_wq) + ret = smp_call_on_cpu(cpu, cppc_get_perf_ctrs_sync, &fb_ctrs, false); + else + ret = cppc_get_perf_ctrs_sync(&fb_ctrs); if (ret) return ret; - delivered_perf = cppc_perf_from_fbctrs(cpu_data, &fb_ctrs_t0, - &fb_ctrs_t1); + delivered_perf = cppc_perf_from_fbctrs(cpu_data, &(fb_ctrs.fb_ctrs_t0), + &(fb_ctrs.fb_ctrs_t1)); return cppc_cpufreq_perf_to_khz(cpu_data, delivered_perf); } @@ -953,7 +977,16 @@ static unsigned int hisi_cppc_cpufreq_get_rate(unsigned int cpu) static void cppc_nvidia_workaround(void) { + int cpu; + sampling_delay_us = 25; + +#ifdef CONFIG_ARM64_AMU_EXTN + cpu = get_cpu_with_amu_feat(); + + if (cpu < nr_cpu_ids) + get_rate_use_wq = true; +#endif } static void cppc_check_hisi_workaround(void)