git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@7494 6f19259b-4bc3-4df7-8a09-765794883524
		
			
				
	
	
		
			544 lines
		
	
	
		
			18 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			544 lines
		
	
	
		
			18 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @file
 | |
|   Public include file for the HII Library
 | |
| 
 | |
|   Copyright (c) 2007 - 2008, Intel Corporation                                                         
 | |
|   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.             
 | |
| 
 | |
| **/
 | |
| 
 | |
| #ifndef __HII_LIB_H__
 | |
| #define __HII_LIB_H__
 | |
| 
 | |
| 
 | |
| /**
 | |
|   Assemble EFI_HII_PACKAGE_LIST according to the passed in packages.
 | |
| 
 | |
|   If GuidId is NULL, then ASSERT.
 | |
|   If not enough resource to complete the operation, then ASSERT.
 | |
| 
 | |
|   @param  NumberOfPackages       Number of packages.
 | |
|   @param  GuidId                 Package GUID.
 | |
|   @param  ...                    Variable argument list for packages to be assembled.
 | |
| 
 | |
|   @return Pointer of EFI_HII_PACKAGE_LIST_HEADER.
 | |
| 
 | |
| **/
 | |
| EFI_HII_PACKAGE_LIST_HEADER *
 | |
| EFIAPI
 | |
| HiiLibPreparePackageList (
 | |
|   IN UINTN                    NumberOfPackages,
 | |
|   IN CONST EFI_GUID                 *GuidId,
 | |
|   ...
 | |
|   )
 | |
| ;
 | |
| 
 | |
