#
|
# Copyright (c) 2018 - 2020, ARM Limited. All rights reserved.
|
#
|
# SPDX-License-Identifier: BSD-2-Clause-Patent
|
#
|
|
################################################################################
|
#
|
# Defines Section - statements that will be processed to create a Makefile.
|
#
|
################################################################################
|
[Defines]
|
PLATFORM_NAME = n1sdp
|
PLATFORM_GUID = 9af67d31-7de8-4a71-a9a8-a597a27659ce
|
PLATFORM_VERSION = 0.1
|
DSC_SPECIFICATION = 0x0001001B
|
OUTPUT_DIRECTORY = Build/$(PLATFORM_NAME)
|
SUPPORTED_ARCHITECTURES = AARCH64
|
BUILD_TARGETS = NOOPT|DEBUG|RELEASE
|
SKUID_IDENTIFIER = DEFAULT
|
FLASH_DEFINITION = Platform/ARM/N1Sdp/N1SdpPlatform.fdf
|
BUILD_NUMBER = 1
|
|
!include Platform/ARM/VExpressPkg/ArmVExpress.dsc.inc
|
!include MdePkg/MdeLibs.dsc.inc
|
|
[LibraryClasses.common]
|
ArmLib|ArmPkg/Library/ArmLib/ArmBaseLib.inf
|
ArmMmuLib|ArmPkg/Library/ArmMmuLib/ArmMmuBaseLib.inf
|
ArmPlatformLib|Silicon/ARM/NeoverseN1Soc/Library/PlatformLib/PlatformLib.inf
|
BasePathLib|ShellPkg/Library/UefiShellLib/UefiShellLib.inf
|
HobLib|MdePkg/Library/DxeHobLib/DxeHobLib.inf
|
TimerLib|ArmPkg/Library/ArmArchTimerLib/ArmArchTimerLib.inf
|
UefiUsbLib|MdePkg/Library/UefiUsbLib/UefiUsbLib.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
|
PciHostBridgeLib|Silicon/ARM/NeoverseN1Soc/Library/PciHostBridgeLib/PciHostBridgeLib.inf
|
PciSegmentLib|MdePkg/Library/BasePciSegmentLibPci/BasePciSegmentLibPci.inf
|
PciLib|MdePkg/Library/BasePciLibPciExpress/BasePciLibPciExpress.inf
|
PciExpressLib|Silicon/ARM/NeoverseN1Soc/Library/NeoverseN1SocPciExpressLib/PciExpressLib.inf
|
|
[LibraryClasses.common.DXE_RUNTIME_DRIVER]
|
BaseMemoryLib|MdePkg/Library/BaseMemoryLib/BaseMemoryLib.inf
|
HobLib|MdePkg/Library/DxeHobLib/DxeHobLib.inf
|
|
[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]
|
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) - Reserved Secure Memory (16MB)
|
gArmTokenSpaceGuid.PcdSystemMemoryBase|0x80000000
|
gArmTokenSpaceGuid.PcdSystemMemorySize|(0x80000000 - 0x01000000)
|
|
# Secondary DDR memory
|
gArmNeoverseN1SocTokenSpaceGuid.PcdDramBlock2Base|0x8080000000
|
|
# GIC Base Addresses
|
gArmTokenSpaceGuid.PcdGicInterruptInterfaceBase|0x2C000000
|
gArmTokenSpaceGuid.PcdGicDistributorBase|0x30000000
|
gArmTokenSpaceGuid.PcdGicRedistributorsBase|0x300C0000
|
|
# PCIe
|
gEfiMdePkgTokenSpaceGuid.PcdPciExpressBaseAddress|0x70000000
|
gEmbeddedTokenSpaceGuid.PcdPrePiCpuIoSize|24
|
gEfiMdeModulePkgTokenSpaceGuid.PcdSrIovSupport|FALSE
|
|
# 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|gEfiMdeModulePkgTokenSpaceGuid.PcdSerialRegisterBase
|
gArmPlatformTokenSpaceGuid.PcdSerialDbgUartBaudRate|gEfiMdePkgTokenSpaceGuid.PcdUartDefaultBaudRate
|
gArmPlatformTokenSpaceGuid.PcdSerialDbgUartClkInHz|50000000
|
|
# SBSA Watchdog
|
gArmTokenSpaceGuid.PcdGenericWatchdogEl2IntrNum|93
|
|
# PL031 RealTimeClock
|
gArmPlatformTokenSpaceGuid.PcdPL031RtcBase|0x1C100000
|
|
# ARM OS Loader
|
gEfiMdePkgTokenSpaceGuid.PcdPlatformBootTimeOut|0
|
|
# ARM Architectural Timer Frequency
|
gArmTokenSpaceGuid.PcdArmArchTimerFreqInHz|100000000
|
gEmbeddedTokenSpaceGuid.PcdMetronomeTickPeriod|1000
|
gEmbeddedTokenSpaceGuid.PcdTimerPeriod|1000
|
|
# ARM Cores and Clusters
|
gArmPlatformTokenSpaceGuid.PcdCoreCount|2
|
gArmPlatformTokenSpaceGuid.PcdClusterCount|2
|
|
# Runtime Variable storage
|
gEfiMdeModulePkgTokenSpaceGuid.PcdEmuVariableNvStoreReserved|0
|
gEfiMdeModulePkgTokenSpaceGuid.PcdEmuVariableNvModeEnable|TRUE
|
gEfiMdeModulePkgTokenSpaceGuid.PcdMaxVariableSize|0x2000
|
gEfiMdeModulePkgTokenSpaceGuid.PcdMaxAuthVariableSize|0x2800
|
|
################################################################################
|
#
|
# 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
|
}
|
|
# Human Interface Support
|
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
|
}
|
|
# 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
|
|
# Usb Support
|
MdeModulePkg/Bus/Pci/UhciDxe/UhciDxe.inf
|
MdeModulePkg/Bus/Pci/EhciDxe/EhciDxe.inf
|
MdeModulePkg/Bus/Pci/XhciDxe/XhciDxe.inf
|
MdeModulePkg/Bus/Usb/UsbBusDxe/UsbBusDxe.inf
|
MdeModulePkg/Bus/Usb/UsbKbDxe/UsbKbDxe.inf
|
MdeModulePkg/Bus/Usb/UsbMassStorageDxe/UsbMassStorageDxe.inf
|
MdeModulePkg/Bus/Pci/NonDiscoverablePciDeviceDxe/NonDiscoverablePciDeviceDxe.inf
|