/** @file Configuration Manager Object parser. Copyright (c) 2021 - 2023, ARM Limited. All rights reserved.
SPDX-License-Identifier: BSD-2-Clause-Patent **/ #include #include #include #include "ConfigurationManagerObjectParser.h" STATIC VOID EFIAPI PrintString ( CONST CHAR8 *Format, UINT8 *Ptr ); STATIC VOID EFIAPI PrintStringPtr ( CONST CHAR8 *Format, UINT8 *Ptr ); STATIC VOID EFIAPI PrintChar4 ( CONST CHAR8 *Format, UINT8 *Ptr ); STATIC VOID EFIAPI PrintChar6 ( CONST CHAR8 *Format, UINT8 *Ptr ); STATIC VOID EFIAPI PrintChar8 ( CONST CHAR8 *Format, UINT8 *Ptr ); /** A parser for EArmObjBootArchInfo. */ STATIC CONST CM_OBJ_PARSER CmArmBootArchInfoParser[] = { { "BootArchFlags", 2, "0x%x", NULL } }; /** A parser for EArchCommonObjPowerManagementProfileInfo. */ STATIC CONST CM_OBJ_PARSER CmArchCommonPowerManagementProfileInfoParser[] = { { "PowerManagementProfile", 1, "0x%x", NULL } }; /** A parser for EArmObjGicCInfo. */ STATIC CONST CM_OBJ_PARSER CmArmGicCInfoParser[] = { { "CPUInterfaceNumber", 4, "0x%x", NULL }, { "AcpiProcessorUid", 4, "0x%x", NULL }, { "Flags", 4, "0x%x", NULL }, { "ParkingProtocolVersion", 4, "0x%x", NULL }, { "PerformanceInterruptGsiv", 4, "0x%x", NULL }, { "ParkedAddress", 8, "0x%llx", NULL }, { "PhysicalBaseAddress", 8, "0x%llx", NULL }, { "GICV", 8, "0x%llx", NULL }, { "GICH", 8, "0x%llx", NULL }, { "VGICMaintenanceInterrupt", 4, "0x%x", NULL }, { "GICRBaseAddress", 8, "0x%llx", NULL }, { "MPIDR", 8, "0x%llx", NULL }, { "ProcessorPowerEfficiencyClass", 1, "0x%x", NULL }, { "SpeOverflowInterrupt", 2, "0x%x", NULL }, { "ProximityDomain", 4, "0x%x", NULL }, { "ClockDomain", 4, "0x%x", NULL }, { "AffinityFlags", 4, "0x%x", NULL }, { "CpcToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "TRBEInterrupt", 2, "0x%x", NULL }, { "EtToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "PsdToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, }; /** A parser for EArmObjGicDInfo. */ STATIC CONST CM_OBJ_PARSER CmArmGicDInfoParser[] = { { "PhysicalBaseAddress", 8, "0x%llx", NULL }, { "SystemVectorBase", 4, "0x%x", NULL }, { "GicVersion", 1, "0x%x", NULL }, }; /** A parser for EArmObjGicMsiFrameInfo. */ STATIC CONST CM_OBJ_PARSER CmArmGicMsiFrameInfoParser[] = { { "GicMsiFrameId", 4, "0x%x", NULL }, { "PhysicalBaseAddress", 8, "0x%llx", NULL }, { "Flags", 4, "0x%x", NULL }, { "SPICount", 2, "0x%x", NULL }, { "SPIBase", 2, "0x%x", NULL } }; /** A parser for EArmObjGicRedistributorInfo. */ STATIC CONST CM_OBJ_PARSER CmArmGicRedistInfoParser[] = { { "DiscoveryRangeBaseAddress", 8, "0x%llx", NULL }, { "DiscoveryRangeLength", 4, "0x%x", NULL } }; /** A parser for EArmObjGicItsInfo. */ STATIC CONST CM_OBJ_PARSER CmArmGicItsInfoParser[] = { { "GicItsId", 4, "0x%x", NULL }, { "PhysicalBaseAddress", 8, "0x%llx", NULL }, { "ProximityDomain", 4, "0x%x", NULL } }; /** A parser for EArchCommonObjConsolePortInfo, EArchCommonObjSerialDebugPortInfo and EArchCommonObjSerialPortInfo. */ STATIC CONST CM_OBJ_PARSER CmArchCommonSerialPortInfoParser[] = { { "BaseAddress", 8, "0x%llx", NULL }, { "Interrupt", 4, "0x%x", NULL }, { "BaudRate", 8, "0x%llx", NULL }, { "Clock", 4, "0x%x", NULL }, { "PortSubtype", 2, "0x%x", NULL }, { "BaseAddressLength", 8, "0x%llx", NULL }, { "AccessSize", 1, "0x%d", NULL } }; /** A parser for EArmObjGenericTimerInfo. */ STATIC CONST CM_OBJ_PARSER CmArmGenericTimerInfoParser[] = { { "CounterControlBaseAddress", 8, "0x%llx", NULL }, { "CounterReadBaseAddress", 8, "0x%llx", NULL }, { "SecurePL1TimerGSIV", 4, "0x%x", NULL }, { "SecurePL1TimerFlags", 4, "0x%x", NULL }, { "NonSecurePL1TimerGSIV", 4, "0x%x", NULL }, { "NonSecurePL1TimerFlags", 4, "0x%x", NULL }, { "VirtualTimerGSIV", 4, "0x%x", NULL }, { "VirtualTimerFlags", 4, "0x%x", NULL }, { "NonSecurePL2TimerGSIV", 4, "0x%x", NULL }, { "NonSecurePL2TimerFlags", 4, "0x%x", NULL }, { "VirtualPL2TimerGSIV", 4, "0x%x", NULL }, { "VirtualPL2TimerFlags", 4, "0x%x", NULL } }; /** A parser for EArmObjPlatformGTBlockInfo. */ STATIC CONST CM_OBJ_PARSER CmArmGTBlockInfoParser[] = { { "GTBlockPhysicalAddress", 8, "0x%llx", NULL }, { "GTBlockTimerFrameCount", 4, "0x%x", NULL }, { "GTBlockTimerFrameToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL } }; /** A parser for EArmObjGTBlockTimerFrameInfo. */ STATIC CONST CM_OBJ_PARSER CmArmGTBlockTimerFrameInfoParser[] = { { "FrameNumber", 1, "0x%x", NULL }, { "PhysicalAddressCntBase", 8, "0x%llx", NULL }, { "PhysicalAddressCntEL0Base", 8, "0x%llx", NULL }, { "PhysicalTimerGSIV", 4, "0x%x", NULL }, { "PhysicalTimerFlags", 4, "0x%x", NULL }, { "VirtualTimerGSIV", 4, "0x%x", NULL }, { "VirtualTimerFlags", 4, "0x%x", NULL }, { "CommonFlags", 4, "0x%x", NULL } }; /** A parser for EArmObjPlatformGenericWatchdogInfo. */ STATIC CONST CM_OBJ_PARSER CmArmGenericWatchdogInfoParser[] = { { "ControlFrameAddress", 8, "0x%llx", NULL }, { "RefreshFrameAddress", 8, "0x%llx", NULL }, { "TimerGSIV", 4, "0x%x", NULL }, { "Flags", 4, "0x%x", NULL } }; /** A parser for EArchCommonObjPciConfigSpaceInfo. */ STATIC CONST CM_OBJ_PARSER CmArchCommonPciConfigSpaceInfoParser[] = { { "BaseAddress", 8, "0x%llx", NULL }, { "PciSegmentGroupNumber", 2, "0x%x", NULL }, { "StartBusNumber", 1, "0x%x", NULL }, { "EndBusNumber", 1, "0x%x", NULL }, { "AddressMapToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "InterruptMapToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, }; /** A parser for EArchCommonObjHypervisorVendorIdentity. */ STATIC CONST CM_OBJ_PARSER CmArchCommonHypervisorVendorIdentityParser[] = { { "HypervisorVendorId", 8, "0x%llx", NULL } }; /** A parser for EArchCommonObjFixedFeatureFlags. */ STATIC CONST CM_OBJ_PARSER CmArchCommonFixedFeatureFlagsParser[] = { { "Flags", 4, "0x%x", NULL } }; /** A parser for EArmObjItsGroup. */ STATIC CONST CM_OBJ_PARSER CmArmItsGroupNodeParser[] = { { "Token", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "ItsIdCount", 4, "0x%x", NULL }, { "ItsIdToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "Identifier", 4, "0x%x", NULL }, }; /** A parser for EArmObjNamedComponent. */ STATIC CONST CM_OBJ_PARSER CmArmNamedComponentNodeParser[] = { { "Token", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "IdMappingCount", 4, "0x%x", NULL }, { "IdMappingToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "Flags", 4, "0x%x", NULL }, { "CacheCoherent", 4, "0x%x", NULL }, { "AllocationHints", 1, "0x%x", NULL }, { "MemoryAccessFlags", 1, "0x%x", NULL }, { "AddressSizeLimit", 1, "0x%x", NULL }, { "ObjectName", sizeof (CHAR8 *), NULL, PrintStringPtr }, { "Identifier", 4, "0x%x", NULL }, }; /** A parser for EArmObjRootComplex. */ STATIC CONST CM_OBJ_PARSER CmArmRootComplexNodeParser[] = { { "Token", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "IdMappingCount", 4, "0x%x", NULL }, { "IdMappingToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "CacheCoherent", 4, "0x%x", NULL }, { "AllocationHints", 1, "0x%x", NULL }, { "MemoryAccessFlags", 1, "0x%x", NULL }, { "AtsAttribute", 4, "0x%x", NULL }, { "PciSegmentNumber", 4, "0x%x", NULL }, { "MemoryAddressSize", 1, "0x%x", NULL }, { "PasidCapabilities", 2, "0x%x", NULL }, { "Flags", 4, "0x%x", NULL }, { "Identifier", 4, "0x%x", NULL }, }; /** A parser for EArmObjSmmuV1SmmuV2. */ STATIC CONST CM_OBJ_PARSER CmArmSmmuV1SmmuV2NodeParser[] = { { "Token", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "IdMappingCount", 4, "0x%x", NULL }, { "IdMappingToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "BaseAddress", 8, "0x%llx", NULL }, { "Span", 8, "0x%llx", NULL }, { "Model", 4, "0x%x", NULL }, { "Flags", 4, "0x%x", NULL }, { "ContextInterruptCount", 4, "0x%x", NULL }, { "ContextInterruptToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "PmuInterruptCount", 4, "0x%x", NULL }, { "PmuInterruptToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "SMMU_NSgIrpt", 4, "0x%x", NULL }, { "SMMU_NSgIrptFlags", 4, "0x%x", NULL }, { "SMMU_NSgCfgIrpt", 4, "0x%x", NULL }, { "SMMU_NSgCfgIrptFlags", 4, "0x%x", NULL }, { "Identifier", 4, "0x%x", NULL }, }; /** A parser for EArmObjSmmuV3. */ STATIC CONST CM_OBJ_PARSER CmArmSmmuV3NodeParser[] = { { "Token", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "IdMappingCount", 4, "0x%x", NULL }, { "IdMappingToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "BaseAddress", 8, "0x%llx", NULL }, { "Flags", 4, "0x%x", NULL }, { "VatosAddress", 8, "0x%llx", NULL }, { "Model", 4, "0x%x", NULL }, { "EventInterrupt", 4, "0x%x", NULL }, { "PriInterrupt", 4, "0x%x", NULL }, { "GerrInterrupt", 4, "0x%x", NULL }, { "SyncInterrupt", 4, "0x%x", NULL }, { "ProximityDomain", 4, "0x%x", NULL }, { "DeviceIdMappingIndex", 4, "0x%x", NULL }, { "Identifier", 4, "0x%x", NULL }, }; /** A parser for EArmObjPmcg. */ STATIC CONST CM_OBJ_PARSER CmArmPmcgNodeParser[] = { { "Token", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "IdMappingCount", 4, "0x%x", NULL }, { "IdMappingToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "BaseAddress", 8, "0x%llx", NULL }, { "OverflowInterrupt", 4, "0x%x", NULL }, { "Page1BaseAddress", 8, "0x%llx", NULL }, { "ReferenceToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "Identifier", 4, "0x%x", NULL }, }; /** A parser for EArmObjGicItsIdentifierArray. */ STATIC CONST CM_OBJ_PARSER CmArmGicItsIdentifierParser[] = { { "ItsId", 4, "0x%x", NULL } }; /** A parser for EArmObjIdMappingArray. */ STATIC CONST CM_OBJ_PARSER CmArmIdMappingParser[] = { { "InputBase", 4, "0x%x", NULL }, { "NumIds", 4, "0x%x", NULL }, { "OutputBase", 4, "0x%x", NULL }, { "OutputReferenceToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "Flags", 4, "0x%x", NULL } }; /** A parser for EArmObjSmmuInterruptArray. */ STATIC CONST CM_OBJ_PARSER CmArchCommonGenericInterruptParser[] = { { "Interrupt", 4, "0x%x", NULL }, { "Flags", 4, "0x%x", NULL } }; /** A parser for EArchCommonObjProcHierarchyInfo. */ STATIC CONST CM_OBJ_PARSER CmArchCommonProcHierarchyInfoParser[] = { { "Token", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "Flags", 4, "0x%x", NULL }, { "ParentToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "AcpiIdObjectToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "NoOfPrivateResources", 4, "0x%x", NULL }, { "PrivateResourcesArrayToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "LpiToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "OverrideNameUidEnabled", 1, "%d", NULL }, { "OverrideName", 2, "0x%x", NULL }, { "OverrideUid", 4, "0x%x", NULL } }; /** A parser for EArchCommonObjCacheInfo. */ STATIC CONST CM_OBJ_PARSER CmArchCommonCacheInfoParser[] = { { "Token", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "NextLevelOfCacheToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "Size", 4, "0x%x", NULL }, { "NumberOfSets", 4, "0x%x", NULL }, { "Associativity", 4, "0x%x", NULL }, { "Attributes", 1, "0x%x", NULL }, { "LineSize", 2, "0x%x", NULL }, { "CacheId", 4, "0x%x", NULL }, }; /** A parser for EArchCommonObjCmRef. */ STATIC CONST CM_OBJ_PARSER CmArchCommonObjRefParser[] = { { "ReferenceToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL } }; /** A parser for EArchCommonObjMemoryAffinityInfo. */ STATIC CONST CM_OBJ_PARSER CmArchCommonMemoryAffinityInfoParser[] = { { "ProximityDomain", 4, "0x%x", NULL }, { "BaseAddress", 8, "0x%llx", NULL }, { "Length", 8, "0x%llx", NULL }, { "Flags", 4, "0x%x", NULL } }; /** A parser for EArchCommonObjDeviceHandleAcpi. */ STATIC CONST CM_OBJ_PARSER CmArchCommonDeviceHandleAcpiParser[] = { { "Hid", 8, "0x%llx", NULL }, { "Uid", 4, "0x%x", NULL } }; /** A parser for EArchCommonObjDeviceHandlePci. */ STATIC CONST CM_OBJ_PARSER CmArchCommonDeviceHandlePciParser[] = { { "SegmentNumber", 2, "0x%x", NULL }, { "BusNumber", 1, "0x%x", NULL }, { "DeviceNumber", 1, "0x%x", NULL }, { "FunctionNumber", 1, "0x%x", NULL } }; /** A parser for EArchCommonObjGenericInitiatorAffinityInfo. */ STATIC CONST CM_OBJ_PARSER CmArchCommonGenericInitiatorAffinityInfoParser[] = { { "ProximityDomain", 4, "0x%x", NULL }, { "Flags", 4, "0x%x", NULL }, { "DeviceHandleType", 1, "0x%x", NULL }, { "DeviceHandleToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL } }; /** A parser for EArmObjCmn600Info. */ STATIC CONST CM_OBJ_PARSER CmArmCmn600InfoParser[] = { { "PeriphBaseAddress", 8, "0x%llx", NULL }, { "PeriphBaseAddressLength", 8, "0x%llx", NULL }, { "RootNodeBaseAddress", 8, "0x%llx", NULL }, { "DtcCount", 1, "0x%x", NULL }, { "DtcInterrupt[0]", 4, "0x%x", NULL }, { "DtcFlags[0]", 4, "0x%x", NULL }, { "DtcInterrupt[1]", 4, "0x%x", NULL }, { "DtcFlags[1]", 4, "0x%x", NULL }, { "DtcInterrupt[2]", 4, "0x%x", NULL }, { "DtcFlags[2]", 4, "0x%x", NULL }, { "DtcInterrupt[3]", 4, "0x%x", NULL }, { "DtcFlags[3]", 4, "0x%x", NULL } }; /** A parser for the EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE structure. */ STATIC CONST CM_OBJ_PARSER AcpiGenericAddressParser[] = { { "AddressSpaceId", 1, "%d", NULL }, { "RegisterBitWidth", 1, "%d", NULL }, { "RegisterBitOffset", 1, "%d", NULL }, { "AccessSize", 1, "%d", NULL }, { "Address", 8, "0x%llx", NULL }, }; /** A parser for EArchCommonObjLpiInfo. */ STATIC CONST CM_OBJ_PARSER CmArchCommonLpiInfoParser[] = { { "MinResidency", 4, "0x%x", NULL }, { "WorstCaseWakeLatency", 4, "0x%x", NULL }, { "Flags", 4, "0x%x", NULL }, { "ArchFlags", 4, "0x%x", NULL }, { "ResCntFreq", 4, "0x%x", NULL }, { "EnableParentState", 4, "0x%x", NULL }, { "IsInteger", 1, "%d", NULL }, { "IntegerEntryMethod", 8, "0x%llx", NULL }, { "RegisterEntryMethod", sizeof (EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "ResidencyCounterRegister", sizeof (EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "UsageCounterRegister", sizeof (EFI_ACPI_6_3_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "StateName", 16, NULL, PrintString }, }; /** A parser for EArchCommonObjPciAddressMapInfo. */ STATIC CONST CM_OBJ_PARSER CmArchCommonPciAddressMapInfoParser[] = { { "SpaceCode", 1, "%d", NULL }, { "PciAddress", 8, "0x%llx", NULL }, { "CpuAddress", 8, "0x%llx", NULL }, { "AddressSize", 8, "0x%llx", NULL }, }; /** A parser for EArchCommonObjPciInterruptMapInfo. */ STATIC CONST CM_OBJ_PARSER CmArchCommonPciInterruptMapInfoParser[] = { { "PciBus", 1, "0x%x", NULL }, { "PciDevice", 1, "0x%x", NULL }, { "PciInterrupt", 1, "0x%x", NULL }, { "IntcInterrupt", sizeof (CM_ARCH_COMMON_GENERIC_INTERRUPT), NULL, NULL, CmArchCommonGenericInterruptParser, ARRAY_SIZE (CmArchCommonGenericInterruptParser) }, }; /** A parser for EArmObjRmr. */ STATIC CONST CM_OBJ_PARSER CmArmRmrInfoParser[] = { { "Token", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "IdMappingCount", 4, "0x%x", NULL }, { "IdMappingToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, { "Identifier", 4, "0x%x", NULL }, { "Flags", 4, "0x%x", NULL }, { "MemRangeDescCount", 4, "0x%x", NULL }, { "MemRangeDescToken", sizeof (CM_OBJECT_TOKEN), "0x%p", NULL }, }; /** A parser for EArmObjMemoryRangeDescriptor. */ STATIC CONST CM_OBJ_PARSER CmArmMemoryRangeDescriptorInfoParser[] = { { "BaseAddress", 8, "0x%llx", NULL }, { "Length", 8, "0x%llx", NULL }, }; /** A parser for EArmObjCpcInfo. */ STATIC CONST CM_OBJ_PARSER CmArmCpcInfoParser[] = { { "Revision", 4, "0x%lx", NULL }, { "HighestPerformanceBuffer", sizeof (EFI_ACPI_6_4_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "HighestPerformanceInteger", 4, "0x%lx", NULL }, { "NominalPerformanceBuffer", sizeof (EFI_ACPI_6_4_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "NominalPerformanceInteger", 4, "0x%lx", NULL }, { "LowestNonlinearPerformanceBuffer", sizeof (EFI_ACPI_6_4_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "LowestNonlinearPerformanceInteger", 4, "0x%lx", NULL }, { "LowestPerformanceBuffer", sizeof (EFI_ACPI_6_4_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "LowestPerformanceInteger", 4, "0x%lx", NULL }, { "GuaranteedPerformanceRegister", sizeof (EFI_ACPI_6_4_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "DesiredPerformanceRegister", sizeof (EFI_ACPI_6_4_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "MinimumPerformanceRegister", sizeof (EFI_ACPI_6_4_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "MaximumPerformanceRegister", sizeof (EFI_ACPI_6_4_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "PerformanceReductionToleranceRegister", sizeof (EFI_ACPI_6_4_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "TimeWindowRegister", sizeof (EFI_ACPI_6_4_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "CounterWraparoundTimeBuffer", sizeof (EFI_ACPI_6_4_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "CounterWraparoundTimeInteger", 4, "0x%lx", NULL }, { "ReferencePerformanceCounterRegister", sizeof (EFI_ACPI_6_4_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "DeliveredPerformanceCounterRegister", sizeof (EFI_ACPI_6_4_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "PerformanceLimitedRegister", sizeof (EFI_ACPI_6_4_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "CPPCEnableRegister", sizeof (EFI_ACPI_6_4_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "AutonomousSelectionEnableBuffer", sizeof (EFI_ACPI_6_4_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "AutonomousSelectionEnableInteger", 4, "0x%lx", NULL }, { "AutonomousActivityWindowRegister", sizeof (EFI_ACPI_6_4_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "EnergyPerformancePreferenceRegister", sizeof (EFI_ACPI_6_4_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "ReferencePerformanceBuffer", sizeof (EFI_ACPI_6_4_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "ReferencePerformanceInteger", 4, "0x%lx", NULL }, { "LowestFrequencyBuffer", sizeof (EFI_ACPI_6_4_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "LowestFrequencyInteger", 4, "0x%lx", NULL }, { "NominalFrequencyBuffer", sizeof (EFI_ACPI_6_4_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "NominalFrequencyInteger", 4, "0x%lx", NULL }, }; /** A parser for the PCC_MAILBOX_REGISTER_INFO struct. */ STATIC CONST CM_OBJ_PARSER CmArmMailboxRegisterInfoParser[] = { { "Register", sizeof (EFI_ACPI_6_4_GENERIC_ADDRESS_STRUCTURE), NULL, NULL, AcpiGenericAddressParser, ARRAY_SIZE (AcpiGenericAddressParser) }, { "PreserveMask", 8, "0x%llx", NULL }, { "WriteMask", 8, "0x%llx", NULL }, }; /** A parser for the PCC_SUBSPACE_CHANNEL_TIMING_INFO struct. */ STATIC CONST CM_OBJ_PARSER CmArmPccSubspaceChannelTimingInfoParser[] = { { "NominalLatency", 4, "0x%x", NULL }, { "MaxPeriodicAccessRate", 4, "0x%x", NULL }, { "MinRequestTurnaroundTime", 2, "0x%x", NULL }, }; /** A parser for EArmObjPccSubspaceType0Info. */ STATIC CONST CM_OBJ_PARSER CmArmPccSubspaceType0InfoParser[] = { { "SubspaceId", 1, "0x%x", NULL }, { "Type", 1, "0x%x", NULL }, { "BaseAddress", 8, "0x%llx", NULL }, { "AddressLength", 8, "0x%llx", NULL }, { "DoorbellReg", sizeof (PCC_MAILBOX_REGISTER_INFO), NULL, NULL, CmArmMailboxRegisterInfoParser, ARRAY_SIZE (CmArmMailboxRegisterInfoParser) }, { "ChannelTiming", sizeof (PCC_SUBSPACE_CHANNEL_TIMING_INFO), NULL, NULL, CmArmPccSubspaceChannelTimingInfoParser, ARRAY_SIZE (CmArmPccSubspaceChannelTimingInfoParser) }, }; /** A parser for EArmObjPccSubspaceType1Info. */ STATIC CONST CM_OBJ_PARSER CmArmPccSubspaceType1InfoParser[] = { { "GenericPccInfo", sizeof (PCC_SUBSPACE_GENERIC_INFO), NULL, NULL, CmArmPccSubspaceType0InfoParser, ARRAY_SIZE (CmArmPccSubspaceType0InfoParser) }, { "PlatIrq", sizeof (CM_ARCH_COMMON_GENERIC_INTERRUPT), NULL, NULL, CmArchCommonGenericInterruptParser, ARRAY_SIZE (CmArchCommonGenericInterruptParser) }, }; /** A parser for EArmObjPccSubspaceType2Info. */ STATIC CONST CM_OBJ_PARSER CmArmPccSubspaceType2InfoParser[] = { { "GenericPccInfo", sizeof (PCC_SUBSPACE_GENERIC_INFO), NULL, NULL, CmArmPccSubspaceType0InfoParser, ARRAY_SIZE (CmArmPccSubspaceType0InfoParser) }, { "PlatIrq", sizeof (CM_ARCH_COMMON_GENERIC_INTERRUPT),NULL,NULL, CmArchCommonGenericInterruptParser, ARRAY_SIZE (CmArchCommonGenericInterruptParser) }, { "PlatIrqAckReg", sizeof (PCC_MAILBOX_REGISTER_INFO), NULL, NULL, CmArmMailboxRegisterInfoParser, ARRAY_SIZE (CmArmMailboxRegisterInfoParser) }, }; /** A parser for EArmObjPccSubspaceType3Info or EArmObjPccSubspaceType4Info. */ STATIC CONST CM_OBJ_PARSER CmArmPccSubspaceType34InfoParser[] = { { "GenericPccInfo", sizeof (PCC_SUBSPACE_GENERIC_INFO), NULL, NULL, CmArmPccSubspaceType0InfoParser, ARRAY_SIZE (CmArmPccSubspaceType0InfoParser) }, { "PlatIrq", sizeof (CM_ARCH_COMMON_GENERIC_INTERRUPT),NULL,NULL, CmArchCommonGenericInterruptParser, ARRAY_SIZE (CmArchCommonGenericInterruptParser) }, { "PlatIrqAckReg", sizeof (PCC_MAILBOX_REGISTER_INFO), NULL, NULL, CmArmMailboxRegisterInfoParser, ARRAY_SIZE (CmArmMailboxRegisterInfoParser) }, { "CmdCompleteCheckReg", sizeof (PCC_MAILBOX_REGISTER_INFO), NULL, NULL, CmArmMailboxRegisterInfoParser, ARRAY_SIZE (CmArmMailboxRegisterInfoParser) }, { "CmdCompleteUpdateReg", sizeof (PCC_MAILBOX_REGISTER_INFO), NULL, NULL, CmArmMailboxRegisterInfoParser, ARRAY_SIZE (CmArmMailboxRegisterInfoParser) }, { "ErrorStatusReg", sizeof (PCC_MAILBOX_REGISTER_INFO), NULL, NULL, CmArmMailboxRegisterInfoParser, ARRAY_SIZE (CmArmMailboxRegisterInfoParser) }, }; /** A parser for EArmObjPccSubspaceType5Info. */ STATIC CONST CM_OBJ_PARSER CmArmPccSubspaceType5InfoParser[] = { { "GenericPccInfo", sizeof (PCC_SUBSPACE_GENERIC_INFO), NULL, NULL, CmArmPccSubspaceType0InfoParser, ARRAY_SIZE (CmArmPccSubspaceType0InfoParser) }, { "Version", 2, "0x%x",NULL }, { "PlatIrq", sizeof (CM_ARCH_COMMON_GENERIC_INTERRUPT),NULL, NULL, CmArchCommonGenericInterruptParser, ARRAY_SIZE (CmArchCommonGenericInterruptParser) }, { "CmdCompleteCheckReg", sizeof (PCC_MAILBOX_REGISTER_INFO), NULL, NULL, CmArmMailboxRegisterInfoParser, ARRAY_SIZE (CmArmMailboxRegisterInfoParser) }, { "ErrorStatusReg", sizeof (PCC_MAILBOX_REGISTER_INFO), NULL, NULL, CmArmMailboxRegisterInfoParser, ARRAY_SIZE (CmArmMailboxRegisterInfoParser) }, }; /** A parser for EArmObjEtInfo. */ STATIC CONST CM_OBJ_PARSER CmArmEtInfo[] = { { "EtType", sizeof (ARM_ET_TYPE), "0x%x", NULL } }; /** A parser for EArmObjPsdInfo. */ STATIC CONST CM_OBJ_PARSER CmArmPsdInfoParser[] = { { "Revision", 1, "0x%x", NULL }, { "DomainId", 4, "0x%x", NULL }, { "CoordType", 4, "0x%x", NULL }, { "NumProc", 4, "0x%x", NULL }, }; /** A parser for Arch Common namespace objects. */ STATIC CONST CM_OBJ_PARSER_ARRAY ArchCommonNamespaceObjectParser[] = { CM_PARSER_ADD_OBJECT_RESERVED (EArchCommonObjReserved), CM_PARSER_ADD_OBJECT (EArchCommonObjPowerManagementProfileInfo, CmArchCommonPowerManagementProfileInfoParser), CM_PARSER_ADD_OBJECT (EArchCommonObjSerialPortInfo, CmArchCommonSerialPortInfoParser), CM_PARSER_ADD_OBJECT (EArchCommonObjConsolePortInfo, CmArchCommonSerialPortInfoParser), CM_PARSER_ADD_OBJECT (EArchCommonObjSerialDebugPortInfo, CmArchCommonSerialPortInfoParser), CM_PARSER_ADD_OBJECT (EArchCommonObjHypervisorVendorIdentity, CmArchCommonHypervisorVendorIdentityParser), CM_PARSER_ADD_OBJECT (EArchCommonObjFixedFeatureFlags, CmArchCommonFixedFeatureFlagsParser), CM_PARSER_ADD_OBJECT (EArchCommonObjCmRef, CmArchCommonObjRefParser), CM_PARSER_ADD_OBJECT (EArchCommonObjPciConfigSpaceInfo, CmArchCommonPciConfigSpaceInfoParser), CM_PARSER_ADD_OBJECT (EArchCommonObjPciAddressMapInfo, CmArchCommonPciAddressMapInfoParser), CM_PARSER_ADD_OBJECT (EArchCommonObjPciInterruptMapInfo, CmArchCommonPciInterruptMapInfoParser), CM_PARSER_ADD_OBJECT (EArchCommonObjMemoryAffinityInfo, CmArchCommonMemoryAffinityInfoParser), CM_PARSER_ADD_OBJECT (EArchCommonObjDeviceHandleAcpi, CmArchCommonDeviceHandleAcpiParser), CM_PARSER_ADD_OBJECT (EArchCommonObjDeviceHandlePci, CmArchCommonDeviceHandlePciParser), CM_PARSER_ADD_OBJECT (EArchCommonObjGenericInitiatorAffinityInfo,CmArchCommonGenericInitiatorAffinityInfoParser), CM_PARSER_ADD_OBJECT (EArchCommonObjLpiInfo, CmArchCommonLpiInfoParser), CM_PARSER_ADD_OBJECT (EArchCommonObjProcHierarchyInfo, CmArchCommonProcHierarchyInfoParser), CM_PARSER_ADD_OBJECT (EArchCommonObjCacheInfo, CmArchCommonCacheInfoParser), CM_PARSER_ADD_OBJECT_RESERVED (EArchCommonObjMax) }; /** A parser for Arm namespace objects. */ STATIC CONST CM_OBJ_PARSER_ARRAY ArmNamespaceObjectParser[] = { CM_PARSER_ADD_OBJECT_RESERVED (EArmObjReserved), CM_PARSER_ADD_OBJECT (EArmObjBootArchInfo, CmArmBootArchInfoParser), CM_PARSER_ADD_OBJECT (EArmObjGicCInfo, CmArmGicCInfoParser), CM_PARSER_ADD_OBJECT (EArmObjGicDInfo, CmArmGicDInfoParser), CM_PARSER_ADD_OBJECT (EArmObjGicMsiFrameInfo, CmArmGicMsiFrameInfoParser), CM_PARSER_ADD_OBJECT (EArmObjGicRedistributorInfo, CmArmGicRedistInfoParser), CM_PARSER_ADD_OBJECT (EArmObjGicItsInfo, CmArmGicItsInfoParser), CM_PARSER_ADD_OBJECT (EArmObjGenericTimerInfo, CmArmGenericTimerInfoParser), CM_PARSER_ADD_OBJECT (EArmObjPlatformGTBlockInfo, CmArmGTBlockInfoParser), CM_PARSER_ADD_OBJECT (EArmObjGTBlockTimerFrameInfo, CmArmGTBlockTimerFrameInfoParser), CM_PARSER_ADD_OBJECT (EArmObjPlatformGenericWatchdogInfo,CmArmGenericWatchdogInfoParser), CM_PARSER_ADD_OBJECT (EArmObjItsGroup, CmArmItsGroupNodeParser), CM_PARSER_ADD_OBJECT (EArmObjNamedComponent, CmArmNamedComponentNodeParser), CM_PARSER_ADD_OBJECT (EArmObjRootComplex, CmArmRootComplexNodeParser), CM_PARSER_ADD_OBJECT (EArmObjSmmuV1SmmuV2, CmArmSmmuV1SmmuV2NodeParser), CM_PARSER_ADD_OBJECT (EArmObjSmmuV3, CmArmSmmuV3NodeParser), CM_PARSER_ADD_OBJECT (EArmObjPmcg, CmArmPmcgNodeParser), CM_PARSER_ADD_OBJECT (EArmObjGicItsIdentifierArray, CmArmGicItsIdentifierParser), CM_PARSER_ADD_OBJECT (EArmObjIdMappingArray, CmArmIdMappingParser), CM_PARSER_ADD_OBJECT (EArmObjSmmuInterruptArray, CmArchCommonGenericInterruptParser), CM_PARSER_ADD_OBJECT (EArmObjCmn600Info, CmArmCmn600InfoParser), CM_PARSER_ADD_OBJECT (EArmObjRmr, CmArmRmrInfoParser), CM_PARSER_ADD_OBJECT (EArmObjMemoryRangeDescriptor, CmArmMemoryRangeDescriptorInfoParser), CM_PARSER_ADD_OBJECT (EArmObjCpcInfo, CmArmCpcInfoParser), CM_PARSER_ADD_OBJECT (EArmObjPccSubspaceType0Info, CmArmPccSubspaceType0InfoParser), CM_PARSER_ADD_OBJECT (EArmObjPccSubspaceType1Info, CmArmPccSubspaceType1InfoParser), CM_PARSER_ADD_OBJECT (EArmObjPccSubspaceType2Info, CmArmPccSubspaceType2InfoParser), CM_PARSER_ADD_OBJECT (EArmObjPccSubspaceType3Info, CmArmPccSubspaceType34InfoParser), CM_PARSER_ADD_OBJECT (EArmObjPccSubspaceType4Info, CmArmPccSubspaceType34InfoParser), CM_PARSER_ADD_OBJECT (EArmObjPccSubspaceType5Info, CmArmPccSubspaceType5InfoParser), CM_PARSER_ADD_OBJECT (EArmObjEtInfo, CmArmEtInfo), CM_PARSER_ADD_OBJECT (EArmObjPsdInfo, CmArmPsdInfoParser), CM_PARSER_ADD_OBJECT_RESERVED (EArmObjMax) }; /** A parser for EStdObjCfgMgrInfo. */ STATIC CONST CM_OBJ_PARSER StdObjCfgMgrInfoParser[] = { { "Revision", 4, "0x%x", NULL }, { "OemId[6]", 6, "%c%c%c%c%c%c", PrintChar6 } }; /** A parser for EStdObjAcpiTableList. */ STATIC CONST CM_OBJ_PARSER StdObjAcpiTableInfoParser[] = { { "AcpiTableSignature", 4, "%c%c%c%c", PrintChar4 }, { "AcpiTableRevision", 1, "%d", NULL }, { "TableGeneratorId", sizeof (ACPI_TABLE_GENERATOR_ID), "0x%x", NULL }, { "AcpiTableData", sizeof (EFI_ACPI_DESCRIPTION_HEADER *), "0x%p", NULL }, { "OemTableId", 8, "%c%c%c%c%c%c%c%c", PrintChar8 }, { "OemRevision", 4, "0x%x", NULL }, { "MinorRevision", 1, "0x%x", NULL }, }; /** A parser for EStdObjSmbiosTableList. */ STATIC CONST CM_OBJ_PARSER StdObjSmbiosTableInfoParser[] = { { "TableGeneratorId", sizeof (SMBIOS_TABLE_GENERATOR_ID), "0x%x", NULL }, { "SmbiosTableData", sizeof (SMBIOS_STRUCTURE *), "0x%p", NULL } }; /** A parser for Standard namespace objects. */ STATIC CONST CM_OBJ_PARSER_ARRAY StdNamespaceObjectParser[] = { CM_PARSER_ADD_OBJECT (EStdObjCfgMgrInfo, StdObjCfgMgrInfoParser), CM_PARSER_ADD_OBJECT (EStdObjAcpiTableList, StdObjAcpiTableInfoParser), CM_PARSER_ADD_OBJECT (EStdObjSmbiosTableList, StdObjSmbiosTableInfoParser), CM_PARSER_ADD_OBJECT_RESERVED (EStdObjMax) }; /** Print string data. The string must be NULL terminated. @param [in] Format Format to print the Ptr. @param [in] Ptr Pointer to the string. **/ STATIC VOID EFIAPI PrintString ( IN CONST CHAR8 *Format, IN UINT8 *Ptr ) { if (Ptr == NULL) { ASSERT (0); return; } DEBUG ((DEBUG_ERROR, "%a", Ptr)); } /** Print string from pointer. The string must be NULL terminated. @param [in] Format Format to print the string. @param [in] Ptr Pointer to the string pointer. **/ STATIC VOID EFIAPI PrintStringPtr ( IN CONST CHAR8 *Format, IN UINT8 *Ptr ) { UINT8 *String; if (Ptr == NULL) { ASSERT (0); return; } String = *(UINT8 **)Ptr; if (String == NULL) { String = (UINT8 *)"(NULLPTR)"; } PrintString (Format, String); } /** Print 4 characters. @param [in] Format Format to print the Ptr. @param [in] Ptr Pointer to the characters. **/ STATIC VOID EFIAPI PrintChar4 ( IN CONST CHAR8 *Format, IN UINT8 *Ptr ) { DEBUG (( DEBUG_ERROR, (Format != NULL) ? Format : "%c%c%c%c", Ptr[0], Ptr[1], Ptr[2], Ptr[3] )); } /** Print 6 characters. @param [in] Format Format to print the Ptr. @param [in] Ptr Pointer to the characters. **/ STATIC VOID EFIAPI PrintChar6 ( IN CONST CHAR8 *Format, IN UINT8 *Ptr ) { DEBUG (( DEBUG_ERROR, (Format != NULL) ? Format : "%c%c%c%c%c%c", Ptr[0], Ptr[1], Ptr[2], Ptr[3], Ptr[4], Ptr[5] )); } /** Print 8 characters. @param [in] Format Format to print the Ptr. @param [in] Ptr Pointer to the characters. **/ STATIC VOID EFIAPI PrintChar8 ( IN CONST CHAR8 *Format, IN UINT8 *Ptr ) { DEBUG (( DEBUG_ERROR, (Format != NULL) ? Format : "%c%c%c%c%c%c%c%c", Ptr[0], Ptr[1], Ptr[2], Ptr[3], Ptr[4], Ptr[5], Ptr[6], Ptr[7] )); } /** Print fields of the objects. @param [in] Data Pointer to the object to print. @param [in] Parser Parser containing the object fields. @param [in] ItemCount Number of entries/fields in the Parser. @param [in] RemainingSize Parse at most *RemainingSize bytes. This function decrements the value from the number bytes consumed. @param [in] IndentLevel Indentation to use when printing. **/ STATIC VOID PrintCmObjDesc ( IN VOID *Data, IN CONST CM_OBJ_PARSER *Parser, IN UINTN ItemCount, IN INTN *RemainingSize, IN UINT32 IndentLevel ) { UINT32 Index; UINT32 IndentIndex; INTN SubStructSize; if ((Data == NULL) || (Parser == NULL) || (ItemCount == 0) || (RemainingSize == NULL)) { ASSERT (0); return; } // Print each field. for (Index = 0; Index < ItemCount; Index++) { // Check there is enough space in left. *RemainingSize -= Parser[Index].Length; if (*RemainingSize < 0) { DEBUG (( DEBUG_ERROR, "\nERROR: %a: Buffer overrun\n", Parser[Index].NameStr )); ASSERT (0); return; } // Indentation for (IndentIndex = 0; IndentIndex < IndentLevel; IndentIndex++) { DEBUG ((DEBUG_INFO, " ")); } DEBUG (( DEBUG_INFO, "%-*a :", OUTPUT_FIELD_COLUMN_WIDTH - 2 * IndentLevel, Parser[Index].NameStr )); if (Parser[Index].PrintFormatter != NULL) { Parser[Index].PrintFormatter (Parser[Index].Format, Data); } else if (Parser[Index].Format != NULL) { switch (Parser[Index].Length) { case 1: DEBUG ((DEBUG_INFO, Parser[Index].Format, *(UINT8 *)Data)); break; case 2: DEBUG ((DEBUG_INFO, Parser[Index].Format, *(UINT16 *)Data)); break; case 4: DEBUG ((DEBUG_INFO, Parser[Index].Format, *(UINT32 *)Data)); break; case 8: DEBUG ((DEBUG_INFO, Parser[Index].Format, ReadUnaligned64 (Data))); break; default: DEBUG (( DEBUG_INFO, "\nERROR: %a: CANNOT PARSE THIS FIELD, Field Length = %d\n", Parser[Index].NameStr, Parser[Index].Length )); } // switch } else if (Parser[Index].SubObjParser != NULL) { SubStructSize = Parser[Index].Length; DEBUG ((DEBUG_INFO, "\n")); PrintCmObjDesc ( Data, Parser[Index].SubObjParser, Parser[Index].SubObjItemCount, &SubStructSize, IndentLevel + 1 ); } else { ASSERT (0); DEBUG (( DEBUG_INFO, "\nERROR: %a: CANNOT PARSE THIS FIELD, Field Length = %d\n", Parser[Index].NameStr, Parser[Index].Length )); } DEBUG ((DEBUG_INFO, "\n")); Data = (UINT8 *)Data + Parser[Index].Length; } // for } /** Parse and print a CmObjDesc. @param [in] CmObjDesc The CmObjDesc to parse and print. **/ VOID EFIAPI ParseCmObjDesc ( IN CONST CM_OBJ_DESCRIPTOR *CmObjDesc ) { UINTN ObjId; UINTN NameSpaceId; UINT32 ObjIndex; UINT32 ObjectCount; INTN RemainingSize; INTN Offset; CONST CM_OBJ_PARSER_ARRAY *ParserArray; if ((CmObjDesc == NULL) || (CmObjDesc->Data == NULL)) { return; } NameSpaceId = GET_CM_NAMESPACE_ID (CmObjDesc->ObjectId); ObjId = GET_CM_OBJECT_ID (CmObjDesc->ObjectId); switch (NameSpaceId) { case EObjNameSpaceStandard: if (ObjId >= EStdObjMax) { ASSERT (0); return; } if (ObjId >= ARRAY_SIZE (StdNamespaceObjectParser)) { DEBUG ((DEBUG_ERROR, "ObjId 0x%x is missing from the StdNamespaceObjectParser array\n", ObjId)); ASSERT (0); return; } ParserArray = &StdNamespaceObjectParser[ObjId]; break; case EObjNameSpaceArm: if (ObjId >= EArmObjMax) { ASSERT (0); return; } if (ObjId >= ARRAY_SIZE (ArmNamespaceObjectParser)) { DEBUG ((DEBUG_ERROR, "ObjId 0x%x is missing from the ArmNamespaceObjectParser array\n", ObjId)); ASSERT (0); return; } ParserArray = &ArmNamespaceObjectParser[ObjId]; break; case EObjNameSpaceArchCommon: if (ObjId >= EArchCommonObjMax) { ASSERT (0); return; } if (ObjId >= ARRAY_SIZE (ArchCommonNamespaceObjectParser)) { DEBUG ((DEBUG_ERROR, "ObjId 0x%x is missing from the ArchCommonNamespaceObjectParser array\n", ObjId)); ASSERT (0); return; } ParserArray = &ArchCommonNamespaceObjectParser[ObjId]; break; default: // Not supported DEBUG ((DEBUG_ERROR, "NameSpaceId 0x%x, ObjId 0x%x is not supported by the parser\n", NameSpaceId, ObjId)); ASSERT (0); return; } // switch ObjectCount = CmObjDesc->Count; RemainingSize = CmObjDesc->Size; Offset = 0; for (ObjIndex = 0; ObjIndex < ObjectCount; ObjIndex++) { DEBUG (( DEBUG_INFO, "\n%-*a [%d/%d]:\n", OUTPUT_FIELD_COLUMN_WIDTH, ParserArray->ObjectName, ObjIndex + 1, ObjectCount )); ASSERT (ObjId == ParserArray->ObjectId); if (ParserArray->Parser == NULL) { DEBUG ((DEBUG_ERROR, "Parser not implemented\n")); RemainingSize = 0; } else { PrintCmObjDesc ( (VOID *)((UINTN)CmObjDesc->Data + Offset), ParserArray->Parser, ParserArray->ItemCount, &RemainingSize, 1 ); if ((RemainingSize > (INTN)CmObjDesc->Size) || (RemainingSize < 0)) { ASSERT (0); return; } Offset = CmObjDesc->Size - RemainingSize; } } // for ASSERT (RemainingSize == 0); }