| /**
 | |
|   This function allocates pool for an EFI_HII_PACKAGE_LIST structure
 | |
|   with additional space that is big enough to host all packages described by the variable 
 | |
|   argument list of package pointers.  The allocated structure is initialized using NumberOfPackages, 
 | |
|   GuidId,  and the variable length argument list of package pointers.
 | |
| 
 | |
|   Then, EFI_HII_PACKAGE_LIST will be register to the default System HII Database. The
 | |
|   Handle to the newly registered Package List is returned throught HiiHandle.
 | |
| 
 | |
|   If HiiHandle is NULL, then ASSERT.
 | |
| 
 | |
|   @param  NumberOfPackages    The number of HII packages to register.
 | |
|   @param  GuidId              Package List GUID ID.
 | |
|   @param  DriverHandle        Optional. If not NULL, the DriverHandle on which an instance of DEVICE_PATH_PROTOCOL is installed.
 | |
|                               This DriverHandle uniquely defines the device that the added packages are associated with.
 | |
|   @param  HiiHandle           On output, the HiiHandle is update with the handle which can be used to retrieve the Package 
 | |
|                               List later. If the functions failed to add the package to the default HII database, this value will
 | |
|                               be set to NULL.
 | |
|   @param  ...                 The variable argument list describing all HII Package.
 | |
| 
 | |
|   @return  EFI_SUCCESS         If the packages are successfully added to the default HII database.
 | |
|   @return  EFI_OUT_OF_RESOURCE Not enough resource to complete the operation.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| EFIAPI
 | |
| HiiLibAddPackages (
 | |
|   IN       UINTN               NumberOfPackages,
 | |
|   IN CONST EFI_GUID            *GuidId,
 | |
|   IN       EFI_HANDLE          DriverHandle, OPTIONAL
 | |
|   OUT      EFI_HII_HANDLE      *HiiHandle,
 | |
|   ...
 | |
|   )
 | |
| ;
 | |
| 
 | |
| /**
 | |
|   Removes a package list from the default HII database.
 | |
| 
 | |
|   If HiiHandle is NULL, then ASSERT.
 | |
|   If HiiHandle is not a valid EFI_HII_HANDLE in the default HII database, then ASSERT.
 | |
| 
 | |
|   @param  HiiHandle                The handle that was previously registered to the data base that is requested for removal.
 | |
|                                              List later.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| EFIAPI
 | |
| HiiLibRemovePackages (
 | |
|   IN      EFI_HII_HANDLE      HiiHandle
 | |
|   )
 | |
| ;
 | |
| 
 | |
| /**
 | |
|   This function adds the string into String Package of each language
 | |
|   supported by the package list.
 | |
| 
 | |
|   If String is NULL, then ASSERT.
 | |
|   If StringId is NULL, the ASSERT.
 | |
|   If PackageList could not be found in the default HII database, then ASSERT.
 | |
| 
 | |
|   @param  PackageList            Handle of the package list where this string will
 | |
|                                             be added.
 | |
|   @param  StringId               On return, contains the new strings id, which is
 | |
|                                           unique within PackageList.
 | |
|   @param  String                 Points to the new null-terminated string.
 | |
| 
 | |
|   @retval EFI_SUCCESS             The new string was added successfully.
 | |
|   @retval EFI_OUT_OF_RESOURCES   Could not add the string due to lack of resources.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| EFIAPI
 | |
| HiiLibNewString (
 | |
|   IN  EFI_HII_HANDLE                  PackageList,
 | |
|   OUT EFI_STRING_ID                   *StringId,
 | |
|   IN  CONST EFI_STRING                String
 | |
|   )
 | |
| ;
 | |
| 
 | |
| /**
 | |
|   This function update the specified string in String Package of each language
 | |
|   supported by the package list.
 | |
| 
 | |
|   If String is NULL, then ASSERT.
 | |
|   If PackageList could not be found in the default HII database, then ASSERT.
 | |
|   If StringId is not found in PackageList, then ASSERT.
 | |
| 
 | |
|   @param  PackageList            Handle of the package list where this string will
 | |
|                                             be added.
 | |
|   @param  StringId               Ths String Id to be updated.
 | |
|   @param  String                 Points to the new null-terminated string.
 | |
| 
 | |
|   @retval EFI_SUCCESS            The new string was added successfully.
 | |
|   @retval EFI_OUT_OF_RESOURCES   Could not add the string due to lack of resources.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| EFIAPI
 | |
| HiiLibSetString (
 | |
|   IN  EFI_HII_HANDLE                  PackageList,
 | |
|   IN  EFI_STRING_ID                   StringId,
 | |
|   IN  CONST EFI_STRING                String
 | |
|   )
 | |
| ;
 | |
| 
 | |
| /**
 | |
|   This function try to retrieve string from String package of current language.
 | |
|   If fails, it try to retrieve string from String package of first language it support.
 | |
| 
 | |
|   If StringSize is NULL, then ASSERT.
 | |
|   If String is NULL and *StringSize is not 0, then ASSERT.
 | |
|   If PackageList could not be found in the default HII database, then ASSERT.
 | |
|   If StringId is not found in PackageList, then ASSERT.
 | |
| 
 | |
|   @param  PackageList     The package list in the HII database to search for
 | |
|                                      the specified string.
 | |
|   @param  StringId          The string's id, which is unique within
 | |
|                                       PackageList.
 | |
|   @param  String             Points to the new null-terminated string.
 | |
|   @param  StringSize       On entry, points to the size of the buffer pointed
 | |
|                                  to by String, in bytes. On return, points to the
 | |
|                                  length of the string, in bytes.
 | |
| 
 | |
|   @retval EFI_SUCCESS            The string was returned successfully.
 | |
|   @retval EFI_NOT_FOUND          The string specified by StringId is not available.
 | |
|   @retval EFI_BUFFER_TOO_SMALL   The buffer specified by StringLength is too small
 | |
|                                  to hold the string.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| EFIAPI
 | |
| HiiLibGetString (
 | |
|   IN  EFI_HII_HANDLE                  PackageList,
 | |
|   IN  EFI_STRING_ID                   StringId,
 | |
|   OUT EFI_STRING                      String,
 | |
|   IN  OUT UINTN                       *StringSize
 | |
|   )
 | |
| ;
 | |
| 
 | |
| /**
 | |
|   Get string specified by StringId form the HiiHandle. The caller
 | |
|   is responsible to free the *String.
 | |
| 
 | |
|   If String is NULL, then ASSERT.
 | |
|   If HiiHandle could not be found in the default HII database, then ASSERT.
 | |
|   If StringId is not found in PackageList, then ASSERT.
 | |
| 
 | |
|   @param  HiiHandle              The HII handle of package list.
 | |
|   @param  StringId               The String ID.
 | |
|   @param  String                 The output string.
 | |
| 
 | |
|   @retval EFI_NOT_FOUND          String is not found.
 | |
|   @retval EFI_SUCCESS            Operation is successful.
 | |
|   @retval EFI_OUT_OF_RESOURCES   There is not enought memory in the system.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| EFIAPI
 | |
| HiiLibGetStringFromHandle (
 | |
|   IN  EFI_HII_HANDLE                  HiiHandle,
 | |
|   IN  EFI_STRING_ID                   StringId,
 | |
|   OUT EFI_STRING                      *String
 | |
|   )
 | |
| ;
 | |
| 
 | |
| /**
 | |
|   Get the string given the StringId and String package Producer's Guid. The caller
 | |
|   is responsible to free the *String.
 | |
| 
 | |
|   If PackageList with the matching ProducerGuid is not found, then ASSERT.
 | |
|   If PackageList with the matching ProducerGuid is found but no String is
 | |
|   specified by StringId is found, then ASSERT.
 | |
| 
 | |
|   @param  ProducerGuid           The Guid of String package list.
 | |
|   @param  StringId               The String ID.
 | |
|   @param  String                 The output string.
 | |
| 
 | |
|   @retval EFI_SUCCESS            Operation is successful.
 | |
|   @retval EFI_OUT_OF_RESOURCES   There is not enought memory in the system.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| EFIAPI
 | |
| HiiLibGetStringFromToken (
 | |
|   IN  EFI_GUID                        *ProducerGuid,
 | |
|   IN  EFI_STRING_ID                   StringId,
 | |
|   OUT EFI_STRING                      *String
 | |
|   )
 | |
| ;
 | |
| 
 | |
| /**
 | |
|   Determines the handles that are currently active in the database.
 | |
|   It's the caller's responsibility to free handle buffer.
 | |
| 
 | |
|   If HandleBufferLength is NULL, then ASSERT.
 | |
|   If HiiHandleBuffer is NULL, then ASSERT.
 | |
| 
 | |
|   @param  HandleBufferLength     On input, a pointer to the length of the handle
 | |
|                                  buffer. On output, the length of the handle buffer
 | |
|                                  that is required for the handles found.
 | |
|   @param  HiiHandleBuffer        Pointer to an array of Hii Handles returned.
 | |
| 
 | |
|   @retval EFI_SUCCESS            Get an array of Hii Handles successfully.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| EFIAPI
 | |
| HiiLibGetHiiHandles (
 | |
|   IN OUT UINTN                     *HandleBufferLength,
 | |
|   OUT    EFI_HII_HANDLE            **HiiHandleBuffer
 | |
|   )
 | |
| ;
 | |
| 
 | |
| /**
 | |
|   Extract Hii package list GUID for given HII handle.
 | |
| 
 | |
|   If HiiHandle could not be found in the default HII database, then ASSERT.
 | |
|   If Guid is NULL, then ASSERT.
 | |
| 
 | |
|   @param  Handle              Hii handle
 | |
|   @param  Guid                Package list GUID
 | |
| 
 | |
|   @retval EFI_SUCCESS            Successfully extract GUID from Hii database.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| EFIAPI
 | |
| HiiLibExtractGuidFromHiiHandle (
 | |
|   IN      EFI_HII_HANDLE      Handle,
 | |
|   OUT     EFI_GUID            *Guid
 | |
|   )
 | |
| ;
 | |
| 
 | |
| /**
 | |
|   Find HII Handle in the default HII database associated with given Device Path.
 | |
| 
 | |
|   If DevicePath is NULL, then ASSERT.
 | |
| 
 | |
|   @param  DevicePath             Device Path associated with the HII package list
 | |
|                                  handle.
 | |
| 
 | |
|   @retval Handle                 HII package list Handle associated with the Device
 | |
|                                         Path.
 | |
|   @retval NULL                   Hii Package list handle is not found.
 | |
| 
 | |
| **/
 | |
