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:
committed by
mergify[bot]
parent
aa65bb4020
commit
1fd8d08970
@ -531,6 +531,27 @@ ParseAcpiAest (
|
|||||||
IN UINT8 AcpiTableRevision
|
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.
|
This function parses the ACPI BGRT table.
|
||||||
When trace is enabled this function parses the BGRT table and
|
When trace is enabled this function parses the BGRT table and
|
||||||
|
@ -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;
|
||||||
|
}
|
||||||
|
}
|
@ -48,6 +48,7 @@ STATIC
|
|||||||
CONST
|
CONST
|
||||||
ACPI_TABLE_PARSER ParserList[] = {
|
ACPI_TABLE_PARSER ParserList[] = {
|
||||||
{ EFI_ACPI_6_3_ARM_ERROR_SOURCE_TABLE_SIGNATURE, ParseAcpiAest },
|
{ 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_BOOT_GRAPHICS_RESOURCE_TABLE_SIGNATURE, ParseAcpiBgrt },
|
||||||
{ EFI_ACPI_6_2_DEBUG_PORT_2_TABLE_SIGNATURE, ParseAcpiDbg2 },
|
{ EFI_ACPI_6_2_DEBUG_PORT_2_TABLE_SIGNATURE, ParseAcpiDbg2 },
|
||||||
{ EFI_ACPI_6_2_DIFFERENTIATED_SYSTEM_DESCRIPTION_TABLE_SIGNATURE,
|
{ EFI_ACPI_6_2_DIFFERENTIATED_SYSTEM_DESCRIPTION_TABLE_SIGNATURE,
|
||||||
|
@ -28,6 +28,7 @@
|
|||||||
AcpiViewConfig.c
|
AcpiViewConfig.c
|
||||||
AcpiViewConfig.h
|
AcpiViewConfig.h
|
||||||
Parsers/Aest/AestParser.c
|
Parsers/Aest/AestParser.c
|
||||||
|
Parsers/Apmt/ApmtParser.c
|
||||||
Parsers/Bgrt/BgrtParser.c
|
Parsers/Bgrt/BgrtParser.c
|
||||||
Parsers/Dbg2/Dbg2Parser.c
|
Parsers/Dbg2/Dbg2Parser.c
|
||||||
Parsers/Dsdt/DsdtParser.c
|
Parsers/Dsdt/DsdtParser.c
|
||||||
|
@ -80,6 +80,7 @@
|
|||||||
" Extra A. Particular types:\r\n"
|
" Extra A. Particular types:\r\n"
|
||||||
" AEST - Arm Error Source Table\r\n"
|
" AEST - Arm Error Source Table\r\n"
|
||||||
" APIC - Multiple APIC Description Table (MADT)\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"
|
" BGRT - Boot Graphics Resource Table\r\n"
|
||||||
" DBG2 - Debug Port Table 2\r\n"
|
" DBG2 - Debug Port Table 2\r\n"
|
||||||
" DSDT - Differentiated System Description Table\r\n"
|
" DSDT - Differentiated System Description Table\r\n"
|
||||||
|
Reference in New Issue
Block a user