2009-07-17 11:10:31 +02:00
|
|
|
/** @file
|
|
|
|
EDK II specific HII relative definition.
|
|
|
|
|
2017-08-23 10:27:26 +02:00
|
|
|
Copyright (c) 2006 - 2017, Intel Corporation. All rights reserved.<BR>
|
2009-07-17 11:10:31 +02:00
|
|
|
|
2019-04-04 01:03:11 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2009-07-17 11:10:31 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef _MDEMODULE_HII_H
|
|
|
|
#define _MDEMODULE_HII_H
|
|
|
|
|
|
|
|
#define NARROW_CHAR 0xFFF0
|
|
|
|
#define WIDE_CHAR 0xFFF1
|
|
|
|
#define NON_BREAKING_CHAR 0xFFF2
|
|
|
|
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// State defined for password statemachine .
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
#define BROWSER_STATE_VALIDATE_PASSWORD 0
|
|
|
|
#define BROWSER_STATE_SET_PASSWORD 1
|
|
|
|
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// GUIDed opcodes defined for EDKII implementation.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
#define EFI_IFR_TIANO_GUID \
|
|
|
|
{ 0xf0b1735, 0x87a0, 0x4193, {0xb2, 0x66, 0x53, 0x8c, 0x38, 0xaf, 0x48, 0xce} }
|
|
|
|
|
|
|
|
#pragma pack(1)
|
|
|
|
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// EDKII implementation extension opcodes, new extension can be added here later.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
#define EFI_IFR_EXTEND_OP_LABEL 0x0
|
|
|
|
#define EFI_IFR_EXTEND_OP_BANNER 0x1
|
|
|
|
#define EFI_IFR_EXTEND_OP_TIMEOUT 0x2
|
|
|
|
#define EFI_IFR_EXTEND_OP_CLASS 0x3
|
|
|
|
#define EFI_IFR_EXTEND_OP_SUBCLASS 0x4
|
|
|
|
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// Label opcode.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
typedef struct _EFI_IFR_GUID_LABEL {
|
|
|
|
EFI_IFR_OP_HEADER Header;
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// EFI_IFR_TIANO_GUID.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
EFI_GUID Guid;
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// EFI_IFR_EXTEND_OP_LABEL.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
UINT8 ExtendOpCode;
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// Label Number.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
UINT16 Number;
|
|
|
|
} EFI_IFR_GUID_LABEL;
|
|
|
|
|
|
|
|
#define EFI_IFR_BANNER_ALIGN_LEFT 0
|
|
|
|
#define EFI_IFR_BANNER_ALIGN_CENTER 1
|
|
|
|
#define EFI_IFR_BANNER_ALIGN_RIGHT 2
|
|
|
|
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// Banner opcode.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
typedef struct _EFI_IFR_GUID_BANNER {
|
|
|
|
EFI_IFR_OP_HEADER Header;
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// EFI_IFR_TIANO_GUID.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
EFI_GUID Guid;
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// EFI_IFR_EXTEND_OP_BANNER
|
|
|
|
///
|
|
|
|
UINT8 ExtendOpCode;
|
|
|
|
EFI_STRING_ID Title; ///< The string token for the banner title.
|
|
|
|
UINT16 LineNumber; ///< 1-based line number.
|
|
|
|
UINT8 Alignment; ///< left, center, or right-aligned.
|
2009-07-17 11:10:31 +02:00
|
|
|
} EFI_IFR_GUID_BANNER;
|
|
|
|
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// Timeout opcode.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
typedef struct _EFI_IFR_GUID_TIMEOUT {
|
|
|
|
EFI_IFR_OP_HEADER Header;
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// EFI_IFR_TIANO_GUID.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
EFI_GUID Guid;
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// EFI_IFR_EXTEND_OP_TIMEOUT.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
UINT8 ExtendOpCode;
|
2011-08-26 09:46:26 +02:00
|
|
|
UINT16 TimeOut; ///< TimeOut Value.
|
2009-07-17 11:10:31 +02:00
|
|
|
} EFI_IFR_GUID_TIMEOUT;
|
|
|
|
|
|
|
|
#define EFI_NON_DEVICE_CLASS 0x00
|
|
|
|
#define EFI_DISK_DEVICE_CLASS 0x01
|
|
|
|
#define EFI_VIDEO_DEVICE_CLASS 0x02
|
|
|
|
#define EFI_NETWORK_DEVICE_CLASS 0x04
|
|
|
|
#define EFI_INPUT_DEVICE_CLASS 0x08
|
|
|
|
#define EFI_ON_BOARD_DEVICE_CLASS 0x10
|
|
|
|
#define EFI_OTHER_DEVICE_CLASS 0x20
|
|
|
|
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// Device Class opcode.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
typedef struct _EFI_IFR_GUID_CLASS {
|
|
|
|
EFI_IFR_OP_HEADER Header;
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// EFI_IFR_TIANO_GUID.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
EFI_GUID Guid;
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// EFI_IFR_EXTEND_OP_CLASS.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
UINT8 ExtendOpCode;
|
2011-08-26 09:46:26 +02:00
|
|
|
UINT16 Class; ///< Device Class from the above.
|
2009-07-17 11:10:31 +02:00
|
|
|
} EFI_IFR_GUID_CLASS;
|
|
|
|
|
|
|
|
#define EFI_SETUP_APPLICATION_SUBCLASS 0x00
|
|
|
|
#define EFI_GENERAL_APPLICATION_SUBCLASS 0x01
|
|
|
|
#define EFI_FRONT_PAGE_SUBCLASS 0x02
|
|
|
|
#define EFI_SINGLE_USE_SUBCLASS 0x03
|
|
|
|
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// SubClass opcode
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
typedef struct _EFI_IFR_GUID_SUBCLASS {
|
|
|
|
EFI_IFR_OP_HEADER Header;
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// EFI_IFR_TIANO_GUID.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
EFI_GUID Guid;
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// EFI_IFR_EXTEND_OP_SUBCLASS.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
UINT8 ExtendOpCode;
|
2011-08-26 09:46:26 +02:00
|
|
|
UINT16 SubClass; ///< Sub Class type from the above.
|
2009-07-17 11:10:31 +02:00
|
|
|
} EFI_IFR_GUID_SUBCLASS;
|
|
|
|
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// GUIDed opcodes support for framework vfr.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
#define EFI_IFR_FRAMEWORK_GUID \
|
|
|
|
{ 0x31ca5d1a, 0xd511, 0x4931, { 0xb7, 0x82, 0xae, 0x6b, 0x2b, 0x17, 0x8c, 0xd7 } }
|
|
|
|
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// Two extended opcodes are added, and new extensions can be added here later.
|
|
|
|
/// One is for framework OneOf question Option Key value;
|
|
|
|
/// another is for framework vareqval.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
#define EFI_IFR_EXTEND_OP_OPTIONKEY 0x0
|
|
|
|
#define EFI_IFR_EXTEND_OP_VAREQNAME 0x1
|
2011-08-26 09:46:26 +02:00
|
|
|
|
|
|
|
///
|
|
|
|
/// Store the framework vfr option key value.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
typedef struct _EFI_IFR_GUID_OPTIONKEY {
|
|
|
|
EFI_IFR_OP_HEADER Header;
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// EFI_IFR_FRAMEWORK_GUID.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
EFI_GUID Guid;
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// EFI_IFR_EXTEND_OP_OPTIONKEY.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
UINT8 ExtendOpCode;
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// OneOf Questiond ID binded by OneOf Option.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
EFI_QUESTION_ID QuestionId;
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// The OneOf Option Value.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
EFI_IFR_TYPE_VALUE OptionValue;
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// The Framework OneOf Option Key Value.
|
|
|
|
///
|
|
|
|
UINT16 KeyValue;
|
2009-07-17 11:10:31 +02:00
|
|
|
} EFI_IFR_GUID_OPTIONKEY;
|
|
|
|
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// Store the framework vfr vareqval name number.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
typedef struct _EFI_IFR_GUID_VAREQNAME {
|
|
|
|
EFI_IFR_OP_HEADER Header;
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// EFI_IFR_FRAMEWORK_GUID.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
EFI_GUID Guid;
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// EFI_IFR_EXTEND_OP_VAREQNAME.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
UINT8 ExtendOpCode;
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// Question ID of the Numeric Opcode created.
|
|
|
|
///
|
2009-07-17 11:10:31 +02:00
|
|
|
EFI_QUESTION_ID QuestionId;
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
/// For vareqval (0x100), NameId is 0x100.
|
|
|
|
/// This value will convert to a Unicode String following this rule;
|
|
|
|
/// sprintf(StringBuffer, "%d", NameId) .
|
2019-02-06 08:44:39 +01:00
|
|
|
/// The Unicode String will be used as a EFI Variable Name.
|
2011-08-26 09:46:26 +02:00
|
|
|
///
|
|
|
|
UINT16 NameId;
|
2009-07-17 11:10:31 +02:00
|
|
|
} EFI_IFR_GUID_VAREQNAME;
|
|
|
|
|
2017-08-23 10:27:26 +02:00
|
|
|
///
|
2019-02-06 08:44:39 +01:00
|
|
|
/// EDKII implementation extension GUID, used to indicate there are bit fields in the varstore.
|
2017-08-23 10:27:26 +02:00
|
|
|
///
|
|
|
|
#define EDKII_IFR_BIT_VARSTORE_GUID \
|
|
|
|
{ 0x82DDD68B, 0x9163, 0x4187, {0x9B, 0x27, 0x20, 0xA8, 0xFD, 0x60 ,0xA7, 0x1D}}
|
|
|
|
|
|
|
|
///
|
2019-02-06 08:44:39 +01:00
|
|
|
/// EDKII implementation extension flags, used to indicate the display style and bit width for bit filed storage.
|
2017-08-23 10:27:26 +02:00
|
|
|
/// Two high bits for display style and the low six bits for bit width.
|
|
|
|
///
|
|
|
|
#define EDKII_IFR_DISPLAY_BIT 0xC0
|
|
|
|
#define EDKII_IFR_DISPLAY_INT_DEC_BIT 0x00
|
|
|
|
#define EDKII_IFR_DISPLAY_UINT_DEC_BIT 0x40
|
|
|
|
#define EDKII_IFR_DISPLAY_UINT_HEX_BIT 0x80
|
|
|
|
|
|
|
|
#define EDKII_IFR_NUMERIC_SIZE_BIT 0x3F
|
|
|
|
|
2009-07-17 11:10:31 +02:00
|
|
|
#pragma pack()
|
|
|
|
|
2011-08-26 09:46:26 +02:00
|
|
|
extern EFI_GUID gEfiIfrTianoGuid;
|
|
|
|
extern EFI_GUID gEfiIfrFrameworkGuid;
|
2017-08-23 10:27:26 +02:00
|
|
|
extern EFI_GUID gEdkiiIfrBitVarStoreGuid;
|
2011-08-26 09:46:26 +02:00
|
|
|
|
2009-07-17 11:10:31 +02:00
|
|
|
#endif
|
|
|
|
|