From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from NAM04-MW2-obe.outbound.protection.outlook.com (NAM04-MW2-obe.outbound.protection.outlook.com [40.107.101.55]) by mx.groups.io with SMTP id smtpd.web09.8990.1662563730832967701 for ; Wed, 07 Sep 2022 08:15:30 -0700 Authentication-Results: mx.groups.io; dkim=pass header.i=@nvidia.com header.s=selector2 header.b=Y+MpSSPX; spf=permerror, err=parse error for token &{10 18 %{i}._ip.%{h}._ehlo.%{d}._spf.vali.email}: invalid domain name (domain: nvidia.com, ip: 40.107.101.55, mailfrom: jbrasen@nvidia.com) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=GGgpRO75B8Cgg0cIyxwYlSAFQN9eLIuYTC+ga1jThBzDEHfdE34s9eA/lYO/I/iv9pqxQSz6ISkWTSznvuFPsEWWrnHmy/sxFnD7XIhf7/AABYDA3OmnO6Ws49acDzjvleD4tGq7QgOU0vq8fyjDRBFjUOl/UDuVlIaJmRZU0FUyzfauQDHHfwIpubAJcZBDlLT6NQqzQMCJXUkaYkNwI5HnzVuxCI0ArGH0S2MT076Z0xGz88bn1v54NlQl2kWUvT3GmiD/GS9Oyin7PVF85al0p4DzFhV3fOpQiFALyAPZ4/26mXnZfe/iWNYvFPbdXBQKNTrFeCXRZkJI/0My1Q== 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=FiKbWUvEYb8/OuRXcvbx1OtDVY5ma6tfl/PTJBISik0=; b=I6bYhJDYoRvfIQYOo42IF5BrXWYKHJ4tIiVHwQUyeMI0prOK8KjDw7XA1Lsdl0m472CQvffSS7o2kszh/X+7e6Pz6FTpZHwpMlZc+YU9ndD+6q27gbKwegSH+dnriG9DnDR3/IxlOtmBoFC9U5Q5pEC6+6S0Loh0A5TuLxDFQFhXT9XSOUfGh4OJSKgn6lroNKp5WwTDDypz/sL54zQ1OcvRzl7Hq7nJiuDfyMR+Agzza+0hvdVSKJ5YRXZZhg9uPWbp88gpYX6Xj6N4gwQo3KkFtgjsy/Dsiq9OfxEHcA/OrDx+hQ5AOqfoHcs5I5YMrz01MycxqqFV4NGO25a47A== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 12.22.5.234) smtp.rcpttodomain=arm.com smtp.mailfrom=nvidia.com; dmarc=pass (p=reject sp=reject pct=100) action=none header.from=nvidia.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=Nvidia.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=FiKbWUvEYb8/OuRXcvbx1OtDVY5ma6tfl/PTJBISik0=; b=Y+MpSSPXUZU/ZBwGuDo4gsPGUfulxJRcfHUlH3vz6y9ISarNfO8e6cdaRhLjLj2dYR94uPIFECtpzKq1o978HA0x9UbA6ZIjd2lQVNvqNLh7RiAMENrIm9gIlNWsAVCwYJoSBBTxSR6j8L1hKqsuWXnpYVNG35tuFGTm6bxUZX366YGIJdySdS3sKTd+E18c6MDDXhVw8VuOMfPnEu6Cav+JZ6cfi+JJXo9fIPLCSm5bFNZnlWLwqYUkb0kdjKZhCxfGaP+WZoqmKmcbvLk1pZ/OUnOhe27eJV3zjUAllycBi037pP02nake9pjUFUOVaELyDvo+YNecwkxnX1HQ3A== Received: from MW4PR03CA0247.namprd03.prod.outlook.com (2603:10b6:303:b4::12) by MW6PR12MB7069.namprd12.prod.outlook.com (2603:10b6:303:238::11) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5588.17; Wed, 7 Sep 2022 15:15:27 +0000 Received: from CO1NAM11FT048.eop-nam11.prod.protection.outlook.com (2603:10b6:303:b4:cafe::5) by MW4PR03CA0247.outlook.office365.com (2603:10b6:303:b4::12) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5612.12 via Frontend Transport; Wed, 7 Sep 2022 15:15:27 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 12.22.5.234) smtp.mailfrom=nvidia.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=nvidia.com; Received-SPF: Pass (protection.outlook.com: domain of nvidia.com designates 12.22.5.234 as permitted sender) receiver=protection.outlook.com; client-ip=12.22.5.234; helo=mail.nvidia.com; pr=C Received: from mail.nvidia.com (12.22.5.234) by CO1NAM11FT048.mail.protection.outlook.com (10.13.175.148) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384) id 15.20.5612.13 via Frontend Transport; Wed, 7 Sep 2022 15:15:27 +0000 Received: from drhqmail202.nvidia.com (10.126.190.181) by DRHQMAIL101.nvidia.com (10.27.9.10) with Microsoft SMTP Server (TLS) id 15.0.1497.38; Wed, 7 Sep 2022 15:15:26 +0000 Received: from drhqmail202.nvidia.com (10.126.190.181) by drhqmail202.nvidia.com (10.126.190.181) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.29; Wed, 7 Sep 2022 08:15:25 -0700 Received: from localhost.localdomain (10.127.8.10) by mail.nvidia.com (10.126.190.181) with Microsoft SMTP Server id 15.2.986.29 via Frontend Transport; Wed, 7 Sep 2022 08:15:25 -0700 From: "Jeff Brasen" To: CC: , , , Jeff Brasen Subject: [PATCH 1/3] DynamicTablesPkg: Add CM_ARM_CPC_INFO object Date: Wed, 7 Sep 2022 09:15:17 -0600 Message-ID: <99283b0ac5e1a9306e28afd2a76059803e2e7376.1662563529.git.jbrasen@nvidia.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: References: MIME-Version: 1.0 X-NVConfidentiality: public Return-Path: jbrasen@nvidia.com X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: CO1NAM11FT048:EE_|MW6PR12MB7069:EE_ X-MS-Office365-Filtering-Correlation-Id: 71d55099-8b31-425c-d438-08da90e3cb77 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: NNsuVsQ7kcm/LFfEuSXHh6hv7NNzLj8CtTPvJhnjq2UxdnpyNwgaZqTJeWhfF50VS1kQTAwuG7ux429cWnR98WEbuZU2Nn7HHCCQUIvJcixMwaNt41aUjvij5o7eynOfHgKYuCZosgEmNxaElRCYNWA3LTosQ0I8ebyJHV/6VoM+jqVUewgXaxjL33uiPp0be0KMxUKQB+TqjCaD4ibRDLTX70ujb/oh1blwDRPM2SGOVKNl70ZNgBvjaNvLg6f8qyB8KZCicbVXh2UR/Y8em7JnOleVzTWHPqiU+AOoPUk+GX8rdpufCLAQ04AIFN3yShVTRYwmBBZDcoilkJd5u9lZwF+yLY7JQtYFyvDeT5z30zWys18H7pr0Wmt6g3xyVs8cECAwA2irY9w743axkD/5DMk3rRpEjXdymomQyi+czP97gt+QvPoRkhTReEtPshzFVLolVnX5A0iM01+wKJ1mBf1kTxMRkJtp5r1/O/uSSkrGmprod36CGvS6buYLzOoGKfnm8vqsUtXcSVML8QoPEmvsN7ch3j63pNtNSUhZVRhTp2heglAj8Y9jsvpw0ULgdwlA1ixXemYyHmR6ctO04z+aRJAV783vd+xS4dcKJvQewN8FaGCdhoLnpEwUymLB5EMllcQa0K0ZHoZ+MDknjsROjYbk1W8ZKgdsAZtEDk9eRgh28Tw1DzYmTSh2AhYl7ZgWl/L11DGZ5hV2FYCIollr8GO1ywZbIoElxP9ikog8sX2wanNj1NVxz/jzJ2Iit5Io2bS/KLmkr3SOhsKBx2PSBaWrzIYGwexTtO/V42XUXfRJA71qE6OadyoS X-Forefront-Antispam-Report: CIP:12.22.5.234;CTRY:US;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:mail.nvidia.com;PTR:InfoNoRecords;CAT:NONE;SFS:(13230016)(4636009)(136003)(376002)(346002)(39860400002)(396003)(40470700004)(36840700001)(46966006)(6916009)(83380400001)(81166007)(47076005)(336012)(186003)(426003)(2616005)(70586007)(36756003)(316002)(8676002)(4326008)(82310400005)(70206006)(54906003)(6666004)(26005)(478600001)(30864003)(107886003)(2906002)(40460700003)(41300700001)(5660300002)(82740400003)(40480700001)(36860700001)(356005)(86362001)(8936002)(36900700001);DIR:OUT;SFP:1101; X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 07 Sep 2022 15:15:27.1012 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 71d55099-8b31-425c-d438-08da90e3cb77 X-MS-Exchange-CrossTenant-Id: 43083d15-7273-40c1-b7db-39efd9ccc17a X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=43083d15-7273-40c1-b7db-39efd9ccc17a;Ip=[12.22.5.234];Helo=[mail.nvidia.com] X-MS-Exchange-CrossTenant-AuthSource: CO1NAM11FT048.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: MW6PR12MB7069 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain Introduce the CM_ARM_CPC_INFO CmObj in the ArmNameSpaceObjects.=0D This allows to describe CPC information, as described in ACPI 6.4,=0D s8.4.7.1 "_CPC (Continuous Performance Control)".=0D =0D Signed-off-by: Jeff Brasen =0D ---=0D .../Include/ArmNameSpaceObjects.h | 146 ++++++++++++++++--=0D .../ConfigurationManagerObjectParser.c | 79 ++++++++++=0D 2 files changed, 208 insertions(+), 17 deletions(-)=0D =0D diff --git a/DynamicTablesPkg/Include/ArmNameSpaceObjects.h b/DynamicTables= Pkg/Include/ArmNameSpaceObjects.h=0D index 102e0f96be..4d3f9ae534 100644=0D --- a/DynamicTablesPkg/Include/ArmNameSpaceObjects.h=0D +++ b/DynamicTablesPkg/Include/ArmNameSpaceObjects.h=0D @@ -63,6 +63,7 @@ typedef enum ArmObjectID {=0D EArmObjPciInterruptMapInfo, ///< 39 - Pci Interrupt Map Info=0D EArmObjRmr, ///< 40 - Reserved Memory Range Nod= e=0D EArmObjMemoryRangeDescriptor, ///< 41 - Memory Range Descriptor=0D + EArmObjCpcInfo, ///< 42 - Continuous Performance Co= ntrol Info=0D EArmObjMax=0D } EARM_OBJECT_ID;=0D =0D @@ -97,99 +98,105 @@ typedef struct CmArmPowerManagementProfileInfo {=0D */=0D typedef struct CmArmGicCInfo {=0D /// The GIC CPU Interface number.=0D - UINT32 CPUInterfaceNumber;=0D + UINT32 CPUInterfaceNumber;=0D =0D /** The ACPI Processor UID. This must match the=0D _UID of the CPU Device object information described=0D in the DSDT/SSDT for the CPU.=0D */=0D - UINT32 AcpiProcessorUid;=0D + UINT32 AcpiProcessorUid;=0D =0D /** The flags field as described by the GICC structure=0D in the ACPI Specification.=0D */=0D - UINT32 Flags;=0D + UINT32 Flags;=0D =0D /** The parking protocol version field as described by=0D the GICC structure in the ACPI Specification.=0D */=0D - UINT32 ParkingProtocolVersion;=0D + UINT32 ParkingProtocolVersion;=0D =0D /** The Performance Interrupt field as described by=0D the GICC structure in the ACPI Specification.=0D */=0D - UINT32 PerformanceInterruptGsiv;=0D + UINT32 PerformanceInterruptGsiv;=0D =0D /** The CPU Parked address field as described by=0D the GICC structure in the ACPI Specification.=0D */=0D - UINT64 ParkedAddress;=0D + UINT64 ParkedAddress;=0D =0D /** The base address for the GIC CPU Interface=0D as described by the GICC structure in the=0D ACPI Specification.=0D */=0D - UINT64 PhysicalBaseAddress;=0D + UINT64 PhysicalBaseAddress;=0D =0D /** The base address for GICV interface=0D as described by the GICC structure in the=0D ACPI Specification.=0D */=0D - UINT64 GICV;=0D + UINT64 GICV;=0D =0D /** The base address for GICH interface=0D as described by the GICC structure in the=0D ACPI Specification.=0D */=0D - UINT64 GICH;=0D + UINT64 GICH;=0D =0D /** The GICV maintenance interrupt=0D as described by the GICC structure in the=0D ACPI Specification.=0D */=0D - UINT32 VGICMaintenanceInterrupt;=0D + UINT32 VGICMaintenanceInterrupt;=0D =0D /** The base address for GICR interface=0D as described by the GICC structure in the=0D ACPI Specification.=0D */=0D - UINT64 GICRBaseAddress;=0D + UINT64 GICRBaseAddress;=0D =0D /** The MPIDR for the CPU=0D as described by the GICC structure in the=0D ACPI Specification.=0D */=0D - UINT64 MPIDR;=0D + UINT64 MPIDR;=0D =0D /** The Processor Power Efficiency class=0D as described by the GICC structure in the=0D ACPI Specification.=0D */=0D - UINT8 ProcessorPowerEfficiencyClass;=0D + UINT8 ProcessorPowerEfficiencyClass;=0D =0D /** Statistical Profiling Extension buffer overflow GSIV. Zero if=0D unsupported by this processor. This field was introduced in=0D ACPI 6.3 (MADT revision 5) and is therefore ignored when=0D generating MADT revision 4 or lower.=0D */=0D - UINT16 SpeOverflowInterrupt;=0D + UINT16 SpeOverflowInterrupt;=0D =0D /** The proximity domain to which the logical processor belongs.=0D This field is used to populate the GICC affinity structure=0D in the SRAT table.=0D */=0D - UINT32 ProximityDomain;=0D + UINT32 ProximityDomain;=0D =0D /** The clock domain to which the logical processor belongs.=0D This field is used to populate the GICC affinity structure=0D in the SRAT table.=0D */=0D - UINT32 ClockDomain;=0D + UINT32 ClockDomain;=0D =0D /** The GICC Affinity flags field as described by the GICC Affinity stru= cture=0D in the SRAT table.=0D */=0D - UINT32 AffinityFlags;=0D + UINT32 AffinityFlags;=0D +=0D + /** Optional field: Reference Token for the Cpc info of this processor.= =0D + Token identifying a CM_ARM_OBJ_REF structure, itself referencing=0D + CM_ARM_CPC_INFO objects.=0D + */=0D + CM_OBJECT_TOKEN CpcToken;=0D } CM_ARM_GICC_INFO;=0D =0D /** A structure that describes the=0D @@ -1070,6 +1077,111 @@ typedef struct CmArmRmrDescriptor {=0D UINT64 Length;=0D } CM_ARM_MEMORY_RANGE_DESCRIPTOR;=0D =0D +/** A structure that describes the Cpc information.=0D +=0D + Continuous Performance Control is described in DSDT/SSDT and associated= =0D + to cpus/clusters in the cpu topology.=0D +=0D + Unsupported Optional registers should be encoded with NULL resource=0D + Register {(SystemMemory, 0, 0, 0, 0)}=0D +=0D + For values that support Integer or Buffer, integer will be used=0D + if buffer is NULL resource.=0D + If resource is not NULL then Integer must be 0=0D +=0D + Cf. ACPI 6.4, s8.4.7.1 _CPC (Continuous Performance Control)=0D +=0D + ID: EArmObjCpcInfo=0D +*/=0D +typedef struct CmArmCpcInfo {=0D + /// Indicates the highest level of performance the processor=0D + /// is theoretically capable of achieving.=0D + EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE HighestPerformanceBuffer;=0D + UINT32 HighestPerformanceInteger;=0D +=0D + /// Indicates the highest sustained performance level of the processor.= =0D + EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE NominalPerformanceBuffer;=0D + UINT32 NominalPerformanceInteger;=0D +=0D + /// Indicates the lowest performance level of the processor with non-lin= ear power savings.=0D + EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE LowestNonlinearPerformanceBuff= er;=0D + UINT32 LowestNonlinearPerformanceInte= ger;=0D +=0D + /// Indicates the lowest performance level of the processor..=0D + EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE LowestPerformanceBuffer;=0D + UINT32 LowestPerformanceInteger;=0D +=0D + /// Guaranteed Performance Register Buffer.=0D + /// Optional=0D + EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE GuaranteedPerformanceRegister;= =0D +=0D + /// Desired Performance Register Buffer.=0D + /// Optional=0D + EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE DesiredPerformanceRegister;=0D +=0D + /// Minimum Performance Register Buffer.=0D + /// Optional=0D + EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE MinimumPerformanceRegister;=0D +=0D + /// Maximum Performance Register Buffer.=0D + /// Optional=0D + EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE MaximumPerformanceRegister;=0D +=0D + /// Performance Reduction Tolerance Register.=0D + /// Optional=0D + EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE PerformanceReductionToleranceR= egister;=0D +=0D + /// Time Window Register.=0D + /// Optional=0D + EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE TimeWindowRegister;=0D +=0D + /// Counter Wraparound Time=0D + /// Optional=0D + EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE CounterWraparoundTimeBuffer;=0D + UINT32 CounterWraparoundTimeInteger;= =0D +=0D + /// Reference Performance Counter Register=0D + EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE ReferencePerformanceCounterReg= ister;=0D +=0D + /// Delivered Performance Counter Register=0D + EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE DeliveredPerformanceCounterReg= ister;=0D +=0D + /// Performance Limited Register=0D + EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE PerformanceLimitedRegister;=0D +=0D + /// CPPC EnableRegister=0D + /// Optional=0D + EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE CPPCEnableRegister;=0D +=0D + /// Autonomous Selection Enable=0D + /// Optional=0D + EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE AutonomousSelectionEnableBuffe= r;=0D + UINT32 AutonomousSelectionEnableInteg= er;=0D +=0D + /// AutonomousActivity-WindowRegister=0D + /// Optional=0D + EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE AutonomousActivityWindowRegist= er;=0D +=0D + /// EnergyPerformance-PreferenceRegister=0D + /// Optional=0D + EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE EnergyPerformancePreferenceReg= ister;=0D +=0D + /// Reference Performance=0D + /// Optional=0D + EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE ReferencePerformanceBuffer;=0D + UINT32 ReferencePerformanceInteger;=0D +=0D + /// Lowest Frequency=0D + /// Optional=0D + EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE LowestFrequencyBuffer;=0D + UINT32 LowestFrequencyInteger;=0D +=0D + /// Nominal Frequency=0D + /// Optional=0D + EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE NominalFrequencyBuffer;=0D + UINT32 NominalFrequencyInteger;=0D +} CM_ARM_CPC_INFO;=0D +=0D #pragma pack()=0D =0D #endif // ARM_NAMESPACE_OBJECTS_H_=0D diff --git a/DynamicTablesPkg/Library/Common/TableHelperLib/ConfigurationMa= nagerObjectParser.c b/DynamicTablesPkg/Library/Common/TableHelperLib/Config= urationManagerObjectParser.c=0D index c1b21d24a4..e2c608443b 100644=0D --- a/DynamicTablesPkg/Library/Common/TableHelperLib/ConfigurationManagerOb= jectParser.c=0D +++ b/DynamicTablesPkg/Library/Common/TableHelperLib/ConfigurationManagerOb= jectParser.c=0D @@ -423,6 +423,83 @@ STATIC CONST CM_OBJ_PARSER CmPciInterruptMapInfoParse= r[] =3D {=0D ARRAY_SIZE (CmArmGenericInterruptParser) },=0D };=0D =0D +/** A parser for EArmObjCpcInfo.=0D +*/=0D +STATIC CONST CM_OBJ_PARSER CmArmCpcInfoParser[] =3D {=0D + { "HighestPerformanceBuffer", sizeof (EFI_ACPI_6_3_GENERIC_= ADDRESS_STRUCTURE),=0D + NULL, NULL, AcpiGenericAddressParser,=0D + ARRAY_SIZE (AcpiGenericAddressParser) },=0D + { "HighestPerformanceInteger", 4, = "0x%llx", NULL },=0D + { "NominalPerformanceBuffer", sizeof (EFI_ACPI_6_3_GENERIC_= ADDRESS_STRUCTURE),=0D + NULL, NULL, AcpiGenericAddressParser,=0D + ARRAY_SIZE (AcpiGenericAddressParser) },=0D + { "NominalPerformanceInteger", 4, = "0x%llx", NULL },=0D + { "LowestNonlinearPerformanceBuffer", sizeof (EFI_ACPI_6_3_GENERIC_= ADDRESS_STRUCTURE),=0D + NULL, NULL, AcpiGenericAddressParser,=0D + ARRAY_SIZE (AcpiGenericAddressParser) },=0D + { "LowestNonlinearPerformanceInteger", 4, = "0x%llx", NULL },=0D + { "LowestPerformanceBuffer", sizeof (EFI_ACPI_6_3_GENERIC_= ADDRESS_STRUCTURE),=0D + NULL, NULL, AcpiGenericAddressParser,=0D + ARRAY_SIZE (AcpiGenericAddressParser) },=0D + { "LowestPerformanceInteger", 4, = "0x%llx", NULL },=0D + { "GuaranteedPerformanceRegister", sizeof (EFI_ACPI_6_3_GENERIC_= ADDRESS_STRUCTURE),=0D + NULL, NULL, AcpiGenericAddressParser,=0D + ARRAY_SIZE (AcpiGenericAddressParser) },=0D + { "DesiredPerformanceRegister", sizeof (EFI_ACPI_6_3_GENERIC_= ADDRESS_STRUCTURE),=0D + NULL, NULL, AcpiGenericAddressParser,=0D + ARRAY_SIZE (AcpiGenericAddressParser) },=0D + { "MinimumPerformanceRegister", sizeof (EFI_ACPI_6_3_GENERIC_= ADDRESS_STRUCTURE),=0D + NULL, NULL, AcpiGenericAddressParser,=0D + ARRAY_SIZE (AcpiGenericAddressParser) },=0D + { "MaximumPerformanceRegister", sizeof (EFI_ACPI_6_3_GENERIC_= ADDRESS_STRUCTURE),=0D + NULL, NULL, AcpiGenericAddressParser,=0D + ARRAY_SIZE (AcpiGenericAddressParser) },=0D + { "PerformanceReductionToleranceRegister", sizeof (EFI_ACPI_6_3_GENERIC_= ADDRESS_STRUCTURE),=0D + NULL, NULL, AcpiGenericAddressParser,=0D + ARRAY_SIZE (AcpiGenericAddressParser) },=0D + { "TimeWindowRegister", sizeof (EFI_ACPI_6_3_GENERIC_= ADDRESS_STRUCTURE),=0D + NULL, NULL, AcpiGenericAddressParser,=0D + ARRAY_SIZE (AcpiGenericAddressParser) },=0D + { "CounterWraparoundTimeBuffer", sizeof (EFI_ACPI_6_3_GENERIC_= ADDRESS_STRUCTURE),=0D + NULL, NULL, AcpiGenericAddressParser,=0D + ARRAY_SIZE (AcpiGenericAddressParser) },=0D + { "CounterWraparoundTimeInteger", 4, = "0x%llx", NULL },=0D + { "ReferencePerformanceCounterRegister", sizeof (EFI_ACPI_6_3_GENERIC_= ADDRESS_STRUCTURE),=0D + NULL, NULL, AcpiGenericAddressParser,=0D + ARRAY_SIZE (AcpiGenericAddressParser) },=0D + { "DeliveredPerformanceCounterRegister", sizeof (EFI_ACPI_6_3_GENERIC_= ADDRESS_STRUCTURE),=0D + NULL, NULL, AcpiGenericAddressParser,=0D + ARRAY_SIZE (AcpiGenericAddressParser) },=0D + { "PerformanceLimitedRegister", sizeof (EFI_ACPI_6_3_GENERIC_= ADDRESS_STRUCTURE),=0D + NULL, NULL, AcpiGenericAddressParser,=0D + ARRAY_SIZE (AcpiGenericAddressParser) },=0D + { "CPPCEnableRegister", sizeof (EFI_ACPI_6_3_GENERIC_= ADDRESS_STRUCTURE),=0D + NULL, NULL, AcpiGenericAddressParser,=0D + ARRAY_SIZE (AcpiGenericAddressParser) },=0D + { "AutonomousSelectionEnableBuffer", sizeof (EFI_ACPI_6_3_GENERIC_= ADDRESS_STRUCTURE),=0D + NULL, NULL, AcpiGenericAddressParser,=0D + ARRAY_SIZE (AcpiGenericAddressParser) },=0D + { "AutonomousSelectionEnableInteger", 4, = "0x%llx", NULL },=0D + { "AutonomousActivityWindowRegister", sizeof (EFI_ACPI_6_3_GENERIC_= ADDRESS_STRUCTURE),=0D + NULL, NULL, AcpiGenericAddressParser,=0D + ARRAY_SIZE (AcpiGenericAddressParser) },=0D + { "EnergyPerformancePreferenceRegister", sizeof (EFI_ACPI_6_3_GENERIC_= ADDRESS_STRUCTURE),=0D + NULL, NULL, AcpiGenericAddressParser,=0D + ARRAY_SIZE (AcpiGenericAddressParser) },=0D + { "ReferencePerformanceBuffer", sizeof (EFI_ACPI_6_3_GENERIC_= ADDRESS_STRUCTURE),=0D + NULL, NULL, AcpiGenericAddressParser,=0D + ARRAY_SIZE (AcpiGenericAddressParser) },=0D + { "ReferencePerformanceInteger", 4, = "0x%llx", NULL },=0D + { "LowestFrequencyBuffer", sizeof (EFI_ACPI_6_3_GENERIC_= ADDRESS_STRUCTURE),=0D + NULL, NULL, AcpiGenericAddressParser,=0D + ARRAY_SIZE (AcpiGenericAddressParser) },=0D + { "LowestFrequencyInteger", 4, = "0x%llx", NULL },=0D + { "NominalFrequencyBuffer", sizeof (EFI_ACPI_6_3_GENERIC_= ADDRESS_STRUCTURE),=0D + NULL, NULL, AcpiGenericAddressParser,=0D + ARRAY_SIZE (AcpiGenericAddressParser) },=0D + { "NominalFrequencyInteger", 4, = "0x%llx", NULL },=0D +};=0D +=0D /** A parser for Arm namespace objects.=0D */=0D STATIC CONST CM_OBJ_PARSER_ARRAY ArmNamespaceObjectParser[] =3D {=0D @@ -501,6 +578,8 @@ STATIC CONST CM_OBJ_PARSER_ARRAY ArmNamespaceObjectPar= ser[] =3D {=0D ARRAY_SIZE (CmArmPciAddressMapInfoParser) },=0D { "EArmObjPciInterruptMapInfo", CmPciInterruptMapInfoParser,=0D ARRAY_SIZE (CmPciInterruptMapInfoParser) },=0D + { "EArmObjCpcInfo", CmArmCpcInfoParser,=0D + ARRAY_SIZE (CmArmCpcInfoParser) },=0D { "EArmObjMax", NULL, = 0 },=0D };=0D =0D -- =0D 2.25.1=0D =0D