UEFI drivers should not depend on TimerLib. They should use BS.Stall() instead. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Olivier Martin <olivier.martin@arm.com> Reviewed-by: Ronald Cron <Ronald.Cron@arm.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@17343 6f19259b-4bc3-4df7-8a09-765794883524
		
			
				
	
	
		
			294 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			294 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| #/** @file
 | |
| # Embedded Package
 | |
| #
 | |
| #
 | |
| # Copyright (c) 2007, Intel Corporation. All rights reserved.<BR>
 | |
| # Copyright (c) 2012-2015, ARM Ltd. All rights reserved.<BR>
 | |
| #
 | |
| #    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                  = Embedded
 | |
|   PLATFORM_GUID                  = 8DBB580B-CF89-4D57-95C6-DFE96C44686E
 | |
|   PLATFORM_VERSION               = 0.1
 | |
|   DSC_SPECIFICATION              = 0x00010005
 | |
|   OUTPUT_DIRECTORY               = Build/Embedded
 | |
|   SUPPORTED_ARCHITECTURES        = IA32|X64|IPF|ARM|AARCH64
 | |
|   BUILD_TARGETS                  = DEBUG|RELEASE
 | |
|   SKUID_IDENTIFIER               = DEFAULT
 | |
|   FLASH_DEFINITION               = EmbeddedPkg/EmbeddedPkg.fdf
 | |
| 
 | |
| 
 | |
| ################################################################################
 | |
| #
 | |
| # SKU Identification section - list of all SKU IDs supported by this
 | |
| #                              Platform.
 | |
| #
 | |
| ################################################################################
 | |
| [SkuIds]
 | |
|   0|DEFAULT              # The entry: 0|DEFAULT is reserved and always required.
 | |
| 
 | |
| ################################################################################
 | |
| #
 | |
| # Library Class section - list of all Library Classes needed by this Platform.
 | |
| #
 | |
| ################################################################################
 | |
| [LibraryClasses.common]
 | |
| #  DebugLib|MdePkg/Library/UefiDebugLibConOut/UefiDebugLibConOut.inf
 | |
|   DebugLib|MdePkg/Library/BaseDebugLibNull/BaseDebugLibNull.inf
 | |
| 
 | |
| 
 | |
|   BaseLib|MdePkg/Library/BaseLib/BaseLib.inf
 | |
|   BaseMemoryLib|MdePkg/Library/BaseMemoryLib/BaseMemoryLib.inf
 | |
|   PciLib|MdePkg/Library/BasePciLibCf8/BasePciLibCf8.inf
 | |
|   PerformanceLib|MdePkg/Library/BasePerformanceLibNull/BasePerformanceLibNull.inf
 | |
|   PrintLib|MdePkg/Library/BasePrintLib/BasePrintLib.inf
 | |
|   UefiDecompressLib|MdePkg/Library/BaseUefiDecompressLib/BaseUefiDecompressLib.inf
 | |
|   EfiFileLib|EmbeddedPkg/Library/EfiFileLib/EfiFileLib.inf
 | |
| 
 | |
|   ReportStatusCodeLib|IntelFrameworkModulePkg/Library/PeiDxeDebugLibReportStatusCode/PeiDxeDebugLibReportStatusCode.inf
 | |
| 
 | |
|   PeCoffGetEntryPointLib|MdePkg/Library/BasePeCoffGetEntryPointLib/BasePeCoffGetEntryPointLib.inf
 | |
|   PeCoffLib|MdePkg/Library/BasePeCoffLib/BasePeCoffLib.inf
 | |
|   PeCoffExtraActionLib|MdePkg/Library/BasePeCoffExtraActionLibNull/BasePeCoffExtraActionLibNull.inf
 | |
|   CacheMaintenanceLib|MdePkg/Library/BaseCacheMaintenanceLib/BaseCacheMaintenanceLib.inf
 | |
|   PrePiLib|EmbeddedPkg/Library/PrePiLib/PrePiLib.inf
 | |
| 
 | |
|   SerialPortLib|MdePkg/Library/BaseSerialPortLibNull/BaseSerialPortLibNull.inf
 | |
|   SerialPortExtLib|EmbeddedPkg/Library/TemplateSerialPortExtLib/TemplateSerialPortExtLib.inf
 | |