| EFI_HII_HANDLE
 | |
| EFIAPI
 | |
| HiiLibDevicePathToHiiHandle (
 | |
|   IN EFI_DEVICE_PATH_PROTOCOL   *DevicePath
 | |
|   )
 | |
| ;
 | |
| 
 | |
| 
 | |
| /**
 | |
|   Get next language from language code list (with separator ';').
 | |
| 
 | |
|   If LangCode is NULL, then ASSERT.
 | |
|   If Lang is NULL, then ASSERT.
 | |
| 
 | |
|   @param  LangCode    On input: point to first language in the list. On
 | |
|                                  output: point to next language in the list, or
 | |
|                                  NULL if no more language in the list.
 | |
|   @param  Lang           The first language in the list.
 | |
| 
 | |
| **/
 | |
| VOID
 | |
| EFIAPI
 | |
| HiiLibGetNextLanguage (
 | |
|   IN OUT CHAR8      **LangCode,
 | |
|   OUT CHAR8         *Lang
 | |
|   )
 | |
| ;
 | |
| 
 | |
| /**
 | |
|   This function returns the list of supported languages, in the format specified
 | |
|   in UEFI specification Appendix M.
 | |
| 
 | |
|   If HiiHandle is not a valid Handle in the default HII database, then ASSERT.
 | |
| 
 | |
|   @param  HiiHandle              The HII package list handle.
 | |
| 
 | |
|   @retval   !NULL  The supported languages.
 | |
|   @retval   NULL    If Supported Languages can not be retrived.
 | |
| 
 | |
| **/
 | |
