Introduce an http client utilizing EDK2 HTTP protocol, to allow fast image downloading from http/https servers. HTTP download speed is usually faster than tftp. The client is based on the same approach as tftp dynamic command, and uses the same UEFI Shell command line parameters. This makes it easy integrating http into existing UEFI Shell scripts. Note that to enable HTTP download, feature Pcd gEfiNetworkPkgTokenSpaceGuid.PcdAllowHttpConnections must be set to TRUE. BZ: https://bugzilla.tianocore.org/show_bug.cgi?id=2860 Signed-off-by: Vladimir Olovyannikov <vladimir.olovyannikov@broadcom.com> Cc: Samer El-Haj-Mahmoud <Samer.El-Haj-Mahmoud@arm.com> Cc: Laszlo Ersek <lersek@redhat.com> Cc: Zhichao Gao <zhichao.gao@intel.com> Cc: Maciej Rabeda <maciej.rabeda@linux.intel.com> Cc: Jiaxin Wu <jiaxin.wu@intel.com> Cc: Siyuan Fu <siyuan.fu@intel.com> Cc: Ray Ni <ray.ni@intel.com> Cc: Liming Gao <liming.gao@intel.com> Cc: Nd <nd@arm.com> Reviewed-by: Zhichao Gao <zhichao.gao@intel.com> Tested-by: Laszlo Ersek <lersek@redhat.com>
		
			
				
	
	
		
			139 lines
		
	
	
		
			7.4 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			139 lines
		
	
	
		
			7.4 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| ## @file ShellPkg.dec
 | |
| # This Package provides all definitions for EFI and UEFI Shell
 | |
| #
 | |
| # (C) Copyright 2013-2014 Hewlett-Packard Development Company, L.P.<BR>
 | |
| # Copyright (c) 2009 - 2018, Intel Corporation. All rights reserved.<BR>
 | |
| # Copyright (c) 2016 - 2018, ARM Limited. All rights reserved.<BR>
 | |
| #
 | |
| # SPDX-License-Identifier: BSD-2-Clause-Patent
 | |
| #
 | |
| ##
 | |
| 
 | |
| [Defines]
 | |
|   DEC_SPECIFICATION              = 0x00010005
 | |
|   PACKAGE_NAME                   = ShellPkg
 | |
|   PACKAGE_GUID                   = C1014BB7-4092-43D4-984F-0738EB424DBF
 | |
|   PACKAGE_VERSION                = 1.02
 | |
| 
 | |
| [Includes]
 | |
|   Include
 | |
| 
 | |
| [LibraryClasses]
 | |
|   ##  @libraryclass  Provides most Shell APIs. Only available for Shell applications
 | |
|   ShellLib|Include/Library/ShellLib.h
 | |
| 
 | |
|   ##  @libraryclass  Provides shell internal support Only available for shell internal commands
 | |
|   ShellCommandLib|Include/Library/ShellCommandLib.h
 | |
| 
 | |
|   ## @libraryclass   Allows for a shell application to have a C style entry point
 | |
|   ShellCEntryLib|Include/Library/ShellCEntryLib.h
 | |
| 
 | |
|   ## @libraryclass   Provides advanced parsing functions
 | |
|   HandleParsingLib|Include/Library/HandleParsingLib.h
 | |
| 
 | |
|   ## @libraryclass   provides BCFG command
 | |
|   BcfgCommandLib|Include/Library/BcfgCommandLib.h
 | |
| 
 | |
|   ## @libraryclass   provides the AcpiView command
 | |
|   AcpiViewCommandLib|Include/Library/AcpiViewCommandLib.h
 | |
| 
 | |
| [Guids]
 | |
|   gEfiShellEnvironment2ExtGuid    = {0xd2c18636, 0x40e5, 0x4eb5, {0xa3, 0x1b, 0x36, 0x69, 0x5f, 0xd4, 0x2c, 0x87}}
 | |
|   gEfiShellPkgTokenSpaceGuid      = {0x171e9188, 0x31d3, 0x40f5, {0xb1, 0x0c, 0x53, 0x9b, 0x2d, 0xb9, 0x40, 0xcd}}
 | |
|   gShellVariableGuid              = {0x158def5a, 0xf656, 0x419c, {0xb0, 0x27, 0x7a, 0x31, 0x92, 0xc0, 0x79, 0xd2}}
 | |
|   gShellMapGuid                   = {0x51271e13, 0x7de3, 0x43af, {0x8b, 0xc2, 0x71, 0xad, 0x3b, 0x82, 0x43, 0x25}}
 | |
|   gShellAliasGuid                 = {0x0053d9d6, 0x2659, 0x4599, {0xa2, 0x6b, 0xef, 0x45, 0x36, 0xe6, 0x31, 0xa9}}
 | |