|   RealTimeClockLib|EmbeddedPkg/Library/TemplateRealTimeClockLib/TemplateRealTimeClockLib.inf
 | |
|   EfiResetSystemLib|EmbeddedPkg/Library/TemplateResetSystemLib/TemplateResetSystemLib.inf
 | |
|   GdbSerialLib|EmbeddedPkg/Library/GdbSerialLib/GdbSerialLib.inf
 | |
| 
 | |
| 
 | |
|  #
 | |
|  # Need to change this for IPF
 | |
|  #
 | |
|   IoLib|MdePkg/Library/BaseIoLibIntrinsic/BaseIoLibIntrinsic.inf
 | |
| 
 | |
|   MemoryAllocationLib|MdePkg/Library/UefiMemoryAllocationLib/UefiMemoryAllocationLib.inf
 | |
|   UefiLib|MdePkg/Library/UefiLib/UefiLib.inf
 | |
|   HobLib|MdePkg/Library/DxeHobLib/DxeHobLib.inf
 | |
|   UefiRuntimeServicesTableLib|MdePkg/Library/UefiRuntimeServicesTableLib/UefiRuntimeServicesTableLib.inf
 | |
|   DevicePathLib|MdePkg/Library/UefiDevicePathLib/UefiDevicePathLib.inf
 | |
|   UefiBootServicesTableLib|MdePkg/Library/UefiBootServicesTableLib/UefiBootServicesTableLib.inf
 | |
|   ExtractGuidedSectionLib|MdePkg/Library/DxeExtractGuidedSectionLib/DxeExtractGuidedSectionLib.inf
 | |
| 
 | |
|   DxeServicesTableLib|MdePkg/Library/DxeServicesTableLib/DxeServicesTableLib.inf
 | |
|   UefiDriverEntryPoint|MdePkg/Library/UefiDriverEntryPoint/UefiDriverEntryPoint.inf
 | |
|   UefiApplicationEntryPoint|MdePkg/Library/UefiApplicationEntryPoint/UefiApplicationEntryPoint.inf
 | |
| 
 | |
|   PcdLib|MdePkg/Library/BasePcdLibNull/BasePcdLibNull.inf
 | |
|   EblCmdLib|EmbeddedPkg/Library/EblCmdLibNull/EblCmdLibNull.inf
 | |
| 
 | |
|   EblNetworkLib|EmbeddedPkg/Library/EblNetworkLib/EblNetworkLib.inf
 | |
| 
 | |
|   AcpiLib|EmbeddedPkg/Library/AcpiLib/AcpiLib.inf
 | |
|   FdtLib|EmbeddedPkg/Library/FdtLib/FdtLib.inf
 | |
| 
 | |
|   # Shell libraries
 | |
|   ShellLib|ShellPkg/Library/UefiShellLib/UefiShellLib.inf
 | |
|   FileHandleLib|MdePkg/Library/UefiFileHandleLib/UefiFileHandleLib.inf
 | |
|   SortLib|MdeModulePkg/Library/UefiSortLib/UefiSortLib.inf
 | |
| 
 | |
|   # Networking Requirements
 | |
|   NetLib|MdeModulePkg/Library/DxeNetLib/DxeNetLib.inf
 | |
|   HiiLib|MdeModulePkg/Library/UefiHiiLib/UefiHiiLib.inf
 | |
|   UefiHiiServicesLib|MdeModulePkg/Library/UefiHiiServicesLib/UefiHiiServicesLib.inf
 | |
| 
 | |
| [LibraryClasses.common.DXE_DRIVER]
 | |
|   PcdLib|MdePkg/Library/DxePcdLib/DxePcdLib.inf
 | |
|   ReportStatusCodeLib|IntelFrameworkModulePkg/Library/DxeReportStatusCodeLibFramework/DxeReportStatusCodeLib.inf
 | |
| 
 | |
| 
 | |
| [LibraryClasses.common.UEFI_APPLICATION]
 | |
|   PcdLib|MdePkg/Library/DxePcdLib/DxePcdLib.inf
 | |
|   ReportStatusCodeLib|IntelFrameworkModulePkg/Library/DxeReportStatusCodeLibFramework/DxeReportStatusCodeLib.inf
 | |
| 
 | |
| [LibraryClasses.common.UEFI_DRIVER]
 | |
|   PcdLib|MdePkg/Library/DxePcdLib/DxePcdLib.inf
 | |