| CHAR8 *
 | |
| EFIAPI
 | |
| HiiLibGetSupportedLanguages (
 | |
|   IN EFI_HII_HANDLE           HiiHandle
 | |
|   )
 | |
| ;
 | |
| 
 | |
| /**
 | |
|   This function returns the list of supported 2nd languages, in the format specified
 | |
|   in UEFI specification Appendix M.
 | |
| 
 | |
|   If HiiHandle is not a valid Handle in the default HII database, then ASSERT.
 | |
|   If not enough resource to complete the operation, then ASSERT.
 | |
| 
 | |
|   @param  HiiHandle              The HII package list handle.
 | |
|   @param  FirstLanguage          Pointer to language name buffer.
 | |
|   
 | |
|   @return The supported languages.
 | |
| 
 | |
| **/
 | |
| CHAR8 *
 | |
| EFIAPI
 | |
| HiiLibGetSupportedSecondaryLanguages (
 | |
|   IN EFI_HII_HANDLE           HiiHandle,
 | |
|   IN CONST CHAR8              *FirstLanguage
 | |
|   )
 | |
| ;
 | |
| 
 | |
| 
 | |
| /**
 | |
|   This function returns the number of supported languages on HiiHandle.
 | |
| 
 | |
|   If HiiHandle is not a valid Handle in the default HII database, then ASSERT.
 | |
|   If not enough resource to complete the operation, then ASSERT.
 | |
| 
 | |
|   @param  HiiHandle              The HII package list handle.
 | |
| 
 | |
|   @return The  number of supported languages.
 | |
| 
 | |
| **/
 | |
| UINT16
 | |
| EFIAPI
 | |
| HiiLibGetSupportedLanguageNumber (
 | |
|   IN EFI_HII_HANDLE           HiiHandle
 | |
|   )
 | |
| ;
 | |
