From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail02.groups.io (mail02.groups.io [66.175.222.108]) by spool.mail.gandi.net (Postfix) with ESMTPS id 8CB52AC1763 for ; Thu, 25 Jan 2024 15:19:12 +0000 (UTC) DKIM-Signature: a=rsa-sha256; bh=LKGBfduXZb8L4VOhNoO51QFcRSEKZz8nAkBv1j17CTs=; c=relaxed/simple; d=groups.io; h=From:To:Cc:Subject:Date:Message-Id:MIME-Version:Precedence:List-Subscribe:List-Help:Sender:List-Id:Mailing-List:Delivered-To:Reply-To:List-Unsubscribe-Post:List-Unsubscribe:Content-Transfer-Encoding; s=20140610; t=1706195951; v=1; b=ntZWIlUebogZqFQkmj7qn1F62OtSE7FbHTJB+hrgVQvasTa+EijA3KYrhuEuDZrXFptVr/yB lqsAhiCrMGlaHXyN6VMckHGBVvzs2z2OF0WqjbSmCLSd0pVA5kxL+FUEbW1QwOm3b+XmBAnWBui x77QmVQ7eam3a2L3+NH6ioq8= X-Received: by 127.0.0.2 with SMTP id d0dFYY7687511xUuRQ4CtJpL; Thu, 25 Jan 2024 07:19:11 -0800 X-Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by mx.groups.io with SMTP id smtpd.web11.20295.1706195950133689937 for ; Thu, 25 Jan 2024 07:19:10 -0800 X-Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id EE70F1FB; Thu, 25 Jan 2024 07:19:53 -0800 (PST) X-Received: from e126645.arm.com (unknown [10.57.47.22]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id 372783F5A1; Thu, 25 Jan 2024 07:19:08 -0800 (PST) From: "PierreGondois" To: devel@edk2.groups.io Cc: Sami Mujawar , Leif Lindholm , Ard Biesheuvel , Pierre Gondois Subject: [edk2-devel] [PATCH v5 00/11] DynamicTablesPkg: Enable _PSD/_CPC generation using SCMI Date: Thu, 25 Jan 2024 16:18:39 +0100 Message-Id: <20240125151850.620749-1-pierre.gondois@arm.com> MIME-Version: 1.0 Precedence: Bulk List-Subscribe: List-Help: Sender: devel@edk2.groups.io List-Id: Mailing-List: list devel@edk2.groups.io; contact devel+owner@edk2.groups.io Reply-To: devel@edk2.groups.io,pierre.gondois@arm.com List-Unsubscribe-Post: List-Unsubscribe=One-Click List-Unsubscribe: X-Gm-Message-State: nhETsuWHdr3p52C8XfdEIjg0x7686176AA= Content-Transfer-Encoding: quoted-printable X-GND-Status: LEGIT Authentication-Results: spool.mail.gandi.net; dkim=pass header.d=groups.io header.s=20140610 header.b=ntZWIlUe; dmarc=fail reason="SPF not aligned (relaxed), DKIM not aligned (relaxed)" header.from=arm.com (policy=none); spf=pass (spool.mail.gandi.net: domain of bounce@groups.io designates 66.175.222.108 as permitted sender) smtp.mailfrom=bounce@groups.io v1: - https://edk2.groups.io/g/devel/message/104115 v2: - https://edk2.groups.io/g/devel/message/104115 - Rebase patches on latest version. v3: - https://edk2.groups.io/g/devel/message/111567 [PATCH 01/11] ArmPkg/ArmScmiDxe: Rename PERFORMANCE_PROTOCOL_VERSION - Note the referenced spec spec is SCMI v3.2 [PATCH 02/11] ArmPkg/ArmScmiDxe: Add PERFORMANCE_DESCRIBE_FASTCHANNEL sup= port - Note the referenced spec spec is SCMI v3.2 - Move SCMI_MESSAGE_ID_PERFORMANCE enum definition out of #pragma pack(1) [PATCH 03/11] MdePkg/Acpi65: Add _PSD/_CPC/State Coordination Types macro= s - Macros used to be added to ACPI 6.4 definition file, move them to the latest ACPI 6.5 definition file [PATCH 10/11] DynamicTablesPkg: Add DynamicTablesScmiInfoLib - Renamed ArmScmiInfoLib to DynamicTablesScmiInfoLib [PATCH 11/11] DynamicTablesPkg: Remove check for _CPC field - Add warning when missing one of the bypassed field All patches: - Rebase on latest master - Use ACPI 6.5 definitions instead of 6.4 previously v4: - https://edk2.groups.io/g/devel/message/112378 - Extracted and submitted patch: - MdePkg/IndustryStandard: Add _PSD/_CPC/Coord types definitions separately at: [1] v5: [PATCH v4 05/10] DynamicTablesPkg: Add CM_ARM_PSD_INFO object - Updated format from "0x%llx" -> "0x%x" [PATCH v4 07/10] DynamicTablesPkg: Add AmlCreatePsdNode() to generate _PS= D - Corrected error handling [PATCH v4 09/10] DynamicTablesPkg: Add DynamicTablesScmiInfoLib - Moved DynamicTablesScmiInfoLib library to AARCH64 section [PATCH v4 10/10] DynamicTablesPkg: Remove check for _CPC field - Added a patch 'DynamicTablesPkg: Add PcdDevelopmentPlatformRelaxations = Pcd' and make use of the new Pcd The SCMI performance protocol allows to query the Operating Performance Points (OPPs) available for each performance domain. Each OPP has a specific frequency/power consumption/performance. On Device Tree (DT) based platforms, the SCMI protocol is directly available from the OS. On ACPI based platforms, the _PSD objects allows to identify CPUs belonging to the same performance domain. CPUs belonging to the same performance domain have the same frequency. The _CPC object allows to describe/control the performance level/frequency of a CPU (i.e. its frequency). This patchset: - Add support for 'DescribeFastchannel' SCMI performance protocol - Add a object to the DynamicTablesPkg to describe the PSD information - Allows to generate _PSD objects in the SsdtCpuTopologyGenerator - Add a ArmScmiInfoLib library populating DynamicTablesPkg CPC objects, relying on the SCMI protocol to fetch the relevant information A patchset for Juno-r2 platforms will be submitted to demonstrate this functionality. [1] https://edk2.groups.io/g/devel/message/111901 Pierre Gondois (11): ArmPkg/ArmScmiDxe: Rename PERFORMANCE_PROTOCOL_VERSION ArmPkg/ArmScmiDxe: Add PERFORMANCE_DESCRIBE_FASTCHANNEL support DynamicTablesPkg: Use new CPC revision macro DynamicTablesPkg: Rename AmlCpcInfo.h to AcpiObjects.h DynamicTablesPkg: Add CM_ARM_PSD_INFO object DynamicTablesPkg: Add PsdToken field to CM_ARM_GICC_INFO object DynamicTablesPkg: Add AmlCreatePsdNode() to generate _PSD DynamicTablesPkg: Generate _PSD in SsdtCpuTopologyGenerator DynamicTablesPkg: Add DynamicTablesScmiInfoLib DynamicTablesPkg: Add PcdDevelopmentPlatformRelaxations Pcd DynamicTablesPkg: Exempt some _CPC field from checks .../ArmScmiDxe/ScmiPerformanceProtocol.c | 80 ++++- .../Protocol/ArmScmiPerformanceProtocol.h | 101 +++++- DynamicTablesPkg/DynamicTables.dsc.inc | 3 + DynamicTablesPkg/DynamicTablesPkg.dec | 8 + DynamicTablesPkg/DynamicTablesPkg.dsc | 3 + .../Include/{AmlCpcInfo.h =3D> AcpiObjects.h} | 20 ++ .../Include/ArmNameSpaceObjects.h | 17 +- .../Include/Library/AmlLib/AmlLib.h | 37 ++- .../Library/DynamicTablesScmiInfoLib.h | 33 ++ .../SsdtCpuTopologyGenerator.c | 96 ++++++ .../Library/Common/AmlLib/AmlLib.inf | 3 + .../Common/AmlLib/CodeGen/AmlCodeGen.c | 228 +++++++++++++- .../ConfigurationManagerObjectParser.c | 14 +- .../DynamicTablesScmiInfoLib.c | 297 ++++++++++++++++++ .../DynamicTablesScmiInfoLib.inf | 31 ++ 15 files changed, 941 insertions(+), 30 deletions(-) rename DynamicTablesPkg/Include/{AmlCpcInfo.h =3D> AcpiObjects.h} (88%) create mode 100644 DynamicTablesPkg/Include/Library/DynamicTablesScmiInf= oLib.h create mode 100644 DynamicTablesPkg/Library/DynamicTablesScmiInfoLib/Dyn= amicTablesScmiInfoLib.c create mode 100644 DynamicTablesPkg/Library/DynamicTablesScmiInfoLib/Dyn= amicTablesScmiInfoLib.inf --=20 2.25.1 -=-=-=-=-=-=-=-=-=-=-=- Groups.io Links: You receive all messages sent to this group. View/Reply Online (#114410): https://edk2.groups.io/g/devel/message/114410 Mute This Topic: https://groups.io/mt/103955491/7686176 Group Owner: devel+owner@edk2.groups.io Unsubscribe: https://edk2.groups.io/g/devel/unsub [rebecca@openfw.io] -=-=-=-=-=-=-=-=-=-=-=-