|   gHandleParsingHiiGuid           = {0xb8969637, 0x81de, 0x43af, {0xbc, 0x9a, 0x24, 0xd9, 0x89, 0x13, 0xf2, 0xf6}}
 | |
|   gShellDebug1HiiGuid             = {0x25f200aa, 0xd3cb, 0x470a, {0xbf, 0x51, 0xe7, 0xd1, 0x62, 0xd2, 0x2e, 0x6f}}
 | |
|   gShellDriver1HiiGuid            = {0xaf0b742, 0x63ec, 0x45bd, {0x8d, 0xb6, 0x71, 0xad, 0x7f, 0x2f, 0xe8, 0xe8}}
 | |
|   gShellInstall1HiiGuid           = {0x7d574d54, 0xd364, 0x4d4a, {0x95, 0xe3, 0x49, 0x45, 0xdb, 0x7a, 0xd3, 0xee}}
 | |
|   gShellLevel1HiiGuid             = {0xdec5daa4, 0x6781, 0x4820, {0x9c, 0x63, 0xa7, 0xb0, 0xe4, 0xf1, 0xdb, 0x31}}
 | |
|   gShellLevel2HiiGuid             = {0xf95a7ccc, 0x4c55, 0x4426, {0xa7, 0xb4, 0xdc, 0x89, 0x61, 0x95, 0xb, 0xae}}
 | |
|   gShellLevel3HiiGuid             = {0x4344558d, 0x4ef9, 0x4725, {0xb1, 0xe4, 0x33, 0x76, 0xe8, 0xd6, 0x97, 0x4f}}
 | |
|   gShellNetwork1HiiGuid           = {0xf3d301bb, 0xf4a5, 0x45a8, {0xb0, 0xb7, 0xfa, 0x99, 0x9c, 0x62, 0x37, 0xae}}
 | |
|   gShellNetwork2HiiGuid           = {0x174b2b5, 0xf505, 0x4b12, {0xaa, 0x60, 0x59, 0xdf, 0xf8, 0xd6, 0xea, 0x37}}
 | |
|   gShellTftpHiiGuid               = {0x738a9314, 0x82c1, 0x4592, {0x8f, 0xf7, 0xc1, 0xbd, 0xf1, 0xb2, 0x0e, 0xd4}}
 | |
|   gShellHttpHiiGuid               = {0x390f84b3, 0x221c, 0x4d9e, {0xb5, 0x06, 0x6d, 0xb9, 0x42, 0x3e, 0x0a, 0x7e}}
 | |
|   gShellBcfgHiiGuid               = {0x5f5f605d, 0x1583, 0x4a2d, {0xa6, 0xb2, 0xeb, 0x12, 0xda, 0xb4, 0xa2, 0xb6}}
 | |
|   gShellAcpiViewHiiGuid           = {0xda8ccdf4, 0xed8f, 0x4ffc, {0xb5, 0xef, 0x2e, 0xf5, 0x5e, 0x24, 0x93, 0x2a}}
 | |
|   # FILE_GUID as defined in ShellPkg/Application/Shell/Shell.inf
 | |
|   gUefiShellFileGuid              = {0x7c04a583, 0x9e3e, 0x4f1c, {0xad, 0x65, 0xe0, 0x52, 0x68, 0xd0, 0xb4, 0xd1}}
 | |
| 
 | |
| [Protocols]
 | |
|   gEfiShellEnvironment2Guid           = {0x47c7b221, 0xc42a, 0x11d2, {0x8e, 0x57, 0x00, 0xa0, 0xc9, 0x69, 0x72, 0x3b}}
 | |
|   gEfiShellInterfaceGuid              = {0x47c7b223, 0xc42a, 0x11d2, {0x8e, 0x57, 0x00, 0xa0, 0xc9, 0x69, 0x72, 0x3b}}
 | |
| 
 | |
| [PcdsFeatureFlag]
 | |
|   ## This flag is used to control whether the shell includes NT32 platform Guids
 | |
|   #  and thereby prevents dependancy on that Pkg
 | |
|   gEfiShellPkgTokenSpaceGuid.PcdShellIncludeNtGuids|TRUE|BOOLEAN|0x0000000E
 | |
| 
 | |
|   ## This flag is used to control HII required by the shell
 | |
|   gEfiShellPkgTokenSpaceGuid.PcdShellRequireHiiPlatform|TRUE|BOOLEAN|0x00000003
 | |
| 
 | |
|   ## This flag is used to control HII required by the shell
 | |
|   gEfiShellPkgTokenSpaceGuid.PcdShellSupportFrameworkHii|FALSE|BOOLEAN|0x00000004
 | |