| 
 | |
| /**
 | |
|   Exports the contents of one or all package lists in the HII database into a buffer.
 | |
| 
 | |
|   If Handle is not NULL and not a valid EFI_HII_HANDLE registered in the database, 
 | |
|   then ASSERT.
 | |
|   If PackageListHeader is NULL, then ASSERT.
 | |
|   If PackageListSize is NULL, then ASSERT.
 | |
| 
 | |
|   @param  Handle                 The HII Handle.
 | |
|   @param  PackageListHeader      A pointer to a buffer that will contain the results of 
 | |
|                                  the export function.
 | |
|   @param  PackageListSize        On output, the length of the buffer that is required for the exported data.
 | |
| 
 | |
|   @retval EFI_SUCCESS            Package exported.
 | |
| 
 | |
|   @retval EFI_OUT_OF_RESOURCES   Not enought memory to complete the operations.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS 
 | |
| EFIAPI
 | |
| HiiLibExportPackageLists (
 | |
|   IN EFI_HII_HANDLE                    Handle,
 | |
|   OUT EFI_HII_PACKAGE_LIST_HEADER      **PackageListHeader,
 | |
|   OUT UINTN                            *PackageListSize
 | |
|   )
 | |
| ;
 | |
| 
 | |
| /**
 | |
|   
 | |
|   This function returns a list of the package handles of the   
 | |
|   specified type that are currently active in the HII database. The   
 | |
|   pseudo-type EFI_HII_PACKAGE_TYPE_ALL will cause all package   
 | |
|   handles to be listed.
 | |
| 
 | |
|   If HandleBufferLength is NULL, then ASSERT.
 | |
|   If HandleBuffer is NULL, the ASSERT.
 | |
|   If PackageType is EFI_HII_PACKAGE_TYPE_GUID and PackageGuid is
 | |
|   NULL, then ASSERT.
 | |
|   If PackageType is not EFI_HII_PACKAGE_TYPE_GUID and PackageGuid is not
 | |
|   NULL, then ASSERT.
 | |
|   
 | |
|   
 | |
|   @param PackageType          Specifies the package type of the packages
 | |
|                               to list or EFI_HII_PACKAGE_TYPE_ALL for
 | |
|                               all packages to be listed.
 | |
|   
 | |
|   @param PackageGuid          If PackageType is
 | |
|                               EFI_HII_PACKAGE_TYPE_GUID, then this is
 | |
|                               the pointer to the GUID which must match
 | |
|                               the Guid field of
 | |
|                               EFI_HII_PACKAGE_GUID_HEADER. Otherwise, it
 | |
|                               must be NULL.
 | |
|   
 | |
|   @param HandleBufferLength   On output, the length of the handle buffer
 | |
|                               that is required for the handles found.
 | |
| 
 | |
|   @param HandleBuffer         On output, an array of EFI_HII_HANDLE  instances returned.
 | |
|                               The caller is responcible to free this pointer allocated.
 | |
| 
 | |
|   @retval EFI_SUCCESS           The matching handles are outputed successfully.
 | |
|                                 HandleBufferLength is updated with the actual length.
 | |
|   @retval EFI_OUT_OF_RESOURCES  Not enough resource to complete the operation.
 | |
|   @retval EFI_NOT_FOUND         No matching handle could not be found in database.
 | |
| **/
 | |
| EFI_STATUS
 | |
| EFIAPI
 | |
| HiiLibListPackageLists (
 | |
|   IN        UINT8                     PackageType,
 | |
|   IN CONST  EFI_GUID                  *PackageGuid,
 | |
|   IN OUT    UINTN                     *HandleBufferLength,
 | |
|   OUT       EFI_HII_HANDLE            **Handle
 | |
|   )
 | |
| ;
 | |
| 
 | |
