ShellPkg/AcpiView: APMT Parser

Add a new parser for the Arm Performance Monitoring Unit Table.
The APMT table describes the properties of PMU support
implemented by components in an Arm-based system.

Signed-off-by: Jeff Brasen <jbrasen@nvidia.com>
Reviewed-by: Zhichao Gao <zhichao.gao@intel.com>
Reviewed-by: Sami Mujawar <sami.mujawar@arm.com>
This commit is contained in:
Jeff Brasen 2022-11-04 10:04:48 -06:00 committed by mergify[bot]
parent aa65bb4020
commit 1fd8d08970
5 changed files with 130 additions and 0 deletions

View File

@ -531,6 +531,27 @@ ParseAcpiAest (
IN UINT8 AcpiTableRevision
);
/**
This function parses the ACPI APMT table.
When trace is enabled this function parses the APMT table and
traces the ACPI table fields.
This function also performs validation of the ACPI table fields.
@param [in] Trace If TRUE, trace the ACPI fields.
@param [in] Ptr Pointer to the start of the buffer.
@param [in] AcpiTableLength Length of the ACPI table.
@param [in] AcpiTableRevision Revision of the ACPI table.
**/
VOID
EFIAPI
ParseAcpiApmt (
IN BOOLEAN Trace,
IN UINT8 *Ptr,
IN UINT32 AcpiTableLength,
IN UINT8 AcpiTableRevision
);
/**
This function parses the ACPI BGRT table.
When trace is enabled this function parses the BGRT table and

View File

@ -0,0 +1,106 @@
/** @file
APMT table parser
Copyright (c) 2022, NVIDIA CORPORATION. All rights reserved.
Copyright (c) 2017 - 2018, ARM Limited. All rights reserved.
SPDX-License-Identifier: BSD-2-Clause-Patent
@par Reference(s):
- ACPI 6.2 Specification - Errata A, September 2017
**/
#include <IndustryStandard/Acpi.h>
#include <IndustryStandard/ArmPerformanceMonitoringUnitTable.h>
#include <Library/UefiLib.h>
#include "AcpiParser.h"
#include "AcpiTableParser.h"
// Local variables
STATIC ACPI_DESCRIPTION_HEADER_INFO AcpiHdrInfo;
STATIC CONST UINT16 *NodeLength;
/**
An ACPI_PARSER array describing the ACPI APMT Table.
**/
STATIC CONST ACPI_PARSER ApmtParser[] = {
PARSE_ACPI_HEADER (&AcpiHdrInfo)
};
/**
An ACPI_PARSER array describing the ACPI Arm PMU Node.
**/
STATIC CONST ACPI_PARSER ArmPmuNodeParser[] = {
{ L"Length", 2, 0, L"0x%x", NULL, (VOID **)&NodeLength, NULL, NULL },
{ L"Node flags", 1, 2, L"0x%x", NULL, NULL, NULL, NULL },
{ L"Node type", 1, 3, L"0x%x", NULL, NULL, NULL, NULL },
{ L"Identifier", 4, 4, L"0x%x", NULL, NULL, NULL, NULL },
{ L"Node Instance primary", 8, 8, L"0x%lx", NULL, NULL, NULL, NULL },
{ L"Node Instance secondary", 4, 16, L"0x%x", NULL, NULL, NULL, NULL },
{ L"Base address 0", 8, 20, L"0x%lx", NULL, NULL, NULL, NULL },
{ L"Base address 1", 8, 28, L"0x%lx", NULL, NULL, NULL, NULL },
{ L"Overflow interrupt", 4, 36, L"0x%x", NULL, NULL, NULL, NULL },
{ L"Reserved1", 4, 40, L"0x%x", NULL, NULL, NULL, NULL },
{ L"Overflow interrupt flags", 4, 44, L"0x%x", NULL, NULL, NULL, NULL },
{ L"Processor affinity", 4, 48, L"0x%x", NULL, NULL, NULL, NULL },
{ L"Implementation ID", 4, 52, L"0x%x", NULL, NULL, NULL, NULL }
};
/**
This function parses the ACPI APMT table.
When trace is enabled this function parses the APMT table and
traces the ACPI table fields.
This function also performs validation of the ACPI table fields.
@param [in] Trace If TRUE, trace the ACPI fields.
@param [in] Ptr Pointer to the start of the buffer.
@param [in] AcpiTableLength Length of the ACPI table.
@param [in] AcpiTableRevision Revision of the ACPI table.
**/
VOID
EFIAPI
ParseAcpiApmt (
IN BOOLEAN Trace,
IN UINT8 *Ptr,
IN UINT32 AcpiTableLength,
IN UINT8 AcpiTableRevision
)
{
UINT32 Offset;
if (!Trace) {
return;
}
ParseAcpi (
Trace,
0,
"APMT",
Ptr,
AcpiTableLength,
PARSER_PARAMS (ApmtParser)
);
Offset = sizeof (EFI_ACPI_DESCRIPTION_HEADER);
while (Offset < AcpiTableLength) {
ParseAcpi (
Trace,
2,
"Arm PMU node",
Ptr + Offset,
(AcpiTableLength - Offset),
PARSER_PARAMS (ArmPmuNodeParser)
);
if (NodeLength == NULL) {
Print (
L"ERROR: Insufficient remaining table buffer length to read the " \
L"Node structure. Length = %d.\n",
(AcpiTableLength - Offset)
);
IncrementErrorCount ();
break;
}
Offset += *NodeLength;
}
}

View File

@ -48,6 +48,7 @@ STATIC
CONST
ACPI_TABLE_PARSER ParserList[] = {
{ EFI_ACPI_6_3_ARM_ERROR_SOURCE_TABLE_SIGNATURE, ParseAcpiAest },
{ EFI_ACPI_6_4_ARM_PERFORMANCE_MONITORING_UNIT_TABLE_SIGNATURE, ParseAcpiApmt },
{ EFI_ACPI_6_2_BOOT_GRAPHICS_RESOURCE_TABLE_SIGNATURE, ParseAcpiBgrt },
{ EFI_ACPI_6_2_DEBUG_PORT_2_TABLE_SIGNATURE, ParseAcpiDbg2 },
{ EFI_ACPI_6_2_DIFFERENTIATED_SYSTEM_DESCRIPTION_TABLE_SIGNATURE,

View File

@ -28,6 +28,7 @@
AcpiViewConfig.c
AcpiViewConfig.h
Parsers/Aest/AestParser.c
Parsers/Apmt/ApmtParser.c
Parsers/Bgrt/BgrtParser.c
Parsers/Dbg2/Dbg2Parser.c
Parsers/Dsdt/DsdtParser.c

View File

@ -80,6 +80,7 @@
" Extra A. Particular types:\r\n"
" AEST - Arm Error Source Table\r\n"
" APIC - Multiple APIC Description Table (MADT)\r\n"
" APMT - Arm Performance Monitoring Unit Table\r\n"
" BGRT - Boot Graphics Resource Table\r\n"
" DBG2 - Debug Port Table 2\r\n"
" DSDT - Differentiated System Description Table\r\n"