# | |
# Copyright (c) 2013-2014, ARM Limited. All rights reserved. | |
# | |
# This program and the accompanying materials | |
# are licensed and made available under the terms and conditions of the BSD License | |
# which accompanies this distribution. The full text of the license may be found at | |
# http://opensource.org/licenses/bsd-license.php | |
# | |
# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | |
# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | |
# | |
################################################################################ | |
# | |
# Defines Section - statements that will be processed to create a Makefile. | |
# | |
################################################################################ | |
[Defines] | |
PLATFORM_NAME = ArmJuno | |
PLATFORM_GUID = ca0722fd-7d3d-45ea-948c-d62b2199807d | |
PLATFORM_VERSION = 0.1 | |
DSC_SPECIFICATION = 0x00010005 | |
OUTPUT_DIRECTORY = Build/ArmJuno | |
SUPPORTED_ARCHITECTURES = AARCH64|ARM | |
BUILD_TARGETS = DEBUG|RELEASE | |
SKUID_IDENTIFIER = DEFAULT | |
FLASH_DEFINITION = ArmPlatformPkg/ArmJunoPkg/ArmJuno.fdf | |
# On RTSM, most peripherals are VExpress Motherboard peripherals | |
!include ArmPlatformPkg/ArmVExpressPkg/ArmVExpress.dsc.inc | |
[LibraryClasses.common] | |
ArmPlatformLib|ArmPlatformPkg/ArmJunoPkg/Library/ArmJunoLib/ArmJunoLib.inf | |
ArmSmcLib|ArmPkg/Library/ArmSmcLib/ArmSmcLib.inf | |
ArmPlatformSysConfigLib|ArmPlatformPkg/ArmVExpressPkg/Library/ArmVExpressSysConfigLib/ArmVExpressSysConfigLib.inf | |
NorFlashPlatformLib|ArmPlatformPkg/ArmJunoPkg/Library/NorFlashJunoLib/NorFlashJunoLib.inf | |
EfiResetSystemLib|ArmPkg/Library/ArmPsciResetSystemLib/ArmPsciResetSystemLib.inf | |
TimerLib|ArmPkg/Library/ArmArchTimerLib/ArmArchTimerLib.inf | |
# USB Requirements | |
UefiUsbLib|MdePkg/Library/UefiUsbLib/UefiUsbLib.inf | |
[LibraryClasses.ARM] | |
ArmLib|ArmPkg/Library/ArmLib/ArmV7/ArmV7Lib.inf | |
[LibraryClasses.AARCH64] | |
ArmLib|ArmPkg/Library/ArmLib/AArch64/AArch64Lib.inf | |
[LibraryClasses.common.SEC] | |
PrePiLib|EmbeddedPkg/Library/PrePiLib/PrePiLib.inf | |
ExtractGuidedSectionLib|EmbeddedPkg/Library/PrePiExtractGuidedSectionLib/PrePiExtractGuidedSectionLib.inf | |
LzmaDecompressLib|IntelFrameworkModulePkg/Library/LzmaCustomDecompressLib/LzmaCustomDecompressLib.inf | |
MemoryAllocationLib|EmbeddedPkg/Library/PrePiMemoryAllocationLib/PrePiMemoryAllocationLib.inf | |
HobLib|EmbeddedPkg/Library/PrePiHobLib/PrePiHobLib.inf | |
PrePiHobListPointerLib|ArmPlatformPkg/Library/PrePiHobListPointerLib/PrePiHobListPointerLib.inf | |
PerformanceLib|MdeModulePkg/Library/PeiPerformanceLib/PeiPerformanceLib.inf | |
PlatformPeiLib|ArmPlatformPkg/PlatformPei/PlatformPeiLib.inf | |
MemoryInitPeiLib|ArmPlatformPkg/MemoryInitPei/MemoryInitPeiLib.inf | |
[BuildOptions] | |
*_*_*_PLATFORM_FLAGS == -I$(WORKSPACE)/ArmPlatformPkg/ArmVExpressPkg/Include -I$(WORKSPACE)/ArmPlatformPkg/ArmJunoPkg/Include | |
################################################################################ | |
# | |
# Pcd Section - list of all EDK II PCD Entries defined by this Platform | |
# | |
################################################################################ | |
[PcdsFeatureFlag.common] | |
gArmPlatformTokenSpaceGuid.PcdSystemMemoryInitializeInSec|TRUE | |
## If TRUE, Graphics Output Protocol will be installed on virtual handle created by ConsplitterDxe. | |
# It could be set FALSE to save size. | |
gEfiMdeModulePkgTokenSpaceGuid.PcdConOutGopSupport|TRUE | |
gEfiMdeModulePkgTokenSpaceGuid.PcdTurnOffUsbLegacySupport|TRUE | |
[PcdsFixedAtBuild.common] | |
gArmPlatformTokenSpaceGuid.PcdFirmwareVendor|"ARM Juno" | |
gEmbeddedTokenSpaceGuid.PcdEmbeddedPrompt|"ArmJuno" | |
# | |
# NV Storage PCDs. Use base of 0x08000000 for NOR0 | |
# | |
gEfiMdeModulePkgTokenSpaceGuid.PcdFlashNvStorageVariableBase|0x0BFC0000 | |
gEfiMdeModulePkgTokenSpaceGuid.PcdFlashNvStorageVariableSize|0x00010000 | |
gEfiMdeModulePkgTokenSpaceGuid.PcdFlashNvStorageFtwWorkingBase|0x0BFD0000 | |
gEfiMdeModulePkgTokenSpaceGuid.PcdFlashNvStorageFtwWorkingSize|0x00010000 | |
gEfiMdeModulePkgTokenSpaceGuid.PcdFlashNvStorageFtwSpareBase|0x0BFE0000 | |
gEfiMdeModulePkgTokenSpaceGuid.PcdFlashNvStorageFtwSpareSize|0x00010000 | |
# System Memory (2GB - 16MB of Trusted DRAM at the top of the 32bit address space) | |
gArmTokenSpaceGuid.PcdSystemMemoryBase|0x80000000 | |
gArmTokenSpaceGuid.PcdSystemMemorySize|0x7F000000 | |
# Juno Dual-Cluster profile | |
gArmPlatformTokenSpaceGuid.PcdCoreCount|6 | |
gArmPlatformTokenSpaceGuid.PcdClusterCount|2 | |
gArmTokenSpaceGuid.PcdVFPEnabled|1 | |
# | |
# ARM PrimeCell | |
# | |
## PL011 - Serial Terminal | |
gEfiMdeModulePkgTokenSpaceGuid.PcdSerialRegisterBase|0x7FF80000 | |
gEfiMdePkgTokenSpaceGuid.PcdUartDefaultBaudRate|115200 | |
gArmPlatformTokenSpaceGuid.PL011UartInteger|4 | |
gArmPlatformTokenSpaceGuid.PL011UartFractional|0 | |
## PL031 RealTimeClock | |
gArmPlatformTokenSpaceGuid.PcdPL031RtcBase|0x1C170000 | |
# LAN9118 Ethernet Driver | |
gEmbeddedTokenSpaceGuid.PcdLan9118DxeBaseAddress|0x18000000 | |
gEmbeddedTokenSpaceGuid.PcdLan9118DefaultMacAddress|0x1215161822242628 | |
# | |
# ARM General Interrupt Controller | |
# | |
gArmTokenSpaceGuid.PcdGicDistributorBase|0x2C010000 | |
gArmTokenSpaceGuid.PcdGicInterruptInterfaceBase|0x2C02F000 | |
# List of Device Paths that support BootMonFs | |
gArmPlatformTokenSpaceGuid.PcdBootMonFsSupportedDevicePaths|L"VenHw(E7223039-5836-41E1-B542-D7EC736C5E59)" | |
# | |
# ARM OS Loader | |
# | |
gArmPlatformTokenSpaceGuid.PcdDefaultBootDescription|L"Linux from NOR Flash" | |
gArmPlatformTokenSpaceGuid.PcdDefaultBootDevicePath|L"VenHw(E7223039-5836-41E1-B542-D7EC736C5E59)/Image" | |
gArmPlatformTokenSpaceGuid.PcdFdtDevicePath|L"VenHw(E7223039-5836-41E1-B542-D7EC736C5E59)/juno.dtb" | |
gArmPlatformTokenSpaceGuid.PcdDefaultBootArgument|"console=ttyAMA0,115200 earlyprintk=pl011,0x7ff80000 root=/dev/sda1 rootwait verbose debug" | |
gArmPlatformTokenSpaceGuid.PcdDefaultBootType|2 | |
# Use the serial console (ConIn & ConOut) and the Graphic driver (ConOut) | |
gArmPlatformTokenSpaceGuid.PcdDefaultConOutPaths|L"VenHw(D3987D4B-971A-435F-8CAF-4967EB627241)/Uart(115200,8,N,1)/VenPcAnsi();VenHw(CE660500-824D-11E0-AC72-0002A5D5C51B)" | |
gArmPlatformTokenSpaceGuid.PcdDefaultConInPaths|L"VenHw(D3987D4B-971A-435F-8CAF-4967EB627241)/Uart(115200,8,N,1)/VenPcAnsi()" | |
# | |
# ARM Architectural Timer Frequency | |
# | |
gArmTokenSpaceGuid.PcdArmArchTimerFreqInHz|50000000 | |
gEmbeddedTokenSpaceGuid.PcdMetronomeTickPeriod|1000 | |
[PcdsPatchableInModule] | |
# Console Resolution (Full HD) | |
gEfiMdeModulePkgTokenSpaceGuid.PcdVideoHorizontalResolution|1920 | |
gEfiMdeModulePkgTokenSpaceGuid.PcdVideoVerticalResolution|1080 | |
################################################################################ | |
# | |
# Components Section - list of all EDK II Modules needed by this Platform | |
# | |
################################################################################ | |
[Components.common] | |
# | |
# PEI Phase modules | |
# | |
ArmPlatformPkg/PrePi/PeiMPCore.inf { | |
<LibraryClasses> | |
ArmPlatformGlobalVariableLib|ArmPlatformPkg/Library/ArmPlatformGlobalVariableLib/PrePi/PrePiArmPlatformGlobalVariableLib.inf | |
} | |
# | |
# DXE | |
# | |
MdeModulePkg/Core/Dxe/DxeMain.inf { | |
<LibraryClasses> | |
PcdLib|MdePkg/Library/BasePcdLibNull/BasePcdLibNull.inf | |
NULL|MdeModulePkg/Library/DxeCrc32GuidedSectionExtractLib/DxeCrc32GuidedSectionExtractLib.inf | |
} | |
# | |
# Architectural Protocols | |
# | |
ArmPkg/Drivers/CpuDxe/CpuDxe.inf | |
MdeModulePkg/Core/RuntimeDxe/RuntimeDxe.inf | |
MdeModulePkg/Universal/SecurityStubDxe/SecurityStubDxe.inf | |
MdeModulePkg/Universal/CapsuleRuntimeDxe/CapsuleRuntimeDxe.inf | |
MdeModulePkg/Universal/MonotonicCounterRuntimeDxe/MonotonicCounterRuntimeDxe.inf | |
EmbeddedPkg/ResetRuntimeDxe/ResetRuntimeDxe.inf | |
EmbeddedPkg/RealTimeClockRuntimeDxe/RealTimeClockRuntimeDxe.inf | |
EmbeddedPkg/MetronomeDxe/MetronomeDxe.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 | |
EmbeddedPkg/SerialDxe/SerialDxe.inf | |
MdeModulePkg/Universal/Variable/RuntimeDxe/VariableRuntimeDxe.inf | |
MdeModulePkg/Universal/FaultTolerantWriteDxe/FaultTolerantWriteDxe.inf | |
# | |
# ACPI Support | |
# | |
MdeModulePkg/Universal/Acpi/AcpiTableDxe/AcpiTableDxe.inf | |
ArmPlatformPkg/ArmJunoPkg/AcpiTables/AcpiTables.inf | |
MdeModulePkg/Universal/HiiDatabaseDxe/HiiDatabaseDxe.inf | |
ArmPkg/Drivers/ArmGic/ArmGicDxe.inf | |
ArmPlatformPkg/Drivers/NorFlashDxe/NorFlashDxe.inf | |
ArmPkg/Drivers/TimerDxe/TimerDxe.inf | |
ArmPkg/Drivers/GenericWatchdogDxe/GenericWatchdogDxe.inf | |
# | |
# Semi-hosting filesystem | |
# | |
ArmPkg/Filesystem/SemihostFs/SemihostFs.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 | |
# Networking stack | |
EmbeddedPkg/Drivers/Lan9118Dxe/Lan9118Dxe.inf | |
# | |
# Usb Support | |
# | |
MdeModulePkg/Bus/Pci/EhciDxe/EhciDxe.inf | |
MdeModulePkg/Bus/Usb/UsbBusDxe/UsbBusDxe.inf | |
MdeModulePkg/Bus/Usb/UsbKbDxe/UsbKbDxe.inf | |
MdeModulePkg/Bus/Usb/UsbMouseDxe/UsbMouseDxe.inf | |
MdeModulePkg/Bus/Usb/UsbMassStorageDxe/UsbMassStorageDxe.inf | |
# | |
# Juno platform driver | |
# | |
ArmPlatformPkg/ArmJunoPkg/Drivers/ArmJunoDxe/ArmJunoDxe.inf | |
# | |
# Bds | |
# | |
MdeModulePkg/Universal/DevicePathDxe/DevicePathDxe.inf | |
ArmPlatformPkg/Bds/Bds.inf | |