|   ReportStatusCodeLib|IntelFrameworkModulePkg/Library/DxeReportStatusCodeLibFramework/DxeReportStatusCodeLib.inf
 | |
| 
 | |
| [LibraryClasses.common.SEC]
 | |
|   ExtractGuidedSectionLib|EmbeddedPkg/Library/PrePiExtractGuidedSectionLib/PrePiExtractGuidedSectionLib.inf
 | |
| 
 | |
| [LibraryClasses.ARM, LibraryClasses.AARCH64]
 | |
|   ArmGicLib|ArmPkg/Drivers/ArmGic/ArmGicLib.inf
 | |
|   ArmSmcLib|ArmPkg/Library/ArmSmcLib/ArmSmcLib.inf
 | |
|   BdsLib|ArmPkg/Library/BdsLib/BdsLib.inf
 | |
|   SemihostLib|ArmPkg/Library/SemihostLib/SemihostLib.inf
 | |
|   NULL|ArmPkg/Library/CompilerIntrinsicsLib/CompilerIntrinsicsLib.inf
 | |
| 
 | |
|   # Add support for GCC stack protector
 | |
|   NULL|MdePkg/Library/BaseStackCheckLib/BaseStackCheckLib.inf
 | |
| 
 | |
| [LibraryClasses.ARM]
 | |
|   ArmLib|ArmPkg/Library/ArmLib/ArmV7/ArmV7Lib.inf
 | |
| 
 | |
| [LibraryClasses.AARCH64]
 | |
|   ArmLib|ArmPkg/Library/ArmLib/AArch64/AArch64Lib.inf
 | |
| 
 | |
| 
 | |
| ################################################################################
 | |
| #
 | |
| # Pcd Section - list of all PCD Entries defined by this Platform
 | |
| #
 | |
| ################################################################################
 | |
| 
 | |
| [PcdsFeatureFlag.common]
 | |
|   gEfiMdePkgTokenSpaceGuid.PcdComponentNameDisable|FALSE
 | |
|   gEfiMdePkgTokenSpaceGuid.PcdDriverDiagnosticsDisable|FALSE
 | |
|   gEfiMdePkgTokenSpaceGuid.PcdComponentName2Disable|FALSE
 | |
|   gEfiMdePkgTokenSpaceGuid.PcdDriverDiagnostics2Disable|FALSE
 | |
| 
 | |
|   #
 | |
|   # Control what commands are supported from the UI
 | |
|   # Turn these on and off to add features or save size
 | |
|   #
 | |
|   gEmbeddedTokenSpaceGuid.PcdEmbeddedMacBoot|TRUE
 | |
|   gEmbeddedTokenSpaceGuid.PcdEmbeddedDirCmd|TRUE
 | |
|   gEmbeddedTokenSpaceGuid.PcdEmbeddedHobCmd|TRUE
 | |
|   gEmbeddedTokenSpaceGuid.PcdEmbeddedHwDebugCmd|TRUE
 | |
|   gEmbeddedTokenSpaceGuid.PcdEmbeddedIoEnable|FALSE
 | |
|   gEmbeddedTokenSpaceGuid.PcdEmbeddedScriptCmd|FALSE
 | |
|   gEmbeddedTokenSpaceGuid.PcdEmbeddedPciDebugCmd|TRUE
 | |
| 
 | |
|   gEmbeddedTokenSpaceGuid.PcdPrePiProduceMemoryTypeInformationHob|FALSE
 | |
| 
 | |
| 
 | |
| [PcdsFixedAtBuild.common]
 | |
|   gEfiMdePkgTokenSpaceGuid.PcdMaximumUnicodeStringLength|1000000
 | |
|   gEfiMdePkgTokenSpaceGuid.PcdMaximumAsciiStringLength|1000000
 | |
|   gEfiMdePkgTokenSpaceGuid.PcdMaximumLinkedListLength|1000000
 | |
|   gEfiMdePkgTokenSpaceGuid.PcdSpinLockTimeout|10000000
 | |
|   gEfiMdePkgTokenSpaceGuid.PcdDebugPropertyMask|0x0f
 | |
|   gEfiMdePkgTokenSpaceGuid.PcdDebugPrintErrorLevel|0x80000000
 | |
