mirror of
				https://git.proxmox.com/git/mirror_edk2
				synced 2025-11-03 22:54:50 +00:00 
			
		
		
		
	https://bugzilla.tianocore.org/show_bug.cgi?id=1373 Replace BSD 2-Clause License with BSD+Patent License. This change is based on the following emails: https://lists.01.org/pipermail/edk2-devel/2019-February/036260.html https://lists.01.org/pipermail/edk2-devel/2018-October/030385.html RFCs with detailed process for the license change: V3: https://lists.01.org/pipermail/edk2-devel/2019-March/038116.html V2: https://lists.01.org/pipermail/edk2-devel/2019-March/037669.html V1: https://lists.01.org/pipermail/edk2-devel/2019-March/037500.html Contributed-under: TianoCore Contribution Agreement 1.1 Signed-off-by: Michael D Kinney <michael.d.kinney@intel.com> Reviewed-by: Hao Wu <hao.a.wu@intel.com> Reviewed-by: Jian J Wang <jian.j.wang@intel.com>
		
			
				
	
	
		
			110 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			INI
		
	
	
	
	
	
			
		
		
	
	
			110 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			INI
		
	
	
	
	
	
## @file
 | 
						|
#  This driver produces UEFI PLATFORM_DRIVER_OVERRIDE_PROTOCOL if this protocol doesn't exist.
 | 
						|
#  It doesn't install again if this protocol exists.
 | 
						|
#  It only implements one interface GetDriver of PLATFORM_DRIVER_OVERRIDE_PROTOCOL protocol
 | 
						|
#  and doesn't support other two interfaces GetDriverPath, DriverLoaded.
 | 
						|
#
 | 
						|
#  This driver also offers an UI interface in device manager to let user configure
 | 
						|
#  platform override protocol to override the default algorithm for matching
 | 
						|
#  drivers to controllers.
 | 
						|
#
 | 
						|
#  The main flow:
 | 
						|
#  1. It dynamicly locate all controller device path.
 | 
						|
#  2. It dynamicly locate all drivers which support binding protocol.
 | 
						|
#  3. It export and dynamicly update two menu to let user select the
 | 
						|
#     mapping between drivers to controllers.
 | 
						|
#  4. It save all the mapping info in NV variables for the following boot,
 | 
						|
#     which will be consumed by GetDriver API of the produced the platform override protocol.
 | 
						|
#
 | 
						|
# Caution: This module is a sample implementation for the test purpose.
 | 
						|
#
 | 
						|
# Copyright (c) 2007 - 2018, Intel Corporation. All rights reserved.<BR>
 | 
						|
#
 | 
						|
#  SPDX-License-Identifier: BSD-2-Clause-Patent
 | 
						|
#
 | 
						|
##
 | 
						|
 | 
						|
[Defines]
 | 
						|
  INF_VERSION                    = 0x00010005
 | 
						|
  BASE_NAME                      = PlatDriOverrideDxe
 | 
						|
  MODULE_UNI_FILE                = PlatDriOverrideDxe.uni
 | 
						|
  FILE_GUID                      = 35034CE2-A6E5-4fb4-BABE-A0156E9B2549
 | 
						|
  MODULE_TYPE                    = DXE_DRIVER
 | 
						|
  VERSION_STRING                 = 1.0
 | 
						|
  ENTRY_POINT                    = PlatDriOverrideDxeInit
 | 
						|
  UNLOAD_IMAGE                   = PlatDriOverrideDxeUnload
 | 
						|
 | 
						|
#
 | 
						|
# The following information is for reference only and not required by the build tools.
 | 
						|
#
 | 
						|
#  VALID_ARCHITECTURES           = IA32 X64 EBC
 | 
						|
#
 | 
						|
 | 
						|
[Sources]
 | 
						|
  VfrStrings.uni
 | 
						|
  Vfr.vfr
 | 
						|
  PlatDriOverrideDxe.c
 | 
						|
  PlatOverMngr.h
 | 
						|
  PlatDriOverrideLib.c
 | 
						|
  InternalPlatDriOverrideDxe.h
 | 
						|
 | 
						|
[Packages]
 | 
						|
  MdePkg/MdePkg.dec
 | 
						|
  MdeModulePkg/MdeModulePkg.dec
 | 
						|
 | 
						|
