## @file
|
# Component description file for Morello Platform
|
#
|
# Copyright (c) 2021, ARM Limited. All rights reserved.<BR>
|
#
|
# SPDX-License-Identifier: BSD-2-Clause-Patent
|
##
|
|
[LibraryClasses.common]
|
ArmLib|ArmPkg/Library/ArmLib/ArmBaseLib.inf
|
ArmMmuLib|ArmPkg/Library/ArmMmuLib/ArmMmuBaseLib.inf
|
ArmPlatformLib|Platform/ARM/Morello/Library/PlatformLib/PlatformLib.inf
|
BasePathLib|ShellPkg/Library/UefiShellLib/UefiShellLib.inf
|
HobLib|MdePkg/Library/DxeHobLib/DxeHobLib.inf
|
TimerLib|ArmPkg/Library/ArmArchTimerLib/ArmArchTimerLib.inf
|
|
# Ramdisk Support
|
FileExplorerLib|MdeModulePkg/Library/FileExplorerLib/FileExplorerLib.inf
|
|
[LibraryClasses.common.SEC]
|
HobLib|MdePkg/Library/PeiHobLib/PeiHobLib.inf
|
MemoryAllocationLib|MdePkg/Library/PeiMemoryAllocationLib/PeiMemoryAllocationLib.inf
|
PcdLib|MdePkg/Library/BasePcdLibNull/BasePcdLibNull.inf
|
PeiServicesLib|MdePkg/Library/PeiServicesLib/PeiServicesLib.inf
|
PeiServicesTablePointerLib|ArmPkg/Library/PeiServicesTablePointerLib/PeiServicesTablePointerLib.inf
|
|
[LibraryClasses.common.PEI_CORE, LibraryClasses.common.PEIM]
|
BaseMemoryLib|MdePkg/Library/BaseMemoryLib/BaseMemoryLib.inf
|
HobLib|MdePkg/Library/PeiHobLib/PeiHobLib.inf
|
MemoryAllocationLib|MdePkg/Library/PeiMemoryAllocationLib/PeiMemoryAllocationLib.inf
|
PcdLib|MdePkg/Library/PeiPcdLib/PeiPcdLib.inf
|
PeiServicesLib|MdePkg/Library/PeiServicesLib/PeiServicesLib.inf
|
PeiServicesTablePointerLib|ArmPkg/Library/PeiServicesTablePointerLib/PeiServicesTablePointerLib.inf
|
ReportStatusCodeLib|MdePkg/Library/BaseReportStatusCodeLibNull/BaseReportStatusCodeLibNull.inf
|
|
[LibraryClasses.common.PEI_CORE]
|
PeiCoreEntryPoint|MdePkg/Library/PeiCoreEntryPoint/PeiCoreEntryPoint.inf
|
|
[LibraryClasses.common.PEIM]
|
PeimEntryPoint|MdePkg/Library/PeimEntryPoint/PeimEntryPoint.inf
|
|
[LibraryClasses.common.DXE_CORE]
|
DxeCoreEntryPoint|MdePkg/Library/DxeCoreEntryPoint/DxeCoreEntryPoint.inf
|
HobLib|MdePkg/Library/DxeCoreHobLib/DxeCoreHobLib.inf
|
MemoryAllocationLib|MdeModulePkg/Library/DxeCoreMemoryAllocationLib/DxeCoreMemoryAllocationLib.inf
|
PcdLib|MdePkg/Library/BasePcdLibNull/BasePcdLibNull.inf
|
|
[LibraryClasses.common.DXE_DRIVER]
|
FdtLib|EmbeddedPkg/Library/FdtLib/FdtLib.inf
|
PciSegmentLib|MdePkg/Library/BasePciSegmentLibPci/BasePciSegmentLibPci.inf
|
PciLib|MdePkg/Library/BasePciLibPciExpress/BasePciLibPciExpress.inf
|
PciExpressLib|MdePkg/Library/BasePciExpressLib/BasePciExpressLib.inf
|
|
[LibraryClasses.common.DXE_RUNTIME_DRIVER]
|
BaseMemoryLib|MdePkg/Library/BaseMemoryLib/BaseMemoryLib.inf
|
HobLib|MdePkg/Library/DxeHobLib/DxeHobLib.inf
|
!if $(TARGET) != RELEASE
|
DebugLib|MdePkg/Library/DxeRuntimeDebugLibSerialPort/DxeRuntimeDebugLibSerialPort.inf
|
!endif
|
|
[LibraryClasses.common.UEFI_DRIVER, LibraryClasses.common.UEFI_APPLICATION, LibraryClasses.common.DXE_RUNTIME_DRIVER, LibraryClasses.common.DXE_DRIVER]
|
PcdLib|MdePkg/Library/DxePcdLib/DxePcdLib.inf
|
|
################################################################################
|
#
|
# Pcd Section - list of all EDK II PCD Entries defined by this Platform
|
#
|
################################################################################
|
|
[PcdsFeatureFlag.common]
|
gArmMorelloTokenSpaceGuid.PcdRamDiskSupported|TRUE
|
gEfiMdeModulePkgTokenSpaceGuid.PcdTurnOffUsbLegacySupport|TRUE
|
|
[PcdsFixedAtBuild.common]
|
gArmTokenSpaceGuid.PcdVFPEnabled|1
|
|
# Stacks for MPCores in Normal World
|
gArmPlatformTokenSpaceGuid.PcdCPUCoresStackBase|0x80000000
|
gArmPlatformTokenSpaceGuid.PcdCPUCorePrimaryStackSize|0x40000
|
gArmPlatformTokenSpaceGuid.PcdCPUCoreSecondaryStackSize|0x0
|
|
# System Memory (2GB - 16MB)
|
gArmTokenSpaceGuid.PcdSystemMemoryBase|0x80000000
|
gArmTokenSpaceGuid.PcdSystemMemorySize|0x7F000000
|
|
# Secondary DDR memory
|
gArmMorelloTokenSpaceGuid.PcdDramBlock2Base|0x8080000000
|
|
# GIC Base Addresses
|
gArmTokenSpaceGuid.PcdGicInterruptInterfaceBase|0x2C000000
|
gArmTokenSpaceGuid.PcdGicDistributorBase|0x30000000
|
gArmTokenSpaceGuid.PcdGicRedistributorsBase|0x300C0000
|
|
# PL011 - Serial Terminal
|
gEfiMdeModulePkgTokenSpaceGuid.PcdSerialRegisterBase|0x2A400000
|
gEfiMdePkgTokenSpaceGuid.PcdUartDefaultBaudRate|115200
|
gEfiMdePkgTokenSpaceGuid.PcdUartDefaultReceiveFifoDepth|0
|
gArmPlatformTokenSpaceGuid.PL011UartClkInHz|50000000
|
gArmPlatformTokenSpaceGuid.PL011UartInterrupt|95
|
|
# PL011 Serial Debug UART (DBG2)
|
gArmPlatformTokenSpaceGuid.PcdSerialDbgRegisterBase|0x1C0A0000
|
gArmPlatformTokenSpaceGuid.PcdSerialDbgUartBaudRate|115200
|
gArmPlatformTokenSpaceGuid.PcdSerialDbgUartClkInHz|50000000
|
|
# SBSA Watchdog
|
gArmTokenSpaceGuid.PcdGenericWatchdogEl2IntrNum|93
|
|
# PL031 RealTimeClock
|
gArmPlatformTokenSpaceGuid.PcdPL031RtcBase|0x1C100000
|
|
# ARM Architectural Timer Frequency
|
gArmTokenSpaceGuid.PcdArmArchTimerFreqInHz|50000000
|
gEmbeddedTokenSpaceGuid.PcdMetronomeTickPeriod|1000
|
gEmbeddedTokenSpaceGuid.PcdTimerPeriod|1000
|
|
# ARM Cores and Clusters
|
gArmPlatformTokenSpaceGuid.PcdCoreCount|2
|
gArmPlatformTokenSpaceGuid.PcdClusterCount|2
|
|
# ACPI Table Version
|
gEfiMdeModulePkgTokenSpaceGuid.PcdAcpiExposedTableVersions|0x20
|
|
# Runtime Variable storage
|
gEfiMdeModulePkgTokenSpaceGuid.PcdEmuVariableNvStoreReserved|0
|
gEfiMdeModulePkgTokenSpaceGuid.PcdEmuVariableNvModeEnable|TRUE
|
gEfiMdeModulePkgTokenSpaceGuid.PcdMaxVariableSize|0x2000
|
gEfiMdeModulePkgTokenSpaceGuid.PcdMaxAuthVariableSize|0x2800
|
|
# RAM Disk
|
gArmMorelloTokenSpaceGuid.PcdRamDiskBase|0x88000000
|
gArmMorelloTokenSpaceGuid.PcdRamDiskSize|0x18000000
|
|
# PCIe
|
gEmbeddedTokenSpaceGuid.PcdPrePiCpuIoSize|24
|
gEfiMdeModulePkgTokenSpaceGuid.PcdSrIovSupport|FALSE
|
gEfiMdePkgTokenSpaceGuid.PcdPciExpressBaseAddress|0x20000000
|
|
[PcdsDynamicHii.common.DEFAULT]
|
gEfiMdePkgTokenSpaceGuid.PcdPlatformBootTimeOut|L"Timeout"|gEfiGlobalVariableGuid|0x0|0
|
|
################################################################################
|
#
|
# Components Section - list of all EDK II Modules needed by this Platform
|
#
|
################################################################################
|
[Components.common]
|
# PEI Phase modules
|
ArmPkg/Drivers/CpuPei/CpuPei.inf
|
ArmPlatformPkg/MemoryInitPei/MemoryInitPeim.inf
|
ArmPlatformPkg/PrePeiCore/PrePeiCoreMPCore.inf
|
ArmPlatformPkg/PlatformPei/PlatformPeim.inf
|
MdeModulePkg/Core/Pei/PeiMain.inf
|
MdeModulePkg/Universal/PCD/Pei/Pcd.inf {
|
<LibraryClasses>
|
PcdLib|MdePkg/Library/BasePcdLibNull/BasePcdLibNull.inf
|
}
|
MdeModulePkg/Universal/Variable/Pei/VariablePei.inf
|
MdeModulePkg/Core/DxeIplPeim/DxeIpl.inf {
|
<LibraryClasses>
|
NULL|MdeModulePkg/Library/LzmaCustomDecompressLib/LzmaCustomDecompressLib.inf
|
}
|
|
# DXE
|
MdeModulePkg/Core/Dxe/DxeMain.inf {
|
<LibraryClasses>
|
NULL|MdeModulePkg/Library/DxeCrc32GuidedSectionExtractLib/DxeCrc32GuidedSectionExtractLib.inf
|
<PcdsFixedAtBuild>
|
gEfiMdePkgTokenSpaceGuid.PcdDebugPrintErrorLevel|0x8000000F
|
}
|
|
# Architectural Protocols
|
ArmPkg/Drivers/CpuDxe/CpuDxe.inf
|
ArmPkg/Drivers/ArmGic/ArmGicDxe.inf
|
ArmPkg/Drivers/TimerDxe/TimerDxe.inf
|
ArmPkg/Drivers/GenericWatchdogDxe/GenericWatchdogDxe.inf
|
EmbeddedPkg/RealTimeClockRuntimeDxe/RealTimeClockRuntimeDxe.inf
|
MdeModulePkg/Core/RuntimeDxe/RuntimeDxe.inf
|
MdeModulePkg/Universal/Metronome/Metronome.inf
|
MdeModulePkg/Universal/ResetSystemRuntimeDxe/ResetSystemRuntimeDxe.inf
|
MdeModulePkg/Universal/CapsuleRuntimeDxe/CapsuleRuntimeDxe.inf
|
MdeModulePkg/Universal/MonotonicCounterRuntimeDxe/MonotonicCounterRuntimeDxe.inf
|
MdeModulePkg/Universal/SecurityStubDxe/SecurityStubDxe.inf
|
|
MdeModulePkg/Universal/Console/ConPlatformDxe/ConPlatformDxe.inf
|
MdeModulePkg/Universal/Console/ConSplitterDxe/ConSplitterDxe.inf
|
MdeModulePkg/Universal/Console/GraphicsConsoleDxe/GraphicsConsoleDxe.inf
|
MdeModulePkg/Universal/Console/TerminalDxe/TerminalDxe.inf
|
MdeModulePkg/Universal/SerialDxe/SerialDxe.inf
|
MdeModulePkg/Universal/Variable/RuntimeDxe/VariableRuntimeDxe.inf {
|
<LibraryClasses>
|
NULL|MdeModulePkg/Library/VarCheckUefiLib/VarCheckUefiLib.inf
|
BaseMemoryLib|MdePkg/Library/BaseMemoryLib/BaseMemoryLib.inf
|
}
|
|
# ACPI Support
|
MdeModulePkg/Universal/Acpi/AcpiTableDxe/AcpiTableDxe.inf
|
MdeModulePkg/Universal/HiiDatabaseDxe/HiiDatabaseDxe.inf
|
|
# FAT filesystem + GPT/MBR partitioning
|
MdeModulePkg/Universal/Disk/DiskIoDxe/DiskIoDxe.inf
|
MdeModulePkg/Universal/Disk/PartitionDxe/PartitionDxe.inf
|
MdeModulePkg/Universal/Disk/UnicodeCollation/EnglishDxe/EnglishDxe.inf
|
FatPkg/EnhancedFatDxe/Fat.inf
|
|
# Bds
|
MdeModulePkg/Universal/BdsDxe/BdsDxe.inf
|
MdeModulePkg/Universal/DevicePathDxe/DevicePathDxe.inf
|
MdeModulePkg/Universal/DisplayEngineDxe/DisplayEngineDxe.inf
|
MdeModulePkg/Universal/SetupBrowserDxe/SetupBrowserDxe.inf
|
MdeModulePkg/Application/UiApp/UiApp.inf {
|
<LibraryClasses>
|
NULL|MdeModulePkg/Library/DeviceManagerUiLib/DeviceManagerUiLib.inf
|
NULL|MdeModulePkg/Library/BootManagerUiLib/BootManagerUiLib.inf
|
NULL|MdeModulePkg/Library/BootMaintenanceManagerUiLib/BootMaintenanceManagerUiLib.inf
|
}
|
|
# RAM Disk
|
MdeModulePkg/Universal/Disk/RamDiskDxe/RamDiskDxe.inf
|
|
# Required by PCI
|
ArmPkg/Drivers/ArmPciCpuIo2Dxe/ArmPciCpuIo2Dxe.inf
|
|
# PCI Support
|
MdeModulePkg/Bus/Pci/PciBusDxe/PciBusDxe.inf
|
MdeModulePkg/Bus/Pci/PciHostBridgeDxe/PciHostBridgeDxe.inf {
|
<PcdsFixedAtBuild>
|
gEfiMdePkgTokenSpaceGuid.PcdDebugPrintErrorLevel|0x8010004F
|
}
|
|
# AHCI Support
|
MdeModulePkg/Bus/Ata/AtaAtapiPassThru/AtaAtapiPassThru.inf
|
MdeModulePkg/Bus/Ata/AtaBusDxe/AtaBusDxe.inf
|
|
# SATA Controller
|
MdeModulePkg/Bus/Pci/SataControllerDxe/SataControllerDxe.inf
|