| /**
 | |
|   Convert language code from RFC3066 to ISO639-2.
 | |
| 
 | |
|   LanguageRfc3066 contain a single RFC 3066 code such as
 | |
|   "en-US" or "fr-FR".
 | |
| 
 | |
|   The LanguageRfc3066 must be a buffer large enough
 | |
|   for ISO_639_2_ENTRY_SIZE characters.
 | |
| 
 | |
|   If LanguageRfc3066 is NULL, then ASSERT.
 | |
|   If LanguageIso639 is NULL, then ASSERT.
 | |
| 
 | |
|   @param  LanguageRfc3066        RFC3066 language code.
 | |
|   @param  LanguageIso639         ISO639-2 language code.
 | |
| 
 | |
|   @retval EFI_SUCCESS            Language code converted.
 | |
|   @retval EFI_NOT_FOUND          Language code not found.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| EFIAPI
 | |
| ConvertRfc3066LanguageToIso639Language (
 | |
|   IN  CHAR8   *LanguageRfc3066,
 | |
|   OUT CHAR8   *LanguageIso639
 | |
|   )
 | |
| ;
 | |
| 
 | |
| /**
 | |
|   Convert language code from ISO639-2 to RFC3066.
 | |
| 
 | |
|   LanguageIso639 contain a single ISO639-2 code such as
 | |
|   "eng" or "fra".
 | |
| 
 | |
|   The LanguageRfc3066 must be a buffer large enough
 | |
|   for RFC_3066_ENTRY_SIZE characters.
 | |
| 
 | |
|   If LanguageIso639 is NULL, then ASSERT.
 | |
|   If LanguageRfc3066 is NULL, then ASSERT.
 | |
| 
 | |
|   @param  LanguageIso639         ISO639-2 language code.
 | |
|   @param  LanguageRfc3066        RFC3066 language code.
 | |
| 
 | |
|   @retval EFI_SUCCESS            Language code converted.
 | |
|   @retval EFI_NOT_FOUND          Language code not found.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| EFIAPI
 | |
| ConvertIso639LanguageToRfc3066Language (
 | |
|   IN  CONST CHAR8   *LanguageIso639,
 | |
|   OUT CHAR8         *LanguageRfc3066
 | |
|   )
 | |
| ;
 | |
| 
 | |
| /**
 | |
|   Convert language code list from RFC3066 to ISO639-2, e.g. "en-US;fr-FR" will
 | |
|   be converted to "engfra".
 | |
| 
 | |
|   If SupportedLanguages is NULL, then ASSERT.
 | |
| 
 | |
|   @param  SupportedLanguages     The RFC3066 language list.
 | |
| 
 | |
|   @return The ISO639-2 language list.
 | |
| 
 | |
| **/
 | |
| CHAR8 *
 | |
| EFIAPI
 | |
| Rfc3066ToIso639 (
 | |
|   CHAR8  *SupportedLanguages
 | |
|   )
 | |
| ;
 | |
| 
 | |
| 
 | |
| /**
 | |
|   Determine what is the current language setting. The space reserved for Lang
 | |
|   must be at least RFC_3066_ENTRY_SIZE bytes;
 | |
| 
 | |
|   If Lang is NULL, then ASSERT.
 | |
| 
 | |
|   @param  Lang                   Pointer of system language. Lang will always be filled with 
 | |
|                                          a valid RFC 3066 language string. If "PlatformLang" is not
 | |
|                                          set in the system, the default language specifed by PcdUefiVariableDefaultPlatformLang
 | |
|                                          is returned.
 | |
| 
 | |
|   @return  EFI_SUCCESS     If the EFI Variable with "PlatformLang" is set and return in Lang.
 | |
|   @return  EFI_NOT_FOUND If the EFI Variable with "PlatformLang" is not set, but a valid default language is return in Lang.
 | |
| 
 | |
| **/
 | |
| EFI_STATUS
 | |
| EFIAPI
 | |
| GetCurrentLanguage (
 | |
|   OUT     CHAR8               *Lang
 | |
|   )
 | |
| ;
 | |
| 
 | |
| #endif
 |