[LibraryClasses]
 | 
						|
  BaseLib
 | 
						|
  DebugLib
 | 
						|
  UefiLib
 | 
						|
  UefiDriverEntryPoint
 | 
						|
  UefiBootServicesTableLib
 | 
						|
  HiiLib
 | 
						|
  BaseMemoryLib
 | 
						|
  MemoryAllocationLib
 | 
						|
  DevicePathLib
 | 
						|
  DxeServicesTableLib
 | 
						|
  UefiRuntimeServicesTableLib
 | 
						|
  PrintLib
 | 
						|
 | 
						|
[Guids]
 | 
						|
  #
 | 
						|
  # This GUID C Name is not required for build since it is from UefiLib and not directly used by this module source.
 | 
						|
  #  gEfiGlobalVariableGuid                     ## SOMETIMES_CONSUMES   ## Variable:L"PlatformLang" # this variable specifies the platform supported language string (RFC 4646 format)
 | 
						|
  #  gEfiGlobalVariableGuid                     ## SOMETIMES_CONSUMES   ## Variable:L"Lang" # this variable specifies the platform supported language string (ISO 639-2 format)
 | 
						|
  #
 | 
						|
  # There could be more than one variables, from PlatDriOver, PlatDriOver1, PlatDriOver2,...
 | 
						|
  #  gEfiCallerIdGuid                           ## Private  ## Variable:L"PlatDriOver"
 | 
						|
  #
 | 
						|
  gEfiIfrTianoGuid                              ## SOMETIMES_PRODUCES   ## UNDEFINED
 | 
						|
  ## SOMETIMES_CONSUMES ## GUID # HiiIsConfigHdrMatch Data
 | 
						|
  ## SOMETIMES_PRODUCES ## GUID # HiiGetBrowserData Data
 | 
						|
  ## SOMETIMES_CONSUMES ## GUID # HiiSetBrowserData Data
 | 
						|
  ## SOMETIMES_PRODUCES ## GUID # HiiConstructConfigHdr Data
 | 
						|
  ## CONSUMES           ## HII
 | 
						|
  gPlatformOverridesManagerGuid
 | 
						|
 | 
						|
[Protocols]
 | 
						|
  gEfiComponentName2ProtocolGuid                ## SOMETIMES_CONSUMES # Get Driver Name if ComponentName2Protocol exists
 | 
						|
  gEfiComponentNameProtocolGuid                 ## SOMETIMES_CONSUMES # Get Driver Name if ComponentNameProtocol exists and ComponentName2Protocol doesn't exist
 | 
						|
  gEfiFirmwareVolume2ProtocolGuid               ## SOMETIMES_CONSUMES # Get Driver Name from EFI UI section if ComponentName2Protocol and ComponentNameProtocol don't exist
 | 
						|
  gEfiPciIoProtocolGuid                         ## SOMETIMES_CONSUMES # Find the PCI device if PciIo protocol is installed
 | 
						|
  gEfiBusSpecificDriverOverrideProtocolGuid     ## SOMETIMES_CONSUMES # Check whether the PCI device contains one or more efi drivers in its option rom by this protocol
 | 
						|
 | 
						|
  gEfiDriverBindingProtocolGuid                 ## SOMETIMES_CONSUMES
 | 
						|
  gEfiLoadedImageProtocolGuid                   ## SOMETIMES_CONSUMES
 | 
						|
  gEfiLoadedImageDevicePathProtocolGuid         ## SOMETIMES_CONSUMES # Show the drivers in the second page that support DriverBindingProtocol, LoadedImageProtocol and LoadedImageDevicePathProtocol
 | 
						|
 | 
						|
  gEfiFormBrowser2ProtocolGuid                  ## CONSUMES
 | 
						|
  gEfiHiiConfigRoutingProtocolGuid              ## CONSUMES
 | 
						|
  gEfiHiiConfigAccessProtocolGuid               ## PRODUCES
 | 
						|
  gEfiPlatformDriverOverrideProtocolGuid        ## PRODUCES
 | 
						|
  ## PRODUCES
 | 
						|
  ## SOMETIMES_CONSUMES # Show the controller device in the first page that support DevicePathProtocol
 | 
						|
  gEfiDevicePathProtocolGuid
 | 
						|
 | 
						|
[Depex]
 | 
						|
  gEfiFormBrowser2ProtocolGuid AND gEfiHiiConfigRoutingProtocolGuid
 | 
						|
 | 
						|
[UserExtensions.TianoCore."ExtraFiles"]
 | 
						|
  PlatDriOverrideDxeExtra.uni
 |