|   gEfiMdePkgTokenSpaceGuid.PcdReportStatusCodePropertyMask|0x06
 | |
|   gEfiMdePkgTokenSpaceGuid.PcdDebugClearMemoryValue|0xAF
 | |
|   gEfiMdePkgTokenSpaceGuid.PcdPerformanceLibraryPropertyMask|0
 | |
|   gEfiMdePkgTokenSpaceGuid.PcdPostCodePropertyMask|0
 | |
|   gEfiMdePkgTokenSpaceGuid.PcdPciExpressBaseAddress|0xE0000000
 | |
|   gEfiMdePkgTokenSpaceGuid.PcdFSBClock|200000000
 | |
|   gEfiMdePkgTokenSpaceGuid.PcdUefiLibMaxPrintBufferSize|320
 | |
|   gEfiMdePkgTokenSpaceGuid.PcdDebugPrintErrorLevel|0x80000000
 | |
|   gEfiMdePkgTokenSpaceGuid.PcdPciExpressBaseAddress|0xE0000000
 | |
|   gEfiMdePkgTokenSpaceGuid.PcdFSBClock|200000000
 | |
|   gEmbeddedTokenSpaceGuid.PcdEmbeddedAutomaticBootCommand|L""
 | |
|   gEmbeddedTokenSpaceGuid.PcdEmbeddedDefaultTextColor|0x07
 | |
|   gEmbeddedTokenSpaceGuid.PcdEmbeddedMemVariableStoreSize|0x10000
 | |
| 
 | |
|   gEmbeddedTokenSpaceGuid.PcdPrePiHobBase|0
 | |
|   gEmbeddedTokenSpaceGuid.PcdPrePiStackBase|0
 | |
|   gEmbeddedTokenSpaceGuid.PcdPrePiStackSize|0
 | |
| 
 | |
| #
 | |
| # Optinal feature to help prevent EFI memory map fragments
 | |
| # Turned on and off via: PcdPrePiProduceMemoryTypeInformationHob
 | |
| # Values are in EFI Pages (4K). DXE Core will make sure that
 | |
| # at least this much of each type of memory can be allocated
 | |
| # from a single memory range. This way you only end up with
 | |
| # maximum of two fragements for each type in the memory map
 | |
| # (the memory used, and the free memory that was prereserved
 | |
| # but not used).
 | |
| #
 | |
|   gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiACPIReclaimMemory|0
 | |
|   gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiACPIMemoryNVS|0
 | |
|   gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiReservedMemoryType|0
 | |
|   gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiRuntimeServicesData|0
 | |
|   gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiRuntimeServicesCode|0
 | |
|   gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiBootServicesCode|0
 | |
|   gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiBootServicesData|0
 | |
|   gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiLoaderCode|0
 | |
|   gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiLoaderData|0
 | |
| 
 | |
| #
 | |
| # Timer config for this platform
 | |
| #
 | |
|   gEmbeddedTokenSpaceGuid.PcdTimerBaseAddress|0x3c700000
 | |
|   gEmbeddedTokenSpaceGuid.PcdTimerVector|7
 | |
|   gEmbeddedTokenSpaceGuid.PcdTimerPeriod|100000
 | |
| 
 | |
| [PcdsFixedAtBuild.IPF]
 | |
|   gEfiMdePkgTokenSpaceGuid.PcdIoBlockBaseAddressForIpf|0x0ffffc000000
 | |
| 
 | |
| #
 | |
| # This makes it so you can source level debug with NT32. VC++ debugger limitiation!
 | |
| #
 | |
| #[BuildOptions]
 | |
| #  DEBUG_*_IA32_DLINK_FLAGS = /EXPORT:InitializeDriver=$(IMAGE_ENTRY_POINT) /ALIGN:4096 /SUBSYSTEM:CONSOLE
 | |
| #  RELEASE_*_IA32_DLINK_FLAGS = /ALIGN:4096
 | |
| #  *_*_IA32_CC_FLAGS = /D EFI_SPECIFICATION_VERSION=0x0002000A /D TIANO_RELEASE_VERSION=0x00080006
 | |
| 
 | |
| [BuildOptions]
 | |
|   RVCT:*_*_ARM_PLATFORM_FLAGS == --cpu=7-A.security
 | |
| 
 | |
| 
 | |
| ################################################################################
 | |
| #
 | |
