| /** @file | |
| Formset guids, form id and VarStore data structure for Boot Maintenance Manager. | |
| Copyright (c) 2004 - 2018, Intel Corporation. All rights reserved.<BR> | |
| SPDX-License-Identifier: BSD-2-Clause-Patent | |
| **/ | |
| #ifndef _FORM_GUID_H_ | |
| #define _FORM_GUID_H_ | |
| #define BOOT_MAINT_FORMSET_GUID \ | |
| { \ | |
| 0x642237c7, 0x35d4, 0x472d, {0x83, 0x65, 0x12, 0xe0, 0xcc, 0xf2, 0x7a, 0x22} \ | |
| } | |
| #define FORM_MAIN_ID 0x1001 | |
| #define FORM_BOOT_ADD_ID 0x1002 | |
| #define FORM_BOOT_DEL_ID 0x1003 | |
| #define FORM_BOOT_CHG_ID 0x1004 | |
| #define FORM_DRV_ADD_ID 0x1005 | |
| #define FORM_DRV_DEL_ID 0x1006 | |
| #define FORM_DRV_CHG_ID 0x1007 | |
| #define FORM_CON_MAIN_ID 0x1008 | |
| #define FORM_CON_IN_ID 0x1009 | |
| #define FORM_CON_OUT_ID 0x100A | |
| #define FORM_CON_ERR_ID 0x100B | |
| #define FORM_FILE_SEEK_ID 0x100C | |
| #define FORM_FILE_NEW_SEEK_ID 0x100D | |
| #define FORM_DRV_ADD_FILE_ID 0x100E | |
| #define FORM_DRV_ADD_HANDLE_ID 0x100F | |
| #define FORM_DRV_ADD_HANDLE_DESC_ID 0x1010 | |
| #define FORM_BOOT_NEXT_ID 0x1011 | |
| #define FORM_TIME_OUT_ID 0x1012 | |
| #define FORM_BOOT_SETUP_ID 0x1014 | |
| #define FORM_DRIVER_SETUP_ID 0x1015 | |
| #define FORM_BOOT_LEGACY_DEVICE_ID 0x1016 | |
| #define FORM_CON_COM_ID 0x1017 | |
| #define FORM_CON_COM_SETUP_ID 0x1018 | |
| #define FORM_BOOT_ADD_DESCRIPTION_ID 0x101F | |
| #define FORM_DRIVER_ADD_FILE_DESCRIPTION_ID 0x1020 | |
| #define FORM_CON_MODE_ID 0x1021 | |
| #define FORM_BOOT_FROM_FILE_ID 0x1024 | |
| #define MAXIMUM_FORM_ID 0x10FF | |
| #define KEY_VALUE_COM_SET_BAUD_RATE 0x1101 | |
| #define KEY_VALUE_COM_SET_DATA_BITS 0x1102 | |
| #define KEY_VALUE_COM_SET_STOP_BITS 0x1103 | |
| #define KEY_VALUE_COM_SET_PARITY 0x1104 | |
| #define KEY_VALUE_COM_SET_TERMI_TYPE 0x1105 | |
| #define KEY_VALUE_MAIN_BOOT_NEXT 0x1106 | |
| #define KEY_VALUE_BOOT_ADD_DESC_DATA 0x1107 | |
| #define KEY_VALUE_BOOT_ADD_OPT_DATA 0x1108 | |
| #define KEY_VALUE_DRIVER_ADD_DESC_DATA 0x1109 | |
| #define KEY_VALUE_DRIVER_ADD_OPT_DATA 0x110A | |
| #define KEY_VALUE_SAVE_AND_EXIT 0x110B | |
| #define KEY_VALUE_NO_SAVE_AND_EXIT 0x110C | |
| #define KEY_VALUE_BOOT_FROM_FILE 0x110D | |
| #define FORM_RESET 0x110E | |
| #define KEY_VALUE_BOOT_DESCRIPTION 0x110F | |
| #define KEY_VALUE_BOOT_OPTION 0x1110 | |
| #define KEY_VALUE_DRIVER_DESCRIPTION 0x1111 | |
| #define KEY_VALUE_DRIVER_OPTION 0x1112 | |
| #define KEY_VALUE_SAVE_AND_EXIT_BOOT 0x1113 | |
| #define KEY_VALUE_NO_SAVE_AND_EXIT_BOOT 0x1114 | |
| #define KEY_VALUE_SAVE_AND_EXIT_DRIVER 0x1115 | |
| #define KEY_VALUE_NO_SAVE_AND_EXIT_DRIVER 0x1116 | |
| #define KEY_VALUE_TRIGGER_FORM_OPEN_ACTION 0x1117 | |
| #define MAXIMUM_NORMAL_KEY_VALUE 0x11FF | |
| // | |
| // Varstore ID defined for Buffer Storage | |
| // | |
| #define VARSTORE_ID_BOOT_MAINT 0x1000 | |
| // | |
| // End Label | |
| // | |
| #define LABEL_FORM_MAIN_START 0xfffc | |
| #define LABEL_FORM_MAIN_END 0xfffd | |
| #define LABEL_BMM_PLATFORM_INFORMATION 0xfffe | |
| #define LABEL_END 0xffff | |
| #define MAX_MENU_NUMBER 100 | |
| /// | |
| /// This is the structure that will be used to store the | |
| /// question's current value. Use it at initialize time to | |
| /// set default value for each question. When using at run | |
| /// time, this map is returned by the callback function, | |
| /// so dynamically changing the question's value will be | |
| /// possible through this mechanism | |
| /// | |
| typedef struct { | |
| // | |
| // Three questions displayed at the main page | |
| // for Timeout, BootNext, Variables respectively | |
| // | |
| UINT16 BootTimeOut; | |
| UINT32 BootNext; | |
| // | |
| // This is the COM1 Attributes value storage | |
| // | |
| UINT8 COM1BaudRate; | |
| UINT8 COM1DataRate; | |
| UINT8 COM1StopBits; | |
| UINT8 COM1Parity; | |
| UINT8 COM1TerminalType; | |
| // | |
| // This is the COM2 Attributes value storage | |
| // | |
| UINT8 COM2BaudRate; | |
| UINT8 COM2DataRate; | |
| UINT8 COM2StopBits; | |
| UINT8 COM2Parity; | |
| UINT8 COM2TerminalType; | |
| // | |
| // Driver Option Add Handle page storage | |
| // | |
| UINT16 DriverAddHandleDesc[MAX_MENU_NUMBER]; | |
| UINT16 DriverAddHandleOptionalData[MAX_MENU_NUMBER]; | |
| UINT8 DriverAddActive; | |
| UINT8 DriverAddForceReconnect; | |
| // | |
| // Console Input/Output/Errorout using COM port check storage | |
| // | |
| UINT8 ConsoleInputCOM1; | |
| UINT8 ConsoleInputCOM2; | |
| UINT8 ConsoleOutputCOM1; | |
| UINT8 ConsoleOutputCOM2; | |
| UINT8 ConsoleErrorCOM1; | |
| UINT8 ConsoleErrorCOM2; | |
| // | |
| // At most 100 input/output/errorout device for console storage | |
| // | |
| UINT8 ConsoleCheck[MAX_MENU_NUMBER]; | |
| // | |
| // At most 100 input/output/errorout device for console storage | |
| // | |
| UINT8 ConsoleInCheck[MAX_MENU_NUMBER]; | |
| UINT8 ConsoleOutCheck[MAX_MENU_NUMBER]; | |
| UINT8 ConsoleErrCheck[MAX_MENU_NUMBER]; | |
| // | |
| // Boot or Driver Option Order storage | |
| // The value is the OptionNumber+1 because the order list value cannot be 0 | |
| // Use UINT32 to hold the potential value 0xFFFF+1=0x10000 | |
| // | |
| UINT32 BootOptionOrder[MAX_MENU_NUMBER]; | |
| UINT32 DriverOptionOrder[MAX_MENU_NUMBER]; | |
| // | |
| // Boot or Driver Option Delete storage | |
| // | |
| BOOLEAN BootOptionDel[MAX_MENU_NUMBER]; | |
| BOOLEAN DriverOptionDel[MAX_MENU_NUMBER]; | |
| BOOLEAN BootOptionDelMark[MAX_MENU_NUMBER]; | |
| BOOLEAN DriverOptionDelMark[MAX_MENU_NUMBER]; | |
| // | |
| // This is the Terminal Attributes value storage | |
| // | |
| UINT8 COMBaudRate[MAX_MENU_NUMBER]; | |
| UINT8 COMDataRate[MAX_MENU_NUMBER]; | |
| UINT8 COMStopBits[MAX_MENU_NUMBER]; | |
| UINT8 COMParity[MAX_MENU_NUMBER]; | |
| UINT8 COMTerminalType[MAX_MENU_NUMBER]; | |
| UINT8 COMFlowControl[MAX_MENU_NUMBER]; | |
| // | |
| // We use DisableMap array to record the enable/disable state of each boot device | |
| // It should be taken as a bit array, from left to right there are totally 256 bits | |
| // the most left one stands for BBS table item 0, and the most right one stands for item 256 | |
| // If the bit is 1, it means the boot device has been disabled. | |
| // | |
| UINT8 DisableMap[32]; | |
| // | |
| // Console Output Text Mode | |
| // | |
| UINT16 ConsoleOutMode; | |
| // | |
| // UINT16 PadArea[10]; | |
| // | |
| UINT16 BootDescriptionData[MAX_MENU_NUMBER]; | |
| UINT16 BootOptionalData[127]; | |
| UINT16 DriverDescriptionData[MAX_MENU_NUMBER]; | |
| UINT16 DriverOptionalData[127]; | |
| BOOLEAN BootOptionChanged; | |
| BOOLEAN DriverOptionChanged; | |
| UINT8 Active; | |
| UINT8 ForceReconnect; | |
| } BMM_FAKE_NV_DATA; | |
| #endif |