X-Git-Url: https://git.proxmox.com/?a=blobdiff_plain;f=IntelFrameworkModulePkg%2FUniversal%2FBdsDxe%2FBootMaint%2FBootMaint.h;h=57acf8554157b4262d44d0687ef4e59244d77fab;hb=e24fc1032db5d5d2395260f6d7af94aa5a2a0802;hp=781c747a3517699c512c7f1d1f3da5bc7aaa8b5d;hpb=13078b3fadb4aaae2d6975ab96a7ad649017589f;p=mirror_edk2.git diff --git a/IntelFrameworkModulePkg/Universal/BdsDxe/BootMaint/BootMaint.h b/IntelFrameworkModulePkg/Universal/BdsDxe/BootMaint/BootMaint.h index 781c747a35..57acf85541 100644 --- a/IntelFrameworkModulePkg/Universal/BdsDxe/BootMaint/BootMaint.h +++ b/IntelFrameworkModulePkg/Universal/BdsDxe/BootMaint/BootMaint.h @@ -1,8 +1,8 @@ /** @file Header file for boot maintenance module. -Copyright (c) 2004 - 2009, Intel Corporation.
-All rights reserved. This program and the accompanying materials +Copyright (c) 2004 - 2011, 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 @@ -23,19 +23,8 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. // // Constants which are variable names used to access variables // -#define VAR_LEGACY_DEV_ORDER L"LegacyDevOrder" - #define VAR_CON_OUT_MODE L"ConOutMode" -/// -/// Guid of a NV Variable which store the information about the -/// FD/HD/CD/NET/BEV order -/// -#define EFI_LEGACY_DEV_ORDER_VARIABLE_GUID \ - { \ - 0xa56074db, 0x65fe, 0x45f7, {0xbd, 0x21, 0x2d, 0x2b, 0xdd, 0x8e, 0x96, 0x52} \ - } - // // String Contant // @@ -55,14 +44,6 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. // #define VAR_FLAG EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_RUNTIME_ACCESS | EFI_VARIABLE_NON_VOLATILE -// -// Define Maxmim characters that will be accepted -// -#define MAX_CHAR 480 -#define MAX_CHAR_SIZE (MAX_CHAR * 2) - -extern EFI_GUID mBootMaintGuid; -extern EFI_GUID mFileExplorerGuid; extern CHAR16 mFileExplorerStorageName[]; extern CHAR16 mBootMaintStorageName[]; // @@ -91,8 +72,6 @@ extern UINT8 FEBin[]; // // Enumeration type definition // -typedef UINT8 BBS_TYPE; - typedef enum _TYPE_OF_TERMINAL { TerminalTypePcAnsi = 0, TerminalTypeVt100, @@ -195,15 +174,14 @@ typedef enum _FILE_EXPLORER_DISPLAY_CONTEXT { #define CON_MODE_VAR_OFFSET VAR_OFFSET (ConsoleOutMode) #define CON_DEVICE_VAR_OFFSET VAR_OFFSET (ConsoleCheck) #define OPTION_ORDER_VAR_OFFSET VAR_OFFSET (OptionOrder) -#define DRIVER_OPTION_ORDER_VAR_OFFSET VAR_OFFSET (DriverOptionToBeDeleted) -#define BOOT_OPTION_DEL_VAR_OFFSET VAR_OFFSET (BootOptionDel) -#define DRIVER_OPTION_DEL_VAR_OFFSET VAR_OFFSET (DriverOptionDel) +#define OPTION_DEL_VAR_OFFSET VAR_OFFSET (OptionDel) #define DRIVER_ADD_OPTION_VAR_OFFSET VAR_OFFSET (DriverAddHandleOptionalData) #define COM_BAUD_RATE_VAR_OFFSET VAR_OFFSET (COMBaudRate) #define COM_DATA_RATE_VAR_OFFSET VAR_OFFSET (COMDataRate) #define COM_STOP_BITS_VAR_OFFSET VAR_OFFSET (COMStopBits) #define COM_PARITY_VAR_OFFSET VAR_OFFSET (COMParity) #define COM_TERMINAL_VAR_OFFSET VAR_OFFSET (COMTerminalType) +#define COM_FLOWCONTROL_VAR_OFFSET VAR_OFFSET (COMFlowControl) #define LEGACY_FD_VAR_OFFSET VAR_OFFSET (LegacyFD) #define LEGACY_HD_VAR_OFFSET VAR_OFFSET (LegacyHD) #define LEGACY_CD_VAR_OFFSET VAR_OFFSET (LegacyCD) @@ -234,15 +212,14 @@ typedef enum _FILE_EXPLORER_DISPLAY_CONTEXT { #define CON_MODE_QUESTION_ID QUESTION_ID (ConsoleOutMode) #define CON_DEVICE_QUESTION_ID QUESTION_ID (ConsoleCheck) #define OPTION_ORDER_QUESTION_ID QUESTION_ID (OptionOrder) -#define DRIVER_OPTION_ORDER_QUESTION_ID QUESTION_ID (DriverOptionToBeDeleted) -#define BOOT_OPTION_DEL_QUESTION_ID QUESTION_ID (BootOptionDel) -#define DRIVER_OPTION_DEL_QUESTION_ID QUESTION_ID (DriverOptionDel) +#define OPTION_DEL_QUESTION_ID QUESTION_ID (OptionDel) #define DRIVER_ADD_OPTION_QUESTION_ID QUESTION_ID (DriverAddHandleOptionalData) #define COM_BAUD_RATE_QUESTION_ID QUESTION_ID (COMBaudRate) #define COM_DATA_RATE_QUESTION_ID QUESTION_ID (COMDataRate) #define COM_STOP_BITS_QUESTION_ID QUESTION_ID (COMStopBits) #define COM_PARITY_QUESTION_ID QUESTION_ID (COMParity) #define COM_TERMINAL_QUESTION_ID QUESTION_ID (COMTerminalType) +#define COM_FLOWCONTROL_QUESTION_ID QUESTION_ID (COMFlowControl) #define LEGACY_FD_QUESTION_ID QUESTION_ID (LegacyFD) #define LEGACY_HD_QUESTION_ID QUESTION_ID (LegacyHD) #define LEGACY_CD_QUESTION_ID QUESTION_ID (LegacyCD) @@ -262,14 +239,15 @@ typedef struct { } COM_ATTR; #pragma pack(1) +/// +/// For each legacy boot option in BBS table, a corresponding Boot#### variables is created. +/// The structure saves the mapping relationship between #### and the index in the BBS table. +/// typedef struct { - BBS_TYPE BbsType; - /// - /// Length = sizeof (UINT16) + SIZEOF (Data) - /// - UINT16 Length; - UINT16 *Data; -} BM_LEGACY_DEV_ORDER_CONTEXT; + UINT16 BootOptionNumber; + UINT16 BbsIndex; + UINT16 BbsType; +} BOOT_OPTION_BBS_MAPPING; #pragma pack() typedef struct { @@ -283,6 +261,8 @@ typedef struct { UINT8 ParityIndex; UINT8 StopBitsIndex; + UINT8 FlowControl; + UINT8 IsConIn; UINT8 IsConOut; UINT8 IsStdErr; @@ -314,10 +294,10 @@ typedef struct { } BM_LOAD_CONTEXT; typedef struct { - BBS_TABLE *BbsTable; - UINTN Index; - UINTN BbsCount; - UINT16 *Description; + BBS_TABLE *BbsEntry; + UINT16 BbsIndex; + UINT16 BbsCount; + CHAR16 *Description; } BM_LEGACY_DEVICE_CONTEXT; typedef struct { @@ -597,6 +577,20 @@ BOpt_IsEfiApp ( Get the Option Number that has not been allocated for use. + @param Type The type of Option. + + @return The available Option Number. + +**/ +UINT16 +BOpt_GetOptionNumber ( + CHAR16 *Type + ); + +/** + + Get the Option Number for Boot#### that does not used. + @return The available Option Number. **/ @@ -607,9 +601,9 @@ BOpt_GetBootOptionNumber ( /** - Get the Option Number that is not in use. +Get the Option Number for Driver#### that does not used. - @return The unused Option Number. +@return The unused Option Number. **/ UINT16 @@ -743,7 +737,7 @@ ChangeVariableDevicePath ( **/ EFI_STATUS ChangeTerminalDevicePath ( - IN OUT EFI_DEVICE_PATH_PROTOCOL *DevicePath, + IN OUT EFI_DEVICE_PATH_PROTOCOL **DevicePath, IN BOOLEAN ChangeTerminal ); @@ -949,14 +943,14 @@ Var_UpdateDriverOrder ( ); /** - Update the legacy BBS boot option. L"LegacyDevOrder" and EfiLegacyDevOrderGuid EFI Variable + Update the legacy BBS boot option. VAR_LEGACY_DEV_ORDER and gEfiLegacyDevOrderVariableGuid EFI Variable is udpated with the new Legacy Boot order. The EFI Variable of "Boot####" and gEfiGlobalVariableGuid is also updated. @param CallbackData The context data for BMM. @return EFI_SUCCESS The function completed successfully. - @retval EFI_NOT_FOUND If L"LegacyDevOrder" and EfiLegacyDevOrderGuid EFI Variable can not be found. + @retval EFI_NOT_FOUND If VAR_LEGACY_DEV_ORDER and gEfiLegacyDevOrderVariableGuid EFI Variable can not be found. **/ EFI_STATUS @@ -1548,8 +1542,8 @@ extern STRING_DEPOSITORY *DriverOptionStrDepository; extern STRING_DEPOSITORY *DriverOptionHelpStrDepository; extern STRING_DEPOSITORY *TerminalStrDepository; extern EFI_DEVICE_PATH_PROTOCOL EndDevicePath[]; -extern EFI_GUID EfiLegacyDevOrderGuid; - +extern UINT16 mFlowControlType[2]; +extern UINT32 mFlowControlValue[2]; // // Shared IFR form update data //