2 EDK II implementation specific HII relative definition.
4 Copyright (c) 2006 - 2008, Intel Corporation. <BR>
5 All rights reserved. This program and the accompanying materials
6 are licensed and made available under the terms and conditions of the BSD License
7 which accompanies this distribution. The full text of the license may be found at
8 http://opensource.org/licenses/bsd-license.php
10 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
11 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
15 #ifndef __MDEMODULE_HII_H__
16 #define __MDEMODULE_HII_H__
18 #define NARROW_CHAR 0xFFF0
19 #define WIDE_CHAR 0xFFF1
20 #define NON_BREAKING_CHAR 0xFFF2
23 // State defined for password statemachine
25 #define BROWSER_STATE_VALIDATE_PASSWORD 0
26 #define BROWSER_STATE_SET_PASSWORD 1
30 // Tiano Implementation specific Device Path definition.
34 VENDOR_DEVICE_PATH VendorDevicePath
;
37 } HII_VENDOR_DEVICE_PATH_NODE
;
41 HII_VENDOR_DEVICE_PATH_NODE Node
;
42 EFI_DEVICE_PATH_PROTOCOL End
;
43 } HII_VENDOR_DEVICE_PATH
;
47 // GUIDed opcodes defined for Tiano
49 #define EFI_IFR_TIANO_GUID \
50 { 0xf0b1735, 0x87a0, 0x4193, {0xb2, 0x66, 0x53, 0x8c, 0x38, 0xaf, 0x48, 0xce} }
54 #define EFI_IFR_EXTEND_OP_LABEL 0x0
55 #define EFI_IFR_EXTEND_OP_BANNER 0x1
56 #define EFI_IFR_EXTEND_OP_TIMEOUT 0x2
57 #define EFI_IFR_EXTEND_OP_CLASS 0x3
58 #define EFI_IFR_EXTEND_OP_SUBCLASS 0x4
61 typedef struct _EFI_IFR_GUID_LABEL
{
62 EFI_IFR_OP_HEADER Header
;
68 #define EFI_IFR_BANNER_ALIGN_LEFT 0
69 #define EFI_IFR_BANNER_ALIGN_CENTER 1
70 #define EFI_IFR_BANNER_ALIGN_RIGHT 2
72 typedef struct _EFI_IFR_GUID_BANNER
{
73 EFI_IFR_OP_HEADER Header
;
75 UINT8 ExtendOpCode
; // Extended opcode is EFI_IFR_EXTEND_OP_BANNER
76 EFI_STRING_ID Title
; // The string token for the banner title
77 UINT16 LineNumber
; // 1-based line number
78 UINT8 Alignment
; // left, center, or right-aligned
79 } EFI_IFR_GUID_BANNER
;
81 typedef struct _EFI_IFR_GUID_TIMEOUT
{
82 EFI_IFR_OP_HEADER Header
;
86 } EFI_IFR_GUID_TIMEOUT
;
88 #define EFI_NON_DEVICE_CLASS 0x00
89 #define EFI_DISK_DEVICE_CLASS 0x01
90 #define EFI_VIDEO_DEVICE_CLASS 0x02
91 #define EFI_NETWORK_DEVICE_CLASS 0x04
92 #define EFI_INPUT_DEVICE_CLASS 0x08
93 #define EFI_ON_BOARD_DEVICE_CLASS 0x10
94 #define EFI_OTHER_DEVICE_CLASS 0x20
96 typedef struct _EFI_IFR_GUID_CLASS
{
97 EFI_IFR_OP_HEADER Header
;
101 } EFI_IFR_GUID_CLASS
;
103 #define EFI_SETUP_APPLICATION_SUBCLASS 0x00
104 #define EFI_GENERAL_APPLICATION_SUBCLASS 0x01
105 #define EFI_FRONT_PAGE_SUBCLASS 0x02
106 #define EFI_SINGLE_USE_SUBCLASS 0x03
108 typedef struct _EFI_IFR_GUID_SUBCLASS
{
109 EFI_IFR_OP_HEADER Header
;
113 } EFI_IFR_GUID_SUBCLASS
;
116 // GUIDed opcodes defined for framework vfr.
118 #define EFI_IFR_FRAMEWORK_GUID \
119 { 0x31ca5d1a, 0xd511, 0x4931, { 0xb7, 0x82, 0xae, 0x6b, 0x2b, 0x17, 0x8c, 0xd7 } }
121 #define EFI_IFR_EXTEND_OP_OPTIONKEY 0x0
122 #define EFI_IFR_EXTEND_OP_VAREQNAME 0x1
125 // Store the framework vfr option key value
127 typedef struct _EFI_IFR_GUID_OPTIONKEY
{
128 EFI_IFR_OP_HEADER Header
;
131 EFI_QUESTION_ID QuestionId
;
132 EFI_IFR_TYPE_VALUE OptionValue
;
134 } EFI_IFR_GUID_OPTIONKEY
;
138 // Store the framework vfr vareqval name number
140 typedef struct _EFI_IFR_GUID_VAREQNAME
{
141 EFI_IFR_OP_HEADER Header
;
144 EFI_QUESTION_ID QuestionId
;
145 EFI_STRING_ID NameId
;
146 } EFI_IFR_GUID_VAREQNAME
;