| # Components Section - list of all Modules needed by this Platform
 | |
| #
 | |
| ################################################################################
 | |
| [Components.common]
 | |
|   EmbeddedPkg/Library/EblAddExternalCommandLib/EblAddExternalCommandLib.inf
 | |
|   EmbeddedPkg/Library/EblCmdLibNull/EblCmdLibNull.inf
 | |
|   EmbeddedPkg/Library/EfiFileLib/EfiFileLib.inf
 | |
|   EmbeddedPkg/Library/GdbSerialDebugPortLib/GdbSerialDebugPortLib.inf
 | |
|   EmbeddedPkg/Library/GdbSerialLib/GdbSerialLib.inf
 | |
|   EmbeddedPkg/Library/PrePiExtractGuidedSectionLib/PrePiExtractGuidedSectionLib.inf
 | |
|   EmbeddedPkg/Library/PrePiLib/PrePiLib.inf
 | |
|   MdePkg/Library/BaseSerialPortLibNull/BaseSerialPortLibNull.inf
 | |
|   EmbeddedPkg/Library/SerialPortExtLibNull/SerialPortExtLibNull.inf
 | |
|   EmbeddedPkg/Library/TemplateResetSystemLib/TemplateResetSystemLib.inf
 | |
|   EmbeddedPkg/Library/TemplateRealTimeClockLib/TemplateRealTimeClockLib.inf
 | |
|   EmbeddedPkg/Library/LzmaHobCustomDecompressLib/LzmaHobCustomDecompressLib.inf
 | |
|   EmbeddedPkg/Library/NullDmaLib/NullDmaLib.inf
 | |
| 
 | |
|   EmbeddedPkg/Ebl/Ebl.inf
 | |
| ####  EmbeddedPkg/EblExternCmd/EblExternCmd.inf
 | |
|   EmbeddedPkg/EmbeddedMonotonicCounter/EmbeddedMonotonicCounter.inf
 | |
|   EmbeddedPkg/RealTimeClockRuntimeDxe/RealTimeClockRuntimeDxe.inf
 | |
|   EmbeddedPkg/ResetRuntimeDxe/ResetRuntimeDxe.inf
 | |
|   EmbeddedPkg/SerialDxe/SerialDxe.inf
 | |
|   EmbeddedPkg/SimpleTextInOutSerial/SimpleTextInOutSerial.inf
 | |
|   EmbeddedPkg/MetronomeDxe/MetronomeDxe.inf {
 | |
|     <LibraryClasses>
 | |
|       TimerLib|MdePkg/Library/BaseTimerLibNullTemplate/BaseTimerLibNullTemplate.inf
 | |
|   }
 | |
| 
 | |
|   EmbeddedPkg/Universal/MmcDxe/MmcDxe.inf
 | |
| 
 | |
|   # FDT installation
 | |
|   EmbeddedPkg/Drivers/FdtPlatformDxe/FdtPlatformDxe.inf {
 | |
|     <LibraryClasses>
 | |
|       # It depends on BdsLib that depends on TimerLib
 | |
|       TimerLib|MdePkg/Library/BaseTimerLibNullTemplate/BaseTimerLibNullTemplate.inf
 | |
|   }
 | |
| 
 | |
|   EmbeddedPkg/Application/AndroidFastboot/AndroidFastbootApp.inf {
 | |
|     <LibraryClasses>
 | |
|       # It depends on BdsLib that depends on TimerLib
 | |
|       TimerLib|MdePkg/Library/BaseTimerLibNullTemplate/BaseTimerLibNullTemplate.inf
 | |
|   }
 | |
|   EmbeddedPkg/Drivers/AndroidFastbootTransportUsbDxe/FastbootTransportUsbDxe.inf
 | |
|   EmbeddedPkg/Drivers/AndroidFastbootTransportTcpDxe/FastbootTransportTcpDxe.inf
 | |
| 
 | |
|   # Drivers
 | |
|   EmbeddedPkg/Drivers/Isp1761UsbDxe/Isp1761UsbDxe.inf
 | |
|   EmbeddedPkg/Drivers/Lan9118Dxe/Lan9118Dxe.inf
 | |
| 
 | |
| [Components.IA32, Components.X64, Components.IPF, Components.ARM]
 | |
|   EmbeddedPkg/GdbStub/GdbStub.inf
 |