mirror of
https://github.com/acidanthera/audk.git
synced 2025-10-23 16:23:47 +02:00
BootMaintenanceManagerUiLib depend on the LeagcyBootMaintUiLib to show the legacy menus. So we need to do the actions related to LegacyUi in BMM after the LeagcyBootMaintUiLib have been initialized. So now : 1). update menus (including legacy menus), 2) re-scan boot options (including legacy boot option) when opening the BMM form. We think when opening BMM form, the LeagcyBootMaintUiLib must have been initialized. Cc: Liming Gao <liming.gao@intel.com> Cc: Eric Dong <eric.dong@intel.com> Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Dandan Bi <dandan.bi@intel.com> Reviewed-by: Eric Dong <eric.dong@intel.com> Reviewed-by: Liming Gao <liming.gao@intel.com>
213 lines
7.1 KiB
C
213 lines
7.1 KiB
C
/** @file
|
|
Formset guids, form id and VarStore data structure for Boot Maintenance Manager.
|
|
|
|
Copyright (c) 2004 - 2016, Intel Corporation. All rights reserved.<BR>
|
|
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 _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
|
|
|