From nobody Tue Apr 7 00:19:44 2026 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 AE23FC4332F for ; Sun, 9 Oct 2022 07:11:48 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230054AbiJIHLr (ORCPT ); Sun, 9 Oct 2022 03:11:47 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41334 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229602AbiJIHLc (ORCPT ); Sun, 9 Oct 2022 03:11:32 -0400 Received: from NAM10-DM6-obe.outbound.protection.outlook.com (mail-dm6nam10on2078.outbound.protection.outlook.com [40.107.93.78]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 5396E95BE; Sun, 9 Oct 2022 00:11:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=iUeDUjPFT8GvtmQtEBDXxa/1JHaKvniWIB7FN56zLIZ3pu2RLot5VWGE1ZjjYTd1MZGFZJwFruLf4GAgKUpTgm5FEenmo5AFjvpezmImuqd1VkxKHWKHeidfP1m4U3+oCZt7joN2VEXGJUUBrt5tzZYqMgm8e9nv8IcZek7qvixirUhsGJ/laLG2HRiMuW5wAqInqfZNSnSWklMjGTxBPmUi3iSMcPCO5xJM2MQGKsrTnvJ6PHK0K7lJj8Te5MU6IKyqdAAofZFxH6eXsiDXkv/iqRBh9A8Po8mSOmYlfPCPCxm+sJt/pp4QjZg9uO2Ka+ZPlCuRF226/BHYv7DYtA== 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=wqlCWw7oz/MsSLARugtCt+Q5U57P8YdPwEm8C2mIUVg=; b=Z7N8I4IaJHIR0hyw2nuZdQDzQomyhnWujGqB0+HYu49/v+9TYqO1nQg7uVbqdT1iXrbKahqEkVgSnlnyyl9NMntFbl3vmKWfPzvzQWf21rVWhia1YAY43Gr3at6mUgPLJOccZVZZEeYUVC8Xl4q1eUpeWg3fg0NV2J8ANPxMAFk/B77CV/A3JosOqD8m4ZCN55h/pVHNUyYixJ0xnOZjbnl1HD+kvNeHUkc4JOdrBusutO+BRln3g7PAGpiFkDrCtEPppY5tN+Ck4CjDZzWe4Z8wXiVdk5okWWl8rPcRod+QUEomlxTimxYxkJ8d5gRZfZbYxD0pBDX2JPPwblxaZQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=intel.com smtp.mailfrom=amd.com; dmarc=pass (p=quarantine sp=quarantine pct=100) action=none header.from=amd.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amd.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=wqlCWw7oz/MsSLARugtCt+Q5U57P8YdPwEm8C2mIUVg=; b=4c6rpB2jzKma9Ds1IsndDxi9BJZR71jA4zGFzzYsVavZ5ie/bQUhUEwqf76Hc2Se0S4QFznBw1Vbdb+wdDet9ns2w23wyTEfq5qk34IliLyUPJaiDzNk37Hq2/y8hte0GpG/FBtfAi9u+t2x3gkNf2I7ewpGap+VYiS5ZlFGOLU= Received: from DM6PR03CA0077.namprd03.prod.outlook.com (2603:10b6:5:333::10) by DS7PR12MB6046.namprd12.prod.outlook.com (2603:10b6:8:85::20) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5709.15; Sun, 9 Oct 2022 07:11:25 +0000 Received: from DM6NAM11FT018.eop-nam11.prod.protection.outlook.com (2603:10b6:5:333:cafe::8b) by DM6PR03CA0077.outlook.office365.com (2603:10b6:5:333::10) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5709.15 via Frontend Transport; Sun, 9 Oct 2022 07:11:25 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 165.204.84.17) smtp.mailfrom=amd.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=amd.com; Received-SPF: Pass (protection.outlook.com: domain of amd.com designates 165.204.84.17 as permitted sender) receiver=protection.outlook.com; client-ip=165.204.84.17; helo=SATLEXMB04.amd.com; pr=C Received: from SATLEXMB04.amd.com (165.204.84.17) by DM6NAM11FT018.mail.protection.outlook.com (10.13.172.110) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.5709.10 via Frontend Transport; Sun, 9 Oct 2022 07:11:25 +0000 Received: from pyuan-Cloudripper.amd.com (10.180.168.240) by SATLEXMB04.amd.com (10.181.40.145) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.28; Sun, 9 Oct 2022 02:11:07 -0500 From: Perry Yuan To: , , CC: , , , , , , , , , Perry Yuan Subject: [PATCH v2 1/9] ACPI: CPPC: Add AMD pstate energy performance preference cppc control Date: Sun, 9 Oct 2022 15:10:25 +0800 Message-ID: <20221009071033.21170-2-Perry.Yuan@amd.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221009071033.21170-1-Perry.Yuan@amd.com> References: <20221009071033.21170-1-Perry.Yuan@amd.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-Originating-IP: [10.180.168.240] X-ClientProxiedBy: SATLEXMB03.amd.com (10.181.40.144) To SATLEXMB04.amd.com (10.181.40.145) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DM6NAM11FT018:EE_|DS7PR12MB6046:EE_ X-MS-Office365-Filtering-Correlation-Id: 4b150c31-2339-4075-27ed-08daa9c57a4e X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: WIqa5QQ67E08LspUkaY3A5y9nmvqNbgH2rmiPzQV5zcVtmpq4UMyqg2msRHlod3SpaJqIEoeQj53rsB44FBBnyoxLS21RjxBeB59jJJ9vPr6mg+kpox8heVWAEPgNuOpsi7xiB0tvqUobX1pUSpG0D12bQGqXn9NtYSwdP7gszm6Ton71wrWzqcbkCMMwkBiZ/F7U/m54BSc/se1wMPuqljU01SThaCswXBYwj3iAfzFLyYk/ULfEcB00sE0G8MsKXVIZSvGILiCC5Zshpe/OrtN2wg9mSxpckij5zIdCXTCyNyHCHEZsCfhp1Tcyb73xteMnaypK1cFFpxtqEIixR5jZllMh8DTuJ4ivFb1LAviBIAYFNn0KCwP2J7Amjc7R6gT7DEtGlwQIbZMEqrvKgytTZfdEshEreAf/p06Jv4j6aao5vgwmnAze8KjAMUZ9xv1WmmB0STB1PolYG0nK5ATIB9bxxpUMd8IccmNGTx2tqhmbn6ipZAWv8/Ifmj1XrCpjUnaVjGM1yjFEai1mfFXIBa+jg2wUI1ndodXk/1P7vrRF8hUHRcweytVmwTFPRwJq0ZDod9odShj7VAdtyXmMZyYyChoajghYsIb6PCsoObBDwsMo2fvsIEN2WOn/k8CigLeW7GDComMKLdcoOhqj8v1lmtVg67kqhj8zYZCXU2K3+yf/zzl5hh4gMdI6oczmkVf4I6NaIK3eAKpIgkMX3hnQQhBOmsb54dv+QfKjob8RCZCMAcyJOFE2fG7w25Y2rcUrSsHnLEJv02BrY48GLqmdO83oLbNhm8P/aqlrHn5x2lBpRCc/Lp0YkzU5w0l+0xWC/FcAP2cpb8lOA== X-Forefront-Antispam-Report: CIP:165.204.84.17;CTRY:US;LANG:en;SCL:1;SRV:;IPV:CAL;SFV:NSPM;H:SATLEXMB04.amd.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230022)(4636009)(376002)(39860400002)(346002)(396003)(136003)(451199015)(40470700004)(36840700001)(46966006)(36860700001)(86362001)(40460700003)(36756003)(356005)(82740400003)(110136005)(40480700001)(316002)(54906003)(81166007)(5660300002)(8936002)(8676002)(4326008)(16526019)(70586007)(70206006)(41300700001)(478600001)(2906002)(82310400005)(336012)(47076005)(426003)(83380400001)(7696005)(6666004)(186003)(1076003)(2616005)(26005)(36900700001)(2101003);DIR:OUT;SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 09 Oct 2022 07:11:25.1315 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 4b150c31-2339-4075-27ed-08daa9c57a4e X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=3dd8961f-e488-4e60-8e11-a82d994e183d;Ip=[165.204.84.17];Helo=[SATLEXMB04.amd.com] X-MS-Exchange-CrossTenant-AuthSource: DM6NAM11FT018.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: DS7PR12MB6046 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Type: text/plain; charset="utf-8" Add the EPP(Energy Performance Preference) support for the AMD SoCs without the dedicated CPPC MSR, those SoCs need to add this cppc acpi functions to update EPP values and desired perf value. In order to get EPP worked, cppc_get_epp_caps() will query EPP preference value and cppc_set_epp_perf() will set EPP new value. Before the EPP works, pstate driver will use cppc_set_auto_epp() to enable EPP function from firmware firstly. Signed-off-by: Perry Yuan --- drivers/acpi/cppc_acpi.c | 128 ++++++++++++++++++++++++++++++++++++++- include/acpi/cppc_acpi.h | 17 ++++++ 2 files changed, 144 insertions(+), 1 deletion(-) diff --git a/drivers/acpi/cppc_acpi.c b/drivers/acpi/cppc_acpi.c index 093675b1a1ff..b0e7817cb97f 100644 --- a/drivers/acpi/cppc_acpi.c +++ b/drivers/acpi/cppc_acpi.c @@ -1365,6 +1365,132 @@ int cppc_get_perf_ctrs(int cpunum, struct cppc_perf= _fb_ctrs *perf_fb_ctrs) } EXPORT_SYMBOL_GPL(cppc_get_perf_ctrs); =20 +/** + * cppc_get_epp_caps - Get the energy preference register value. + * @cpunum: CPU from which to get epp preference level. + * @perf_caps: Return address. + * + * Return: 0 for success, -EIO otherwise. + */ +int cppc_get_epp_caps(int cpunum, struct cppc_perf_caps *perf_caps) +{ + struct cpc_desc *cpc_desc =3D per_cpu(cpc_desc_ptr, cpunum); + struct cpc_register_resource *energy_perf_reg; + u64 energy_perf; + + if (!cpc_desc) { + pr_warn("No CPC descriptor for CPU:%d\n", cpunum); + return -ENODEV; + } + + energy_perf_reg =3D &cpc_desc->cpc_regs[ENERGY_PERF]; + + if (!CPC_SUPPORTED(energy_perf_reg)) + pr_warn("energy perf reg update is unsupported!\n"); + + if (CPC_IN_PCC(energy_perf_reg)) { + int pcc_ss_id =3D per_cpu(cpu_pcc_subspace_idx, cpunum); + struct cppc_pcc_data *pcc_ss_data =3D NULL; + int ret =3D 0; + + if (pcc_ss_id < 0) + return -EIO; + + pcc_ss_data =3D pcc_data[pcc_ss_id]; + + down_write(&pcc_ss_data->pcc_lock); + + if (send_pcc_cmd(pcc_ss_id, CMD_READ) >=3D 0) { + cpc_read(cpunum, energy_perf_reg, &energy_perf); + perf_caps->energy_perf =3D energy_perf; + } else { + ret =3D -EIO; + } + + up_write(&pcc_ss_data->pcc_lock); + + return ret; + } + + return 0; +} +EXPORT_SYMBOL_GPL(cppc_get_epp_caps); + +int cppc_set_auto_epp(int cpu, bool enable) +{ + int pcc_ss_id =3D per_cpu(cpu_pcc_subspace_idx, cpu); + struct cpc_register_resource *auto_sel_reg; + struct cpc_desc *cpc_desc =3D per_cpu(cpc_desc_ptr, cpu); + struct cppc_pcc_data *pcc_ss_data =3D NULL; + int ret =3D -EINVAL; + + if (!cpc_desc) { + pr_warn("No CPC descriptor for CPU:%d\n", cpu); + return -EINVAL; + } + + auto_sel_reg =3D &cpc_desc->cpc_regs[AUTO_SEL_ENABLE]; + + if (CPC_IN_PCC(auto_sel_reg)) { + if (pcc_ss_id < 0) + return -EIO; + + ret =3D cpc_write(cpu, auto_sel_reg, enable); + if (ret) + return ret; + + pcc_ss_data =3D pcc_data[pcc_ss_id]; + + down_write(&pcc_ss_data->pcc_lock); + /* after writing CPC, transfer the ownership of PCC to platform */ + ret =3D send_pcc_cmd(pcc_ss_id, CMD_WRITE); + up_write(&pcc_ss_data->pcc_lock); + return ret; + } + + return cpc_write(cpu, auto_sel_reg, enable); +} +EXPORT_SYMBOL_GPL(cppc_set_auto_epp); + +/* + * Set Energy Performance Preference Register value through + * Performance Controls Interface + */ +int cppc_set_epp_perf(int cpu, struct cppc_perf_ctrls *perf_ctrls) +{ + int pcc_ss_id =3D per_cpu(cpu_pcc_subspace_idx, cpu); + struct cpc_register_resource *epp_set_reg; + struct cpc_desc *cpc_desc =3D per_cpu(cpc_desc_ptr, cpu); + struct cppc_pcc_data *pcc_ss_data =3D NULL; + int ret =3D -EINVAL; + + if (!cpc_desc) { + pr_warn("No CPC descriptor for CPU:%d\n", cpu); + return -EINVAL; + } + + epp_set_reg =3D &cpc_desc->cpc_regs[ENERGY_PERF]; + + if (CPC_IN_PCC(epp_set_reg)) { + if (pcc_ss_id < 0) + return -EIO; + + ret =3D cpc_write(cpu, epp_set_reg, perf_ctrls->energy_perf); + if (ret) + return ret; + + pcc_ss_data =3D pcc_data[pcc_ss_id]; + + down_write(&pcc_ss_data->pcc_lock); + /* after writing CPC, transfer the ownership of PCC to platform */ + ret =3D send_pcc_cmd(pcc_ss_id, CMD_WRITE); + up_write(&pcc_ss_data->pcc_lock); + } + + return ret; +} +EXPORT_SYMBOL_GPL(cppc_set_epp_perf); + /** * cppc_set_enable - Set to enable CPPC on the processor by writing the * Continuous Performance Control package EnableRegister field. @@ -1400,7 +1526,7 @@ int cppc_set_enable(int cpu, bool enable) pcc_ss_data =3D pcc_data[pcc_ss_id]; =20 down_write(&pcc_ss_data->pcc_lock); - /* after writing CPC, transfer the ownership of PCC to platfrom */ + /* after writing CPC, transfer the ownership of PCC to platform */ ret =3D send_pcc_cmd(pcc_ss_id, CMD_WRITE); up_write(&pcc_ss_data->pcc_lock); return ret; diff --git a/include/acpi/cppc_acpi.h b/include/acpi/cppc_acpi.h index c5614444031f..10d91aeedaca 100644 --- a/include/acpi/cppc_acpi.h +++ b/include/acpi/cppc_acpi.h @@ -108,12 +108,14 @@ struct cppc_perf_caps { u32 lowest_nonlinear_perf; u32 lowest_freq; u32 nominal_freq; + u32 energy_perf; }; =20 struct cppc_perf_ctrls { u32 max_perf; u32 min_perf; u32 desired_perf; + u32 energy_perf; }; =20 struct cppc_perf_fb_ctrs { @@ -149,6 +151,9 @@ extern bool cpc_ffh_supported(void); extern bool cpc_supported_by_cpu(void); extern int cpc_read_ffh(int cpunum, struct cpc_reg *reg, u64 *val); extern int cpc_write_ffh(int cpunum, struct cpc_reg *reg, u64 val); +extern int cppc_set_auto_epp(int cpu, bool enable); +extern int cppc_get_epp_caps(int cpunum, struct cppc_perf_caps *perf_caps); +extern int cppc_set_epp_perf(int cpu, struct cppc_perf_ctrls *perf_ctrls); #else /* !CONFIG_ACPI_CPPC_LIB */ static inline int cppc_get_desired_perf(int cpunum, u64 *desired_perf) { @@ -202,6 +207,18 @@ static inline int cpc_write_ffh(int cpunum, struct cpc= _reg *reg, u64 val) { return -ENOTSUPP; } +static inline int cppc_set_auto_epp(int cpu, bool enable) +{ + return -ENOTSUPP; +} +static inline int cppc_set_epp_perf(int cpu, struct cppc_perf_ctrls *perf_= ctrls) +{ + return -ENOTSUPP; +} +static inline int cppc_get_epp_caps(int cpunum, struct cppc_perf_caps *per= f_caps) +{ + return -ENOTSUPP; +} #endif /* !CONFIG_ACPI_CPPC_LIB */ =20 #endif /* _CPPC_ACPI_H*/ --=20 2.34.1 From nobody Tue Apr 7 00:19:44 2026 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 9269CC43217 for ; Sun, 9 Oct 2022 07:11:33 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229995AbiJIHLc (ORCPT ); Sun, 9 Oct 2022 03:11:32 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41316 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229602AbiJIHL3 (ORCPT ); Sun, 9 Oct 2022 03:11:29 -0400 Received: from NAM11-CO1-obe.outbound.protection.outlook.com (mail-co1nam11on2073.outbound.protection.outlook.com [40.107.220.73]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7B24795BE; Sun, 9 Oct 2022 00:11:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=cfhP7yDvo9/ffbUp0rcEhLtIbIaNkpY6JiJLDggZR3zRE73ujv2KSEXWyDZ4VN4Bk5PfLTuNJCQ7srVH/6/Wi8aP+2JzYUXFhaw/C8NLW7RxD/KpcFNsqrrFs5FnwNdjPMdIQL4ztsXEUesfR2R6BP4xRI90Kv1lrtobCLISLK4pYvNt36uOchSAIcg/xaJa1eB6jTRW5R5SMxaI2zhBBT3KoD5xpqS5xQ20fPj0RBYhGbVpXrv4fTZYsE9sxvJXQ97LP+orjvUVz8ns6nIZgpR/JSyQMWEMPo53/bBKDqVuJoKjdgAhIjKwbjB++nzFHml09BHOs3QOcl5AFvFkTA== 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=cvLV8b2WBCHL4JYNEZv5XZDmOonX3mlPcA7RHdrvDA8=; b=MIK8PRD/CMAI+ucNIVJM8I271EHm/39xG5B0CznkHZCHMfek2j8IfRzUf/qxLajPK0org0l796kTCi2/TTPWCwK72Jto0QMXvHCFcH7kOUGpE4DlClR/nlq+V+nNYHSHKEoLUdkGvNQ7l6OMY7ownnmgicIIkoFg0/1eWR+pGZJu1sfGHklD/7UH9eg9QMF0NWPJwUeph+8Vm08C+5LITWdaNAMjXfqFQ4gMdWmBGriNx2DzCKcJ3ZG1cCAhUcppfKdXit/vkgDTGyrc3f/A9mAp05teU0/aJDOz99EB0y9L3z7nNtXkGBQbrdsMn2TGZfMXGk54n4atL8Hhsl+zcQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=intel.com smtp.mailfrom=amd.com; dmarc=pass (p=quarantine sp=quarantine pct=100) action=none header.from=amd.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amd.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=cvLV8b2WBCHL4JYNEZv5XZDmOonX3mlPcA7RHdrvDA8=; b=y7OgjtfVwqygq2uggPz2XP/XdGTtDKKOmiXLoilgmvJylwU1z2L9FBr81Z4Efi9G/nH0VQNpD+Np3yIBTV3haM5owFAkaC0iMtxqn9t6hJmjP3H0ckxmR/f/i7IOWK4TEyi1vE2ihwjILxXufW5ctoKxsoUfiawoFamARnkMujM= Received: from DM6PR03CA0100.namprd03.prod.outlook.com (2603:10b6:5:333::33) by SA0PR12MB4464.namprd12.prod.outlook.com (2603:10b6:806:9f::11) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5709.15; Sun, 9 Oct 2022 07:11:25 +0000 Received: from DM6NAM11FT018.eop-nam11.prod.protection.outlook.com (2603:10b6:5:333:cafe::cf) by DM6PR03CA0100.outlook.office365.com (2603:10b6:5:333::33) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5709.15 via Frontend Transport; Sun, 9 Oct 2022 07:11:25 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 165.204.84.17) smtp.mailfrom=amd.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=amd.com; Received-SPF: Pass (protection.outlook.com: domain of amd.com designates 165.204.84.17 as permitted sender) receiver=protection.outlook.com; client-ip=165.204.84.17; helo=SATLEXMB04.amd.com; pr=C Received: from SATLEXMB04.amd.com (165.204.84.17) by DM6NAM11FT018.mail.protection.outlook.com (10.13.172.110) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.5709.10 via Frontend Transport; Sun, 9 Oct 2022 07:11:25 +0000 Received: from pyuan-Cloudripper.amd.com (10.180.168.240) by SATLEXMB04.amd.com (10.181.40.145) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.28; Sun, 9 Oct 2022 02:11:11 -0500 From: Perry Yuan To: , , CC: , , , , , , , , , Perry Yuan Subject: [PATCH v2 2/9] cpufreq: amd_pstate: add module parameter to load amd pstate EPP driver Date: Sun, 9 Oct 2022 15:10:26 +0800 Message-ID: <20221009071033.21170-3-Perry.Yuan@amd.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221009071033.21170-1-Perry.Yuan@amd.com> References: <20221009071033.21170-1-Perry.Yuan@amd.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-Originating-IP: [10.180.168.240] X-ClientProxiedBy: SATLEXMB03.amd.com (10.181.40.144) To SATLEXMB04.amd.com (10.181.40.145) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DM6NAM11FT018:EE_|SA0PR12MB4464:EE_ X-MS-Office365-Filtering-Correlation-Id: 72f7b351-bbb5-464c-73ca-08daa9c57a7b X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: andjh9TUSt47Qc6VO4kbKA9/AP6dp5t/Aitw3FVB10SXl2xnZtR1wzWdPm9XfZLOlgQ50SBSALKopBeQm8+vPiI0HhLXWsP6BNGnwbZONYijggWODIRCWkUPYICw2cpxoUoxeYtyBDXSA9yPHAUobMiSCMe1CsqQFaCniY3y/Sj5tqV7acT7DSL/w2qaIOoyn/DnJN+++VSzW2wHdasphW7h2rO+kM2Uo8QTghOmz4TCv9H0aUeIDi3lvSFOQMPkiUsjyyzYC3hl9SG2S3++65yRfDdlXEHbN83VYwT5F90O3mDx4N3zKiW9V83Fgj4OAOq69zufxmFNGiQZRwtZJG5TeKJsrLpndnJNE+snYrmLioga8SG2Mb2itl9l+yNMWvb5Z6P9sJo1rBE+5lQCK7WR8uYyGUmQzohKX8ldKlYwWKZDMqmJRKmHSIA73Ahx41sXKYLP6j6dqKvCTsiRQem5zike10n7l1uc6VSBpIc3Alk5uoRqTORsiUgzyyncSas0ioVI8PKKfE7wSrKGk4kbVZWcsz7Gd/BbFoK7XjIqqHJLK1ZiLmiQ6nxTJl0IlihDcJFxwDBvFH8urVmGW5nwTG47EHDcS1+zZlxfTzvm355f/7jn0JLkK755jyJkQIMqkeONOYAoana3Vdk8Zrloa/0Qv8esZJbw4+qBbz2WqpGoju81ULro3S74/27QkLnJ9iTSzy73FjIUgMiCW9sOfzaHsmuDuf4ijNvFpG4Lee6SiddyeF8c4E9y+ggxiU4Pte+ybm62xaZx9kKB8DSD0LasDlLPhdQsFKDs41bOTVg3/bTtnBllIkiiSkD6uQHCFk/G4uhrBLH5XF1AGw== X-Forefront-Antispam-Report: CIP:165.204.84.17;CTRY:US;LANG:en;SCL:1;SRV:;IPV:CAL;SFV:NSPM;H:SATLEXMB04.amd.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230022)(4636009)(39860400002)(136003)(376002)(346002)(396003)(451199015)(36840700001)(46966006)(40470700004)(7696005)(2616005)(356005)(316002)(2906002)(26005)(36756003)(36860700001)(82740400003)(8936002)(41300700001)(81166007)(86362001)(70206006)(6666004)(70586007)(82310400005)(40480700001)(4326008)(54906003)(478600001)(5660300002)(8676002)(110136005)(40460700003)(83380400001)(47076005)(426003)(16526019)(1076003)(186003)(336012)(36900700001)(2101003);DIR:OUT;SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 09 Oct 2022 07:11:25.4283 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 72f7b351-bbb5-464c-73ca-08daa9c57a7b X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=3dd8961f-e488-4e60-8e11-a82d994e183d;Ip=[165.204.84.17];Helo=[SATLEXMB04.amd.com] X-MS-Exchange-CrossTenant-AuthSource: DM6NAM11FT018.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: SA0PR12MB4464 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Type: text/plain; charset="utf-8" The amd_pstate mode parameter will allow user to select which amd pstate working mode as booting mode, amd_pstate instance or amd_pstate_epp instanc= e. 1) amd_pstate instance is depending on the target operation mode. 2) amd_pstate_epp instance is depending on the set_policy operation mode.It is also called active mode that AMD SMU has EPP algorithm to control the CPU runtime frequency according to the EPP set value and workload. Signed-off-by: Perry Yuan --- drivers/cpufreq/amd-pstate.c | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/drivers/cpufreq/amd-pstate.c b/drivers/cpufreq/amd-pstate.c index f52b8f2fe529..14a275c22aff 100644 --- a/drivers/cpufreq/amd-pstate.c +++ b/drivers/cpufreq/amd-pstate.c @@ -63,6 +63,10 @@ module_param(shared_mem, bool, 0444); MODULE_PARM_DESC(shared_mem, "enable amd-pstate on processors with shared memory solution (false =3D= disabled (default), true =3D enabled)"); =20 +static bool epp_enabled =3D false; +module_param(epp_enabled, bool, 0444); +MODULE_PARM_DESC(epp_enabled, "Enable energy performance preference (EPP) = control"); + static struct cpufreq_driver amd_pstate_driver; =20 /** --=20 2.34.1 From nobody Tue Apr 7 00:19:44 2026 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 9AB36C433FE for ; Sun, 9 Oct 2022 07:11:41 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229901AbiJIHLj (ORCPT ); Sun, 9 Oct 2022 03:11:39 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41324 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229905AbiJIHLa (ORCPT ); Sun, 9 Oct 2022 03:11:30 -0400 Received: from NAM12-BN8-obe.outbound.protection.outlook.com (mail-bn8nam12on2063.outbound.protection.outlook.com [40.107.237.63]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A528323388; Sun, 9 Oct 2022 00:11:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=E8GK3v9kMSMfyZDnjMG8vwxZbdZCaGtogag67Cn3KOsCOolw+yuu/m5AxLlxP7NnEhKjHsIxOF3KisSaH0vuX7QgcEZmU29+NSVMnHAt6dy2lznQwYEv+ri963qdCqpl8J3fl5t7YNCNVw0L0TFJrKs3jBkZlkbvQEC/4VBJl1pq3Ho94M7wvdu2abAdAL5oZFf0PNM1eG1lP9v9YRvCMxV7blmUKPsuK19rU+dWtHmhl4xKqOQmCOGVL2LRixV6NiuMP8VA1ryqTmnH/cFce1FFdMi7JJlM8RMO68QiHtZoQbCX2MAs6vzFbJ4zw6mgaSd9hFy1PHYez8JIiUMnXw== 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=btPwwPHv+BWB3mpjbjX83dVXxe6qjvTS7bl+4/fSJm4=; b=RRZmjy6/5st56sw3BqysUtDm/ZWFwzZlgb/LJ7KnyBMp1Dx9S9bkFsXEz9q/BHBnkl49GC8rEfo8kEOFV8d7ioAPWdKcEAN5jx+eCzlvKjBUe2LNVlxML1FVXj23B+whRJjuAGCoGQYxLZUCFhXsFFmg5xe5P+7MHAUFbOaSxcbQ775NEF7D7FOkxSiGkyhAc2iSBnW/PDvrFqrP/y+WU1gjh/PtCdKLMXiJaCvFNfyvrS6ziInKsXBZgK1nnLscFsYV91uYyX+/rXApnro9iEDozlzwW/2fnbA8XFWAa/v8+BZomUoohJYOOoOtsEv9EJ0psfvOVSOXDjrJoepl3w== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=intel.com smtp.mailfrom=amd.com; dmarc=pass (p=quarantine sp=quarantine pct=100) action=none header.from=amd.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amd.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=btPwwPHv+BWB3mpjbjX83dVXxe6qjvTS7bl+4/fSJm4=; b=LPrZiGaa9S026y+sSaBc/AB5M6etMeWkfO8wuEef4uxRT+cLT6R0SZeX7ctlYbkSnq3QsKJUdcqOGQwuEM6An111JrEIdavI03gaBkXrRkCBjHO/Pub34ctAF9waMEW/kpAY4+LhyIJXOxrM0I8sZOgSG1gjInPwOKD/y9v6Zks= Received: from DM6PR03CA0078.namprd03.prod.outlook.com (2603:10b6:5:333::11) by DM6PR12MB4465.namprd12.prod.outlook.com (2603:10b6:5:28f::17) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5709.15; Sun, 9 Oct 2022 07:11:26 +0000 Received: from DM6NAM11FT018.eop-nam11.prod.protection.outlook.com (2603:10b6:5:333:cafe::38) by DM6PR03CA0078.outlook.office365.com (2603:10b6:5:333::11) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5676.26 via Frontend Transport; Sun, 9 Oct 2022 07:11:26 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 165.204.84.17) smtp.mailfrom=amd.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=amd.com; Received-SPF: Pass (protection.outlook.com: domain of amd.com designates 165.204.84.17 as permitted sender) receiver=protection.outlook.com; client-ip=165.204.84.17; helo=SATLEXMB04.amd.com; pr=C Received: from SATLEXMB04.amd.com (165.204.84.17) by DM6NAM11FT018.mail.protection.outlook.com (10.13.172.110) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.5709.10 via Frontend Transport; Sun, 9 Oct 2022 07:11:25 +0000 Received: from pyuan-Cloudripper.amd.com (10.180.168.240) by SATLEXMB04.amd.com (10.181.40.145) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.28; Sun, 9 Oct 2022 02:11:14 -0500 From: Perry Yuan To: , , CC: , , , , , , , , , Perry Yuan Subject: [PATCH v2 3/9] cpufreq: cpufreq: export cpufreq cpu release and acquire Date: Sun, 9 Oct 2022 15:10:27 +0800 Message-ID: <20221009071033.21170-4-Perry.Yuan@amd.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221009071033.21170-1-Perry.Yuan@amd.com> References: <20221009071033.21170-1-Perry.Yuan@amd.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-Originating-IP: [10.180.168.240] X-ClientProxiedBy: SATLEXMB03.amd.com (10.181.40.144) To SATLEXMB04.amd.com (10.181.40.145) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DM6NAM11FT018:EE_|DM6PR12MB4465:EE_ X-MS-Office365-Filtering-Correlation-Id: d911f30d-901f-4925-e499-08daa9c57ace X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: QkSOr1iMpoYkSFCCDuO1Pw21vNBfRSyiS/6fJ6wIhznv39o1uKDuLxvhs60li+xuwIr0wKllWisLFIlhgWhig9lKs9r+l3SX1U7O88zUYhOcWp18jVO1HeV16JOSpt1JAwSey48TneCtESYetyxS4yT1mNjwoa3RHRHciEoTQdrNGpRkLUx8nMum2S9vLgNHHKQxUucgRIQ4yFSbce91b3sPd68C4BiOgLfnZDXDPaIAUZGvaydGGubFZv61pbjIiNrqRX9T2Cq3PcPNVC5E49sqH4jfWg8DZCRKw+kwW6BQ9we3/MKet5W6jerVIrMMe+CbMlpbGJY1sTdq4VEkaw/W+7WOWEB/hsfvmfr8RRxCp3xlv7kcG7t1yIfrDBztJn0CiBeOMQ2JyIKFaaLRw/a57NZmKVxb/gwDJmMOcYB1DeS3ONvmy5OwGhIBB23xhQsIqdPae6Ba5XYRYcoNZ3/7+vBlO/ap/mhRAiUHnnM1aoV+YBDh7rztyOkYTW9tHorVQ1wCJOSt/RGbIzLQPVowbBNu90IxsCpykO6FWT73sdN8sYehe4SkhqoO/XrPinKg1fJr9LjdLZnaGV44zINHSS+ia5HN3+CmCIuwqifRsFCL3//XgbTpNGvwh+hcsg6qOFw2+AN0KVAosOGnKSHBZ+FAYOK9u1JXL+dVs6ps0ceCekyAj700eAkeZ2BNLxyZmEwtFWPjyusLUhXGr9utuOS4DSBsp0jKibO+LpllVcZVpPjYIDej3OK7YCoeu1gwtUiqPAGLwUadpaowJCzQVO3SkKHxKrKCFkJUIrpR4ZVx5jvR3HIcc1VphIqu X-Forefront-Antispam-Report: CIP:165.204.84.17;CTRY:US;LANG:en;SCL:1;SRV:;IPV:CAL;SFV:NSPM;H:SATLEXMB04.amd.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230022)(4636009)(396003)(39860400002)(346002)(376002)(136003)(451199015)(46966006)(40470700004)(36840700001)(36860700001)(36756003)(81166007)(356005)(40460700003)(40480700001)(82740400003)(86362001)(8676002)(4326008)(70586007)(70206006)(316002)(110136005)(2906002)(54906003)(41300700001)(8936002)(4744005)(426003)(5660300002)(47076005)(83380400001)(16526019)(1076003)(186003)(336012)(2616005)(6666004)(478600001)(82310400005)(7696005)(26005)(2101003)(36900700001);DIR:OUT;SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 09 Oct 2022 07:11:25.9752 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: d911f30d-901f-4925-e499-08daa9c57ace X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=3dd8961f-e488-4e60-8e11-a82d994e183d;Ip=[165.204.84.17];Helo=[SATLEXMB04.amd.com] X-MS-Exchange-CrossTenant-AuthSource: DM6NAM11FT018.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: DM6PR12MB4465 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Type: text/plain; charset="utf-8" cpufreq_cpu_release" and "cpufreq_cpu_acquire" are only used internally by drivers/cpufreq/cpufreq.c currently. Export them so that other drivers such as the AMD P-state driver can use th= em as well. Signed-off-by: Perry Yuan --- drivers/cpufreq/cpufreq.c | 2 ++ 1 file changed, 2 insertions(+) diff --git a/drivers/cpufreq/cpufreq.c b/drivers/cpufreq/cpufreq.c index 69b3d61852ac..a491fea4985e 100644 --- a/drivers/cpufreq/cpufreq.c +++ b/drivers/cpufreq/cpufreq.c @@ -262,6 +262,7 @@ void cpufreq_cpu_release(struct cpufreq_policy *policy) =20 cpufreq_cpu_put(policy); } +EXPORT_SYMBOL_GPL(cpufreq_cpu_release); =20 /** * cpufreq_cpu_acquire - Find policy for a CPU, mark it as busy and lock i= t. @@ -291,6 +292,7 @@ struct cpufreq_policy *cpufreq_cpu_acquire(unsigned int= cpu) =20 return policy; } +EXPORT_SYMBOL_GPL(cpufreq_cpu_acquire); =20 /********************************************************************* * EXTERNALLY AFFECTING FREQUENCY CHANGES * --=20 2.34.1 From nobody Tue Apr 7 00:19:44 2026 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 81DB3C4332F for ; Sun, 9 Oct 2022 07:11:45 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230028AbiJIHLm (ORCPT ); Sun, 9 Oct 2022 03:11:42 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41336 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229456AbiJIHLc (ORCPT ); Sun, 9 Oct 2022 03:11:32 -0400 Received: from NAM12-MW2-obe.outbound.protection.outlook.com (mail-mw2nam12on2056.outbound.protection.outlook.com [40.107.244.56]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 308BEBC18; Sun, 9 Oct 2022 00:11:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=k7IaP9g3BUGs9h54R41qjw+2e3yCJkotIuFIN0nCs+LbsS+ZwLtP/vbuJ92Fm3y0evozd2GyoTSjO7jYmexWinq8yhd+oKOUarmfJQJisE1LfXtikfQeJzF3nrd45t7vbamccYybFDkG5h6wN9CSrzAa/+EU1+/7AiqMRFCDQQL9PCzKXsAHyAFMZGuQMB3fWNYlLOE3gcM8ty7oKM76npFYaumF54+o7n3vJMctRL0L8fY+X3ZVjoHoyhykZ4m437oQb1opmugnuv8DDCRCVGB+ZWNhWaLkuS41qC1cPCLIG+rgfGyySZKleYWoPv8jVY3kavgcWyzPvFQohsFM6g== 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=eyOdA0xgsn2S6ntfuGkWBS+LaNrHdTzhR45MQZboLBo=; b=Ljk4/Egjjn7KLFq2nLQL+zB2QTu8xYYpWjS3XZ0NTTMKiMJ42diHFNNsvHwZ7TQil7AxVGVk2Mi5nKTV0RhGMMK+guL3iehfXIfEfANynuq9MMxrHoYJMqeHjbuHmnodwjv9Ww5RYM3bdEcG/Xq/D8IQG4p1xOehFAR7Nh4VdBJl6FqieOJ13zeJfiUMD0G92q4zgSOouQ+eHLL0AnVo5SPUZKIxjVvZjGKaaCmK1Bj6tRLuTuMCiLcuEfDIuV71nb+Z9jFtmyX6wE3Tlr4c1s4BjCzWB5nyXTC6GW9iriFEdlQvHGF1RTaw+H4EjXjlMzL2xQYYV7L4JgUfWuu2sA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=intel.com smtp.mailfrom=amd.com; dmarc=pass (p=quarantine sp=quarantine pct=100) action=none header.from=amd.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amd.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=eyOdA0xgsn2S6ntfuGkWBS+LaNrHdTzhR45MQZboLBo=; b=FzvM5T676WfKVH+f9s244VAZaF/xjMpHmKuAKzLjwF0aSWDy+bcAuxuXSfQCI3k/0zAcpLJOiG4zcoHur/tKgNZrDrioKzOyFp7BBW6jll9Wy1LY+nYuULSOH4NEdgioCD7+4tPBYPD70XLWOr1II8jp2pimMRLKH35R6NFYTuE= Received: from DM6PR03CA0082.namprd03.prod.outlook.com (2603:10b6:5:333::15) by PH8PR12MB6724.namprd12.prod.outlook.com (2603:10b6:510:1cf::20) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5709.15; Sun, 9 Oct 2022 07:11:28 +0000 Received: from DM6NAM11FT018.eop-nam11.prod.protection.outlook.com (2603:10b6:5:333:cafe::db) by DM6PR03CA0082.outlook.office365.com (2603:10b6:5:333::15) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5709.15 via Frontend Transport; Sun, 9 Oct 2022 07:11:28 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 165.204.84.17) smtp.mailfrom=amd.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=amd.com; Received-SPF: Pass (protection.outlook.com: domain of amd.com designates 165.204.84.17 as permitted sender) receiver=protection.outlook.com; client-ip=165.204.84.17; helo=SATLEXMB04.amd.com; pr=C Received: from SATLEXMB04.amd.com (165.204.84.17) by DM6NAM11FT018.mail.protection.outlook.com (10.13.172.110) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.5709.10 via Frontend Transport; Sun, 9 Oct 2022 07:11:28 +0000 Received: from pyuan-Cloudripper.amd.com (10.180.168.240) by SATLEXMB04.amd.com (10.181.40.145) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.28; Sun, 9 Oct 2022 02:11:18 -0500 From: Perry Yuan To: , , CC: , , , , , , , , , Perry Yuan Subject: [PATCH v2 4/9] x86/msr: Add the MSR definition for AMD CPPC boost state Date: Sun, 9 Oct 2022 15:10:28 +0800 Message-ID: <20221009071033.21170-5-Perry.Yuan@amd.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221009071033.21170-1-Perry.Yuan@amd.com> References: <20221009071033.21170-1-Perry.Yuan@amd.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-Originating-IP: [10.180.168.240] X-ClientProxiedBy: SATLEXMB03.amd.com (10.181.40.144) To SATLEXMB04.amd.com (10.181.40.145) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DM6NAM11FT018:EE_|PH8PR12MB6724:EE_ X-MS-Office365-Filtering-Correlation-Id: 665b7499-e295-44b7-9350-08daa9c57c28 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 9wgk1eTEEbujIYNunLW4hL6kvyuycBIm6DNbTCNab5VYBNcnZHguPyQmARixfvIsZeSErinbtX3TY61tEWY4cbN7Y988bKgBUgUNoit1loWzmCS0MwpjXKenfDs4IBmf6JRMSjXjjayDQaQQXWm9ViYX9AoUXAf/TW5+3xLKmUlpC8BKe1/Yd8WRqZqLI4oLVty/Dvlc9sdjHwxrvVqU0ejXPcwbBcRBBgBe1tK95WlQbgebMVtz2S0jhOzQF9i1VSEYVN7bmkpEdVG8W6/kI42PllA5kHHsdf0xyfItwrcecCsfpL1Wn8jLnazult5hYGKtu+/0wcu5tu/eKf0xDsQzyC77xwshQOwQHulfqhflfD/cHj23SDCFamL+fPqikcXMlvKqRz5pR4LOm2cxy/4VmIrn9IMz9NsVAdwMnpiw0NfhmWBeU8X13DjvlC95lCY+ACh3osvOyO/au/y+vKcypukloYCvjSaXM/e8kB6/LCWQzGbNXcGEAhh678eTAOT3uDdM7QKmrPKQGHxYpVIIWhMKudj8oTp4ey9uDjrYf+ho3EtN5zhdM87BjZ0UjRInserIzQAbajLvaq7ZboGApZdR6GPvQRlfWPnoc2y901hxHdny90l990ul7zjgprt1BO56Ua6GQ4pofxUs3Ea3e1AmUhj9X+3lvutofT3JWr4EoIGOgQvibND0qvDgseC2IM6eD4iPHAAdhYNoN6G9g34WCoBEhcCcxAZmd4krB5y0HevmDBtVbrFo1stSr9k7pzRyD8Ht03e6+pIZ7NqzxevqdTSRYcJMcOtl4VuRwI3y59fGxT4qOC6/RG3DxG69DYwJOqotZGMP9kCQ4L9bFtTHUe4adA2LySqUUxmA2NFW5KfcFbqRci+h8FODFP31VcUy/OXSVow1bzWM0w== X-Forefront-Antispam-Report: CIP:165.204.84.17;CTRY:US;LANG:en;SCL:1;SRV:;IPV:CAL;SFV:NSPM;H:SATLEXMB04.amd.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230022)(4636009)(39860400002)(346002)(376002)(136003)(396003)(451199015)(40470700004)(36840700001)(46966006)(36860700001)(36756003)(8936002)(426003)(47076005)(83380400001)(5660300002)(336012)(41300700001)(16526019)(1076003)(186003)(4326008)(2906002)(86362001)(40460700003)(70206006)(2616005)(8676002)(70586007)(316002)(54906003)(110136005)(81166007)(356005)(26005)(7696005)(6666004)(82740400003)(966005)(478600001)(40480700001)(82310400005)(2101003)(36900700001);DIR:OUT;SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 09 Oct 2022 07:11:28.2406 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 665b7499-e295-44b7-9350-08daa9c57c28 X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=3dd8961f-e488-4e60-8e11-a82d994e183d;Ip=[165.204.84.17];Helo=[SATLEXMB04.amd.com] X-MS-Exchange-CrossTenant-AuthSource: DM6NAM11FT018.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: PH8PR12MB6724 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Type: text/plain; charset="utf-8" This MSR can be used to check whether the CPU frequency boost state is enabled in the hardware control. User can change the boost state in the BIOS setting,amd_pstate driver will update the boost state according to this msr value. AMD Processor Programming Reference (PPR) Link: https://www.amd.com/system/files/TechDocs/40332.pdf [p1095] Link: https://www.amd.com/system/files/TechDocs/56569-A1-PUB.zip [p162] Signed-off-by: Perry Yuan --- arch/x86/include/asm/msr-index.h | 3 +++ 1 file changed, 3 insertions(+) diff --git a/arch/x86/include/asm/msr-index.h b/arch/x86/include/asm/msr-in= dex.h index 6674bdb096f3..e5ea1c9f747b 100644 --- a/arch/x86/include/asm/msr-index.h +++ b/arch/x86/include/asm/msr-index.h @@ -569,6 +569,7 @@ #define MSR_AMD_CPPC_CAP2 0xc00102b2 #define MSR_AMD_CPPC_REQ 0xc00102b3 #define MSR_AMD_CPPC_STATUS 0xc00102b4 +#define MSR_AMD_CPPC_HW_CTL 0xc0010015 =20 #define AMD_CPPC_LOWEST_PERF(x) (((x) >> 0) & 0xff) #define AMD_CPPC_LOWNONLIN_PERF(x) (((x) >> 8) & 0xff) @@ -579,6 +580,8 @@ #define AMD_CPPC_MIN_PERF(x) (((x) & 0xff) << 8) #define AMD_CPPC_DES_PERF(x) (((x) & 0xff) << 16) #define AMD_CPPC_ENERGY_PERF_PREF(x) (((x) & 0xff) << 24) +#define AMD_CPPC_PRECISION_BOOST_BIT 25 +#define AMD_CPPC_PRECISION_BOOST_ENABLED BIT_ULL(AMD_CPPC_PRECISION_= BOOST_BIT) =20 /* AMD Performance Counter Global Status and Control MSRs */ #define MSR_AMD64_PERF_CNTR_GLOBAL_STATUS 0xc0000300 --=20 2.34.1 From nobody Tue Apr 7 00:19:44 2026 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 12F20C433FE for ; Sun, 9 Oct 2022 07:11:54 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229744AbiJIHLw (ORCPT ); Sun, 9 Oct 2022 03:11:52 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41396 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230009AbiJIHLe (ORCPT ); Sun, 9 Oct 2022 03:11:34 -0400 Received: from NAM10-BN7-obe.outbound.protection.outlook.com (mail-bn7nam10on2043.outbound.protection.outlook.com [40.107.92.43]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 34C8423394; Sun, 9 Oct 2022 00:11:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=XsknZ0wS5AnLLJiMjq3kU1+GYwy62suCFHHY+2cNEkshIoAILLiA07Us/Zb152dDpNAQXINb2jYG3baLJuSzm4jSh7Bc+J9GuorwvdBQnI1G+L+eLRhz6TYTmYVCq1OSYVNj+muPuRAUyn883FhNGXXDvKpzBoCkzhohTo3QCFD9QwbVPtLz/ehO2es2OvXyeIWTAcehDNIdxE9N80NgnbrYt34iF3qFcUt0HXBR9cgSeEQ4GTGeEchlbis1ulgvk3O8FpBHfDpmglMdCF2DLFaCdpzVT3s958oZBf1Q1jJMhL4krce+m6WSr1yb3g9zw5iOaIzUo48W4uj8JGM5xw== 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=fcgwwgUTea8LzxYVtl63IA8DkBDwDsPFufaAzSXP5Xw=; b=lSWi2XvQaL54meEajJeSX2WNQW8MlS/oDTvSjkDh5ctOdSV8qzJQvGPspPqAoB8jm11tCCZkIEe0BrQD+JM/rRF7Npw3UXVa0mT/ACz8eEj6V2xzZHFcbi/cPAyjOv2n3dUjnRUkFI4TvjRo1Cl+HUQyJQQajm+QFXidLRYeKedvqBVPcTlA4JOX/Ml0wKJODzWNYtLyAVYsrcKKWDP7XXp4TMgIMkY6ZOq5ipafI321H0wZ1dOB5Z5L+cYxflj/LuDxLT5oN6FpFrQMd2WqcAXjMVngixQGcwlwx1wOTCdxplt2itq+0TiQSJCYhXEDgQ7hMCVTPQP4PNUrh28dSQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=intel.com smtp.mailfrom=amd.com; dmarc=pass (p=quarantine sp=quarantine pct=100) action=none header.from=amd.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amd.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=fcgwwgUTea8LzxYVtl63IA8DkBDwDsPFufaAzSXP5Xw=; b=OBAAROgA/eOd6Zic6dMgZP3DYzh0ZX74vuFlWdpgnxY7MozSKB6+q8to+rr5Ly1u/JW6GkuMA4H2cd243oX9EiQnKgjZAgN3Uub7uD0hE4gZ8nRC3SUhFIva2nR4TokFsOtmC37FMl9EHvjMG74jvV0RJ8RzB4SCQLYxHBAS7ZY= Received: from DM6PR03CA0100.namprd03.prod.outlook.com (2603:10b6:5:333::33) by SA1PR12MB6822.namprd12.prod.outlook.com (2603:10b6:806:25d::17) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5676.18; Sun, 9 Oct 2022 07:11:29 +0000 Received: from DM6NAM11FT018.eop-nam11.prod.protection.outlook.com (2603:10b6:5:333:cafe::cf) by DM6PR03CA0100.outlook.office365.com (2603:10b6:5:333::33) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5709.15 via Frontend Transport; Sun, 9 Oct 2022 07:11:29 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 165.204.84.17) smtp.mailfrom=amd.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=amd.com; Received-SPF: Pass (protection.outlook.com: domain of amd.com designates 165.204.84.17 as permitted sender) receiver=protection.outlook.com; client-ip=165.204.84.17; helo=SATLEXMB04.amd.com; pr=C Received: from SATLEXMB04.amd.com (165.204.84.17) by DM6NAM11FT018.mail.protection.outlook.com (10.13.172.110) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.5709.10 via Frontend Transport; Sun, 9 Oct 2022 07:11:29 +0000 Received: from pyuan-Cloudripper.amd.com (10.180.168.240) by SATLEXMB04.amd.com (10.181.40.145) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.28; Sun, 9 Oct 2022 02:11:21 -0500 From: Perry Yuan To: , , CC: , , , , , , , , , Perry Yuan Subject: [PATCH v2 5/9] Documentation: amd-pstate: add EPP profiles introduction Date: Sun, 9 Oct 2022 15:10:29 +0800 Message-ID: <20221009071033.21170-6-Perry.Yuan@amd.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221009071033.21170-1-Perry.Yuan@amd.com> References: <20221009071033.21170-1-Perry.Yuan@amd.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-Originating-IP: [10.180.168.240] X-ClientProxiedBy: SATLEXMB03.amd.com (10.181.40.144) To SATLEXMB04.amd.com (10.181.40.145) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DM6NAM11FT018:EE_|SA1PR12MB6822:EE_ X-MS-Office365-Filtering-Correlation-Id: cf8b8fad-8dab-4d1a-c6e3-08daa9c57c9f X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: RBWGf8wb9mCUapHYyMyUEf7pFOxtlyRoNpmcX5/m3gJ33TBs2tPiJd74P3CLwGjJlgCOAKc5O2qfkQQ0bWlAaJSp0mDAutOFIT1jriyfOu5xN2bqOon1wCyb12S8+/GxphVLNq1RP+hySV2kt/hE4nXO8spmEVPQaql5qdgaYYqDyaf+K05dG8ijGRsMPzS8srU/uEeT8/CqVjFcDTLGjlD+gz/q6lfGelAhXLFy5Q8udHLsk0uVQYd1RhriNIFQubCoEs2HyIz+n78COky60oK1wr8REa9i4tHQOkYcLSYohhskiZP8rxzSZ/QoHeOpOLrFFkgVbjPM8BJwIO7v9DdPgvC753r7tX/Y9L6FVoFfQ32DjrX1X+X93WER1eyoan/7v/Du9j0zOzzkicvSej2BKjPm9sSdnmuw7TG6RYHUIzxmgs/NJK8qpytu2yScYFqGSW1Li0JQT4S62/UuZ+DHmmFC8tLyP0NeeoJIECgBt87QrkHdoAkzXGpn4ogMJTzBxDpyX0JFNTj8HzY3bWQBB2N/GW21+Qn7l571mn7bM0nVgRSPCDzzKtJPwYgdB3RHcpnSu7K167yVeZKqvPKDKZAWgfsNy1LnveIiSopKxZ3ZTYSVAq9aAdCxXPt55MgTwZRcMNKKtWKgZ43oB7J/vTuS9FlI8BbTTKPNJK3LltDM2aSSeHK0YWhpqH/Qm9FY1bFT/NBseNQfUkyzbS8CuM0lL0ocn/dNXzbHQnEtiakQyOOE8NWN6ZxlRx1IIwJ6QM43OTvkwv036ojMlXP36f1sXThdP8QmTLvUOUrLXKz3RvP3HJhhTCiEcsRKI+0aLDaaLDVECpsUf0glnw== X-Forefront-Antispam-Report: CIP:165.204.84.17;CTRY:US;LANG:en;SCL:1;SRV:;IPV:CAL;SFV:NSPM;H:SATLEXMB04.amd.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230022)(4636009)(39860400002)(376002)(136003)(396003)(346002)(451199015)(40470700004)(46966006)(36840700001)(26005)(7696005)(40480700001)(36756003)(8936002)(70206006)(4326008)(70586007)(82740400003)(54906003)(110136005)(316002)(8676002)(36860700001)(86362001)(81166007)(2906002)(356005)(478600001)(47076005)(5660300002)(426003)(336012)(186003)(1076003)(41300700001)(40460700003)(83380400001)(82310400005)(2616005)(16526019)(2101003)(36900700001);DIR:OUT;SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 09 Oct 2022 07:11:29.0218 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: cf8b8fad-8dab-4d1a-c6e3-08daa9c57c9f X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=3dd8961f-e488-4e60-8e11-a82d994e183d;Ip=[165.204.84.17];Helo=[SATLEXMB04.amd.com] X-MS-Exchange-CrossTenant-AuthSource: DM6NAM11FT018.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: SA1PR12MB6822 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Type: text/plain; charset="utf-8" The patch add AMD pstate EPP feature introduction and what EPP preference supported for AMD processors. User can get supported list from energy_performance_available_preferences attribute file, or update current profile to energy_performance_preference file 1) See all EPP profiles $ sudo cat /sys/devices/system/cpu/cpu0/cpufreq/energy_performance_availabl= e_preferences default performance balance_performance balance_power power 2) Check current EPP profile $ sudo cat /sys/devices/system/cpu/cpu0/cpufreq/energy_performance_preferen= ce performance 3) Set new EPP profile $ sudo bash -c "echo power > /sys/devices/system/cpu/cpu0/cpufreq/energy_pe= rformance_preference" Signed-off-by: Perry Yuan --- Documentation/admin-guide/pm/amd-pstate.rst | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/Documentation/admin-guide/pm/amd-pstate.rst b/Documentation/ad= min-guide/pm/amd-pstate.rst index 83b58eb4ab4d..d0f0e115013b 100644 --- a/Documentation/admin-guide/pm/amd-pstate.rst +++ b/Documentation/admin-guide/pm/amd-pstate.rst @@ -261,6 +261,25 @@ lowest non-linear performance in `AMD CPPC Performance= Capability `_.) This attribute is read-only. =20 +``energy_performance_available_preferences`` + +All the supported EPP preference could be selected, List of the strings th= at +can be set to the ``energy_performance_preference`` attribute +those different profiles represent different energy vs efficiency hints pr= ovided +to low-level firmware +however, the ``default`` represents the epp value is set by platform firmw= are +This attribute is read-only. + +``energy_performance_preference`` + +The current energy performance preference can be read from this attribute. +and user can change current preference according to energy or performance = needs +Please get all support profiles list from +``energy_performance_available_preferences`` attribute, all the profiles a= re +integer values defined between 0 to 255 when EPP feature is enabled by pla= tform +firmware, if EPP feature is disabled, driver will ignore the written value +This attribute is read-write. + Other performance and frequency values can be read back from ``/sys/devices/system/cpu/cpuX/acpi_cppc/``, see :ref:`cppc_sysfs`. =20 --=20 2.34.1 From nobody Tue Apr 7 00:19:44 2026 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 94F36C433FE for ; Sun, 9 Oct 2022 07:11:59 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229490AbiJIHL4 (ORCPT ); Sun, 9 Oct 2022 03:11:56 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41402 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230010AbiJIHLe (ORCPT ); Sun, 9 Oct 2022 03:11:34 -0400 Received: from NAM02-DM3-obe.outbound.protection.outlook.com (mail-dm3nam02on20616.outbound.protection.outlook.com [IPv6:2a01:111:f400:7e83::616]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 9F4632A40E; Sun, 9 Oct 2022 00:11:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=EIF60k7cMuuWuEAAH+7MQCZrhDjxb0evQBl2P/fGq/88tYyHlv53b+OAtanuZdllrCcm3AE0rNIlcwiT+vENPvbQmZF4P9vzrn835F1A4VaJXfNMTTUBxWjxpItX/z3Uk0Vl2qlxcLM+sMmr5/6V/nCyidr0+0CSokoZmrphsIZz0BO4Y7SjbNAMhiYvuDCsvAEMrAUXGCO8MlkhtkZnV4zjShwfsiCCp7ZFrxTeNpeC57q6owPzA8+TfvJkJnDdbmDMG7+B+woq8MQPvVI2Q2ov6/HcTCBRdp7IrY9rcc6hmw3FdrV59leSQEOpEOjTVwoKuohuQahIigi+maICSg== 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=gLR/RPd285R7HOJk/OaThtOEmnZVKOLfnoo2UfZm8zc=; b=Wxg/g2Vv8EySs5hJ0nsLv/Jz2gsAYEDdOepzxz441s+x7T0eihxeZmmZhZF8z4de1Lvu9bkldgKlQCD/nZeryAbjaRyfttC1y5penoTSgGnK8l8BG4P79fqnMDHO2sLt6mYMJLoIjdE1yusHQm06TP9QvVjd5YnWqc4Brn5xC28ZZUmEIK+UbiUGdimsD0yARx+A3ywRvI0gm3M8ngaKVmUK3N6GGZf3iUCs0OUojCZxeT2mRNfM9SUpBfcgjTVn1EHPhFRX/AGmCgNavbyZCWB6FXTEc1mHMyYRyUW1k781aTCSpIZ/cl/bSON/YDp6CjQ0rOeRbxr8WsAfJMMjZg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=intel.com smtp.mailfrom=amd.com; dmarc=pass (p=quarantine sp=quarantine pct=100) action=none header.from=amd.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amd.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=gLR/RPd285R7HOJk/OaThtOEmnZVKOLfnoo2UfZm8zc=; b=HPLvyXvyJWt+9O3al0lIZNA7CSRY+ff8lhVqAx6mjsCtsSI5yVR0O5cemKf/xWrqBKJEpWrcwyzvnMF8UNkeoZklsyInvVpNzqhab6Zlkggs9JFWVPXshc//KTFHPDQB5SRoTlSLYHLUVWvXoOsNhGvka+eECRVk+QABX92pVvU= Received: from DM6PR03CA0077.namprd03.prod.outlook.com (2603:10b6:5:333::10) by DM4PR12MB5149.namprd12.prod.outlook.com (2603:10b6:5:390::14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5709.15; Sun, 9 Oct 2022 07:11:29 +0000 Received: from DM6NAM11FT018.eop-nam11.prod.protection.outlook.com (2603:10b6:5:333:cafe::76) by DM6PR03CA0077.outlook.office365.com (2603:10b6:5:333::10) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5709.15 via Frontend Transport; Sun, 9 Oct 2022 07:11:29 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 165.204.84.17) smtp.mailfrom=amd.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=amd.com; Received-SPF: Pass (protection.outlook.com: domain of amd.com designates 165.204.84.17 as permitted sender) receiver=protection.outlook.com; client-ip=165.204.84.17; helo=SATLEXMB04.amd.com; pr=C Received: from SATLEXMB04.amd.com (165.204.84.17) by DM6NAM11FT018.mail.protection.outlook.com (10.13.172.110) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.5709.10 via Frontend Transport; Sun, 9 Oct 2022 07:11:29 +0000 Received: from pyuan-Cloudripper.amd.com (10.180.168.240) by SATLEXMB04.amd.com (10.181.40.145) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.28; Sun, 9 Oct 2022 02:11:24 -0500 From: Perry Yuan To: , , CC: , , , , , , , , , Perry Yuan Subject: [PATCH v2 6/9] cpufreq: amd_pstate: add AMD pstate EPP support for shared memory type processor Date: Sun, 9 Oct 2022 15:10:30 +0800 Message-ID: <20221009071033.21170-7-Perry.Yuan@amd.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221009071033.21170-1-Perry.Yuan@amd.com> References: <20221009071033.21170-1-Perry.Yuan@amd.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-Originating-IP: [10.180.168.240] X-ClientProxiedBy: SATLEXMB03.amd.com (10.181.40.144) To SATLEXMB04.amd.com (10.181.40.145) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DM6NAM11FT018:EE_|DM4PR12MB5149:EE_ X-MS-Office365-Filtering-Correlation-Id: b16be755-30c9-4a4b-ac41-08daa9c57d08 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: sc4c7eXqIo0lHHmzDcDbjoOj5iVk9iqLpI5BAL2xbs+b/WLta/PL0Lnt4sZkBr07xId25vUwKzoDC03PNYdx5o59NcZlMZvIg0/DGPDwuQu3R2sF4PqvjMSWZXi4S0ZwUU1gg0eC9C/7dkFCQS9bz5oGN5KTnPmxkSLI1RgfLwcGi7t+btNlQ484f66WmN0B/tJs3Nraril04Dd6nDjRYpB01nkkITY2FgD4WIkLIV6BDgfoyPM2PMfCcmNCOAIbb6XBrJhh97bZyJDX0jMNkYeTCB8mlMwOj/YUpgB5amofbt4TkrVWdKTw+qqlLsojPDED5qIRCKHKYPltxPtQP7DnyiiQ/IG0b7vm5wpx992P5YWDAe9vm86oTWZcQ7s/uLCp1AQhEf4rhnT5E+vA0oHBii78Qa/BVum2q51VHOb/Tdk5hPDIuTNxzRqtnyLga4e+zSDyh/3ME1ft2p9e95HXizMJpY/2Dg/ohUimJCp+UcGdAm6H9ezU58+TptKQxaFz8sT9aLaGBOD/iRUhwKI6YAda+LNMCKaxXD77zj8oWZmrP1y7623YT7t3PaibQDdgo9QYPzrve2jI4QRGhXPM66db/gZtxXDZNTuWEWdgAzCa+Yg2Rx+Cxkc5tsaDa9YgSPnEh2gyfY69J89jJ9n+aqtszwbkGUELBhCivqImva8pNtOMbWpsFGCrN9/rXsyXxaPGKfeZBkYNng33CBfbsPJEnuuPofZOEDNGmgh8VTbWSnWBZNHa9If5B9UawH8g2qzSth9Yskek1ixcigB5CBSFQ2Z8JHqQVfqNlXIG5Ic4U3/foVY79i+bD5yJF7x8t4pnF3kD3mdBWbzEbQ== X-Forefront-Antispam-Report: CIP:165.204.84.17;CTRY:US;LANG:en;SCL:1;SRV:;IPV:CAL;SFV:NSPM;H:SATLEXMB04.amd.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230022)(4636009)(396003)(376002)(39860400002)(346002)(136003)(451199015)(46966006)(40470700004)(36840700001)(2906002)(8676002)(316002)(36860700001)(4326008)(70206006)(70586007)(54906003)(110136005)(41300700001)(6666004)(478600001)(36756003)(5660300002)(82310400005)(86362001)(47076005)(7696005)(8936002)(16526019)(1076003)(426003)(336012)(2616005)(82740400003)(186003)(356005)(81166007)(26005)(40480700001)(40460700003)(2101003)(36900700001);DIR:OUT;SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 09 Oct 2022 07:11:29.6937 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: b16be755-30c9-4a4b-ac41-08daa9c57d08 X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=3dd8961f-e488-4e60-8e11-a82d994e183d;Ip=[165.204.84.17];Helo=[SATLEXMB04.amd.com] X-MS-Exchange-CrossTenant-AuthSource: DM6NAM11FT018.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: DM4PR12MB5149 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Type: text/plain; charset="utf-8" Add Energy Performance Preference support for AMD SOCs which do not contain a designated MSR for CPPC support. A shared memory interface is used for CPPC on these SOCs and the ACPI PCC channel is used to enable EPP and reset the desired performance. Signed-off-by: Perry Yuan --- drivers/cpufreq/amd-pstate.c | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/drivers/cpufreq/amd-pstate.c b/drivers/cpufreq/amd-pstate.c index 14a275c22aff..4c24fe391a55 100644 --- a/drivers/cpufreq/amd-pstate.c +++ b/drivers/cpufreq/amd-pstate.c @@ -135,12 +135,25 @@ static inline int pstate_enable(bool enable) =20 static int cppc_enable(bool enable) { + struct cppc_perf_ctrls perf_ctrls; int cpu, ret =3D 0; =20 for_each_present_cpu(cpu) { ret =3D cppc_set_enable(cpu, enable); if (ret) return ret; + if (epp_enabled) { + /* Enable autonomous mode for EPP */ + ret =3D cppc_set_auto_epp(cpu, enable); + if (ret) + return ret; + + /* Set desired perf as zero to allow EPP firmware control */ + perf_ctrls.desired_perf =3D 0; + ret =3D cppc_set_perf(cpu, &perf_ctrls); + if (ret) + return ret; + } } =20 return ret; --=20 2.34.1 From nobody Tue Apr 7 00:19:44 2026 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 88074C433F5 for ; Sun, 9 Oct 2022 07:12:20 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230053AbiJIHMS (ORCPT ); Sun, 9 Oct 2022 03:12:18 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41704 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230051AbiJIHLq (ORCPT ); Sun, 9 Oct 2022 03:11:46 -0400 Received: from NAM02-BN1-obe.outbound.protection.outlook.com (mail-bn1nam07on2052.outbound.protection.outlook.com [40.107.212.52]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4DDE63384F; Sun, 9 Oct 2022 00:11:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=fRxX0joW1WZKq2gK9+iM7N9I8KUmFw/DlJBdPGkCxG9/lHYHdzIgDphLPJ04BwFsjtDedAbJUTHAfD5dYADIH2Efmmk5IQ3W2iN3zuCwLI/jFiLz2JzjcRUACSS0Wn4S3vRztdWvBVFbN3aFaur9kvini9Bm1p8IcRaxSfBi5FADyo+4SvNfovzscINB4OHJVyqJEn+cNGzZ6VThTHIWId3uL5l9D8KE2ZC+oEiMAVbogptuSeyH/ZdBIuVMUdwB357grjGgdz+R361w5Q6UHlvmLZCcTHfVjEcyU97o009gBTaayH0lWQCHdAh8eJQepXGLuVmoZoDVDmz0QR5hAw== 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=OUe8rLv7eX+N6EQlKUR00aPck5ZXZpuuE4ZMUemk3O4=; b=eP0ZG/Ez6DXi3i3wRuE/2CjGOm4LCDq0i63w/j4pF9sQjoXhL7B6yE1BuQE+vHBCX7OKiaO54GqJIWvmR9l4GQmrAw/+BfLluOVtSAgk2pp2MRMiQPMMRibPleF3S2z5S6kYsZOdfAWpiJuUS5/2fqaxOnsQ137i9juM1AZ3Vj27x5o7abKDRxau7RoimNac45PV52AlZY8XHLsTUrzpml6aMFdTVV5rNQJIqTW+GxGiqvuHO+3but26ycpYvAoOzD7/MFzCox5xUJhH6DkiFvcvl4LLCz2wkGlc2EXx9Bdmc3I8Abzz3V9R0uxIGn2lJXUWOEuL8BvWy9JXNh9Dlg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=intel.com smtp.mailfrom=amd.com; dmarc=pass (p=quarantine sp=quarantine pct=100) action=none header.from=amd.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amd.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=OUe8rLv7eX+N6EQlKUR00aPck5ZXZpuuE4ZMUemk3O4=; b=nvfB91/NI2KwClArrO4jdP35cCMCObf+nJz6bxrUzrGDEk39CD2eXsvrxi515ljbV1gOUOQFXiAVwWq8Dz0x5RAp0bDikMEXXp9HqOQGPY63PN6UMO+0c8oHmrIp9gZQvH5ZmiZfO822eHcI1BNxCR3McPzUqPY8Gpr4wm0JAv0= Received: from DS7PR05CA0021.namprd05.prod.outlook.com (2603:10b6:5:3b9::26) by CH3PR12MB7595.namprd12.prod.outlook.com (2603:10b6:610:14c::11) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5676.17; Sun, 9 Oct 2022 07:11:32 +0000 Received: from DM6NAM11FT095.eop-nam11.prod.protection.outlook.com (2603:10b6:5:3b9:cafe::a9) by DS7PR05CA0021.outlook.office365.com (2603:10b6:5:3b9::26) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5723.13 via Frontend Transport; Sun, 9 Oct 2022 07:11:32 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 165.204.84.17) smtp.mailfrom=amd.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=amd.com; Received-SPF: Pass (protection.outlook.com: domain of amd.com designates 165.204.84.17 as permitted sender) receiver=protection.outlook.com; client-ip=165.204.84.17; helo=SATLEXMB04.amd.com; pr=C Received: from SATLEXMB04.amd.com (165.204.84.17) by DM6NAM11FT095.mail.protection.outlook.com (10.13.172.180) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.5709.10 via Frontend Transport; Sun, 9 Oct 2022 07:11:32 +0000 Received: from pyuan-Cloudripper.amd.com (10.180.168.240) by SATLEXMB04.amd.com (10.181.40.145) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.28; Sun, 9 Oct 2022 02:11:28 -0500 From: Perry Yuan To: , , CC: , , , , , , , , , Perry Yuan Subject: [PATCH v2 7/9] cpufreq: amd_pstate: add AMD Pstate EPP support for the MSR based processors Date: Sun, 9 Oct 2022 15:10:31 +0800 Message-ID: <20221009071033.21170-8-Perry.Yuan@amd.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221009071033.21170-1-Perry.Yuan@amd.com> References: <20221009071033.21170-1-Perry.Yuan@amd.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-Originating-IP: [10.180.168.240] X-ClientProxiedBy: SATLEXMB03.amd.com (10.181.40.144) To SATLEXMB04.amd.com (10.181.40.145) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DM6NAM11FT095:EE_|CH3PR12MB7595:EE_ X-MS-Office365-Filtering-Correlation-Id: 02cdc7b3-02bb-47be-4f4e-08daa9c57ebf X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 0cIJF7Yzi0mwJwWblpWMjVv8sbyf8qUk6gSMzS7GBVZMdsxKiNwtLIe4QLch8Oa4xtbIVHFqv/HKomSDwSIIWxN/5wknU/IcxgeM7O6zN26iR6QTSKxi5iG2DPhD9N8tBjaS/CbeEj3TkVf0IxrhmgyZ7WSJelw5K+LlY4LljBBYNVk1FQZmyg7dH78Szj65whePFpjVLG69J2x6j4EiW0uQaeyHIAcsSPHZzG/HYvmr7LDjIFn6MUrCE9sFbvD9Ts1N7bFMEqjvX4Z8LIZpdbZdzm8dFLbDgNTPmApAXUzVP4LOZzwk2H/JHJwKAYlkpmA3V/pnp6lRSACNkoerLjRfBmcWa0DQTQxhq8O8rMMS/gUh+fkFj2B3Gw0gF1OFEm1ZsGLWioAVwxK5qaIkT31OZxaRcbuwMp+q/+ZUJ0/PjGSppDXtet52Z6AjrY2pyckHOlv0cbtpFT3OLBSxk6ZQipu7/68Q7ZkIdXs63/HypqjS4xIAzgTh2TXi11VkxzlJ/8TL9kSrMNH+qbKGSLF/qEsm0vI/YlHesoqbDh8QYs9vVRj1avBcup9igMuTZTed53o1It5Cvac7a4PzrciPK5PfTXLMPDic6N6UO8yE5e5Uc+vvhdihE4UYNIov2YaDig4dIU1ubpkuk4xqgQcQZH+TPhNZaBQ2k0+bswwPf9RzuBmUhGd2AY+PQkTTUcftmHo9n/2ZHCSHaMFfaUbDlutiufqJ5Hr8WtCG6ZoHhOEoAfSuFr5VEcG2n7wAg61qnT26MVlBr/eR5WL3OYiPVSUCJMYazsaSaOPfIj01Bb7rZI340axYV7p2VdT9VjcLOzEaJCoQtjb7yT9UD7FsCZGWqg5e5GnD9igLIgk= X-Forefront-Antispam-Report: CIP:165.204.84.17;CTRY:US;LANG:en;SCL:1;SRV:;IPV:CAL;SFV:NSPM;H:SATLEXMB04.amd.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230022)(4636009)(346002)(396003)(39860400002)(136003)(376002)(451199015)(36840700001)(46966006)(40470700004)(26005)(40480700001)(36756003)(40460700003)(81166007)(36860700001)(82740400003)(86362001)(82310400005)(4326008)(8676002)(356005)(316002)(70586007)(70206006)(2906002)(30864003)(54906003)(5660300002)(8936002)(41300700001)(2616005)(47076005)(426003)(1076003)(186003)(336012)(83380400001)(478600001)(16526019)(7696005)(6666004)(110136005)(36900700001)(2101003)(309714004);DIR:OUT;SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 09 Oct 2022 07:11:32.5839 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 02cdc7b3-02bb-47be-4f4e-08daa9c57ebf X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=3dd8961f-e488-4e60-8e11-a82d994e183d;Ip=[165.204.84.17];Helo=[SATLEXMB04.amd.com] X-MS-Exchange-CrossTenant-AuthSource: DM6NAM11FT095.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: CH3PR12MB7595 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Type: text/plain; charset="utf-8" Add EPP driver support for those AMD CPUs which has full MSR feature enabled, The EPP is used in the DPM controller to drive the frequency that a core is going to operate during short periods of activity. EPP values will be utilized for different OS profiles (balanced, performanc= e, power savings). cppc performance can be controlled by the user space interf= ace sys attributes for min and max frequency limits, when pstate driver is working under power save policy. EPP scale is 0 - 255, 0 is the max performance and 255 is min level. balance_performance (0x80) can provide best balance performance and watt for most of system, meanwhile user can choose performance policy on needs. $ cat /sys/devices/system/cpu/cpufreq/policy0/energy_performance_available_= preferences default performance balance_performance balance_power power $ cat /sys/devices/system/cpu/cpufreq/policy0/energy_performance_preference balance_performance Signed-off-by: Perry Yuan --- arch/x86/include/asm/msr-index.h | 4 + drivers/cpufreq/amd-pstate.c | 798 ++++++++++++++++++++++++++++++- 2 files changed, 794 insertions(+), 8 deletions(-) diff --git a/arch/x86/include/asm/msr-index.h b/arch/x86/include/asm/msr-in= dex.h index e5ea1c9f747b..53cbdb0c522b 100644 --- a/arch/x86/include/asm/msr-index.h +++ b/arch/x86/include/asm/msr-index.h @@ -588,6 +588,10 @@ #define MSR_AMD64_PERF_CNTR_GLOBAL_CTL 0xc0000301 #define MSR_AMD64_PERF_CNTR_GLOBAL_STATUS_CLR 0xc0000302 =20 +#define AMD_CPPC_EPP_PERFORMANCE 0x00 +#define AMD_CPPC_EPP_BALANCE_PERFORMANCE 0x80 +#define AMD_CPPC_EPP_BALANCE_POWERSAVE 0xBF +#define AMD_CPPC_EPP_POWERSAVE 0xFF /* Fam 17h MSRs */ #define MSR_F17H_IRPERF 0xc00000e9 =20 diff --git a/drivers/cpufreq/amd-pstate.c b/drivers/cpufreq/amd-pstate.c index 4c24fe391a55..98fb4a31791e 100644 --- a/drivers/cpufreq/amd-pstate.c +++ b/drivers/cpufreq/amd-pstate.c @@ -65,9 +65,11 @@ MODULE_PARM_DESC(shared_mem, =20 static bool epp_enabled =3D false; module_param(epp_enabled, bool, 0444); -MODULE_PARM_DESC(epp_enabled, "Enable energy performance preference (EPP) = control"); +MODULE_PARM_DESC(epp_enabled, + "Enable energy performance preference (EPP) control"); =20 -static struct cpufreq_driver amd_pstate_driver; +static struct cpufreq_driver *default_pstate_driver; +static struct amd_cpudata **all_cpu_data; =20 /** * struct amd_aperf_mperf @@ -79,6 +81,7 @@ struct amd_aperf_mperf { u64 aperf; u64 mperf; u64 tsc; + u64 time; }; =20 /** @@ -101,7 +104,19 @@ struct amd_aperf_mperf { * @prev: Last Aperf/Mperf/tsc count value read from register * @freq: current cpu frequency value * @boost_supported: check whether the Processor or SBIOS supports boost m= ode - * + * @epp_powersave: Last saved CPPC energy performance preference + when policy switched to performance + * @epp_policy: Last saved policy used to set energy-performance preference + * @epp_cached: Cached CPPC energy-performance preference value + * @policy: Cpufreq policy value + * @sched_flags: Store scheduler flags for possible cross CPU update + * @update_util_set: CPUFreq utility callback is set + * @last_update: Time stamp of the last performance state update + * @cppc_boost_min: Last CPPC boosted min performance state + * @cppc_cap1_cached: Cached value of the last CPPC Capabilities MSR + * @update_util: Cpufreq utility callback information + * @sample: the stored performance sample + * The amd_cpudata is key private data for each CPU thread in AMD P-State,= and * represents all the attributes and goals that AMD P-State requests at ru= ntime. */ @@ -126,8 +141,197 @@ struct amd_cpudata { =20 u64 freq; bool boost_supported; + u64 cppc_hw_conf_cached; + + /* EPP feature related attributes*/ + s16 epp_powersave; + s16 epp_policy; + s16 epp_cached; + u32 policy; + u32 sched_flags; + bool update_util_set; + u64 last_update; + u64 last_io_update; + u32 cppc_boost_min; + u64 cppc_cap1_cached; + struct update_util_data update_util; + struct amd_aperf_mperf sample; +}; + +/** + * struct amd_pstate_params - global parameters for the performance control + * @ cppc_boost_disabled wheher the core performance boost disabled + */ +struct amd_pstate_params { + bool cppc_boost_disabled; +}; + +/* + * AMD Energy Preference Performance (EPP) + * The EPP is used in the CCLK DPM controller to drive + * the frequency that a core is going to operate during + * short periods of activity. EPP values will be utilized for + * different OS profiles (balanced, performance, power savings) + * display strings corresponding to EPP index in the + * energy_perf_strings[] + * index String + *------------------------------------- + * 0 default + * 1 performance + * 2 balance_performance + * 3 balance_power + * 4 power + */ +enum energy_perf_value_index { + EPP_INDEX_DEFAULT =3D 0, + EPP_INDEX_PERFORMANCE, + EPP_INDEX_BALANCE_PERFORMANCE, + EPP_INDEX_BALANCE_POWERSAVE, + EPP_INDEX_POWERSAVE, +}; + +static const char * const energy_perf_strings[] =3D { + [EPP_INDEX_DEFAULT] =3D "default", + [EPP_INDEX_PERFORMANCE] =3D "performance", + [EPP_INDEX_BALANCE_PERFORMANCE] =3D "balance_performance", + [EPP_INDEX_BALANCE_POWERSAVE] =3D "balance_power", + [EPP_INDEX_POWERSAVE] =3D "power", + NULL +}; + +static unsigned int epp_values[] =3D { + [EPP_INDEX_DEFAULT] =3D 0, + [EPP_INDEX_PERFORMANCE] =3D AMD_CPPC_EPP_PERFORMANCE, + [EPP_INDEX_BALANCE_PERFORMANCE] =3D AMD_CPPC_EPP_BALANCE_PERFORMANCE, + [EPP_INDEX_BALANCE_POWERSAVE] =3D AMD_CPPC_EPP_BALANCE_POWERSAVE, + [EPP_INDEX_POWERSAVE] =3D AMD_CPPC_EPP_POWERSAVE, }; =20 +static struct amd_pstate_params global_params; + +static DEFINE_MUTEX(amd_pstate_limits_lock); +static DEFINE_MUTEX(amd_pstate_driver_lock); +static DEFINE_SPINLOCK(amd_pstate_cpu_lock); + +static bool cppc_boost __read_mostly; +struct kobject *amd_pstate_kobj; + +#ifdef CONFIG_ACPI_CPPC_LIB +static s16 amd_pstate_get_epp(struct amd_cpudata *cpudata, u64 cppc_req_ca= ched) +{ + s16 epp; + struct cppc_perf_caps perf_caps; + int ret; + + if (boot_cpu_has(X86_FEATURE_CPPC)) { + if (!cppc_req_cached) { + epp =3D rdmsrl_on_cpu(cpudata->cpu, MSR_AMD_CPPC_REQ, + &cppc_req_cached); + if (epp) + return epp; + } + epp =3D (cppc_req_cached >> 24) & 0xFF; + } else { + ret =3D cppc_get_epp_caps(cpudata->cpu, &perf_caps); + if (ret < 0) { + pr_debug("Could not retrieve energy perf value (%d)\n", ret); + return -EIO; + } + epp =3D (s16) perf_caps.energy_perf; + } + + return epp; +} +#endif + +static int amd_pstate_get_energy_pref_index(struct amd_cpudata *cpudata, i= nt *raw_epp) +{ + s16 epp; + int index =3D -EINVAL; + + *raw_epp =3D 0; + epp =3D amd_pstate_get_epp(cpudata, 0); + if (epp < 0) + return epp; + + switch (epp) { + case AMD_CPPC_EPP_PERFORMANCE: + index =3D EPP_INDEX_PERFORMANCE; + break; + case AMD_CPPC_EPP_BALANCE_PERFORMANCE: + index =3D EPP_INDEX_BALANCE_PERFORMANCE; + break; + case AMD_CPPC_EPP_BALANCE_POWERSAVE: + index =3D EPP_INDEX_BALANCE_POWERSAVE; + break; + case AMD_CPPC_EPP_POWERSAVE: + index =3D EPP_INDEX_POWERSAVE; + break; + default: + *raw_epp =3D epp; + index =3D 0; + } + + return index; +} + +#ifdef CONFIG_ACPI_CPPC_LIB +static int amd_pstate_set_epp(struct amd_cpudata *cpudata, u32 epp) +{ + int ret; + struct cppc_perf_ctrls perf_ctrls; + + if (boot_cpu_has(X86_FEATURE_CPPC)) { + u64 value =3D READ_ONCE(cpudata->cppc_req_cached); + + value &=3D ~GENMASK_ULL(31, 24); + value |=3D (u64)epp << 24; + WRITE_ONCE(cpudata->cppc_req_cached, value); + + ret =3D wrmsrl_on_cpu(cpudata->cpu, MSR_AMD_CPPC_REQ, value); + if (!ret) + cpudata->epp_cached =3D epp; + } else { + perf_ctrls.energy_perf =3D epp; + ret =3D cppc_set_epp_perf(cpudata->cpu, &perf_ctrls); + if (ret) { + pr_debug("failed to set energy perf value (%d)\n", ret); + return ret; + } + cpudata->epp_cached =3D epp; + } + + return ret; +} + +static int amd_pstate_set_energy_pref_index(struct amd_cpudata *cpudata, + int pref_index, bool use_raw, + u32 raw_epp) +{ + int epp =3D -EINVAL; + int ret; + + if (!pref_index) { + pr_debug("EPP pref_index is invalid\n"); + return -EINVAL; + } + + if (use_raw) + epp =3D raw_epp; + else if (epp =3D=3D -EINVAL) + epp =3D epp_values[pref_index]; + + if (epp > 0 && cpudata->policy =3D=3D CPUFREQ_POLICY_PERFORMANCE) { + pr_debug("EPP cannot be set under performance policy\n"); + return -EBUSY; + } + + ret =3D amd_pstate_set_epp(cpudata, epp); + + return ret; +} +#endif + static inline int pstate_enable(bool enable) { return wrmsrl_safe(MSR_AMD_CPPC_ENABLE, enable); @@ -496,7 +700,7 @@ static void amd_pstate_boost_init(struct amd_cpudata *c= pudata) return; =20 cpudata->boost_supported =3D true; - amd_pstate_driver.boost_enabled =3D true; + default_pstate_driver->boost_enabled =3D true; } =20 static int amd_pstate_cpu_init(struct cpufreq_policy *policy) @@ -660,10 +864,108 @@ static ssize_t show_amd_pstate_highest_perf(struct c= pufreq_policy *policy, return sprintf(&buf[0], "%u\n", perf); } =20 +static ssize_t show_energy_performance_available_preferences( + struct cpufreq_policy *policy, char *buf) +{ + int i =3D 0; + int ret =3D 0; + + while (energy_perf_strings[i] !=3D NULL) + ret +=3D sprintf(&buf[ret], "%s ", energy_perf_strings[i++]); + + ret +=3D sprintf(&buf[ret], "\n"); + + return ret; +} + +static ssize_t store_energy_performance_preference( + struct cpufreq_policy *policy, const char *buf, size_t count) +{ + struct amd_cpudata *cpudata =3D policy->driver_data; + char str_preference[21]; + bool raw =3D false; + ssize_t ret; + u32 epp =3D 0; + + ret =3D sscanf(buf, "%20s", str_preference); + if (ret !=3D 1) + return -EINVAL; + + ret =3D match_string(energy_perf_strings, -1, str_preference); + if (ret < 0) { + ret =3D kstrtouint(buf, 10, &epp); + if (ret) + return ret; + + if ((epp > 255) || (epp < 0)) + return -EINVAL; + + raw =3D true; + } + + mutex_lock(&amd_pstate_limits_lock); + ret =3D amd_pstate_set_energy_pref_index(cpudata, ret, raw, epp); + mutex_unlock(&amd_pstate_limits_lock); + + return ret ?: count; +} + +static ssize_t show_energy_performance_preference( + struct cpufreq_policy *policy, char *buf) +{ + struct amd_cpudata *cpudata =3D policy->driver_data; + int preference, raw_epp; + + preference =3D amd_pstate_get_energy_pref_index(cpudata, &raw_epp); + if (preference < 0) + return preference; + + if (raw_epp) + return sprintf(buf, "%d\n", raw_epp); + else + return sprintf(buf, "%s\n", energy_perf_strings[preference]); +} + +static void amd_pstate_update_policies(void) +{ + int cpu; + + for_each_possible_cpu(cpu) + cpufreq_update_policy(cpu); +} + +static ssize_t show_pstate_dynamic_boost(struct kobject *kobj, + struct kobj_attribute *attr, char *buf) +{ + return sprintf(buf, "%u\n", cppc_boost); +} + +static ssize_t store_pstate_dynamic_boost(struct kobject *a, + struct kobj_attribute *b, + const char *buf, size_t count) +{ + unsigned int input; + int ret; + + ret =3D kstrtouint(buf, 10, &input); + if (ret) + return ret; + + mutex_lock(&amd_pstate_driver_lock); + cppc_boost =3D !!input; + amd_pstate_update_policies(); + mutex_unlock(&amd_pstate_driver_lock); + + return count; +} + cpufreq_freq_attr_ro(amd_pstate_max_freq); cpufreq_freq_attr_ro(amd_pstate_lowest_nonlinear_freq); =20 cpufreq_freq_attr_ro(amd_pstate_highest_perf); +cpufreq_freq_attr_rw(energy_performance_preference); +cpufreq_freq_attr_ro(energy_performance_available_preferences); +define_one_global_rw(pstate_dynamic_boost); =20 static struct freq_attr *amd_pstate_attr[] =3D { &amd_pstate_max_freq, @@ -672,6 +974,424 @@ static struct freq_attr *amd_pstate_attr[] =3D { NULL, }; =20 +static struct freq_attr *amd_pstate_epp_attr[] =3D { + &amd_pstate_max_freq, + &amd_pstate_lowest_nonlinear_freq, + &amd_pstate_highest_perf, + &energy_performance_preference, + &energy_performance_available_preferences, + NULL, +}; + +static struct attribute *pstate_global_attributes[] =3D { + &pstate_dynamic_boost.attr, + NULL +}; + +static const struct attribute_group amd_pstate_global_attr_group =3D { + .attrs =3D pstate_global_attributes, +}; + +static inline void update_boost_state(void) +{ + u64 misc_en; + struct amd_cpudata *cpudata; + + cpudata =3D all_cpu_data[0]; + rdmsrl(MSR_AMD_CPPC_HW_CTL, misc_en); + global_params.cppc_boost_disabled =3D misc_en & AMD_CPPC_PRECISION_BOOST_= ENABLED; +} + +static int amd_pstate_init_cpu(unsigned int cpunum) +{ + struct amd_cpudata *cpudata; + + cpudata =3D all_cpu_data[cpunum]; + if (!cpudata) { + cpudata =3D kzalloc(sizeof(*cpudata), GFP_KERNEL); + if (!cpudata) + return -ENOMEM; + WRITE_ONCE(all_cpu_data[cpunum], cpudata); + + cpudata->cpu =3D cpunum; + } + cpudata->epp_powersave =3D -EINVAL; + cpudata->epp_policy =3D 0; + pr_debug("controlling: cpu %d\n", cpunum); + return 0; +} + +static int __amd_pstate_cpu_init(struct cpufreq_policy *policy) +{ + int min_freq, max_freq, nominal_freq, lowest_nonlinear_freq, ret; + struct amd_cpudata *cpudata; + struct device *dev; + int rc; + u64 value; + + rc =3D amd_pstate_init_cpu(policy->cpu); + if (rc) + return rc; + + cpudata =3D all_cpu_data[policy->cpu]; + + dev =3D get_cpu_device(policy->cpu); + if (!dev) + goto free_cpudata1; + + rc =3D amd_pstate_init_perf(cpudata); + if (rc) + goto free_cpudata1; + + min_freq =3D amd_get_min_freq(cpudata); + max_freq =3D amd_get_max_freq(cpudata); + nominal_freq =3D amd_get_nominal_freq(cpudata); + lowest_nonlinear_freq =3D amd_get_lowest_nonlinear_freq(cpudata); + if (min_freq < 0 || max_freq < 0 || min_freq > max_freq) { + dev_err(dev, "min_freq(%d) or max_freq(%d) value is incorrect\n", + min_freq, max_freq); + ret =3D -EINVAL; + goto free_cpudata1; + } + + policy->min =3D min_freq; + policy->max =3D max_freq; + + policy->cpuinfo.min_freq =3D min_freq; + policy->cpuinfo.max_freq =3D max_freq; + /* It will be updated by governor */ + policy->cur =3D policy->cpuinfo.min_freq; + + /* Initial processor data capability frequencies */ + cpudata->max_freq =3D max_freq; + cpudata->min_freq =3D min_freq; + cpudata->nominal_freq =3D nominal_freq; + cpudata->lowest_nonlinear_freq =3D lowest_nonlinear_freq; + + policy->driver_data =3D cpudata; + + update_boost_state(); + cpudata->epp_cached =3D amd_pstate_get_epp(cpudata, value); + + policy->min =3D policy->cpuinfo.min_freq; + policy->max =3D policy->cpuinfo.max_freq; + + if (boot_cpu_has(X86_FEATURE_CPPC)) + policy->fast_switch_possible =3D true; + + if (!shared_mem && boot_cpu_has(X86_FEATURE_CPPC)) { + ret =3D rdmsrl_on_cpu(cpudata->cpu, MSR_AMD_CPPC_REQ, &value); + if (ret) + return ret; + WRITE_ONCE(cpudata->cppc_req_cached, value); + + ret =3D rdmsrl_on_cpu(cpudata->cpu, MSR_AMD_CPPC_CAP1, &value); + if (ret) + return ret; + WRITE_ONCE(cpudata->cppc_cap1_cached, value); + } + amd_pstate_boost_init(cpudata); + + return 0; + +free_cpudata1: + kfree(cpudata); + return ret; +} + +static int amd_pstate_epp_cpu_init(struct cpufreq_policy *policy) +{ + int ret; + + ret =3D __amd_pstate_cpu_init(policy); + if (ret) + return ret; + /* + * Set the policy to powersave to provide a valid fallback value in case + * the default cpufreq governor is neither powersave nor performance. + */ + policy->policy =3D CPUFREQ_POLICY_POWERSAVE; + + return 0; +} + +static int amd_pstate_epp_cpu_exit(struct cpufreq_policy *policy) +{ + pr_debug("amd-pstate: CPU %d exiting\n", policy->cpu); + policy->fast_switch_possible =3D false; + return 0; +} + +static void amd_pstate_update_max_freq(unsigned int cpu) +{ + struct cpufreq_policy *policy =3D cpufreq_cpu_acquire(cpu); + + if (!policy) + return; + + refresh_frequency_limits(policy); + cpufreq_cpu_release(policy); +} + +static void amd_pstate_epp_update_limits(unsigned int cpu) +{ + mutex_lock(&amd_pstate_driver_lock); + update_boost_state(); + if (global_params.cppc_boost_disabled) { + for_each_possible_cpu(cpu) + amd_pstate_update_max_freq(cpu); + } else { + cpufreq_update_policy(cpu); + } + mutex_unlock(&amd_pstate_driver_lock); +} + +static int cppc_boost_hold_time_ns =3D 3 * NSEC_PER_MSEC; + +static inline void amd_pstate_boost_up(struct amd_cpudata *cpudata) +{ + u64 hwp_req =3D READ_ONCE(cpudata->cppc_req_cached); + u64 hwp_cap =3D READ_ONCE(cpudata->cppc_cap1_cached); + u32 max_limit =3D (hwp_req & 0xff); + u32 min_limit =3D (hwp_req & 0xff00) >> 8; + u32 boost_level1; + + /* If max and min are equal or already at max, nothing to boost */ + if (max_limit =3D=3D min_limit) + return; + + /* Set boost max and min to initial value */ + if (!cpudata->cppc_boost_min) + cpudata->cppc_boost_min =3D min_limit; + + boost_level1 =3D ((AMD_CPPC_NOMINAL_PERF(hwp_cap) + min_limit) >> 1); + + if (cpudata->cppc_boost_min < boost_level1) + cpudata->cppc_boost_min =3D boost_level1; + else if (cpudata->cppc_boost_min < AMD_CPPC_NOMINAL_PERF(hwp_cap)) + cpudata->cppc_boost_min =3D AMD_CPPC_NOMINAL_PERF(hwp_cap); + else if (cpudata->cppc_boost_min =3D=3D AMD_CPPC_NOMINAL_PERF(hwp_cap)) + cpudata->cppc_boost_min =3D max_limit; + else + return; + + hwp_req &=3D ~AMD_CPPC_MIN_PERF(~0L); + hwp_req |=3D AMD_CPPC_MIN_PERF(cpudata->cppc_boost_min); + wrmsrl_safe_on_cpu(cpudata->cpu, MSR_AMD_CPPC_REQ, hwp_req); + cpudata->last_update =3D cpudata->sample.time; +} + +static inline void amd_pstate_boost_down(struct amd_cpudata *cpudata) +{ + bool expired; + + if (cpudata->cppc_boost_min) { + expired =3D time_after64(cpudata->sample.time, cpudata->last_update + + cppc_boost_hold_time_ns); + + if (expired) { + wrmsrl_safe_on_cpu(cpudata->cpu, MSR_AMD_CPPC_REQ, + cpudata->cppc_req_cached); + cpudata->cppc_boost_min =3D 0; + } + } + + cpudata->last_update =3D cpudata->sample.time; +} + +static inline void amd_pstate_boost_update_util(struct amd_cpudata *cpudat= a, + u64 time) +{ + cpudata->sample.time =3D time; + if (smp_processor_id() !=3D cpudata->cpu) + return; + + if (cpudata->sched_flags & SCHED_CPUFREQ_IOWAIT) { + bool do_io =3D false; + + cpudata->sched_flags =3D 0; + /* + * Set iowait_boost flag and update time. Since IO WAIT flag + * is set all the time, we can't just conclude that there is + * some IO bound activity is scheduled on this CPU with just + * one occurrence. If we receive at least two in two + * consecutive ticks, then we treat as boost candidate. + * This is leveraged from Intel Pstate driver. + */ + if (time_before64(time, cpudata->last_io_update + 2 * TICK_NSEC)) + do_io =3D true; + + cpudata->last_io_update =3D time; + + if (do_io) + amd_pstate_boost_up(cpudata); + + } else { + amd_pstate_boost_down(cpudata); + } +} + +static inline void amd_pstate_cppc_update_hook(struct update_util_data *da= ta, + u64 time, unsigned int flags) +{ + struct amd_cpudata *cpudata =3D container_of(data, + struct amd_cpudata, update_util); + + cpudata->sched_flags |=3D flags; + + if (smp_processor_id() =3D=3D cpudata->cpu) + amd_pstate_boost_update_util(cpudata, time); +} + +static void amd_pstate_clear_update_util_hook(unsigned int cpu) +{ + struct amd_cpudata *cpudata =3D all_cpu_data[cpu]; + + if (!cpudata->update_util_set) + return; + + cpufreq_remove_update_util_hook(cpu); + cpudata->update_util_set =3D false; + synchronize_rcu(); +} + +static void amd_pstate_set_update_util_hook(unsigned int cpu_num) +{ + struct amd_cpudata *cpudata =3D all_cpu_data[cpu_num]; + + if (!cppc_boost) { + if (cpudata->update_util_set) + amd_pstate_clear_update_util_hook(cpudata->cpu); + return; + } + + if (cpudata->update_util_set) + return; + + cpudata->sample.time =3D 0; + cpufreq_add_update_util_hook(cpu_num, &cpudata->update_util, + amd_pstate_cppc_update_hook); + cpudata->update_util_set =3D true; +} + +static void amd_pstate_epp_init(unsigned int cpu) +{ + struct amd_cpudata *cpudata =3D all_cpu_data[cpu]; + u32 max_perf, min_perf; + u64 value; + s16 epp; + int ret; + + max_perf =3D READ_ONCE(cpudata->highest_perf); + min_perf =3D READ_ONCE(cpudata->lowest_perf); + + value =3D READ_ONCE(cpudata->cppc_req_cached); + + if (cpudata->policy =3D=3D CPUFREQ_POLICY_PERFORMANCE) + min_perf =3D max_perf; + + /* Initial min/max values for CPPC Performance Controls Register */ + value &=3D ~AMD_CPPC_MIN_PERF(~0L); + value |=3D AMD_CPPC_MIN_PERF(min_perf); + + value &=3D ~AMD_CPPC_MAX_PERF(~0L); + value |=3D AMD_CPPC_MAX_PERF(max_perf); + + /* CPPC EPP feature require to set zero to the desire perf bit */ + value &=3D ~AMD_CPPC_DES_PERF(~0L); + value |=3D AMD_CPPC_DES_PERF(0); + + if (cpudata->epp_policy =3D=3D cpudata->policy) + goto skip_epp; + + cpudata->epp_policy =3D cpudata->policy; + + if (cpudata->policy =3D=3D CPUFREQ_POLICY_PERFORMANCE) { + epp =3D amd_pstate_get_epp(cpudata, value); + cpudata->epp_powersave =3D epp; + if (epp < 0) + goto skip_epp; + /* force the epp value to be zero for performance policy */ + epp =3D 0; + } else { + if (cpudata->epp_powersave < 0) + goto skip_epp; + /* Get BIOS pre-defined epp value */ + epp =3D amd_pstate_get_epp(cpudata, value); + if (epp) + goto skip_epp; + epp =3D cpudata->epp_powersave; + } + /* Set initial EPP value */ + if (boot_cpu_has(X86_FEATURE_CPPC)) { + value &=3D ~GENMASK_ULL(31, 24); + value |=3D (u64)epp << 24; + } + +skip_epp: + WRITE_ONCE(cpudata->cppc_req_cached, value); + ret =3D wrmsrl_on_cpu(cpudata->cpu, MSR_AMD_CPPC_REQ, value); + if (!ret) + cpudata->epp_cached =3D epp; +} + +static void amd_pstate_set_max_limits(struct amd_cpudata *cpudata) +{ + u64 hwp_cap =3D READ_ONCE(cpudata->cppc_cap1_cached); + u64 hwp_req =3D READ_ONCE(cpudata->cppc_req_cached); + u32 max_limit =3D (hwp_cap >> 24) & 0xff; + + hwp_req &=3D ~AMD_CPPC_MIN_PERF(~0L); + hwp_req |=3D AMD_CPPC_MIN_PERF(max_limit); + wrmsrl_on_cpu(cpudata->cpu, MSR_AMD_CPPC_REQ, hwp_req); +} + +static int amd_pstate_epp_set_policy(struct cpufreq_policy *policy) +{ + struct amd_cpudata *cpudata; + + if (!policy->cpuinfo.max_freq) + return -ENODEV; + + pr_debug("set_policy: cpuinfo.max %u policy->max %u\n", + policy->cpuinfo.max_freq, policy->max); + + cpudata =3D all_cpu_data[policy->cpu]; + cpudata->policy =3D policy->policy; + + if (boot_cpu_has(X86_FEATURE_CPPC)) { + mutex_lock(&amd_pstate_limits_lock); + + if (cpudata->policy =3D=3D CPUFREQ_POLICY_PERFORMANCE) { + amd_pstate_clear_update_util_hook(policy->cpu); + amd_pstate_set_max_limits(cpudata); + } else { + amd_pstate_set_update_util_hook(policy->cpu); + } + + if (boot_cpu_has(X86_FEATURE_CPPC)) + amd_pstate_epp_init(policy->cpu); + + mutex_unlock(&amd_pstate_limits_lock); + } + + return 0; +} + +static void amd_pstate_verify_cpu_policy(struct amd_cpudata *cpudata, + struct cpufreq_policy_data *policy) +{ + update_boost_state(); + cpufreq_verify_within_cpu_limits(policy); +} + +static int amd_pstate_epp_verify_policy(struct cpufreq_policy_data *policy) +{ + amd_pstate_verify_cpu_policy(all_cpu_data[policy->cpu], policy); + pr_debug("policy_max =3D%d, policy_min=3D%d\n", policy->max, policy->min); + return 0; +} + static struct cpufreq_driver amd_pstate_driver =3D { .flags =3D CPUFREQ_CONST_LOOPS | CPUFREQ_NEED_UPDATE_LIMITS, .verify =3D amd_pstate_verify, @@ -685,8 +1405,20 @@ static struct cpufreq_driver amd_pstate_driver =3D { .attr =3D amd_pstate_attr, }; =20 +static struct cpufreq_driver amd_pstate_epp_driver =3D { + .flags =3D CPUFREQ_CONST_LOOPS, + .verify =3D amd_pstate_epp_verify_policy, + .setpolicy =3D amd_pstate_epp_set_policy, + .init =3D amd_pstate_epp_cpu_init, + .exit =3D amd_pstate_epp_cpu_exit, + .update_limits =3D amd_pstate_epp_update_limits, + .name =3D "amd_pstate_epp", + .attr =3D amd_pstate_epp_attr, +}; + static int __init amd_pstate_init(void) { + static struct amd_cpudata **cpudata; int ret; =20 if (boot_cpu_data.x86_vendor !=3D X86_VENDOR_AMD) @@ -701,10 +1433,24 @@ static int __init amd_pstate_init(void) if (cpufreq_get_current_driver()) return -EEXIST; =20 + cpudata =3D vzalloc(array_size(sizeof(void *), num_possible_cpus())); + if (!cpudata) + return -ENOMEM; + WRITE_ONCE(all_cpu_data, cpudata); + + if (epp_enabled) { + pr_info("AMD CPPC loading with amd_pstate_epp driver instance.\n"); + default_pstate_driver =3D &amd_pstate_epp_driver; + } else { + pr_info("AMD CPPC loading with amd_pstate driver instance.\n"); + default_pstate_driver =3D &amd_pstate_driver; + } + /* capability check */ if (boot_cpu_has(X86_FEATURE_CPPC)) { + if (!epp_enabled) + default_pstate_driver->adjust_perf =3D amd_pstate_adjust_perf; pr_debug("AMD CPPC MSR based functionality is supported\n"); - amd_pstate_driver.adjust_perf =3D amd_pstate_adjust_perf; } else if (shared_mem) { static_call_update(amd_pstate_enable, cppc_enable); static_call_update(amd_pstate_init_perf, cppc_init_perf); @@ -721,19 +1467,55 @@ static int __init amd_pstate_init(void) return ret; } =20 - ret =3D cpufreq_register_driver(&amd_pstate_driver); + ret =3D cpufreq_register_driver(default_pstate_driver); if (ret) - pr_err("failed to register amd_pstate_driver with return %d\n", + pr_err("failed to register amd pstate driver with return %d\n", ret); =20 + amd_pstate_kobj =3D kobject_create_and_add("amd-pstate", &cpu_subsys.dev_= root->kobj); + if (!amd_pstate_kobj) + pr_err("amd-pstate: Global sysfs registration failed.\n"); + + ret =3D sysfs_create_group(amd_pstate_kobj, &amd_pstate_global_attr_group= ); + if (ret) { + pr_err("amd-pstate: Sysfs attribute export failed with error %d.\n", + ret); + } + return ret; } =20 +static inline void amd_pstate_kobj_cleanup(struct kobject *kobj) +{ + kobject_del(kobj); + kobject_put(kobj); +} + static void __exit amd_pstate_exit(void) { - cpufreq_unregister_driver(&amd_pstate_driver); + unsigned int cpu; + + cpufreq_unregister_driver(default_pstate_driver); =20 amd_pstate_enable(false); + + sysfs_remove_group(amd_pstate_kobj, &amd_pstate_global_attr_group); + amd_pstate_kobj_cleanup(amd_pstate_kobj); + + cpus_read_lock(); + for_each_online_cpu(cpu) { + if (all_cpu_data[cpu]) { + if (default_pstate_driver =3D=3D &amd_pstate_epp_driver) + amd_pstate_clear_update_util_hook(cpu); + + spin_lock(&amd_pstate_cpu_lock); + kfree(all_cpu_data[cpu]); + WRITE_ONCE(all_cpu_data[cpu], NULL); + spin_unlock(&amd_pstate_cpu_lock); + } + } + cpus_read_unlock(); + } =20 module_init(amd_pstate_init); --=20 2.34.1 From nobody Tue Apr 7 00:19:44 2026 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 AF7FCC433FE for ; Sun, 9 Oct 2022 07:12:50 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230160AbiJIHMr (ORCPT ); Sun, 9 Oct 2022 03:12:47 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42534 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230084AbiJIHMK (ORCPT ); Sun, 9 Oct 2022 03:12:10 -0400 Received: from NAM12-BN8-obe.outbound.protection.outlook.com (mail-bn8nam12on2069.outbound.protection.outlook.com [40.107.237.69]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 537EA32EC8; Sun, 9 Oct 2022 00:11:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=gIHjWcxtQ9uvIPVzNW1w9wwzB/q5Z8oQeORHje8wYEEoGPw4CDambTSUHEpQBe36HlfToYAISjHpJ3G8ELFpb6nbcDd4jGnnu4XA1Iti9a/oxoYeCjNVs1A5iW1dh2HGIFlVGab6i9izKlqP9s7kIpYR+NfeVFNATQ3CFnw5KE5CpXunfQERoFdr43nPfBB9nb6JygfF2Uy2/HV8fKNzPamdztv6qyVupPb+kErSofWN0uIZ6vpp+0S5tEWTyslZ+WeMrpSyBXMHstRYxF/wDa50yZMF45gTdKKfErXVoLY1yxDIPn2fYzG9FzX3/BFa+qJsalppoH+MTeFEvgAH4w== 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=Rur2Ae3e0XBhSL02k2EV41i/hm2m/P/8GHajXbu4SXA=; b=Lt9/uJpzxXtl20XhuMuteylhu8b16AOHWxS5ejnws5atvEntCB3ZlErk0IlLZXvMoG4ss0gIge0Iow9oJYOUTx9bWnhkQvJ47b4wzQ5x+wja4u1r9e/kzOs7MF0Y4pWZfj04nRS5/F6jUlC3Q0zTVW75Bm6dAvR2M3gw1XgDyh+mn6egYUtIKpVOMpi1wVoT4wy9cJgxg16oGmfyzWluD0fwuN79+Kg+fV6wCRjm2VW0u1wCefLKZ0tRBuNs82SZLLrW0ADoBI+0d7NtKDaO9Nux+SSC5PZcZLDGdOzAu7MgCgq+IX+EXVbGh8RVR/IXAJo1pQtqvqrPZ1d+9zLheA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=intel.com smtp.mailfrom=amd.com; dmarc=pass (p=quarantine sp=quarantine pct=100) action=none header.from=amd.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amd.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=Rur2Ae3e0XBhSL02k2EV41i/hm2m/P/8GHajXbu4SXA=; b=FoQ0M4L8RL3fTZPUT9LVeWiLpF7F25Uy8kNEADuMajQBhC6Qi9up/qrXsms0jri1jeNyuGb+HUluwl3wIyvTC6XWT/sHXFLUyvJGizyoDkUYxpw7MD5S/Xo5lZRvnCeV6ST/65VgF1c047zvZs0goSmQWxogwwrpG6mMlIuND20= Received: from DS7P222CA0025.NAMP222.PROD.OUTLOOK.COM (2603:10b6:8:2e::31) by PH7PR12MB6761.namprd12.prod.outlook.com (2603:10b6:510:1ab::22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5676.20; Sun, 9 Oct 2022 07:11:36 +0000 Received: from DM6NAM11FT046.eop-nam11.prod.protection.outlook.com (2603:10b6:8:2e:cafe::63) by DS7P222CA0025.outlook.office365.com (2603:10b6:8:2e::31) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5709.15 via Frontend Transport; Sun, 9 Oct 2022 07:11:36 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 165.204.84.17) smtp.mailfrom=amd.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=amd.com; Received-SPF: Pass (protection.outlook.com: domain of amd.com designates 165.204.84.17 as permitted sender) receiver=protection.outlook.com; client-ip=165.204.84.17; helo=SATLEXMB04.amd.com; pr=C Received: from SATLEXMB04.amd.com (165.204.84.17) by DM6NAM11FT046.mail.protection.outlook.com (10.13.172.121) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.5709.10 via Frontend Transport; Sun, 9 Oct 2022 07:11:35 +0000 Received: from pyuan-Cloudripper.amd.com (10.180.168.240) by SATLEXMB04.amd.com (10.181.40.145) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.28; Sun, 9 Oct 2022 02:11:32 -0500 From: Perry Yuan To: , , CC: , , , , , , , , , Perry Yuan Subject: [PATCH v2 8/9] cpufreq: amd_pstate: implement amd pstate cpu online and offline callback Date: Sun, 9 Oct 2022 15:10:32 +0800 Message-ID: <20221009071033.21170-9-Perry.Yuan@amd.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221009071033.21170-1-Perry.Yuan@amd.com> References: <20221009071033.21170-1-Perry.Yuan@amd.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-Originating-IP: [10.180.168.240] X-ClientProxiedBy: SATLEXMB03.amd.com (10.181.40.144) To SATLEXMB04.amd.com (10.181.40.145) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DM6NAM11FT046:EE_|PH7PR12MB6761:EE_ X-MS-Office365-Filtering-Correlation-Id: 7e23a09c-d815-4a9c-6960-08daa9c580b9 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: XWF9QqK58jCc3XgH3tkAUvIAe6DTcF69Mo5xBN6/Ie80d6orNqXGDbPV/5MeMrgAcTvqweqG2zhX4dqm9BC3AkQ/9DhR83/A3wOg2kTRMuUOQQVizcTurt+IeqTGk2iteaV49pwsaHA17Az0bJAVeIUFHDl49eMO0q78CtwQbKkva+I0HJIW0eQBfsRrPao5KQTRCEq7IJLpDLITm7GMUM/efuGw1vlPDHPPMrjsoVcXl+WMxJ2i5lvna1ZkXumgeNM7fduWSKUrBTtfNtEvn6nrNhNTLGu4902mvy9kHlnBeobBL39abRPUWI7SwLL2CBPdfCUFfgbl6VP4uNtUbUS0rE2eR3+jHpWDAIK9yr3S6MFvgKgcwW/3GmKCtjH0lEEqahTvbgiJAM/1pRb3a3+Neebs/3owbbaLHBYOWinHuiQcv2dri/kbGXAFwyVxApD2Dv9k6UOVHf8gfBzxMgNqgaZwGoVEqshe2hLk9Jz7TR8AB11YiX+gvDpKLU6Be5jsi1vhUIi6xY/7s9VRC4xXwgbVYyNjuR+X2IAcgs8R7yn2aExTpOe/z9I/GjYao9FXcmmge1KrA2jKcdMPKDlhhv1V33R05rUTMSbIGy0jSlJohuuuSMhhDjGCSJZmLJERGhKbq6axbZhwugKvZ1wPWHqYRruV7sWimuMX8CEwDBuMyhUMD/FnrcY+AxHiphJaJLoFyZFqxu91mMLFKobwY3ftchVRsg+e0jrs3lrKUgAhFUKzUwtc1rw2tE9XxMJHA1A7K6OAnGudDbhH49kYVA368MV1l4oFEIbtPgJ+RvAVDuofGzxKQsQOPkWD4wS/M8DAn7y2ddEj/eDnRw== X-Forefront-Antispam-Report: CIP:165.204.84.17;CTRY:US;LANG:en;SCL:1;SRV:;IPV:CAL;SFV:NSPM;H:SATLEXMB04.amd.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230022)(4636009)(39860400002)(136003)(396003)(376002)(346002)(451199015)(40470700004)(46966006)(36840700001)(70586007)(82310400005)(36756003)(70206006)(8676002)(2906002)(40480700001)(110136005)(40460700003)(186003)(478600001)(5660300002)(1076003)(26005)(54906003)(86362001)(4326008)(7696005)(81166007)(16526019)(83380400001)(82740400003)(8936002)(2616005)(426003)(36860700001)(316002)(41300700001)(356005)(336012)(47076005)(2101003)(36900700001);DIR:OUT;SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 09 Oct 2022 07:11:35.8851 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 7e23a09c-d815-4a9c-6960-08daa9c580b9 X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=3dd8961f-e488-4e60-8e11-a82d994e183d;Ip=[165.204.84.17];Helo=[SATLEXMB04.amd.com] X-MS-Exchange-CrossTenant-AuthSource: DM6NAM11FT046.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: PH7PR12MB6761 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Type: text/plain; charset="utf-8" The patch adds online and offline driver callback support to allow cpu core= s go offline and help to restore the previous working states when core goes back online later for EPP driver mode. Signed-off-by: Perry Yuan --- drivers/cpufreq/amd-pstate.c | 101 ++++++++++++++++++++++++++++++++++- 1 file changed, 100 insertions(+), 1 deletion(-) diff --git a/drivers/cpufreq/amd-pstate.c b/drivers/cpufreq/amd-pstate.c index 98fb4a31791e..1a3ecc2e148a 100644 --- a/drivers/cpufreq/amd-pstate.c +++ b/drivers/cpufreq/amd-pstate.c @@ -116,7 +116,8 @@ struct amd_aperf_mperf { * @cppc_cap1_cached: Cached value of the last CPPC Capabilities MSR * @update_util: Cpufreq utility callback information * @sample: the stored performance sample - + * @suspended: Whether or not the driver has been suspended. + * * The amd_cpudata is key private data for each CPU thread in AMD P-State,= and * represents all the attributes and goals that AMD P-State requests at ru= ntime. */ @@ -156,6 +157,7 @@ struct amd_cpudata { u64 cppc_cap1_cached; struct update_util_data update_util; struct amd_aperf_mperf sample; + bool suspended; }; =20 /** @@ -216,6 +218,9 @@ static DEFINE_SPINLOCK(amd_pstate_cpu_lock); static bool cppc_boost __read_mostly; struct kobject *amd_pstate_kobj; =20 +/* the flag whether the pstate driver is exiting */ +static bool pstate_exiting; + #ifdef CONFIG_ACPI_CPPC_LIB static s16 amd_pstate_get_epp(struct amd_cpudata *cpudata, u64 cppc_req_ca= ched) { @@ -1378,6 +1383,96 @@ static int amd_pstate_epp_set_policy(struct cpufreq_= policy *policy) return 0; } =20 +static void amd_pstate_epp_reenable(struct amd_cpudata *cpudata) +{ + struct cppc_perf_ctrls perf_ctrls; + u64 value, max_perf; + int ret; + + ret =3D amd_pstate_enable(true); + if (ret) + pr_err("failed to enable amd pstate during resume, return %d\n", ret); + + value =3D READ_ONCE(cpudata->cppc_req_cached); + max_perf =3D READ_ONCE(cpudata->highest_perf); + + if (boot_cpu_has(X86_FEATURE_CPPC)) { + wrmsrl_on_cpu(cpudata->cpu, MSR_AMD_CPPC_REQ, value); + } else { + perf_ctrls.max_perf =3D max_perf; + perf_ctrls.energy_perf =3D AMD_CPPC_ENERGY_PERF_PREF(cpudata->epp_cached= ); + cppc_set_perf(cpudata->cpu, &perf_ctrls); + } +} + +static int amd_pstate_epp_cpu_online(struct cpufreq_policy *policy) +{ + struct amd_cpudata *cpudata =3D all_cpu_data[policy->cpu]; + + pr_debug("AMD CPU Core %d going online\n", cpudata->cpu); + + if (epp_enabled) { + amd_pstate_epp_reenable(cpudata); + cpudata->suspended =3D false; + } + + return 0; +} + +static void amd_pstate_epp_offline(struct cpufreq_policy *policy) +{ + struct amd_cpudata *cpudata =3D all_cpu_data[policy->cpu]; + struct cppc_perf_ctrls perf_ctrls; + int min_perf; + u64 value; + + min_perf =3D READ_ONCE(cpudata->lowest_perf); + value =3D READ_ONCE(cpudata->cppc_req_cached); + + mutex_lock(&amd_pstate_limits_lock); + if (boot_cpu_has(X86_FEATURE_CPPC)) { + cpudata->epp_policy =3D CPUFREQ_POLICY_UNKNOWN; + + /* Set max perf same as min perf */ + value &=3D ~AMD_CPPC_MAX_PERF(~0L); + value |=3D AMD_CPPC_MAX_PERF(min_perf); + value &=3D ~AMD_CPPC_MIN_PERF(~0L); + value |=3D AMD_CPPC_MIN_PERF(min_perf); + wrmsrl_on_cpu(cpudata->cpu, MSR_AMD_CPPC_REQ, value); + } else { + perf_ctrls.desired_perf =3D 0; + perf_ctrls.max_perf =3D min_perf; + perf_ctrls.energy_perf =3D AMD_CPPC_ENERGY_PERF_PREF(AMD_CPPC_EPP_POWERS= AVE); + cppc_set_perf(cpudata->cpu, &perf_ctrls); + } + mutex_unlock(&amd_pstate_limits_lock); +} + +static int amd_pstate_cpu_offline(struct cpufreq_policy *policy) +{ + struct amd_cpudata *cpudata =3D all_cpu_data[policy->cpu]; + + pr_debug("AMD CPU Core %d going offline\n", cpudata->cpu); + + if (cpudata->suspended) + return 0; + + if (pstate_exiting) + return 0; + + if (epp_enabled) + amd_pstate_epp_offline(policy); + + return 0; +} + +static int amd_pstate_epp_cpu_offline(struct cpufreq_policy *policy) +{ + amd_pstate_clear_update_util_hook(policy->cpu); + + return amd_pstate_cpu_offline(policy); +} + static void amd_pstate_verify_cpu_policy(struct amd_cpudata *cpudata, struct cpufreq_policy_data *policy) { @@ -1412,6 +1507,8 @@ static struct cpufreq_driver amd_pstate_epp_driver = =3D { .init =3D amd_pstate_epp_cpu_init, .exit =3D amd_pstate_epp_cpu_exit, .update_limits =3D amd_pstate_epp_update_limits, + .offline =3D amd_pstate_epp_cpu_offline, + .online =3D amd_pstate_epp_cpu_online, .name =3D "amd_pstate_epp", .attr =3D amd_pstate_epp_attr, }; @@ -1481,6 +1578,7 @@ static int __init amd_pstate_init(void) pr_err("amd-pstate: Sysfs attribute export failed with error %d.\n", ret); } + pstate_exiting =3D false; =20 return ret; } @@ -1495,6 +1593,7 @@ static void __exit amd_pstate_exit(void) { unsigned int cpu; =20 + pstate_exiting =3D true; cpufreq_unregister_driver(default_pstate_driver); =20 amd_pstate_enable(false); --=20 2.34.1 From nobody Tue Apr 7 00:19:44 2026 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 65DF1C433FE for ; Sun, 9 Oct 2022 07:12:28 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230061AbiJIHMY (ORCPT ); Sun, 9 Oct 2022 03:12:24 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41812 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230029AbiJIHLr (ORCPT ); Sun, 9 Oct 2022 03:11:47 -0400 Received: from NAM10-DM6-obe.outbound.protection.outlook.com (mail-dm6nam10on2066.outbound.protection.outlook.com [40.107.93.66]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E472A3336B; Sun, 9 Oct 2022 00:11:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=e0kEvmq7Fu7Q8VQY2WaFXM3f/F3KMZMAFi/eqVg84WsAnKjMuDgC3II+3nIbD3It8t4rqkroWm/ZpfWh7oAkuo83AtsQ2SnJy+7UEMCH9dWC+G5LeWiAudcqMPW1Um/lEHiuMzg7IpY5Es0UkKfLOWLcvZ+aueGrEbX6PkcMBkiDH89SDmj5mcvq5FSup6049XKd3KtwRmR+umJmVcPDxq/af8zpPolwNaTqwbh4szwlQ5+lMong0Jr81ND0JyT7DEODDBPDguyGto2+T8DzAmujaURx8m+WRQN2EfwLfjJlPisQjGnRz4TyUnM59VDeQdX4kPeaS64LtGFx4zSrIA== 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=YmeL10S28uUxf7CpfSdZCwsk0jld7opG7DXjhiKE7Dw=; b=Ks6H4RKNd5tfeZ/7zgdQkoOtpCSerbsnLIFaz5gH713RUOt3h6vUcdQZ2vciWJAY89QjjDZJZGb508vdLjMJnIep+UCmeppBDyNSlN+vPykbAT+ppsVas7O7FHdQE2Ycz1aE3X1kay1Fe+jWL88lEmjuO9z9A7pzUh8bCaHp/4mDt+ZhzQceRj+kN5NiICCat1PyPYZv51G4qsM9roI7ITHHbWxutTnoJjyFsQFesT6wnMdjd1/skJmI/SQ7tFCl4kdE5RpTycYPJHTEXr7X8fUQzq5uYY/CtSkrp3BW7FhExWKk51+0UBbkSyi/b/9ibepyJPP/VtAIhbhfw58D8g== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=intel.com smtp.mailfrom=amd.com; dmarc=pass (p=quarantine sp=quarantine pct=100) action=none header.from=amd.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amd.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=YmeL10S28uUxf7CpfSdZCwsk0jld7opG7DXjhiKE7Dw=; b=L4JfLYdCoqzP+4iAcUwTSZI1YseYJDX1r94fEE+qWuMByc0grZXlPfC6sy+2ipukr6iDxM51jykayjs89a17HHtbMF9OYtVmlNVW3d6zfApMGSDTE3ohLI32CIsHvwxT5+/rB1Hd5VZmvfx8xiD8S7yZ4DYFXj+TLaC11Uv7+AI= Received: from DS7P222CA0004.NAMP222.PROD.OUTLOOK.COM (2603:10b6:8:2e::14) by BY5PR12MB4260.namprd12.prod.outlook.com (2603:10b6:a03:206::22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5709.15; Sun, 9 Oct 2022 07:11:39 +0000 Received: from DM6NAM11FT046.eop-nam11.prod.protection.outlook.com (2603:10b6:8:2e:cafe::a0) by DS7P222CA0004.outlook.office365.com (2603:10b6:8:2e::14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5709.15 via Frontend Transport; Sun, 9 Oct 2022 07:11:39 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 165.204.84.17) smtp.mailfrom=amd.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=amd.com; Received-SPF: Pass (protection.outlook.com: domain of amd.com designates 165.204.84.17 as permitted sender) receiver=protection.outlook.com; client-ip=165.204.84.17; helo=SATLEXMB04.amd.com; pr=C Received: from SATLEXMB04.amd.com (165.204.84.17) by DM6NAM11FT046.mail.protection.outlook.com (10.13.172.121) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.5709.10 via Frontend Transport; Sun, 9 Oct 2022 07:11:39 +0000 Received: from pyuan-Cloudripper.amd.com (10.180.168.240) by SATLEXMB04.amd.com (10.181.40.145) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.28; Sun, 9 Oct 2022 02:11:35 -0500 From: Perry Yuan To: , , CC: , , , , , , , , , Perry Yuan Subject: [PATCH v2 9/9] cpufreq: amd-pstate: implement suspend and resume callbacks Date: Sun, 9 Oct 2022 15:10:33 +0800 Message-ID: <20221009071033.21170-10-Perry.Yuan@amd.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221009071033.21170-1-Perry.Yuan@amd.com> References: <20221009071033.21170-1-Perry.Yuan@amd.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-Originating-IP: [10.180.168.240] X-ClientProxiedBy: SATLEXMB03.amd.com (10.181.40.144) To SATLEXMB04.amd.com (10.181.40.145) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DM6NAM11FT046:EE_|BY5PR12MB4260:EE_ X-MS-Office365-Filtering-Correlation-Id: 42928b30-f3a0-4e9f-4c13-08daa9c582a9 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: cQlkZJzXs7byXhbSegSLMFMzpdbnHgW3HOcSN1ptQZDRvX4X22qL1MLGbYQ67EZNJWzOYaX2uBabC5eAviB4h+/RVZeo/8rltE6dqvyRueHP41wTjA8VE2EZIG9I0T1kbraIkqiITdhU0ZTD9zH5X+TupfQJp9wXSRlKfScnzGhLYJ3ulbBn1KTkcjLWfr2tSkjDitpRVoGCyB5BXflos85X8GKkEyIvIRN32NKwDio5o9q/+gZi2qUV77sEVbW9Sl4Sgdm3HQX146kNZ/qUsngXPzqrdfCaadBkG/D27imoWqcE5ccPfoplDf026rkkshjHFD9OkBgpjLOJm3KVWsuT02TfWnQyNeLv54N39xPODCUxgwAqyrFef2Z6NOj9e5FWnzDpgFMj3z4M5uWddYWa3xK6Ep1kz4pfichBwmf96D8t4dKdHaYawrSRh9REHd6kh0yhnTuSYGlgdAkn2mJax6hMWQTDOqDOLDRU+Km55ueGDKe8xBbImiHcT5ldA48kUvW5fEhT2W1Bk7DEAkMqBmUdaS97mpoBDJzujRIlG/wmQXN+ADjX8fLHDaGMIWFTUge0Pv6CLtLHLxJo16JjUDFsEPrYvMKMN5xIHST5BNXQnm+sDulVuF9YK0YWmo6xnUIV+Rc4cTj29CylzD00MdiSpYcsgE2yL4MVzjt186qRA7B4qGNvd7nHhRDlxWYkXcbBd/lKyJSC/FN9e4u0rPlZSy8VUNvS9jCLz7RJWY9AQkeupM64MIV962smHgDQJ5EXUHTjBdZRn3rC2jb2mdQKm5AKjvYsCrXBLFx3YEeX9vSOr0Q+HFGupZpfYnFTQAU57OFANtpK5dw7XQ== X-Forefront-Antispam-Report: CIP:165.204.84.17;CTRY:US;LANG:en;SCL:1;SRV:;IPV:CAL;SFV:NSPM;H:SATLEXMB04.amd.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230022)(4636009)(396003)(39850400004)(376002)(346002)(136003)(451199015)(46966006)(40470700004)(36840700001)(8936002)(426003)(81166007)(47076005)(82310400005)(5660300002)(8676002)(4326008)(41300700001)(2616005)(16526019)(1076003)(186003)(70206006)(83380400001)(70586007)(336012)(36860700001)(7696005)(36756003)(86362001)(478600001)(356005)(82740400003)(26005)(15650500001)(316002)(54906003)(110136005)(40460700003)(2906002)(40480700001)(36900700001)(2101003);DIR:OUT;SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 09 Oct 2022 07:11:39.1506 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 42928b30-f3a0-4e9f-4c13-08daa9c582a9 X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=3dd8961f-e488-4e60-8e11-a82d994e183d;Ip=[165.204.84.17];Helo=[SATLEXMB04.amd.com] X-MS-Exchange-CrossTenant-AuthSource: DM6NAM11FT046.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: BY5PR12MB4260 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Type: text/plain; charset="utf-8" add suspend and resume support for the AMD processors by amd_pstate_epp driver instance. When the CPPC is suspended, EPP driver will set EPP profile to 'power' profile and set max/min perf to lowest perf value. When resume happens, it will restore the MSR registers with previous cached value. Signed-off-by: Perry Yuan --- drivers/cpufreq/amd-pstate.c | 40 ++++++++++++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) diff --git a/drivers/cpufreq/amd-pstate.c b/drivers/cpufreq/amd-pstate.c index 1a3ecc2e148a..f93336f69756 100644 --- a/drivers/cpufreq/amd-pstate.c +++ b/drivers/cpufreq/amd-pstate.c @@ -1473,6 +1473,44 @@ static int amd_pstate_epp_cpu_offline(struct cpufreq= _policy *policy) return amd_pstate_cpu_offline(policy); } =20 +static int amd_pstate_epp_suspend(struct cpufreq_policy *policy) +{ + struct amd_cpudata *cpudata =3D all_cpu_data[policy->cpu]; + int ret; + + /* avoid suspending when EPP is not enabled */ + if (!epp_enabled) + return 0; + + /* set this flag to avoid setting core offline*/ + cpudata->suspended =3D true; + + /* disable CPPC in lowlevel firmware */ + ret =3D amd_pstate_enable(false); + if (ret) + pr_err("failed to suspend, return %d\n", ret); + + return 0; +} + +static int amd_pstate_epp_resume(struct cpufreq_policy *policy) +{ + struct amd_cpudata *cpudata =3D all_cpu_data[policy->cpu]; + + if (cpudata->suspended) { + mutex_lock(&amd_pstate_limits_lock); + + /* enable amd pstate from suspend state*/ + amd_pstate_epp_reenable(cpudata); + + mutex_unlock(&amd_pstate_limits_lock); + + cpudata->suspended =3D false; + } + + return 0; +} + static void amd_pstate_verify_cpu_policy(struct amd_cpudata *cpudata, struct cpufreq_policy_data *policy) { @@ -1509,6 +1547,8 @@ static struct cpufreq_driver amd_pstate_epp_driver = =3D { .update_limits =3D amd_pstate_epp_update_limits, .offline =3D amd_pstate_epp_cpu_offline, .online =3D amd_pstate_epp_cpu_online, + .suspend =3D amd_pstate_epp_suspend, + .resume =3D amd_pstate_epp_resume, .name =3D "amd_pstate_epp", .attr =3D amd_pstate_epp_attr, }; --=20 2.34.1