From patchwork Tue Feb 27 12:55:14 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Shyam Sundar S K X-Patchwork-Id: 13573767 Received: from NAM12-MW2-obe.outbound.protection.outlook.com (mail-mw2nam12on2080.outbound.protection.outlook.com [40.107.244.80]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 96E4C1386CF for ; Tue, 27 Feb 2024 12:56:01 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.244.80 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709038566; cv=fail; b=pt5sdEhS30zBCqvB3MMIB/ivNl6BbhpYvZgBk6PwGzpUenbJKwAMQX6Ob7rzwHCSRa1hQ6ZOfr4xJcKu/sx/FIZmeykhG68/mu4009uZ3TmJ4OAHlmUf6o5VArNlluGobsyurC7ltb9y3nhpH6dcaimXgBT9Pz9qiZTrbd7qsRE= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709038566; c=relaxed/simple; bh=POl0k//QV8QvXRyYx/rfoJxMQJVqreEoqZHQllZyAdc=; h=From:To:CC:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=Y8mZQQI9NG+B894F4PqPaVJHNX9mj56xkuaXisxedRbIlcx9toGlBI5T/L8XQvoCooQnUYQeToWtsxzgd23F2lHMdl4js6cj38EF2b2ICQypsHKJO02P1c1XGMLnS4/fUoNGNrL0TiHA770JTRdHyMH4JUZLXi7DUxChb/by604= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=amd.com; spf=fail smtp.mailfrom=amd.com; dkim=pass (1024-bit key) header.d=amd.com header.i=@amd.com header.b=24ytN89t; arc=fail smtp.client-ip=40.107.244.80 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=amd.com Authentication-Results: smtp.subspace.kernel.org; spf=fail smtp.mailfrom=amd.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=amd.com header.i=@amd.com header.b="24ytN89t" ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=hdTf56mqIq2VAvq+d0zfCoug4/3bF5HDSrcesYE/xtJIvOxdJDk+0KTA2Ev1Ja65SoweRVxTshA6UU2LvlMA+O/d5DEu+VaY2WQIzrOQkm9uH2Ltu8SPRc1M00HDcRPmZOI4mteTGfmIlXr52Qfvr+h5qnMXIjY5DCYW5mEKJsGkZksOfN/dc1bZoCWDEHcy0I8gFIUwmrEMdTwIFAUtE0JsHXgupbD4FBbUYhGMDZMDKNL/Mb+gP3WxVow/jRMza/bHd/IIL3sbJZY/jTdh24bHxAo9F58e8u5PHxAdBo3FpRcQPapH8pU3ebonaXFnJdfVK+H6wyDHZOLUvptoEQ== 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=tP/ijOjjRdCibl+hSZpg0ZeEPPHy5GuHyrPgzH1W9tQ=; b=TGVyDYwPyzhvSgHEu0gH19WgIWWntRHO7MPKr0JJJL7j6KR+NfuMzGTgCHtNbPrWTAmJLV4FsqkVh3CoOO+vXbH0WZyI2au4QhRSr1HGUWvJF5pdhMINOJsbXXHg3FDlQ8OGr2oguaLZNHnl7KVTeNxKVgtMVW/Ow2AjzvxEumDh8sU4lfJ/dlpTrpDry41WCW1f2z4sm3Y67IOK1Fw83dm/aSG6Awb2PrtwFBFhA5r91Cmad59msv8WGFb9vF6EFc8yfR/yFdz55Eayn8cwdHb28fjqBku5wyrwpCZsBRY5QnbgF56/Dv0+Ze6Eyi+f5bTZI3M/ZYjqLTUaGHcJMA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=redhat.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 (0) 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=tP/ijOjjRdCibl+hSZpg0ZeEPPHy5GuHyrPgzH1W9tQ=; b=24ytN89tid0EL2OMehGvSdMRiPQPkkHynV+mDJxr4L3oD7bd2l4GjOnvRe4FaGwT/c2SxF5EtfaVFTUmfJwxPkWYGuoaIkfLyx7A/JJbOtyE3IzU1tnKvaL3wVETQ8xaAgoyFUU2db5lrAW4MWThZ3IV+aNioRGQAAhFM4rCT6k= Received: from DM6PR18CA0010.namprd18.prod.outlook.com (2603:10b6:5:15b::23) by DS7PR12MB6144.namprd12.prod.outlook.com (2603:10b6:8:98::8) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7316.39; Tue, 27 Feb 2024 12:55:58 +0000 Received: from CY4PEPF0000EE3E.namprd03.prod.outlook.com (2603:10b6:5:15b:cafe::df) by DM6PR18CA0010.outlook.office365.com (2603:10b6:5:15b::23) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7292.49 via Frontend Transport; Tue, 27 Feb 2024 12:55:57 +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 CY4PEPF0000EE3E.mail.protection.outlook.com (10.167.242.18) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.7292.25 via Frontend Transport; Tue, 27 Feb 2024 12:55:57 +0000 Received: from jatayu.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.2507.35; Tue, 27 Feb 2024 06:55:55 -0600 From: Shyam Sundar S K To: , CC: , , "Shyam Sundar S K" Subject: [PATCH 1/7] platform/x86/amd/pmf: Differentiate PMF ACPI versions Date: Tue, 27 Feb 2024 18:25:14 +0530 Message-ID: <20240227125520.3153140-2-Shyam-sundar.S-k@amd.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20240227125520.3153140-1-Shyam-sundar.S-k@amd.com> References: <20240227125520.3153140-1-Shyam-sundar.S-k@amd.com> Precedence: bulk X-Mailing-List: platform-driver-x86@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-ClientProxiedBy: SATLEXMB04.amd.com (10.181.40.145) To SATLEXMB04.amd.com (10.181.40.145) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: CY4PEPF0000EE3E:EE_|DS7PR12MB6144:EE_ X-MS-Office365-Filtering-Correlation-Id: db246728-4398-4f16-72c7-08dc3793710f X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 9M0cjV/p4ldfloGXMSn8b9Bsbjnq2iMgIk6Akoew/S0Iuy43oQExmUAZ5OeAt45M7BPxG2baW9BpgCqXRuIFOuSgoYOi0+BtbuFzwMcTL6guMGUW5dUsVhAif0HaJgByBCq0uYctINtXDiDcMms1cJJKh1Dqt9BAvViVmFy/L7ISVLvJlZKrycSjg7mH4fDYpX5L9f4mR3kZNGN7yR3xY1dJZlbalU9fVerI2JwK9pvlt9WTi1r+Xp0R6bYM7Sg4dU5lC5ZKpF+RqmHbhwrQX+2FeexP8d8k08v5PZZm4KXoQujgdCwyThzySratINS51zfoflONQ9kOcrS0GB6/f5VsyCZeqcGMG6DAvJuHeL39CnN+begjCfZ6L3Pue3x/gC7Z5wJRPFqgm91DNWkMc3f1+9W7L6qsbQBd4vOZY5GlpWcs/R3I9S8rSnH9zlVEMCikTdVwLM+NP2HL3Mslh/2TTMum48wen6KzQJGnOqpePJdeaB6CqBhGtZ3hkF9mjjplp32YjSQ30bvBMZoX6HZwkyqKNPzc8Quq+/MWnsjXWw6JHCyPlid4mJ/vswiG1XXVISgB9CN0HreqLnQP431tH5XqXjmVMPQln6ectRZoKIDJvYzB/nDCRdUsj+cQoD5eTBz3JTlrbGwfL9IOJZolJ9sV3fWlHCRVyroSzPp/WEMAVK3Jeqqvof6zBCIQN/E9m1oip39JvWndTJgKUCVbkntw9uYAiEwNrHO51tFQT2YEq0mAnPqd2dmjl7lY 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:(13230031)(36860700004)(82310400014);DIR:OUT;SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 27 Feb 2024 12:55:57.5232 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: db246728-4398-4f16-72c7-08dc3793710f 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: CY4PEPF0000EE3E.namprd03.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: DS7PR12MB6144 For family 1AH, certain PMF features have been enhanced - leading to a newer APMF (AMD PMF) spec (BIOS and PMF driver interface) called v2. This information would be fed into the if_version field of the verify_interface method of the APMF call from the BIOS. Use this information to store the version number to differentiate between v1 or v2 and also store the information into the PMF private data structure, as this information would be required for further code branching to support the latest silicon. Co-developed-by: Patil Rajesh Reddy Signed-off-by: Patil Rajesh Reddy Signed-off-by: Shyam Sundar S K Reviewed-by: Kuppuswamy Sathyanarayanan --- drivers/platform/x86/amd/pmf/acpi.c | 6 ++++-- drivers/platform/x86/amd/pmf/pmf.h | 1 + 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/drivers/platform/x86/amd/pmf/acpi.c b/drivers/platform/x86/amd/pmf/acpi.c index f2eb07ef855a..1f287a147c57 100644 --- a/drivers/platform/x86/amd/pmf/acpi.c +++ b/drivers/platform/x86/amd/pmf/acpi.c @@ -218,8 +218,10 @@ static int apmf_if_verify_interface(struct amd_pmf_dev *pdev) return err; pdev->supported_func = output.supported_functions; - dev_dbg(pdev->dev, "supported functions:0x%x notifications:0x%x\n", - output.supported_functions, output.notification_mask); + dev_dbg(pdev->dev, "supported functions:0x%x notifications:0x%x version:%u\n", + output.supported_functions, output.notification_mask, output.version); + + pdev->pmf_if_version = output.version; return 0; } diff --git a/drivers/platform/x86/amd/pmf/pmf.h b/drivers/platform/x86/amd/pmf/pmf.h index 66cae1cca73c..e51ac981af73 100644 --- a/drivers/platform/x86/amd/pmf/pmf.h +++ b/drivers/platform/x86/amd/pmf/pmf.h @@ -231,6 +231,7 @@ struct amd_pmf_dev { u64 policy_addr; void *policy_base; bool smart_pc_enabled; + u16 pmf_if_version; }; struct apmf_sps_prop_granular { From patchwork Tue Feb 27 12:55:15 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Shyam Sundar S K X-Patchwork-Id: 13573768 Received: from NAM04-MW2-obe.outbound.protection.outlook.com (mail-mw2nam04on2042.outbound.protection.outlook.com [40.107.101.42]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 398AE13A24E for ; Tue, 27 Feb 2024 12:56:02 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.101.42 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709038567; cv=fail; b=PD9IIn7uZYCpuOBKegCjUKDJPAZli/R9cRLlLN3OOlaA1Ft/PrBhkznOYkwE7qpjb6qGkutnNSA8rpyXr+PwCmQaKd14J/81GDiI/S8E5s9vDhnpdl+zKv4Ku6nalMQMC36YRvWa/ShXbEfHGQNkTRbSmBANaZnAYVflTzmBNVw= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709038567; c=relaxed/simple; bh=nieY9V8EnTJtfcsLEnfcKLUmM7eRA7/YAQjqMLNRnFY=; h=From:To:CC:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=HjCT5rMyGaaFLK4XiS9PKi6eUH1tU8mHWynC9UZxZuEkaQebBn3ioaOUJrl8ez+Zhm3t+chz2XWr5ObPqvkmt2n0nWqYhKfXvDtnPY99EoqeK66RNfd5nGVMfRZfH5xEoWiBGStDew/Ss0B4VfIxDop+uwpbB8xLfPxuoie6OX8= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=amd.com; spf=fail smtp.mailfrom=amd.com; dkim=pass (1024-bit key) header.d=amd.com header.i=@amd.com header.b=Ie9cXVf3; arc=fail smtp.client-ip=40.107.101.42 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=amd.com Authentication-Results: smtp.subspace.kernel.org; spf=fail smtp.mailfrom=amd.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=amd.com header.i=@amd.com header.b="Ie9cXVf3" ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=GYWwgtuTSge+jL3GIO6N+c3z4fbw0JR/bH4i3aLes7US2PyRBzOaWrKuBuFFnnJTuFXA1m4tH2w9JU8aVjSl+yiU06p/lGqMiqYxyoutvwkK3k4hL/Ss9J8cCgw/NVxGQ9lfMlJ2jWdOfWU8xdFQdDv8DZXaOjt/nwIQ++vTRfej/EcATiSb29P9nX2PbqFIvdLTl6VE+TJu5zWWpGL5lCiK8hur18o35AMOo9bhsNIwuW76ONRZho0Nxx1aFZMV/U4lBFL5Dm2a/p/pIAIabV7+UXgmzTmr7IkNdwayB6s9aeuYD/8izRsWlAOULzATV24m3Ub8gaxhgB5XysicUw== 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=lzScb9vySsJ2+A2abn4NzdjMtc6L+M81LFSHXfm2NQc=; b=flYHa5+Bbt7tx1/tfrkJMZWMJrA0TCiiPB//cZh0DBnrtS+JHZFwt7CUHmYGK/vMHTZSdOmvObtC3wj5evHsJeuSyFnAeqD7+FmG28vXUR3Cqtk9COBh6l5I8i+vpe4nmK/seTIilCH2KhIejwIpF/fJqqoI5kK9Q7LSXUyUzmkPGC0yelZAw0HTbakCWFoPvCr28p2tSGbTCfAEC+2chccnZFZ5ilRVHeNT4/agMTIHn2wL+AOt/W51D1ewghc4Mdhpy3HMQ0iM/cVv9vQ4wA625u0JDb3EQNsB5c1mVe5+PqLi4Kfw+FkuQbAC7v8v1RIkSydZLEIFrwerm8ktAQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=redhat.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 (0) 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=lzScb9vySsJ2+A2abn4NzdjMtc6L+M81LFSHXfm2NQc=; b=Ie9cXVf3tVSVSuYkKh+JwPudoLXRXwgyvspnodc2RdEMEKIkyTNdX62m7zc/7qSNXzS07zNKJa6go24T3tIJvsxXaG7J8D9JE3GfqQjgVGvgdVuwYfc9zLkmavF2NsNvyOR6zyqXUlHlcZ2Kjsn3bRTmqbS80JtlMiM0q44aj+0= Received: from DM6PR06CA0079.namprd06.prod.outlook.com (2603:10b6:5:336::12) by IA0PR12MB8228.namprd12.prod.outlook.com (2603:10b6:208:402::10) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7316.36; Tue, 27 Feb 2024 12:55:59 +0000 Received: from CY4PEPF0000EE3B.namprd03.prod.outlook.com (2603:10b6:5:336:cafe::ba) by DM6PR06CA0079.outlook.office365.com (2603:10b6:5:336::12) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7292.49 via Frontend Transport; Tue, 27 Feb 2024 12:55:59 +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 CY4PEPF0000EE3B.mail.protection.outlook.com (10.167.242.15) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.7292.25 via Frontend Transport; Tue, 27 Feb 2024 12:55:59 +0000 Received: from jatayu.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.2507.35; Tue, 27 Feb 2024 06:55:57 -0600 From: Shyam Sundar S K To: , CC: , , "Shyam Sundar S K" Subject: [PATCH 2/7] platform/x86/amd/pmf: Disable debugfs support for querying power thermals Date: Tue, 27 Feb 2024 18:25:15 +0530 Message-ID: <20240227125520.3153140-3-Shyam-sundar.S-k@amd.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20240227125520.3153140-1-Shyam-sundar.S-k@amd.com> References: <20240227125520.3153140-1-Shyam-sundar.S-k@amd.com> Precedence: bulk X-Mailing-List: platform-driver-x86@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-ClientProxiedBy: SATLEXMB04.amd.com (10.181.40.145) To SATLEXMB04.amd.com (10.181.40.145) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: CY4PEPF0000EE3B:EE_|IA0PR12MB8228:EE_ X-MS-Office365-Filtering-Correlation-Id: fd976b5e-0e5e-4d8d-1090-08dc3793724e X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: VNwLFftqtAdSYNVJHcUwdPTqUsr0QI2MLq1NfYhkLGJRcDUWew2hOchg1xM6RAcj4KDYVr4Iq6GvzBcYGOnCbu7fZdiY8TR8gSY38EIvdof0vR04BmUXS2JJMQpI9XRiRroI3qBL8ekS4A0+9LA1QPXUrCKezn9XtS/NUn7oaq7uMitbqQLRjkSra/lHfh0ClGBePiinlDHBq7b6yUXACOj3s/6nHADyn4p87NJ8YhVQjbMxH7h3bSFGLExHI9wEvn2mWa/j/n0XSkOw4OwumbVJAyii9fsbYTyfzXHHnAYsYDXM/ZUITDAkWOYrRRq6FBae3FKitse8yTZ+HSRP+mKogwLkpLUrfe+JVzUA8MifbGuOdmWjz4DzgdQ3qyj6TlSVRvS8ZkwHx369Rbc/8MotQt6weQUSbAOp7RTFNo0VoyE0UoLkCc2424nqzGkIkcOSsGwtePnboZ718YPbC6hlnAIXJ4+mVXl4hLW5iKjLOKsWS1Dc8l63rGtBDrl880bRkA6WjTHyiTWs4xseu4spEsEIeuVuJUrAsPooPB2Uk0JHAa80lzvUZ5pjdvq2E0BoyrmCsB5franXu44y2WJVN3LCqi1ScxkwnGqabIXw5SQh7gOQzGFml0plRH4htMGNsj8f10lVk9ucsc0mX5ZovSRw/D38DAEt/m12hjMzietQgZId7SCZPayd6PS2kbYbVOxChcFwWPTQFz3svqbLakwmmYPNmne7qu/fzkoi38onZbohuOUoSV2BZRyk 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:(13230031)(36860700004)(82310400014);DIR:OUT;SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 27 Feb 2024 12:55:59.6112 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: fd976b5e-0e5e-4d8d-1090-08dc3793724e 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: CY4PEPF0000EE3B.namprd03.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: IA0PR12MB8228 The GET interface to receive the active power thermal information from the PMFW has been depricated. Hence drop the debugfs support for the newer platforms. Co-developed-by: Patil Rajesh Reddy Signed-off-by: Patil Rajesh Reddy Signed-off-by: Shyam Sundar S K --- drivers/platform/x86/amd/pmf/core.c | 5 +++-- drivers/platform/x86/amd/pmf/pmf.h | 2 ++ 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/drivers/platform/x86/amd/pmf/core.c b/drivers/platform/x86/amd/pmf/core.c index 4f734e049f4a..2230bc2b1f59 100644 --- a/drivers/platform/x86/amd/pmf/core.c +++ b/drivers/platform/x86/amd/pmf/core.c @@ -113,8 +113,9 @@ static void amd_pmf_dbgfs_unregister(struct amd_pmf_dev *dev) static void amd_pmf_dbgfs_register(struct amd_pmf_dev *dev) { dev->dbgfs_dir = debugfs_create_dir("amd_pmf", NULL); - debugfs_create_file("current_power_limits", 0644, dev->dbgfs_dir, dev, - ¤t_power_limits_fops); + if (dev->pmf_if_version == PMF_IF_V1) + debugfs_create_file("current_power_limits", 0644, dev->dbgfs_dir, dev, + ¤t_power_limits_fops); } int amd_pmf_get_power_source(void) diff --git a/drivers/platform/x86/amd/pmf/pmf.h b/drivers/platform/x86/amd/pmf/pmf.h index e51ac981af73..4364af72a7a3 100644 --- a/drivers/platform/x86/amd/pmf/pmf.h +++ b/drivers/platform/x86/amd/pmf/pmf.h @@ -83,6 +83,8 @@ #define TA_OUTPUT_RESERVED_MEM 906 #define MAX_OPERATION_PARAMS 4 +#define PMF_IF_V1 1 + /* AMD PMF BIOS interfaces */ struct apmf_verify_interface { u16 size; From patchwork Tue Feb 27 12:55:16 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Shyam Sundar S K X-Patchwork-Id: 13573769 Received: from NAM12-BN8-obe.outbound.protection.outlook.com (mail-bn8nam12on2057.outbound.protection.outlook.com [40.107.237.57]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 0D79613329D for ; Tue, 27 Feb 2024 12:56:05 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.237.57 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709038567; cv=fail; b=fx1USuMbhG9KSHGSJTiv6yqgzdeSTYEFmQpSzRX26VQRTfRc4WOgowiVFbNVzOpEin1QR9uqAa7wjbDMGRmNshi+weXQpEmMvY8QiJSubhYYeGcLEAhu7gqKG1e6XOHTl6Ln+Yd9AgELSQy765NLE/DSOEO0yEtAQcioRlfI9S4= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709038567; c=relaxed/simple; bh=jolHCB9GEn1lRCx/4gsLgIsWobXKUFDv34yi7YbLwzc=; h=From:To:CC:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=gxiKpSOa7kA/MON/LtZqw/n1xn2jtjfYGtGOwnuqK3xpPeYTlWovF7sFVfuW/aHOK72Kk8HuIcuyI91f08XIAwNL8liRMrkBcGrAi2JXj2jfpxuWAgopPGnNXbAHez2J7UyLD1QUJCQfWFrS1UCQJ5BpiZq0ca/iHHf+3zPw5c4= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=amd.com; spf=fail smtp.mailfrom=amd.com; dkim=pass (1024-bit key) header.d=amd.com header.i=@amd.com header.b=p7z2jzwi; arc=fail smtp.client-ip=40.107.237.57 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=amd.com Authentication-Results: smtp.subspace.kernel.org; spf=fail smtp.mailfrom=amd.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=amd.com header.i=@amd.com header.b="p7z2jzwi" ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=aF6oMDISfbSGdxtq+UbBz13d1Nh2ib8WwmE21NX1ppcA8EtOr8523w+pdgWcRLlq2MJZPms3NkTnx1x/k3NiKo7LrgzmWrvbhLQpmth4SM0aPI6tRueVQ1tjdTlBogvUXOsCs+J+dUK/aKYTq3+fAYmNk9ggAPVZFklJpG7Uf9LsOtjrWaqEY6siyCMULg+1MiLhyFoiOKU3gGM17Wfdlmef9e/CWOrOLpnfVmJfp2TRkt4n+bQVci9QVZAS+kyFh3swhhmw4atD/ONnz20Q3lmI1RY5XiYmec05qGLiOmjnIx13Chc1p0C7DOFRaKIBF64zb5ZaRlY/LV5wEQCH2g== 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=UynB4HAJRyDS6QflPsYbh08yqJRxbfTe1ZqnwUxzHYk=; b=RMCppJw39xFgInRjk4JmkkEE2ot2mQh7/wVzzBfIlPvwv2dcGyKcvtUnR0B4lgZfBFMUP1fsAmqfuN6BzBA72NWb5mtEx8C2qkgZkIGT9DrfOFt2jkok1PkgTd990/6PwN/3aZWrsA+80fz0Kez4CQmkN2O8fXLtqYZhiWobXztd7gyyTz6+yM4fA/BbluNBlfKSe19me8028S/DMh9rpOCTj6egCzchrSQDsfT7FHNmTnm8I4Qsj5xrgbwXGwJ+ikifcbpJE8IDRLr3ErN43G5NZdsCx9v1pVTTAO5a0CuYEEf9VksRr+74Sk2Ynd+nvXEQyHiq/785lrIT8MDzlA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=redhat.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 (0) 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=UynB4HAJRyDS6QflPsYbh08yqJRxbfTe1ZqnwUxzHYk=; b=p7z2jzwiWH0rTIpMqWuL45j5GlrqsWbo/IAX+Ua7+SyHHqMx3dKBy4Jq5w5rKeUqJH2waRoqF9PHMlCiiu5+IJ9eXT+kuoDbONdlgz8FdI51qbXygmBpkYL2Yr0IHUFCqjkEjrw6jTHfKwcRHE3s/sQ0yU0jYD5wuhW5cj7z3+A= Received: from DM6PR18CA0004.namprd18.prod.outlook.com (2603:10b6:5:15b::17) by MN0PR12MB5812.namprd12.prod.outlook.com (2603:10b6:208:378::11) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7316.34; Tue, 27 Feb 2024 12:56:02 +0000 Received: from CY4PEPF0000EE3E.namprd03.prod.outlook.com (2603:10b6:5:15b:cafe::74) by DM6PR18CA0004.outlook.office365.com (2603:10b6:5:15b::17) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7292.50 via Frontend Transport; Tue, 27 Feb 2024 12:56:01 +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 CY4PEPF0000EE3E.mail.protection.outlook.com (10.167.242.18) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.7292.25 via Frontend Transport; Tue, 27 Feb 2024 12:56:01 +0000 Received: from jatayu.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.2507.35; Tue, 27 Feb 2024 06:55:59 -0600 From: Shyam Sundar S K To: , CC: , , "Shyam Sundar S K" Subject: [PATCH 3/7] platform/x86/amd/pmf: Add support to get sbios requests in PMF driver Date: Tue, 27 Feb 2024 18:25:16 +0530 Message-ID: <20240227125520.3153140-4-Shyam-sundar.S-k@amd.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20240227125520.3153140-1-Shyam-sundar.S-k@amd.com> References: <20240227125520.3153140-1-Shyam-sundar.S-k@amd.com> Precedence: bulk X-Mailing-List: platform-driver-x86@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-ClientProxiedBy: SATLEXMB04.amd.com (10.181.40.145) To SATLEXMB04.amd.com (10.181.40.145) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: CY4PEPF0000EE3E:EE_|MN0PR12MB5812:EE_ X-MS-Office365-Filtering-Correlation-Id: c363ea1f-24fe-4b89-b71f-08dc3793739c X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: m3a+iopgsNETPur+MLPCoba2HFPYSoHkwyCOyUq2nQiHGzh0knZgdnC9Y4wBPz/LA/FB/3lnDxjVxM4lqeXx17GO7fNjZE3MAttT9YLEdzrxoOr7lWEfsAz1JQjpJoJuJk9mO75zMFksbByJX0ymnv6ZR2l7wvWRW5Ni+OrpSlTTeDVkjC+ZQqnLEA7jPSxXrLpNcSzqYSk9HcoHjuDuBdErk+hwtrTjbTDgcjJYovzNrV4Uy55fNYCcQDP+cKMMl2ZP/CoWkgwx7Z6z79Pw17S0uGQhuPyNUiRCeWYjx2haTCnoODYsUHuxrP34DP6FJUwAPWZK6I3Ittg2872Iq0l3N4NQ16C3HUGaVy6PZe5J2WbGLtuTRYYdMfk0PkZKXz8oiJ+1xx0msN3WgP+N+Bfmc9ea8ZpaSFNJeMHVSxw7maiRLU2snuRlA9HrjD4jgZSrRTcMF2k0dc84mYihFMmd7Un+62piscSuGEXzZGRhbxstQonOH7zQ6Lfs0GPUPylRf+caD1sW6sgp6jztHZl08RtWbQqXLuPDrs1XB4X7zm3PTyilv2dG2Acs3xb0l2LU3OQkavP1u8qWEEl6LEONfu3uyJaUYwuFk5XFyi6jMTtdXYewYdC0cB0lcZkJ81zfAvVzsDL6oFgUP7w+dvcShezAlackEAmL9tjGXGAVHO/2Jy3ox0pJK+StJ8TJtQV4UmF052qGxl/oci5XJ9AAwpVslA7Wu7pa4aaZlPqw5ViHKFqV1N2Aqx7lgdCy 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:(13230031)(36860700004)(82310400014);DIR:OUT;SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 27 Feb 2024 12:56:01.8044 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: c363ea1f-24fe-4b89-b71f-08dc3793739c 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: CY4PEPF0000EE3E.namprd03.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: MN0PR12MB5812 Update the APMF function index 2 for family 1Ah, that gets the information of SBIOS requests (like the pending requests from BIOS, custom notifications, updation of power limits etc). Co-developed-by: Patil Rajesh Reddy Signed-off-by: Patil Rajesh Reddy Signed-off-by: Shyam Sundar S K --- drivers/platform/x86/amd/pmf/acpi.c | 6 ++++++ drivers/platform/x86/amd/pmf/pmf.h | 13 +++++++++++++ 2 files changed, 19 insertions(+) diff --git a/drivers/platform/x86/amd/pmf/acpi.c b/drivers/platform/x86/amd/pmf/acpi.c index 1f287a147c57..1b2a099c0cef 100644 --- a/drivers/platform/x86/amd/pmf/acpi.c +++ b/drivers/platform/x86/amd/pmf/acpi.c @@ -166,6 +166,12 @@ int apmf_get_auto_mode_def(struct amd_pmf_dev *pdev, struct apmf_auto_mode *data return apmf_if_call_store_buffer(pdev, APMF_FUNC_AUTO_MODE, data, sizeof(*data)); } +int apmf_get_sbios_requests_v2(struct amd_pmf_dev *pdev, struct apmf_sbios_req_v2 *req) +{ + return apmf_if_call_store_buffer(pdev, APMF_FUNC_SBIOS_REQUESTS, + req, sizeof(*req)); +} + int apmf_get_sbios_requests(struct amd_pmf_dev *pdev, struct apmf_sbios_req *req) { return apmf_if_call_store_buffer(pdev, APMF_FUNC_SBIOS_REQUESTS, diff --git a/drivers/platform/x86/amd/pmf/pmf.h b/drivers/platform/x86/amd/pmf/pmf.h index 4364af72a7a3..f11d2a348696 100644 --- a/drivers/platform/x86/amd/pmf/pmf.h +++ b/drivers/platform/x86/amd/pmf/pmf.h @@ -116,6 +116,18 @@ struct apmf_sbios_req { u8 skin_temp_hs2; } __packed; +struct apmf_sbios_req_v2 { + u16 size; + u32 pending_req; + u8 rsvd; + u32 update_ppt_pmf; + u32 update_ppt_pmf_apu_only; + u32 update_stt_min; + u8 update_stt_apu; + u8 update_stt_hs2; + u32 custom_policy[10]; +} __packed; + struct apmf_fan_idx { u16 size; u8 fan_ctl_mode; @@ -612,6 +624,7 @@ void amd_pmf_init_auto_mode(struct amd_pmf_dev *dev); void amd_pmf_deinit_auto_mode(struct amd_pmf_dev *dev); void amd_pmf_trans_automode(struct amd_pmf_dev *dev, int socket_power, ktime_t time_elapsed_ms); int apmf_get_sbios_requests(struct amd_pmf_dev *pdev, struct apmf_sbios_req *req); +int apmf_get_sbios_requests_v2(struct amd_pmf_dev *pdev, struct apmf_sbios_req_v2 *req); void amd_pmf_update_2_cql(struct amd_pmf_dev *dev, bool is_cql_event); int amd_pmf_reset_amt(struct amd_pmf_dev *dev); From patchwork Tue Feb 27 12:55:17 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Shyam Sundar S K X-Patchwork-Id: 13573771 Received: from NAM02-DM3-obe.outbound.protection.outlook.com (mail-dm3nam02on2057.outbound.protection.outlook.com [40.107.95.57]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 4ABC013329D for ; Tue, 27 Feb 2024 12:56:10 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.95.57 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709038573; cv=fail; b=qow5BYJkD7RNNnqxZszZ046WJR6Ho/5sYcAO9JQSXWoKXMsL8yqMNhTgRIw+bFfncxGBtwBt+sPYlI2tEGiwPBiOUehrH6SGHhiBFUtFT3d4OeEYRecHOl5NBnJ2/Uz2zLa9z9tiSOCnGmWMQTckOxUHt7kwpsbKsnpZ4/L+lL8= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709038573; c=relaxed/simple; bh=ZHQSEDDwWAXZvt00fzNtOWtRp4doBKZDDF+ZqVzoAGs=; h=From:To:CC:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=SFHsqozIri8K5dU258qnw5G4oAOAmyWAQ5QwymZCojdc9D7ZLgrsSOdV6fplEvMKYnQwv6nLNmHnaZj8K+DbttFWrGLUSYLyYfe5p+UTdaEDa7v32A6vWm7KfjBFLVE9yp2XuXtaTStVFSARwe22tt+yJUJWfp3nEKYba4b+sY8= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=amd.com; spf=fail smtp.mailfrom=amd.com; dkim=pass (1024-bit key) header.d=amd.com header.i=@amd.com header.b=EI1RqkVY; arc=fail smtp.client-ip=40.107.95.57 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=amd.com Authentication-Results: smtp.subspace.kernel.org; spf=fail smtp.mailfrom=amd.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=amd.com header.i=@amd.com header.b="EI1RqkVY" ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=kS4rxB2ON5PxDGThQygieuDQq0iI3KRcpq23ep4/3SwAWhDyUc7dM1lxHIiZ9Aljd4R2Ocq3oxuxt7zZMz2tQm5qYTJJnErncwEoX/j0vZmDGapmCPV0RUkYisaJHWJvw6tikiLx7a6VzY8xlv/fIqXszFD1PSYpbuXajQkVPUnj+F8cnHQySQIHlvO3Q3WcDo6UmGLSCfgiFqFZM+YrH2u29r+f0rs9DhMcUdN4sXsAKYEcV8yFb3HssKvWg+ccQNqBiA1nx/qeTWhTFT68HKG8yVAWExlj4/VJh9o7t0BpqKXHQTLuR7qWmvZ/KHYUiM+BYkwzCjJaRMCXy72osw== 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=1AS9RZ6f6P2/thvFucTjQOBWUceaJOjUDsyWJG572dA=; b=KBLZH8B+5rWeLWt14GpQfY5k9SvqJwtYdhuXQBzIBHf0z6YvrCgAc9stv2/xQj35L0++ANvZEQMth7xxL/wCFQiwOwym5Bw3CoGP85D9K5+j4A5Vxr9bTkY6d+kHWVvk68MmBPq9VnPMXucNquCpPAYFYYnj4Sfl27CmE2jHp+2GCY9XV4UyziUqkawFaYId2T9VmAFMhDEHQ4z0KcuLJ/Lv8hRlXVCng/h2yuoswujgkR+Q3FnHroZ8E1X/PnyROvAYcH/rV04kugdOl7yKJc5128d7X6HQ8tIhDqsBgsW5v2lvFUt+mrRbCBBilZeyma0HNXkVJ8is6L6xGaLbsQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=redhat.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 (0) 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=1AS9RZ6f6P2/thvFucTjQOBWUceaJOjUDsyWJG572dA=; b=EI1RqkVYOJvOF6cLg+VNAnLHT3gvsZrzlnSub+1SzGcjOsyyhGmEjRroFWtzmP2l/xcrB+NwFAKEBLDq+YMp2rf+A1POFfyE9l9+yChmDrF5CR4lAjurInjkLgQigV1Q4+KIZIGOs3a1SWMfCtmQuMRI5KhLZCwKSosGtoPMhzM= Received: from DM6PR06CA0098.namprd06.prod.outlook.com (2603:10b6:5:336::31) by CH2PR12MB4278.namprd12.prod.outlook.com (2603:10b6:610:ab::17) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7316.39; Tue, 27 Feb 2024 12:56:04 +0000 Received: from CY4PEPF0000EE3B.namprd03.prod.outlook.com (2603:10b6:5:336:cafe::de) by DM6PR06CA0098.outlook.office365.com (2603:10b6:5:336::31) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7292.49 via Frontend Transport; Tue, 27 Feb 2024 12:56:04 +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 CY4PEPF0000EE3B.mail.protection.outlook.com (10.167.242.15) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.7292.25 via Frontend Transport; Tue, 27 Feb 2024 12:56:04 +0000 Received: from jatayu.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.2507.35; Tue, 27 Feb 2024 06:56:01 -0600 From: Shyam Sundar S K To: , CC: , , "Shyam Sundar S K" Subject: [PATCH 4/7] platform/x86/amd/pmf: Add support to notify sbios heart beat event Date: Tue, 27 Feb 2024 18:25:17 +0530 Message-ID: <20240227125520.3153140-5-Shyam-sundar.S-k@amd.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20240227125520.3153140-1-Shyam-sundar.S-k@amd.com> References: <20240227125520.3153140-1-Shyam-sundar.S-k@amd.com> Precedence: bulk X-Mailing-List: platform-driver-x86@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-ClientProxiedBy: SATLEXMB04.amd.com (10.181.40.145) To SATLEXMB04.amd.com (10.181.40.145) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: CY4PEPF0000EE3B:EE_|CH2PR12MB4278:EE_ X-MS-Office365-Filtering-Correlation-Id: e40350d3-8d54-4c24-ef92-08dc37937516 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: BHr0eAQ/5E+p0UYRrMp/NMNWjyPgbYpkHgLDWBCVihOCQptXrDWtMK4TP/OSWNp3Jzx53AaCYZITlVNV9FtuTf4lwxOliHBsrAlS+lu+feBB4E5/biwvoskVuDCh0A99jtUvNbW7EpQ2RcAsFNf8znTec1G9Be92v2xOu6rMzfvSae0AF3t8KHMn773W2Ep7zxQI9hZZsskcfR8c/2xkKvhsKpq4dibDQFyXDUpeBTlpQaiGelx36b3mqPI9ROxfRrM3xXzFq1Bilc182898+YB/t1f6WMmc+vMkY8LAfatg5KuiwXzF4Lozlk73ZyU3COfXzcyPlGNnZiYhI/Zim6w/e6TYL9xaHd+wsSrZfj5gNo4s+SAijyKjOLxj5T1KGqkfJmy4Tm3uIR1OwPdvXQrkIFetDGchCRJaaoAcpVhd8U3Z/wKEFC9/iB0kOoTwiqg7ChRALv8MZ8XSmPji4PSvpmLa3RywSpnTZC49/pRF9GAg1lZD059Uozo00qVpp1jKvTWWEPTZG6HRM5rLJ0S4kYvKK+AbkD/VaTSP3CkUEqFwJJCazCRNOj6C1cuiX9oYjjqt5EVsKcNqhDJbfF8rZTt7KBzIwD3C0UNyf70Y12Ubeor84YiQogUk4qWT7WWLQJ2TiUzqwJn8ri1DF9g/vvRCvNdmNVzID7e66AulKukLJrg2xmT4l0gDb1anxA8gJxp1Jh3tqmy3bRC9diK7fLSv0VneTQCgB80LCOkrK9wYxvRqSxguFRL/9SWY 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:(13230031)(36860700004)(82310400014);DIR:OUT;SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 27 Feb 2024 12:56:04.2831 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: e40350d3-8d54-4c24-ef92-08dc37937516 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: CY4PEPF0000EE3B.namprd03.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: CH2PR12MB4278 Add support for newer revision of the heart beat notify events. This event is used to notify to the OEM BIOS on driver load/unload/suspend/resume scenarios. If OEM BIOS does not receive the heart beat event from PMF driver, OEM BIOS shall conclude that PMF driver is no more active and BIOS will update to the legacy system power thermals. Co-developed-by: Patil Rajesh Reddy Signed-off-by: Patil Rajesh Reddy Signed-off-by: Shyam Sundar S K --- drivers/platform/x86/amd/pmf/acpi.c | 42 +++++++++++++++++++++++++++-- drivers/platform/x86/amd/pmf/core.c | 10 +++++++ drivers/platform/x86/amd/pmf/pmf.h | 17 ++++++++++++ 3 files changed, 67 insertions(+), 2 deletions(-) diff --git a/drivers/platform/x86/amd/pmf/acpi.c b/drivers/platform/x86/amd/pmf/acpi.c index 1b2a099c0cef..0fc8ad0ac3e9 100644 --- a/drivers/platform/x86/amd/pmf/acpi.c +++ b/drivers/platform/x86/amd/pmf/acpi.c @@ -140,6 +140,44 @@ static void apmf_sbios_heartbeat_notify(struct work_struct *work) kfree(info); } +int amd_pmf_notify_sbios_heartbeat_event_v2(struct amd_pmf_dev *dev, u8 flag) +{ + struct sbios_hb_event_v2 args = { }; + struct acpi_buffer params; + union acpi_object *info; + + args.size = sizeof(args); + + switch (flag) { + case ON_LOAD: + args.load = 1; + break; + case ON_UNLOAD: + args.unload = 1; + break; + case ON_SUSPEND: + args.suspend = 1; + break; + case ON_RESUME: + args.resume = 1; + break; + default: + return -EINVAL; + } + + params.length = sizeof(args); + params.pointer = (void *)&args; + + info = apmf_if_call(dev, APMF_FUNC_SBIOS_HEARTBEAT_V2, ¶ms); + if (!info) + return -EIO; + + dev_dbg(dev->dev, "Sending v2 heartbeat event to SBIOS\n"); + + kfree(info); + return 0; +} + int apmf_update_fan_idx(struct amd_pmf_dev *pdev, bool manual, u32 idx) { union acpi_object *info; @@ -328,7 +366,7 @@ void apmf_acpi_deinit(struct amd_pmf_dev *pmf_dev) { acpi_handle ahandle = ACPI_HANDLE(pmf_dev->dev); - if (pmf_dev->hb_interval) + if (pmf_dev->hb_interval && pmf_dev->pmf_if_version == PMF_IF_V1) cancel_delayed_work_sync(&pmf_dev->heart_beat); if (is_apmf_func_supported(pmf_dev, APMF_FUNC_AUTO_MODE) && @@ -352,7 +390,7 @@ int apmf_acpi_init(struct amd_pmf_dev *pmf_dev) goto out; } - if (pmf_dev->hb_interval) { + if (pmf_dev->hb_interval && pmf_dev->pmf_if_version == PMF_IF_V1) { /* send heartbeats only if the interval is not zero */ INIT_DELAYED_WORK(&pmf_dev->heart_beat, apmf_sbios_heartbeat_notify); schedule_delayed_work(&pmf_dev->heart_beat, 0); diff --git a/drivers/platform/x86/amd/pmf/core.c b/drivers/platform/x86/amd/pmf/core.c index 2230bc2b1f59..5e52eb32ab2b 100644 --- a/drivers/platform/x86/amd/pmf/core.c +++ b/drivers/platform/x86/amd/pmf/core.c @@ -300,6 +300,9 @@ static int amd_pmf_suspend_handler(struct device *dev) if (pdev->smart_pc_enabled) cancel_delayed_work_sync(&pdev->pb_work); + if (is_apmf_func_supported(pdev, APMF_FUNC_SBIOS_HEARTBEAT_V2)) + amd_pmf_notify_sbios_heartbeat_event_v2(pdev, ON_SUSPEND); + return 0; } @@ -317,6 +320,9 @@ static int amd_pmf_resume_handler(struct device *dev) if (pdev->smart_pc_enabled) schedule_delayed_work(&pdev->pb_work, msecs_to_jiffies(2000)); + if (is_apmf_func_supported(pdev, APMF_FUNC_SBIOS_HEARTBEAT_V2)) + amd_pmf_notify_sbios_heartbeat_event_v2(pdev, ON_RESUME); + return 0; } @@ -444,6 +450,8 @@ static int amd_pmf_probe(struct platform_device *pdev) amd_pmf_dbgfs_register(dev); amd_pmf_init_features(dev); apmf_install_handler(dev); + if (is_apmf_func_supported(dev, APMF_FUNC_SBIOS_HEARTBEAT_V2)) + amd_pmf_notify_sbios_heartbeat_event_v2(dev, ON_LOAD); dev_info(dev->dev, "registered PMF device successfully\n"); @@ -455,6 +463,8 @@ static void amd_pmf_remove(struct platform_device *pdev) struct amd_pmf_dev *dev = platform_get_drvdata(pdev); amd_pmf_deinit_features(dev); + if (is_apmf_func_supported(dev, APMF_FUNC_SBIOS_HEARTBEAT_V2)) + amd_pmf_notify_sbios_heartbeat_event_v2(dev, ON_UNLOAD); apmf_acpi_deinit(dev); amd_pmf_dbgfs_unregister(dev); mutex_destroy(&dev->lock); diff --git a/drivers/platform/x86/amd/pmf/pmf.h b/drivers/platform/x86/amd/pmf/pmf.h index f11d2a348696..5cad11369697 100644 --- a/drivers/platform/x86/amd/pmf/pmf.h +++ b/drivers/platform/x86/amd/pmf/pmf.h @@ -30,6 +30,7 @@ #define APMF_FUNC_STATIC_SLIDER_GRANULAR 9 #define APMF_FUNC_DYN_SLIDER_AC 11 #define APMF_FUNC_DYN_SLIDER_DC 12 +#define APMF_FUNC_SBIOS_HEARTBEAT_V2 16 /* Message Definitions */ #define SET_SPL 0x03 /* SPL: Sustained Power Limit */ @@ -85,6 +86,21 @@ #define PMF_IF_V1 1 +struct sbios_hb_event_v2 { + u16 size; + u8 load; + u8 unload; + u8 suspend; + u8 resume; +} __packed; + +enum sbios_hb_v2 { + ON_LOAD, + ON_UNLOAD, + ON_SUSPEND, + ON_RESUME, +}; + /* AMD PMF BIOS interfaces */ struct apmf_verify_interface { u16 size; @@ -600,6 +616,7 @@ int amd_pmf_get_power_source(void); int apmf_install_handler(struct amd_pmf_dev *pmf_dev); int apmf_os_power_slider_update(struct amd_pmf_dev *dev, u8 flag); int amd_pmf_set_dram_addr(struct amd_pmf_dev *dev, bool alloc_buffer); +int amd_pmf_notify_sbios_heartbeat_event_v2(struct amd_pmf_dev *dev, u8 flag); /* SPS Layer */ int amd_pmf_get_pprof_modes(struct amd_pmf_dev *pmf); From patchwork Tue Feb 27 12:55:18 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Shyam Sundar S K X-Patchwork-Id: 13573770 Received: from NAM11-CO1-obe.outbound.protection.outlook.com (mail-co1nam11on2077.outbound.protection.outlook.com [40.107.220.77]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 3EC9C13329D for ; Tue, 27 Feb 2024 12:56:09 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.220.77 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709038571; cv=fail; b=RhbyMxlkIgNe7fv3AlzWWU4GAhNK2y/kgU8ilzJpYk5B5xXLaU22CzBHcThX3Ey1IPOqzJKrVAXUptbUIMP045WsFF+30AOzAsJafz+NcywZLgL4VajcLmP3Qn1jJVEO08ZCB/WZTZiE+W16ErTgHb3lYWszjGTu6vQr4Zl2Kgc= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709038571; c=relaxed/simple; bh=Ji8sfLL5r8Vhc5yp+XZmRtoT7Z/iCKPyoALEWrHp3js=; h=From:To:CC:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=GHqC+9ndI3l4cdEUr5qNwYKOpQX80M0RDnfYz6QDOzKU+KTpRqTMZgzlbpS5RwT3cuEA15YhsFg3hakh2Pby2m0LfsfEPwimHu/nwEiZZSVygQM8//EvV0vwE2bd6fH0J9rz7fQNhVu8LpaKdOBxx8q4Jpz4ZgmRUqj/R7MhNrw= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=amd.com; spf=fail smtp.mailfrom=amd.com; dkim=pass (1024-bit key) header.d=amd.com header.i=@amd.com header.b=d5dqhHvm; arc=fail smtp.client-ip=40.107.220.77 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=amd.com Authentication-Results: smtp.subspace.kernel.org; spf=fail smtp.mailfrom=amd.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=amd.com header.i=@amd.com header.b="d5dqhHvm" ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=NGwnHGlihN2P3SltVwrjcRaGUk9CZ4ocD4E6sHKiGJf08g7pWTPDsQJ+n2ZY+H3bEpMB3TfMdNquRK2kYgzzVVDqK4XksofUC0MdpVLcHqyL6KiWrbNYaSmpAQK3T98DijVQ2cfFXOhbW00ptGcQFhbhg1ed3BEi8Cta91HiSyJof9MioIegEgcUSBkY5NnuDXeaz+oV07C5UL2wQwB8Vvw8N5QvQx/0v3a7jTbV0CrliGNhzjN6xfncToHlbBR+MMs1rjlzeGGCwqOmQxp2OpcY29C0SO0pgy0N9l9T/9pbiU/6suDzan/yXuPiI6iWrpOHFanItafMMAW/AIEbvQ== 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=vSlFsK8bBrA2orhZYp6xNH27VT0CObcMz78Z2EEIQj8=; b=gjpU9kkdP0kN/NFRy9leeEypP+IWay7ygZ253YR7gX4d8MUG9dkGnerIwcch08B1usIWLzqvH/0NjB/2Gm6YD0lzB+10VeXTF5QPkOdYgBur9enS+e8pqt2KqGaaePzRQfprIiekO7PuOV2KeHVcTQVHd59Ha/9tCc1tbTWmn6tLBZgkMouZFC5GCmDCzXamfl8Blij13EDH/S4pdp7blcsUTAY8VqMUJscB+ZBjPI9dGLxrG9vQP+GRY0bo2XiNzYdIeQUpcb6I7wA0j7BtWFJEU2EKEU1A2F6TS/i5abe6lL+eTiiBLHnkiOUTvpDJJmlbCIoy1o51XqG6ubF4mA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=redhat.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 (0) 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=vSlFsK8bBrA2orhZYp6xNH27VT0CObcMz78Z2EEIQj8=; b=d5dqhHvmKPk+XASXijoZRnkM5eo8zxjFbN5sfNB1y7f4Wc/wuSrc52uQGc/qHUrM3zC5JWFFW14y42WS3haRfx2JjsF2ZiC94ruYfdrePkd+mtpo6Sc7KULPwlCE5rcQbCQQhgUpyCa4gogGTFK5PubjM5h9SffrqajU3/IMfJw= Received: from CY5PR04CA0007.namprd04.prod.outlook.com (2603:10b6:930:1e::27) by CY5PR12MB6370.namprd12.prod.outlook.com (2603:10b6:930:20::22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7316.36; Tue, 27 Feb 2024 12:56:06 +0000 Received: from CY4PEPF0000EE3F.namprd03.prod.outlook.com (2603:10b6:930:1e:cafe::7e) by CY5PR04CA0007.outlook.office365.com (2603:10b6:930:1e::27) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7292.50 via Frontend Transport; Tue, 27 Feb 2024 12:56:06 +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 CY4PEPF0000EE3F.mail.protection.outlook.com (10.167.242.19) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.7292.25 via Frontend Transport; Tue, 27 Feb 2024 12:56:06 +0000 Received: from jatayu.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.2507.35; Tue, 27 Feb 2024 06:56:03 -0600 From: Shyam Sundar S K To: , CC: , , "Shyam Sundar S K" Subject: [PATCH 5/7] platform/x86/amd/pmf: Add support to get APTS index numbers for static slider Date: Tue, 27 Feb 2024 18:25:18 +0530 Message-ID: <20240227125520.3153140-6-Shyam-sundar.S-k@amd.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20240227125520.3153140-1-Shyam-sundar.S-k@amd.com> References: <20240227125520.3153140-1-Shyam-sundar.S-k@amd.com> Precedence: bulk X-Mailing-List: platform-driver-x86@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-ClientProxiedBy: SATLEXMB04.amd.com (10.181.40.145) To SATLEXMB04.amd.com (10.181.40.145) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: CY4PEPF0000EE3F:EE_|CY5PR12MB6370:EE_ X-MS-Office365-Filtering-Correlation-Id: a66f540d-3873-4bad-eb99-08dc3793766d X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: jT8ev0VjbYtfFIOZ2uck5qYiL53O0Li3FxJd0GXX0RavaO3T/gOnuTedjnXvViRLnBTcaSEJQQrOjEBl8fwtoVyBvxQmOmsbZg9rRE+pV/FOwfg8+BYu+qQY/MYs0PKoku8D0Hw1SXvD9lswChTQO79pbhUGot9WwTtIbYJUvXAG/N/dwPEQeEvXiv86SRdUtgRZUSBnoGxxcevUSkcA/Z1UEsq/0qlrfV0Kg4fVrIqJnWxls8qxxXrJaUSH9NiBGfzWUnw1uLhh/Mi435N95u+P8drAtREKWMxRJDy6frma+r5pxVROI93Ob8k3Kv/ghqxuSfUEv4rV6QHp2xdL6ICYN0mDHhyu3GQrjM2RgYbCWJNQMotrHesUTBdmJosExtP2YESugo3ab+lCUIKwFoNosjuHy//fpDUTik/orWcrX41/B8tlnzVeKLdRoujl5kENEiPZEZcB9nZmW6emy4r2TZ8o33bAOqYtQaRz1wcrLRItkhUXO/kNUbG/et7HfwHNCRa4GTyCcxMunPjmelgoacGWXixMn598EME3sKyYcg0lz8fVud2aHwnM3h7avoIS+lxLwZFx7cr93jCtn9UH1aXimv6wdiSITlLFAXCPtJWZDmBMQ81HMPJO7WmqvzDmjUekWzYNlFPpAxR5yH5C7emsEvuX2oh2g4bLl2FPqWwJHnHv6tejtwVDgQsY94KLj8KsW6NgRay9lnTModKRh+qERU3D/QgnoMWTwtFfKZj20rNRvraAskNRIG22 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:(13230031)(82310400014)(36860700004);DIR:OUT;SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 27 Feb 2024 12:56:06.5309 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: a66f540d-3873-4bad-eb99-08dc3793766d 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: CY4PEPF0000EE3F.namprd03.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: CY5PR12MB6370 APMF spec has a newer section called the APTS (AMD Performance and Thermal State) information, where each slider/power mode is associated with an index number. Add support to get these indices for the Static Slider. Co-developed-by: Patil Rajesh Reddy Signed-off-by: Patil Rajesh Reddy Signed-off-by: Shyam Sundar S K --- drivers/platform/x86/amd/pmf/acpi.c | 10 +++++++ drivers/platform/x86/amd/pmf/pmf.h | 24 +++++++++++++++++ drivers/platform/x86/amd/pmf/sps.c | 42 ++++++++++++++++++++++++++++- 3 files changed, 75 insertions(+), 1 deletion(-) diff --git a/drivers/platform/x86/amd/pmf/acpi.c b/drivers/platform/x86/amd/pmf/acpi.c index 0fc8ad0ac3e9..28df45c058db 100644 --- a/drivers/platform/x86/amd/pmf/acpi.c +++ b/drivers/platform/x86/amd/pmf/acpi.c @@ -96,6 +96,16 @@ int is_apmf_func_supported(struct amd_pmf_dev *pdev, unsigned long index) return !!(pdev->supported_func & BIT(index - 1)); } +int apmf_get_static_slider_granular_v2(struct amd_pmf_dev *pdev, + struct apmf_static_slider_granular_output_v2 *data) +{ + if (!is_apmf_func_supported(pdev, APMF_FUNC_STATIC_SLIDER_GRANULAR)) + return -EINVAL; + + return apmf_if_call_store_buffer(pdev, APMF_FUNC_STATIC_SLIDER_GRANULAR, + data, sizeof(*data)); +} + int apmf_get_static_slider_granular(struct amd_pmf_dev *pdev, struct apmf_static_slider_granular_output *data) { diff --git a/drivers/platform/x86/amd/pmf/pmf.h b/drivers/platform/x86/amd/pmf/pmf.h index 5cad11369697..b27e96aeac23 100644 --- a/drivers/platform/x86/amd/pmf/pmf.h +++ b/drivers/platform/x86/amd/pmf/pmf.h @@ -85,6 +85,7 @@ #define MAX_OPERATION_PARAMS 4 #define PMF_IF_V1 1 +#define PMF_IF_V2 2 struct sbios_hb_event_v2 { u16 size; @@ -264,6 +265,17 @@ struct amd_pmf_dev { u16 pmf_if_version; }; +struct apmf_sps_prop_granular_v2 { + u8 ac_best_perf; + u8 ac_balanced; + u8 ac_best_pwr_efficiency; + u8 ac_energy_saver; + u8 dc_best_perf; + u8 dc_balanced; + u8 dc_best_pwr_efficiency; + u8 dc_battery_saver; +} __packed; + struct apmf_sps_prop_granular { u32 fppt; u32 sppt; @@ -285,6 +297,16 @@ struct amd_pmf_static_slider_granular { struct apmf_sps_prop_granular prop[POWER_SOURCE_MAX][POWER_MODE_MAX]; }; +struct apmf_static_slider_granular_output_v2 { + u16 size; + struct apmf_sps_prop_granular_v2 sps_idx; +} __packed; + +struct amd_pmf_static_slider_granular_v2 { + u16 size; + struct apmf_sps_prop_granular_v2 sps_idx; +}; + struct os_power_slider { u16 size; u8 slider_event; @@ -634,6 +656,8 @@ const char *amd_pmf_source_as_str(unsigned int state); int apmf_update_fan_idx(struct amd_pmf_dev *pdev, bool manual, u32 idx); int amd_pmf_set_sps_power_limits(struct amd_pmf_dev *pmf); +int apmf_get_static_slider_granular_v2(struct amd_pmf_dev *dev, + struct apmf_static_slider_granular_output_v2 *data); /* Auto Mode Layer */ int apmf_get_auto_mode_def(struct amd_pmf_dev *pdev, struct apmf_auto_mode *data); diff --git a/drivers/platform/x86/amd/pmf/sps.c b/drivers/platform/x86/amd/pmf/sps.c index 33e23e25c8b1..dc4c7ccd4c43 100644 --- a/drivers/platform/x86/amd/pmf/sps.c +++ b/drivers/platform/x86/amd/pmf/sps.c @@ -10,6 +10,7 @@ #include "pmf.h" +static struct amd_pmf_static_slider_granular_v2 config_store_v2; static struct amd_pmf_static_slider_granular config_store; #ifdef CONFIG_AMD_PMF_DEBUG @@ -63,10 +64,46 @@ static void amd_pmf_dump_sps_defaults(struct amd_pmf_static_slider_granular *dat pr_debug("Static Slider Data - END\n"); } + +static void amd_pmf_dump_sps_defaults_v2(struct amd_pmf_static_slider_granular_v2 *data) +{ + pr_debug("Static Slider APTS state index data - BEGIN"); + pr_debug("size: %u\n", data->size); + pr_debug("ac_best_perf: %u\n", data->sps_idx.ac_best_perf); + pr_debug("ac_balanced: %u\n", data->sps_idx.ac_balanced); + pr_debug("ac_best_pwr_efficiency: %u\n", data->sps_idx.ac_best_pwr_efficiency); + pr_debug("ac_energy_saver: %u\n", data->sps_idx.ac_energy_saver); + pr_debug("dc_best_perf: %u\n", data->sps_idx.dc_best_perf); + pr_debug("dc_balanced: %u\n", data->sps_idx.dc_balanced); + pr_debug("dc_best_pwr_efficiency: %u\n", data->sps_idx.dc_best_pwr_efficiency); + pr_debug("dc_battery_saver: %u\n", data->sps_idx.dc_battery_saver); + pr_debug("Static Slider APTS state index data - END\n"); +} #else static void amd_pmf_dump_sps_defaults(struct amd_pmf_static_slider_granular *data) {} +static void amd_pmf_dump_sps_defaults_v2(struct amd_pmf_static_slider_granular_v2 *data) {} #endif +static void amd_pmf_load_defaults_sps_v2(struct amd_pmf_dev *dev) +{ + struct apmf_static_slider_granular_output_v2 output; + + memset(&config_store_v2, 0, sizeof(config_store_v2)); + apmf_get_static_slider_granular_v2(dev, &output); + + config_store_v2.size = output.size; + config_store_v2.sps_idx.ac_best_perf = output.sps_idx.ac_best_perf; + config_store_v2.sps_idx.ac_balanced = output.sps_idx.ac_balanced; + config_store_v2.sps_idx.ac_best_pwr_efficiency = output.sps_idx.ac_best_pwr_efficiency; + config_store_v2.sps_idx.ac_energy_saver = output.sps_idx.ac_energy_saver; + config_store_v2.sps_idx.dc_best_perf = output.sps_idx.dc_best_perf; + config_store_v2.sps_idx.dc_balanced = output.sps_idx.dc_balanced; + config_store_v2.sps_idx.dc_best_pwr_efficiency = output.sps_idx.dc_best_pwr_efficiency; + config_store_v2.sps_idx.dc_battery_saver = output.sps_idx.dc_battery_saver; + + amd_pmf_dump_sps_defaults_v2(&config_store_v2); +} + static void amd_pmf_load_defaults_sps(struct amd_pmf_dev *dev) { struct apmf_static_slider_granular_output output; @@ -256,7 +293,10 @@ int amd_pmf_init_sps(struct amd_pmf_dev *dev) dev->current_profile = PLATFORM_PROFILE_BALANCED; if (is_apmf_func_supported(dev, APMF_FUNC_STATIC_SLIDER_GRANULAR)) { - amd_pmf_load_defaults_sps(dev); + if (dev->pmf_if_version == PMF_IF_V2) + amd_pmf_load_defaults_sps_v2(dev); + else + amd_pmf_load_defaults_sps(dev); /* update SPS balanced power mode thermals */ amd_pmf_set_sps_power_limits(dev); From patchwork Tue Feb 27 12:55:19 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Shyam Sundar S K X-Patchwork-Id: 13573772 Received: from NAM10-MW2-obe.outbound.protection.outlook.com (mail-mw2nam10on2040.outbound.protection.outlook.com [40.107.94.40]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 4CDFF13A258 for ; Tue, 27 Feb 2024 12:56:11 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.94.40 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709038574; cv=fail; b=sf5IerEKvnUiJPvY7t8F+ZTI8FIzMP1xrIKTxyRcQyE06D9f1NBE5nkZRkLM/0/TeniL+6oVqpik24UYYeR2arRdK0b/LxKr4u7CztdTD/DHVhUIduQLD+k9BRTs/yhGfoCKtCyxqTg6hexQMdFyljvyNtWoaJWf0vTwVXIr03c= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709038574; c=relaxed/simple; bh=NwoxSWVVvJpwxTWaiBu2ROZpd29wKjLDAKmX/kfJL4k=; h=From:To:CC:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=IQG8WOwnLKnCiR/COcrvCcRltIwWCg1pvp6Sm3xyDw4tBRXhKamhUqcx31H7DRS573zRb2qw2ty+9TKsrUraheiJPNCmCsx0pn+SY4JWjqFz3W1ipnA0BMPR3WTThOp6BjtLAy5OMPm4oiyPpvEpM6DCaj9i2LvniidJlz8OStg= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=amd.com; spf=fail smtp.mailfrom=amd.com; dkim=pass (1024-bit key) header.d=amd.com header.i=@amd.com header.b=aJS4zCDx; arc=fail smtp.client-ip=40.107.94.40 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=amd.com Authentication-Results: smtp.subspace.kernel.org; spf=fail smtp.mailfrom=amd.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=amd.com header.i=@amd.com header.b="aJS4zCDx" ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=lgn90MfWJo1zqWyTFpy0Hr7958baI3g3/nb6FO92QQ3IQDT3cQd7DPXNjFUsYldJIxLPblVJ8Fw03sdMCxpp/jS264gLQaXfrJsmkP1E9UTaqMESbvaQj5j9Lm0Dd5eA8OVvA/EAk3ukuJLXQErtuVApNvuK3ADnAcx3tK2OGZ4ktOu0qyhZD6k/X+Q21acwGno5ZbNMnrCxUbD5jBADLcyk+OFYAoRlXxm3XjGyJoeaunrA7aRgQ3ord27hSbzO+tHNs6U4JXdq+ITg5Y2Nt+Wsq1Xpl7BsJox4B4t/G6esLS/Q0RW+X7Mx/RXaqG9gVepAqm6eOGWuKwPPZwWVJg== 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=AOavwb04dwK6piHXQ5JHRdCfTXIDiROEplOmg0P+cOM=; b=ktFhRB5RTmNLdQ0uXyVtk28U4ySpwJvXOm3+vSYxl5V6XWCkWGge/sRg1S7jAXhthypqZpSMPCx+hS6RfYNgBfdz5gkYQqeUPkJqMUUZ+mF4NTp+8iY0Gj6l+QWTjuK0JrRfPj55Sgvzj7oervtrPqzHVoJv4tKODx2OEe4PEPlGl5mDphlXQRzfUTL7/tg6oQSgS3GvpuTD2tVCMvMiNGPPvT1lmBk0ORt/n3gFOvPwjfUEqP3H8sdnIwovuMoVqaZB1JsQ0GmvapK9lTpp0MCWXi3SxaJLH8fmiR756kMIC99nq9T/gh5KhcghElylw0BUJj3O2a+YgMuPoc94bQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=redhat.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 (0) 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=AOavwb04dwK6piHXQ5JHRdCfTXIDiROEplOmg0P+cOM=; b=aJS4zCDx0cJUY2NfpLtBI6SS5jEnHbmzI81RKg1GYgv/d9he/9B7luRb2pA0HitYhIWpnU66fcZBXTavDrfDrkmATwEXVAracemppU0CotOYGxugHs7xJ+QU0/gA16jGuWD2q2VvPlzAeyA3UiDjMQrrK4U+QR7EfVbxm6uq4C4= Received: from CY8PR10CA0038.namprd10.prod.outlook.com (2603:10b6:930:4b::22) by SA1PR12MB8886.namprd12.prod.outlook.com (2603:10b6:806:375::6) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7316.39; Tue, 27 Feb 2024 12:56:08 +0000 Received: from CY4PEPF0000EE3A.namprd03.prod.outlook.com (2603:10b6:930:4b:cafe::73) by CY8PR10CA0038.outlook.office365.com (2603:10b6:930:4b::22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7292.50 via Frontend Transport; Tue, 27 Feb 2024 12:56:08 +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 CY4PEPF0000EE3A.mail.protection.outlook.com (10.167.242.14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.7292.25 via Frontend Transport; Tue, 27 Feb 2024 12:56:08 +0000 Received: from jatayu.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.2507.35; Tue, 27 Feb 2024 06:56:05 -0600 From: Shyam Sundar S K To: , CC: , , "Shyam Sundar S K" Subject: [PATCH 6/7] platform/x86/amd/pmf: Add support to get sps default APTS index values Date: Tue, 27 Feb 2024 18:25:19 +0530 Message-ID: <20240227125520.3153140-7-Shyam-sundar.S-k@amd.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20240227125520.3153140-1-Shyam-sundar.S-k@amd.com> References: <20240227125520.3153140-1-Shyam-sundar.S-k@amd.com> Precedence: bulk X-Mailing-List: platform-driver-x86@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-ClientProxiedBy: SATLEXMB04.amd.com (10.181.40.145) To SATLEXMB04.amd.com (10.181.40.145) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: CY4PEPF0000EE3A:EE_|SA1PR12MB8886:EE_ X-MS-Office365-Filtering-Correlation-Id: 4df26ddc-b8d4-46cc-0c8e-08dc3793778f X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 0S01AWdnF70KXQUXPzi8/mLTCwtDm58QSSDCEo88434/3BNaLhICtcxEH+V1tBAMYfI6ODnFHqnOuon2A63XoLDTR6eehl+HD7Z5vnF02iDuZnETgHRoJ5mbys85xnld4jhHXESko1TQFAwzgouZdA7ECI2/cIy6LMwvipHUL2p6sevNRProLUPQK8O8I0DB1yV2XvTMK7C4KSeY4dD7/osjQvt5XnVMlqLeUYv2JVop5TTf8xZmd/QHCX7Acjk0g9xwjMkOpZgzjn8B7jMhyFeIhiB2oaBvMzGyAVo0HR9Dhsewyrr9ogJdbjAp4xtn37tOIiLgIbtVOouLAK4qUEZJhy31UQBpZkQavBebPLlo7+pR0+L0wJaRIvEvbc+F/06MVM13RoFuWbvPAvThbGYCxN31QsVTt8rzG/a0cTaIfDtyQdYgCZ5M85U3IC6Jo7NCUmIhjoo8taUjX/5qmqXxQmpZE7dm26QnbbgZssxshH65710QS83cmCQslmrQcAZnY5co0XWv3rMjoDOFiHo9JRgaWQ5OdK54IPsRAA4moIqJ7BV+KzhV5FIHz5US59BlI6LTSGQUH92U9RtKT8zuj6k9ww7Q49XKpk7+ZSPSANEZN1DEj8Eso0wF2kuY5mdGNkHBVbpY26Z4l/o4ZdLgy8STgLlRbEcP1ru+9HNtaenOAPOURjRQ0nVTAgaoYc4OPDibEQm6qxECP7uPSahK8eNdGB9mAgaElshBwxEBkURFiPAP1unZULKE7T8h 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:(13230031)(36860700004)(82310400014);DIR:OUT;SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 27 Feb 2024 12:56:08.4257 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 4df26ddc-b8d4-46cc-0c8e-08dc3793778f 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: CY4PEPF0000EE3A.namprd03.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: SA1PR12MB8886 During the driver probe, the default cache values for the static slider would be obtained by evaluating the APTS method. Add support to use these values as the thermal settings to be updated on the system based on the changing platform-profiles. Co-developed-by: Patil Rajesh Reddy Signed-off-by: Patil Rajesh Reddy Signed-off-by: Shyam Sundar S K --- drivers/platform/x86/amd/pmf/acpi.c | 74 +++++++++++++++++++++++++++++ drivers/platform/x86/amd/pmf/pmf.h | 25 ++++++++++ drivers/platform/x86/amd/pmf/sps.c | 52 +++++++++++++++++++- 3 files changed, 149 insertions(+), 2 deletions(-) diff --git a/drivers/platform/x86/amd/pmf/acpi.c b/drivers/platform/x86/amd/pmf/acpi.c index 28df45c058db..ea9b3871a374 100644 --- a/drivers/platform/x86/amd/pmf/acpi.c +++ b/drivers/platform/x86/amd/pmf/acpi.c @@ -90,12 +90,86 @@ static int apmf_if_call_store_buffer(struct amd_pmf_dev *pdev, int fn, void *des return err; } +static union acpi_object *apts_if_call(struct amd_pmf_dev *pdev, u32 state_index) +{ + struct acpi_buffer buffer = { ACPI_ALLOCATE_BUFFER, NULL }; + acpi_handle ahandle = ACPI_HANDLE(pdev->dev); + struct acpi_object_list apts_if_arg_list; + union acpi_object apts_if_args[3]; + acpi_status status; + + apts_if_arg_list.count = 3; + apts_if_arg_list.pointer = &apts_if_args[0]; + + apts_if_args[0].type = ACPI_TYPE_INTEGER; + apts_if_args[0].integer.value = 1; + apts_if_args[1].type = ACPI_TYPE_INTEGER; + apts_if_args[1].integer.value = state_index; + apts_if_args[2].type = ACPI_TYPE_INTEGER; + apts_if_args[2].integer.value = 0; + + status = acpi_evaluate_object(ahandle, "APTS", &apts_if_arg_list, &buffer); + if (ACPI_FAILURE(status)) { + dev_err(pdev->dev, "APTS state_idx:%u call failed\n", state_index); + kfree(buffer.pointer); + return NULL; + } + + return buffer.pointer; +} + +static int apts_if_call_store_buffer(struct amd_pmf_dev *pdev, + u32 index, void *data, size_t out_sz) +{ + union acpi_object *info; + size_t size; + int err = 0; + + info = apts_if_call(pdev, index); + if (!info) + return -EIO; + + if (info->type != ACPI_TYPE_BUFFER) { + dev_err(pdev->dev, "object is not a buffer\n"); + err = -EINVAL; + goto out; + } + + size = *(u16 *)info->buffer.pointer; + if (info->buffer.length < size) { + dev_err(pdev->dev, "buffer smaller than header size %u < %zu\n", + info->buffer.length, size); + err = -EINVAL; + goto out; + } + + if (size < out_sz) { + dev_err(pdev->dev, "buffer too small %zu\n", size); + err = -EINVAL; + goto out; + } + + memcpy(data, info->buffer.pointer, out_sz); +out: + kfree(info); + return err; +} + int is_apmf_func_supported(struct amd_pmf_dev *pdev, unsigned long index) { /* If bit-n is set, that indicates function n+1 is supported */ return !!(pdev->supported_func & BIT(index - 1)); } +int apts_get_static_slider_granular_v2(struct amd_pmf_dev *pdev, + struct amd_pmf_apts_granular_output *data, u32 apts_idx) +{ + if (!is_apmf_func_supported(pdev, APMF_FUNC_STATIC_SLIDER_GRANULAR)) + return -EINVAL; + + return apts_if_call_store_buffer(pdev, apts_idx, data, sizeof(*data)); +} + int apmf_get_static_slider_granular_v2(struct amd_pmf_dev *pdev, struct apmf_static_slider_granular_output_v2 *data) { diff --git a/drivers/platform/x86/amd/pmf/pmf.h b/drivers/platform/x86/amd/pmf/pmf.h index b27e96aeac23..f99805827510 100644 --- a/drivers/platform/x86/amd/pmf/pmf.h +++ b/drivers/platform/x86/amd/pmf/pmf.h @@ -87,6 +87,29 @@ #define PMF_IF_V1 1 #define PMF_IF_V2 2 +#define APTS_MAX_STATES 16 + +/* APTS PMF BIOS Interface */ +struct amd_pmf_apts_output { + u16 table_version; + u32 fan_table_idx; + u32 pmf_ppt; + u32 ppt_pmf_apu_only; + u32 stt_min_limit; + u8 stt_skin_temp_limit_apu; + u8 stt_skin_temp_limit_hs2; +} __packed; + +struct amd_pmf_apts_granular_output { + u16 size; + struct amd_pmf_apts_output val; +} __packed; + +struct amd_pmf_apts_granular { + u16 size; + struct amd_pmf_apts_output val[APTS_MAX_STATES]; +}; + struct sbios_hb_event_v2 { u16 size; u8 load; @@ -658,6 +681,8 @@ int apmf_update_fan_idx(struct amd_pmf_dev *pdev, bool manual, u32 idx); int amd_pmf_set_sps_power_limits(struct amd_pmf_dev *pmf); int apmf_get_static_slider_granular_v2(struct amd_pmf_dev *dev, struct apmf_static_slider_granular_output_v2 *data); +int apts_get_static_slider_granular_v2(struct amd_pmf_dev *pdev, + struct amd_pmf_apts_granular_output *data, u32 apts_idx); /* Auto Mode Layer */ int apmf_get_auto_mode_def(struct amd_pmf_dev *pdev, struct apmf_auto_mode *data); diff --git a/drivers/platform/x86/amd/pmf/sps.c b/drivers/platform/x86/amd/pmf/sps.c index dc4c7ccd4c43..067fabdaa503 100644 --- a/drivers/platform/x86/amd/pmf/sps.c +++ b/drivers/platform/x86/amd/pmf/sps.c @@ -12,6 +12,7 @@ static struct amd_pmf_static_slider_granular_v2 config_store_v2; static struct amd_pmf_static_slider_granular config_store; +static struct amd_pmf_apts_granular apts_config_store; #ifdef CONFIG_AMD_PMF_DEBUG static const char *slider_as_str(unsigned int state) @@ -79,11 +80,56 @@ static void amd_pmf_dump_sps_defaults_v2(struct amd_pmf_static_slider_granular_v pr_debug("dc_battery_saver: %u\n", data->sps_idx.dc_battery_saver); pr_debug("Static Slider APTS state index data - END\n"); } + +static void amd_pmf_dump_apts_sps_defaults(struct amd_pmf_apts_granular *info) +{ + int i; + + pr_debug("Static Slider APTS index default values data - BEGIN"); + + for (i = 0; i < APTS_MAX_STATES; i++) { + pr_debug("index[%d]: table_version = %u\n", i, info->val[i].table_version); + pr_debug("index[%d]: fan_table_idx = %u\n", i, info->val[i].fan_table_idx); + pr_debug("index[%d]: pmf_ppt = %u\n", i, info->val[i].pmf_ppt); + pr_debug("index[%d]: ppt_pmf_apu_only = %u\n", i, info->val[i].ppt_pmf_apu_only); + pr_debug("index[%d]: stt_min_limit = %u\n", i, info->val[i].stt_min_limit); + pr_debug("index[%d]: stt_skin_temp_limit_apu = %u\n", + i, info->val[i].stt_skin_temp_limit_apu); + pr_debug("index[%d]: stt_skin_temp_limit_hs2 = %u\n", + i, info->val[i].stt_skin_temp_limit_hs2); + } + + pr_debug("Static Slider APTS index default values data - END"); +} #else static void amd_pmf_dump_sps_defaults(struct amd_pmf_static_slider_granular *data) {} static void amd_pmf_dump_sps_defaults_v2(struct amd_pmf_static_slider_granular_v2 *data) {} +static void amd_pmf_dump_apts_sps_defaults(struct amd_pmf_apts_granular *info) {} #endif +static void amd_pmf_load_apts_defaults_sps_v2(struct amd_pmf_dev *pdev) +{ + struct amd_pmf_apts_granular_output output; + int i; + + memset(&apts_config_store, 0, sizeof(apts_config_store)); + + for (i = 0; i < APTS_MAX_STATES; i++) { + apts_get_static_slider_granular_v2(pdev, &output, i); + apts_config_store.val[i].table_version = output.val.table_version; + apts_config_store.val[i].fan_table_idx = output.val.fan_table_idx; + apts_config_store.val[i].pmf_ppt = output.val.pmf_ppt; + apts_config_store.val[i].ppt_pmf_apu_only = output.val.ppt_pmf_apu_only; + apts_config_store.val[i].stt_min_limit = output.val.stt_min_limit; + apts_config_store.val[i].stt_skin_temp_limit_apu = + output.val.stt_skin_temp_limit_apu; + apts_config_store.val[i].stt_skin_temp_limit_hs2 = + output.val.stt_skin_temp_limit_hs2; + } + + amd_pmf_dump_apts_sps_defaults(&apts_config_store); +} + static void amd_pmf_load_defaults_sps_v2(struct amd_pmf_dev *dev) { struct apmf_static_slider_granular_output_v2 output; @@ -293,10 +339,12 @@ int amd_pmf_init_sps(struct amd_pmf_dev *dev) dev->current_profile = PLATFORM_PROFILE_BALANCED; if (is_apmf_func_supported(dev, APMF_FUNC_STATIC_SLIDER_GRANULAR)) { - if (dev->pmf_if_version == PMF_IF_V2) + if (dev->pmf_if_version == PMF_IF_V2) { amd_pmf_load_defaults_sps_v2(dev); - else + amd_pmf_load_apts_defaults_sps_v2(dev); + } else { amd_pmf_load_defaults_sps(dev); + } /* update SPS balanced power mode thermals */ amd_pmf_set_sps_power_limits(dev); From patchwork Tue Feb 27 12:55:20 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Shyam Sundar S K X-Patchwork-Id: 13573773 Received: from NAM10-BN7-obe.outbound.protection.outlook.com (mail-bn7nam10on2040.outbound.protection.outlook.com [40.107.92.40]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id D19DD13A258 for ; Tue, 27 Feb 2024 12:56:15 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.92.40 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709038577; cv=fail; b=I98J1lCuTVN3ysJgjquZdp8cex7cI0trx0CRZhF6Gdnz8u7d9XgxijnSMt1tKu21kUTkmz+DkPcUkVDiROzAEufZccO2mTxtfKRCrJWp2wA8J03g+t+OdSKW6VBd6Dxd38rFQXmZk2GVVmCxDMJXCx8Edt6P33jrOpr9UHz5NSk= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709038577; c=relaxed/simple; bh=cD2hHyYpaAlCCobpJvWc2k68RSExhGiFMlZEhg8UPdc=; h=From:To:CC:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=HZegoyZDSw3kPTb45nSSjVpVMpnsFBFdJNjRUpNW1O43I6j1RVNV1X3nUj0mGINsUwBGd/08AZwnF5fuvGdF4qsz/Or0N6ef5Aqe+51pZkxOPaoGXHiQq8JLwfFhdmy7VjZ6ZIa2T5COFYW7lnBSGr2zPHKqVlJtgGnlLlgv5Gs= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=amd.com; spf=fail smtp.mailfrom=amd.com; dkim=pass (1024-bit key) header.d=amd.com header.i=@amd.com header.b=1HUkf1df; arc=fail smtp.client-ip=40.107.92.40 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=amd.com Authentication-Results: smtp.subspace.kernel.org; spf=fail smtp.mailfrom=amd.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=amd.com header.i=@amd.com header.b="1HUkf1df" ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=U8ceso36LhaefAWPTHd8gA3Av9EFv4kPevhq/1XPUEC64uru/oOOqCnQJrpw4VIF5TFXQURNbGBiljsYx3KgdIC+I5qeLaz4ndMUJ9tAP8erYaDGyUXm7YdYIKliURn+HURLVeeawlAzDMJW3E3oQuhhjNMaPU675awvUkth7TerskwwVLQJc1sRoQhpp3K6QvUJQACzONA6K/sx63FzE/umT3rGBLBb6l7uKmTFr1KgxlF/Ah+P8vxxN2gOoHpyDRxaKXtLViwsLwIZ64cFNSMUTygcAHy2T1NI/HwVLTeSObFA1X+J6CNb6aJyUjSkgBsmDEN2+Uo3yPguQ1l4Hg== 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=SvSRgORzEYrm5MAp2nVIcABjpa5aXH5WJNUediu8xl8=; b=XduVJYndJx6ZL7RUw/fDIeNAcpi94iThbH90QU9Hc77P6ebCCbdV6Ze3y0kIW20a8xWM5yYkdrBjpKKVXSz9bCa3/Z3yvilZHsuSYD9nPwGSql5IPr0rtlfW53vOc079wq55yMErsHX4/FNRC2ZQSVytBGTg2C0BAD37U47pigansajAycrsibaeXK8byjmzaGt99hEpWy2ALpRCclCvaih/A4/JL0kNINJswvmFbNnwuWjpHz/yD4u3+Kc56fSfb1aL2NT4TINX91BZ3tRHJ7rQohsktKs0iY1CVU2OEiijkHNP9rdkpzFIgQLIRkEOGob0DLpF3R9m9zXSC16qUA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=redhat.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 (0) 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=SvSRgORzEYrm5MAp2nVIcABjpa5aXH5WJNUediu8xl8=; b=1HUkf1df0AsUvxVg2xH1mc04jVOD/HjlPY+wFWb7alV/SGX+kZZCz+w28VIibYY0Kidmt8cN/6cEsA0iZMZN1pQoHT81kWrYGOeBBWDxb1tJ/rx6XHxMxfHicNRplqFrjiCaGDA8j3grsPEVOlWWbiK/yXajOF2d3ajZnupq4sA= Received: from CY8PR10CA0034.namprd10.prod.outlook.com (2603:10b6:930:4b::11) by PH7PR12MB6785.namprd12.prod.outlook.com (2603:10b6:510:1ab::19) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7316.36; Tue, 27 Feb 2024 12:56:11 +0000 Received: from CY4PEPF0000EE3A.namprd03.prod.outlook.com (2603:10b6:930:4b:cafe::f5) by CY8PR10CA0034.outlook.office365.com (2603:10b6:930:4b::11) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7292.49 via Frontend Transport; Tue, 27 Feb 2024 12:56:11 +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 CY4PEPF0000EE3A.mail.protection.outlook.com (10.167.242.14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.7292.25 via Frontend Transport; Tue, 27 Feb 2024 12:56:10 +0000 Received: from jatayu.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.2507.35; Tue, 27 Feb 2024 06:56:08 -0600 From: Shyam Sundar S K To: , CC: , , "Shyam Sundar S K" Subject: [PATCH 7/7] platform/x86/amd/pmf: Update sps power thermals according to the platform-profiles Date: Tue, 27 Feb 2024 18:25:20 +0530 Message-ID: <20240227125520.3153140-8-Shyam-sundar.S-k@amd.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20240227125520.3153140-1-Shyam-sundar.S-k@amd.com> References: <20240227125520.3153140-1-Shyam-sundar.S-k@amd.com> Precedence: bulk X-Mailing-List: platform-driver-x86@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-ClientProxiedBy: SATLEXMB04.amd.com (10.181.40.145) To SATLEXMB04.amd.com (10.181.40.145) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: CY4PEPF0000EE3A:EE_|PH7PR12MB6785:EE_ X-MS-Office365-Filtering-Correlation-Id: 87cf2949-d7c0-4600-c04d-08dc37937907 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 2Ny9jyAJJgH1ViJMfac5MoGaXXZMdAtd+jovNeWs+GXwjYkRu2F2oTytInWQyCNtuk8zQOxTItxh9J8UEQTA4cIsQvmendXqs+vB9ROHjS1gV1KQfMN43gnQHiCDhkju3lpUWr++3FgBt1/EiIeMCg2c2ebK8uGVPJavCFVyVudOE7742DI1B+rzkSCFqJ/lE5Ne0qIeYMCaBwXM2QTuO1H1/5gm8/QfdGHNQNaSTjit4KLy/P+lRlV8QGxHI5yRdlpRBE0SqXw6JojA7ypb0mhfMB8ne65MBqWNNdoQ8Lel3MIW9OztpO7tPcltZJ08pHgWOzcyzFDikQb2KqUcfWM14mklV4/+WOL+JlKRZOITs8Evul4Lqe5PJrtuTDhHw+0R8dOU3dTSG8Ikjb1S2ypZfVj6wNL/t47oOyrIKlXbceLqlwrJ1NLqyEha8FD4scxN7rkGaxlxYY69eAKs6LMAGxiJaEPGEuMj7KxQYfWwnhYzgTSmCepcNAvquCPM6OvZk9kMVlx6EIG465AzTbyhC+HDA80x4G2By5vOEp5ODSOGsMrBHEUmOxkb9qPxyidBh3KrEqeFlSZpKOzs0y48vhU91iOwVyuEtT7FFMtQmgJ9Qs3iVCVUPalYhMny/wc9MS9AsG9U/CaNWetZXohRUTIqOG82y1LqDFNK47wAHst6aSy3zAo4UrnK7HRdc/dpxjVCSuWvqEOHcnMzWElE/VIjocWsEgKEiBY4FJ3aezP3QUvhUy1ENMiP6/Wb 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:(13230031)(36860700004)(82310400014);DIR:OUT;SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 27 Feb 2024 12:56:10.8632 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 87cf2949-d7c0-4600-c04d-08dc37937907 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: CY4PEPF0000EE3A.namprd03.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: PH7PR12MB6785 Update power thermals according to the platform-profiles selected by the user. Co-developed-by: Patil Rajesh Reddy Signed-off-by: Patil Rajesh Reddy Signed-off-by: Shyam Sundar S K --- drivers/platform/x86/amd/pmf/pmf.h | 2 ++ drivers/platform/x86/amd/pmf/sps.c | 54 ++++++++++++++++++++++++++++++ 2 files changed, 56 insertions(+) diff --git a/drivers/platform/x86/amd/pmf/pmf.h b/drivers/platform/x86/amd/pmf/pmf.h index f99805827510..09600b612964 100644 --- a/drivers/platform/x86/amd/pmf/pmf.h +++ b/drivers/platform/x86/amd/pmf/pmf.h @@ -51,6 +51,8 @@ #define GET_STT_LIMIT_APU 0x20 #define GET_STT_LIMIT_HS2 0x21 #define SET_P3T 0x23 /* P3T: Peak Package Power Limit */ +#define SET_PMF_PPT 0x25 +#define SET_PMF_PPT_APU_ONLY 0x26 /* OS slider update notification */ #define DC_BEST_PERF 0 diff --git a/drivers/platform/x86/amd/pmf/sps.c b/drivers/platform/x86/amd/pmf/sps.c index 067fabdaa503..1ae06a4743a8 100644 --- a/drivers/platform/x86/amd/pmf/sps.c +++ b/drivers/platform/x86/amd/pmf/sps.c @@ -177,6 +177,19 @@ static void amd_pmf_load_defaults_sps(struct amd_pmf_dev *dev) amd_pmf_dump_sps_defaults(&config_store); } +static void amd_pmf_update_slider_v2(struct amd_pmf_dev *dev, int idx) +{ + amd_pmf_send_cmd(dev, SET_PMF_PPT, false, apts_config_store.val[idx].pmf_ppt, NULL); + amd_pmf_send_cmd(dev, SET_PMF_PPT_APU_ONLY, false, + apts_config_store.val[idx].ppt_pmf_apu_only, NULL); + amd_pmf_send_cmd(dev, SET_STT_MIN_LIMIT, false, + apts_config_store.val[idx].stt_min_limit, NULL); + amd_pmf_send_cmd(dev, SET_STT_LIMIT_APU, false, + apts_config_store.val[idx].stt_skin_temp_limit_apu, NULL); + amd_pmf_send_cmd(dev, SET_STT_LIMIT_HS2, false, + apts_config_store.val[idx].stt_skin_temp_limit_hs2, NULL); +} + void amd_pmf_update_slider(struct amd_pmf_dev *dev, bool op, int idx, struct amd_pmf_static_slider_granular *table) { @@ -209,6 +222,44 @@ void amd_pmf_update_slider(struct amd_pmf_dev *dev, bool op, int idx, } } +static int amd_pmf_update_sps_power_limits_v2(struct amd_pmf_dev *pdev, int pwr_mode) +{ + int src = amd_pmf_get_power_source(); + + if (src == POWER_SOURCE_AC) { + switch (pwr_mode) { + case POWER_MODE_PERFORMANCE: + amd_pmf_update_slider_v2(pdev, config_store_v2.sps_idx.ac_best_perf); + break; + case POWER_MODE_BALANCED_POWER: + amd_pmf_update_slider_v2(pdev, config_store_v2.sps_idx.ac_balanced); + break; + case POWER_MODE_POWER_SAVER: + amd_pmf_update_slider_v2(pdev, + config_store_v2.sps_idx.ac_best_pwr_efficiency); + break; + default: + return -EINVAL; + } + } else if (src == POWER_SOURCE_DC) { + switch (pwr_mode) { + case POWER_MODE_PERFORMANCE: + amd_pmf_update_slider_v2(pdev, config_store_v2.sps_idx.dc_best_perf); + break; + case POWER_MODE_BALANCED_POWER: + amd_pmf_update_slider_v2(pdev, config_store_v2.sps_idx.dc_balanced); + break; + case POWER_MODE_POWER_SAVER: + amd_pmf_update_slider_v2(pdev, + config_store_v2.sps_idx.dc_best_pwr_efficiency); + break; + default: + return -EINVAL; + } + } + return 0; +} + int amd_pmf_set_sps_power_limits(struct amd_pmf_dev *pmf) { int mode; @@ -217,6 +268,9 @@ int amd_pmf_set_sps_power_limits(struct amd_pmf_dev *pmf) if (mode < 0) return mode; + if (pmf->pmf_if_version == PMF_IF_V2) + return amd_pmf_update_sps_power_limits_v2(pmf, mode); + amd_pmf_update_slider(pmf, SLIDER_OP_SET, mode, NULL); return 0;