2 Function and Macro defintions for IFR parsing. To get the default value from IFR package, the IFR
3 opcode needs to be parsed. Most of code is taken from MdeModulePkg\Universal\SetupBrowserDxe\IfrParse.c.
5 Copyright (c) 2008, Intel Corporation
6 All rights reserved. This program and the accompanying materials
7 are licensed and made available under the terms and conditions of the BSD License
8 which accompanies this distribution. The full text of the license may be found at
9 http://opensource.org/licenses/bsd-license.php
11 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
12 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
16 #ifndef _HII_THUNK_UEFI_IFR_PARSER_
17 #define _HII_THUNK_UEFI_IFR_PARSER_
21 #include <Protocol/Print.h>
22 #include <Protocol/HiiConfigAccess.h>
23 #include <Protocol/HiiConfigRouting.h>
24 #include <Protocol/HiiDatabase.h>
25 #include <Protocol/HiiString.h>
28 // IFR relative definition
30 #define EFI_HII_EXPRESSION_INCONSISTENT_IF 0
31 #define EFI_HII_EXPRESSION_NO_SUBMIT_IF 1
32 #define EFI_HII_EXPRESSION_GRAY_OUT_IF 2
33 #define EFI_HII_EXPRESSION_SUPPRESS_IF 3
34 #define EFI_HII_EXPRESSION_DISABLE_IF 4
35 #define EFI_HII_EXPRESSION_VALUE 5
36 #define EFI_HII_EXPRESSION_RULE 6
38 #define EFI_HII_VARSTORE_BUFFER 0
39 #define EFI_HII_VARSTORE_NAME_VALUE 1
40 #define EFI_HII_VARSTORE_EFI_VARIABLE 2
42 #define FORM_INCONSISTENT_VALIDATION 0
43 #define FORM_NO_SUBMIT_VALIDATION 1
45 extern EFI_GUID gTianoHiiIfrGuid
;
50 EFI_IFR_TYPE_VALUE Value
;
53 #define NAME_VALUE_NODE_SIGNATURE EFI_SIGNATURE_32 ('N', 'V', 'S', 'T')
63 #define NAME_VALUE_NODE_FROM_LINK(a) CR (a, NAME_VALUE_NODE, Link, NAME_VALUE_NODE_SIGNATURE)
65 #define FORMSET_STORAGE_SIGNATURE EFI_SIGNATURE_32 ('F', 'S', 'T', 'G')
71 UINT8 Type
; // Storage type
76 CHAR16
*Name
; // For EFI_IFR_VARSTORE
79 UINT8
*EditBuffer
; // Edit copy for Buffer Storage
81 LIST_ENTRY NameValueListHead
; // List of NAME_VALUE_NODE
83 UINT32 Attributes
; // For EFI_IFR_VARSTORE_EFI: EFI Variable attribute
85 CHAR16
*ConfigHdr
; // <ConfigHdr>
86 CHAR16
*ConfigRequest
; // <ConfigRequest> = <ConfigHdr> + <RequestElement>
87 UINTN ElementCount
; // Number of <RequestElement> in the <ConfigRequest>
88 UINTN SpareStrLen
; // Spare length of ConfigRequest string buffer
91 #define FORMSET_STORAGE_FROM_LINK(a) CR (a, FORMSET_STORAGE, Link, FORMSET_STORAGE_SIGNATURE)
93 #define EXPRESSION_OPCODE_SIGNATURE EFI_SIGNATURE_32 ('E', 'X', 'O', 'P')
101 UINT8 Format
; // For EFI_IFR_TO_STRING, EFI_IFR_FIND
102 UINT8 Flags
; // For EFI_IFR_SPAN
103 UINT8 RuleId
; // For EFI_IFR_RULE_REF
105 EFI_HII_VALUE Value
; // For EFI_IFR_EQ_ID_VAL, EFI_IFR_UINT64, EFI_IFR_UINT32, EFI_IFR_UINT16, EFI_IFR_UINT8, EFI_IFR_STRING_REF1
107 EFI_QUESTION_ID QuestionId
; // For EFI_IFR_EQ_ID_ID, EFI_IFR_EQ_ID_LIST, EFI_IFR_QUESTION_REF1
108 EFI_QUESTION_ID QuestionId2
;
110 UINT16 ListLength
; // For EFI_IFR_EQ_ID_LIST
113 EFI_STRING_ID DevicePath
; // For EFI_IFR_QUESTION_REF3_2, EFI_IFR_QUESTION_REF3_3
117 #define EXPRESSION_OPCODE_FROM_LINK(a) CR (a, EXPRESSION_OPCODE, Link, EXPRESSION_OPCODE_SIGNATURE)
119 #define FORM_EXPRESSION_SIGNATURE EFI_SIGNATURE_32 ('F', 'E', 'X', 'P')
125 UINT8 Type
; // Type for this expression
127 UINT8 RuleId
; // For EFI_IFR_RULE only
128 EFI_STRING_ID Error
; // For EFI_IFR_NO_SUBMIT_IF, EFI_IFR_INCONSISTENT_IF only
130 EFI_HII_VALUE Result
; // Expression evaluation result
132 LIST_ENTRY OpCodeListHead
; // OpCodes consist of this expression (EXPRESSION_OPCODE)
135 #define FORM_EXPRESSION_FROM_LINK(a) CR (a, FORM_EXPRESSION, Link, FORM_EXPRESSION_SIGNATURE)
137 #define QUESTION_DEFAULT_SIGNATURE EFI_SIGNATURE_32 ('Q', 'D', 'F', 'T')
144 EFI_HII_VALUE Value
; // Default value
146 FORM_EXPRESSION
*ValueExpression
; // Not-NULL indicates default value is provided by EFI_IFR_VALUE
149 #define QUESTION_DEFAULT_FROM_LINK(a) CR (a, QUESTION_DEFAULT, Link, QUESTION_DEFAULT_SIGNATURE)
151 #define QUESTION_OPTION_SIGNATURE EFI_SIGNATURE_32 ('Q', 'O', 'P', 'T')
160 EFI_IMAGE_ID ImageId
;
162 FORM_EXPRESSION
*SuppressExpression
; // Non-NULL indicates nested inside of SuppressIf
165 #define QUESTION_OPTION_FROM_LINK(a) CR (a, QUESTION_OPTION, Link, QUESTION_OPTION_SIGNATURE)
167 #define FORM_BROWSER_STATEMENT_SIGNATURE EFI_SIGNATURE_32 ('F', 'S', 'T', 'A')
172 UINT8 Operand
; // The operand (first byte) of this Statement or Question
177 EFI_STRING_ID Prompt
;
179 EFI_STRING_ID TextTwo
; // For EFI_IFR_TEXT
184 EFI_QUESTION_ID QuestionId
; // The value of zero is reserved
185 EFI_VARSTORE_ID VarStoreId
; // A value of zero indicates no variable storage
186 FORMSET_STORAGE
*Storage
;
188 EFI_STRING_ID VarName
;
193 CHAR16
*VariableName
; // Name/Value or EFI Variable name
194 CHAR16
*BlockName
; // Buffer storage block name: "OFFSET=...WIDTH=..."
196 EFI_HII_VALUE HiiValue
; // Edit copy for checkbox, numberic, oneof
197 UINT8
*BufferValue
; // Edit copy for string, password, orderedlist
200 // OpCode specific members
202 UINT8 Flags
; // for EFI_IFR_CHECKBOX, EFI_IFR_DATE, EFI_IFR_NUMERIC, EFI_IFR_ONE_OF,
203 // EFI_IFR_ORDERED_LIST, EFI_IFR_STRING,EFI_IFR_SUBTITLE,EFI_IFR_TIME, EFI_IFR_BANNER
204 UINT8 MaxContainers
; // for EFI_IFR_ORDERED_LIST
206 UINT16 BannerLineNumber
; // for EFI_IFR_BANNER, 1-based line number
207 EFI_STRING_ID QuestionConfig
; // for EFI_IFR_ACTION, if 0 then no configuration string will be processed
209 UINT64 Minimum
; // for EFI_IFR_ONE_OF/EFI_IFR_NUMERIC, it's Min/Max value
210 UINT64 Maximum
; // for EFI_IFR_STRING/EFI_IFR_PASSWORD, it's Min/Max length
213 EFI_DEFAULT_ID DefaultId
; // for EFI_IFR_RESET_BUTTON
214 EFI_FORM_ID RefFormId
; // for EFI_IFR_REF
215 EFI_QUESTION_ID RefQuestionId
; // for EFI_IFR_REF2
216 EFI_GUID RefFormSetId
; // for EFI_IFR_REF3
217 EFI_STRING_ID RefDevicePath
; // for EFI_IFR_REF4
220 // Get from IFR parsing
222 FORM_EXPRESSION
*ValueExpression
; // nested EFI_IFR_VALUE, provide Question value and indicate Question is ReadOnly
223 LIST_ENTRY DefaultListHead
; // nested EFI_IFR_DEFAULT list (QUESTION_DEFAULT), provide default values
224 LIST_ENTRY OptionListHead
; // nested EFI_IFR_ONE_OF_OPTION list (QUESTION_OPTION)
226 EFI_IMAGE_ID ImageId
; // nested EFI_IFR_IMAGE
227 UINT8 RefreshInterval
; // nested EFI_IFR_REFRESH, refresh interval(in seconds) for Question value, 0 means no refresh
228 BOOLEAN InSubtitle
; // nesting inside of EFI_IFR_SUBTITLE
230 LIST_ENTRY InconsistentListHead
;// nested inconsistent expression list (FORM_EXPRESSION)
231 LIST_ENTRY NoSubmitListHead
; // nested nosubmit expression list (FORM_EXPRESSION)
232 FORM_EXPRESSION
*GrayOutExpression
; // nesting inside of GrayOutIf
233 FORM_EXPRESSION
*SuppressExpression
; // nesting inside of SuppressIf
235 } FORM_BROWSER_STATEMENT
;
237 #define FORM_BROWSER_STATEMENT_FROM_LINK(a) CR (a, FORM_BROWSER_STATEMENT, Link, FORM_BROWSER_STATEMENT_SIGNATURE)
239 #define FORM_BROWSER_FORM_SIGNATURE EFI_SIGNATURE_32 ('F', 'F', 'R', 'M')
246 EFI_STRING_ID FormTitle
;
248 EFI_IMAGE_ID ImageId
;
250 LIST_ENTRY ExpressionListHead
; // List of Expressions (FORM_EXPRESSION)
251 LIST_ENTRY StatementListHead
; // List of Statements and Questions (FORM_BROWSER_STATEMENT)
254 #define FORM_BROWSER_FORM_FROM_LINK(a) CR (a, FORM_BROWSER_FORM, Link, FORM_BROWSER_FORM_SIGNATURE)
256 #define FORMSET_DEFAULTSTORE_SIGNATURE EFI_SIGNATURE_32 ('F', 'D', 'F', 'S')
263 EFI_STRING_ID DefaultName
;
264 } FORMSET_DEFAULTSTORE
;
266 #define FORMSET_DEFAULTSTORE_FROM_LINK(a) CR (a, FORMSET_DEFAULTSTORE, Link, FORMSET_DEFAULTSTORE_SIGNATURE)
269 EFI_HII_HANDLE HiiHandle
;
270 EFI_HANDLE DriverHandle
;
271 EFI_HII_CONFIG_ACCESS_PROTOCOL
*ConfigAccess
;
272 EFI_DEVICE_PATH_PROTOCOL
*DevicePath
;
274 UINTN IfrBinaryLength
;
275 UINT8
*IfrBinaryData
;
278 EFI_STRING_ID FormSetTitle
;
282 EFI_IMAGE_ID ImageId
;
284 FORM_BROWSER_STATEMENT
*StatementBuffer
; // Buffer for all Statements and Questions
285 EXPRESSION_OPCODE
*ExpressionBuffer
; // Buffer for all Expression OpCode
287 LIST_ENTRY StorageListHead
; // Storage list (FORMSET_STORAGE)
288 LIST_ENTRY DefaultStoreListHead
; // DefaultStore list (FORMSET_DEFAULTSTORE)
289 LIST_ENTRY FormListHead
; // Form list (FORM_BROWSER_FORM)
290 } FORM_BROWSER_FORMSET
;
295 IN FORM_BROWSER_FORMSET
*FormSet
,
296 IN FORM_BROWSER_FORM
*Form
,
297 IN OUT FORM_EXPRESSION
*Expression
303 IN FORM_BROWSER_FORMSET
*FormSet
309 IN OUT FORM_BROWSER_FORMSET
*FormSet