| 
 | |
|   ## This flag forces the shell to present a user console.  Allows for earlier debugging of platforms.
 | |
|   gEfiShellPkgTokenSpaceGuid.PcdShellForceConsole|FALSE|BOOLEAN|0x0000000F
 | |
| 
 | |
| [PcdsFixedAtBuild]
 | |
|   ## This flag is used to control initialization of the shell library
 | |
|   #  This should be FALSE for compiling the shell application itself only.
 | |
|   #  This should be FALSE for compiling the dynamic command drivers.
 | |
|   gEfiShellPkgTokenSpaceGuid.PcdShellLibAutoInitialize|TRUE|BOOLEAN|0x00000005
 | |
| 
 | |
|   ## This is the max buffer for ShellLib and internal Shell printings.
 | |
|   gEfiShellPkgTokenSpaceGuid.PcdShellPrintBufferSize|16000|UINT16|0x0000000C
 | |
| 
 | |
|   ## This flag is used to control the commands available in the shell
 | |
|   gEfiShellPkgTokenSpaceGuid.PcdShellSupportLevel|3|UINT8|0x00000001
 | |
| 
 | |
|   ## This flag is used to control the profiles available in the shell
 | |
|   #  don't forget to update the text file if you change this.
 | |
|   #  bit 0 = Drivers1
 | |
|   #  bit 1 = Debug1
 | |
|   #  bit 2 = Install1
 | |
|   #  bit 3 = Network1
 | |
|   #  bit 4 = Network2
 | |
|   gEfiShellPkgTokenSpaceGuid.PcdShellProfileMask|0xFF|UINT8|0x0000000D
 | |
| 
 | |
|   ## This is the character count for allocation for consistent mappings
 | |
|   gEfiShellPkgTokenSpaceGuid.PcdShellMapNameLength|50|UINT8|0x00000009
 | |
| 
 | |
|   ## This determines how many bytes are read out of files at a time for file operations (type, copy, etc...)
 | |
|   gEfiShellPkgTokenSpaceGuid.PcdShellFileOperationSize|0x1000|UINT32|0x0000000A
 | |
| 
 | |
|   ## This determines the max count of history commands
 | |
|   gEfiShellPkgTokenSpaceGuid.PcdShellMaxHistoryCommandCount|0x0020|UINT16|0x00000014
 | |
| 
 | |
| [PcdsFixedAtBuild, PcdsPatchableInModule, PcdsDynamic, PcdsDynamicEx]
 | |
|   ## This flag is used to control the protocols produced by the shell
 | |
|   #  If TRUE the shell will produce EFI_SHELL_ENVIRONMENT2 and EFI_SHELL_INTERFACE
 | |
|   gEfiShellPkgTokenSpaceGuid.PcdShellSupportOldProtocols|FALSE|BOOLEAN|0x00000002
 | |
| 
 | |
|   ## this flag determines whether Page Break (-b) defaults to on or off in the shell
 | |
|   gEfiShellPkgTokenSpaceGuid.PcdShellPageBreakDefault|FALSE|BOOLEAN|0x00000006
 | |
| 
 | |
|   ## this flag determines whether insert mode for typing is default (FALSE means typeover)
 | |
|   gEfiShellPkgTokenSpaceGuid.PcdShellInsertModeDefault|TRUE|BOOLEAN|0x00000007
 | |
| 
 | |
|   ## this flag determines the default number of screens kept for history log.
 | |
|   #  the spec defines 3 as the minimum
 | |
|   gEfiShellPkgTokenSpaceGuid.PcdShellScreenLogCount|3|UINT8|0x00000008
 | |
| 
 | |
|   ## Unicode string of the shell supplier
 | |
|   gEfiShellPkgTokenSpaceGuid.PcdShellSupplier|L"EDK II"|VOID*|0x00000010
 | |
| 
 | |
|   ## Do extended decode of USB for determining media type
 | |
|   gEfiShellPkgTokenSpaceGuid.PcdUsbExtendedDecode|TRUE|BOOLEAN|0x00000011
 | |
| 
 | |
|   ## Do iSCSI decode for map names.
 | |
|   # This is disabled by default due to the length of generated strings
 | |
|   gEfiShellPkgTokenSpaceGuid.PcdShellDecodeIScsiMapNames|FALSE|BOOLEAN|0x00000012
 | |
| 
 | |
|   ## Controls Extended decode for Vendor device path nodes for map names.
 | |
|   # Up to this many bytes of vendor specific data will be used. Default is 0
 | |
|   # (disabled).
 | |
|   gEfiShellPkgTokenSpaceGuid.PcdShellVendorExtendedDecode|0|UINT32|0x00000013
 |