3 The definition of CFormPkg's member function
5 Copyright (c) 2004 - 2011, Intel Corporation. All rights reserved.<BR>
6 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 _EFIIFRCLASS_H_
17 #define _EFIIFRCLASS_H_
22 #include "VfrUtilityLib.h"
24 #define NO_QST_REFED "no question refered"
32 * The functions below are used for flags setting
34 static inline BOOLEAN
_FLAGS_ZERO (
41 static inline VOID
_FLAG_CLEAR (
49 static inline UINT8
_FLAG_TEST_AND_CLEAR (
54 UINT8 Ret
= Flags
& Mask
;
59 static inline UINT8
_IS_EQUAL (
64 return Flags
== Value
;
68 * The definition of CIfrBin
75 struct SPendingAssign
{
76 CHAR8
*mKey
; // key ! unique
82 struct SPendingAssign
*mNext
;
84 SPendingAssign (IN CHAR8
*, IN VOID
*, IN UINT32
, IN UINT32
, IN CONST CHAR8
*);
87 VOID
SetAddrAndLen (IN VOID
*, IN UINT32
);
88 VOID
AssignValue (IN VOID
*, IN UINT32
);
89 CHAR8
* GetKey (VOID
);
96 struct SBufferNode
*mNext
;
102 SBufferNode
*mBufferNodeQueueHead
;
103 SBufferNode
*mBufferNodeQueueTail
;
104 SBufferNode
*mCurrBufferNode
;
106 SBufferNode
*mReadBufferNode
;
107 UINT32 mReadBufferOffset
;
111 VOID
_WRITE_PKG_LINE (IN
FILE *, IN UINT32
, IN CONST CHAR8
*, IN CHAR8
*, IN UINT32
);
112 VOID
_WRITE_PKG_END (IN
FILE *, IN UINT32
, IN CONST CHAR8
*, IN CHAR8
*, IN UINT32
);
115 SPendingAssign
*PendingAssignList
;
118 CFormPkg (IN UINT32 BufferSize
);
121 CHAR8
* IfrBinBufferGet (IN UINT32
);
122 inline UINT32
GetPkgLength (VOID
);
125 UINT32
Read (IN CHAR8
*, IN UINT32
);
128 EFI_VFR_RETURN_CODE
BuildPkgHdr (OUT EFI_HII_PACKAGE_HEADER
**);
129 EFI_VFR_RETURN_CODE
BuildPkg (IN
FILE *, IN PACKAGE_DATA
*PkgData
= NULL
);
130 EFI_VFR_RETURN_CODE
BuildPkg (OUT PACKAGE_DATA
&);
131 EFI_VFR_RETURN_CODE
GenCFile (IN CHAR8
*, IN
FILE *, IN PACKAGE_DATA
*PkgData
= NULL
);
134 EFI_VFR_RETURN_CODE
AssignPending (IN CHAR8
*, IN VOID
*, IN UINT32
, IN UINT32
, IN CONST CHAR8
*Msg
= NULL
);
135 VOID
DoPendingAssign (IN CHAR8
*, IN VOID
*, IN UINT32
);
136 bool HavePendingUnassigned (VOID
);
137 VOID
PendingAssignPrintAll (VOID
);
138 EFI_VFR_RETURN_CODE
DeclarePendingQuestion (
139 IN CVfrVarDataTypeDB
&lCVfrVarDataTypeDB
,
140 IN CVfrDataStorage
&lCVfrDataStorage
,
141 IN CVfrQuestionDB
&lCVfrQuestionDB
,
142 IN EFI_GUID
*LocalFormSetGuid
,
147 extern CFormPkg gCFormPkg
;
160 #define EFI_IFR_RECORDINFO_IDX_INVALUD 0xFFFFFF
161 #define EFI_IFR_RECORDINFO_IDX_START 0x0
163 class CIfrRecordInfoDB
{
167 SIfrRecord
*mIfrRecordListHead
;
168 SIfrRecord
*mIfrRecordListTail
;
170 SIfrRecord
* GetRecordInfoFromIdx (IN UINT32
);
171 BOOLEAN
CheckQuestionOpCode (IN UINT8
);
172 BOOLEAN
CheckIdOpCode (IN UINT8
);
173 EFI_QUESTION_ID
GetOpcodeQuestionId (IN EFI_IFR_OP_HEADER
*);
175 CIfrRecordInfoDB (VOID
);
176 ~CIfrRecordInfoDB (VOID
);
178 inline VOID
TurnOn (VOID
) {
182 inline VOID
TurnOff (VOID
) {
186 UINT32
IfrRecordRegister (IN UINT32
, IN CHAR8
*, IN UINT8
, IN UINT32
);
187 VOID
IfrRecordInfoUpdate (IN UINT32
, IN UINT32
, IN CHAR8
*, IN UINT8
, IN UINT32
);
188 VOID
IfrRecordOutput (IN
FILE *, IN UINT32 LineNo
);
189 VOID
IfrRecordOutput (OUT PACKAGE_DATA
&);
190 EFI_VFR_RETURN_CODE
IfrRecordAdjust (VOID
);
193 extern CIfrRecordInfoDB gCIfrRecordInfoDB
;
196 * The definition of CIfrObj
198 extern BOOLEAN gCreateOp
;
211 CIfrObj (IN UINT8 OpCode
, OUT CHAR8
**IfrObj
= NULL
, IN UINT8 ObjBinLen
= 0, IN BOOLEAN DelayEmit
= FALSE
);
212 virtual ~CIfrObj(VOID
);
214 VOID
_EMIT_PENDING_OBJ (VOID
);
216 inline VOID
SetLineNo (IN UINT32 LineNo
) {
220 inline CHAR8
* GetObjBinAddr (VOID
) {
224 inline UINT8
GetObjBinLen (VOID
) {
228 inline bool ExpendObjBin (IN UINT8 Size
) {
229 if ((mDelayEmit
== TRUE
) && ((mObjBinLen
+ Size
) > mObjBinLen
)) {
230 mObjBinLen
= mObjBinLen
+ Size
;
239 * The definition of CIfrOpHeader
243 EFI_IFR_OP_HEADER
*mHeader
;
246 CIfrOpHeader (IN UINT8 OpCode
, IN VOID
*StartAddr
, IN UINT8 Length
= 0);
247 CIfrOpHeader (IN CIfrOpHeader
&);
249 VOID
IncLength (UINT8 Size
) {
250 if ((mHeader
->Length
+ Size
) > mHeader
->Length
) {
251 mHeader
->Length
= mHeader
->Length
+ Size
;
255 VOID
DecLength (UINT8 Size
) {
256 if (mHeader
->Length
>= Size
) {
262 return mHeader
->Length
;
266 return mHeader
->Scope
;
269 VOID
SetScope (IN UINT8 Scope
) {
270 mHeader
->Scope
= Scope
;
273 VOID
UpdateHeader (IN EFI_IFR_OP_HEADER
*Header
) {
278 extern UINT8 gScopeCount
;
281 * The definition of CIfrStatementHeader
283 class CIfrStatementHeader
{
285 EFI_IFR_STATEMENT_HEADER
*mHeader
;
288 CIfrStatementHeader (
289 IN EFI_IFR_STATEMENT_HEADER
*StartAddr
290 ) : mHeader ((EFI_IFR_STATEMENT_HEADER
*)StartAddr
) {
292 mHeader
->Help
= EFI_STRING_ID_INVALID
;
293 mHeader
->Prompt
= EFI_STRING_ID_INVALID
;
296 EFI_IFR_STATEMENT_HEADER
*GetStatementHeader () {
300 VOID
SetPrompt (IN EFI_STRING_ID Prompt
) {
301 mHeader
->Prompt
= Prompt
;
304 VOID
SetHelp (IN EFI_STRING_ID Help
) {
305 mHeader
->Help
= Help
;
310 * The definition of CIfrQuestionHeader
312 #define EFI_IFR_QUESTION_FLAG_DEFAULT 0
314 class CIfrQuestionHeader
: public CIfrStatementHeader
{
316 EFI_IFR_QUESTION_HEADER
*mHeader
;
318 EFI_IFR_STATEMENT_HEADER
* QH2SH (EFI_IFR_QUESTION_HEADER
*Qheader
) {
319 return &(Qheader
)->Header
;
323 EFI_QUESTION_ID
QUESTION_ID (VOID
) {
324 return mHeader
->QuestionId
;
327 EFI_VARSTORE_ID
VARSTORE_ID (VOID
) {
328 return mHeader
->VarStoreId
;
331 VOID
VARSTORE_INFO (OUT EFI_VARSTORE_INFO
*Info
) {
333 Info
->mVarStoreId
= mHeader
->VarStoreId
;
334 memcpy (&Info
->mVarStoreId
, &mHeader
->VarStoreInfo
, sizeof (Info
->mVarStoreId
));
339 return mHeader
->Flags
;
344 IN EFI_IFR_QUESTION_HEADER
*StartAddr
,
345 IN UINT8 Flags
= EFI_IFR_QUESTION_FLAG_DEFAULT
346 ) : CIfrStatementHeader (QH2SH(StartAddr
)) {
348 mHeader
->QuestionId
= EFI_QUESTION_ID_INVALID
;
349 mHeader
->VarStoreId
= EFI_VARSTORE_ID_INVALID
;
350 mHeader
->VarStoreInfo
.VarName
= EFI_STRING_ID_INVALID
;
351 mHeader
->VarStoreInfo
.VarOffset
= EFI_VAROFFSET_INVALID
;
352 mHeader
->Flags
= Flags
;
355 VOID
SetQuestionId (IN EFI_QUESTION_ID QuestionId
) {
356 mHeader
->QuestionId
= QuestionId
;
359 VOID
SetVarStoreInfo (IN EFI_VARSTORE_INFO
*Info
) {
360 mHeader
->VarStoreId
= Info
->mVarStoreId
;
361 mHeader
->VarStoreInfo
.VarName
= Info
->mInfo
.mVarName
;
362 mHeader
->VarStoreInfo
.VarOffset
= Info
->mInfo
.mVarOffset
;
365 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 Flags
) {
366 if (_FLAG_TEST_AND_CLEAR (Flags
, EFI_IFR_FLAG_READ_ONLY
)) {
367 mHeader
->Flags
|= EFI_IFR_FLAG_READ_ONLY
;
370 _FLAG_CLEAR (Flags
, 0x02);
372 if (_FLAG_TEST_AND_CLEAR (Flags
, EFI_IFR_FLAG_CALLBACK
)) {
373 mHeader
->Flags
|= EFI_IFR_FLAG_CALLBACK
;
377 // ignore NVAccessFlag
379 _FLAG_CLEAR (Flags
, 0x08);
381 if (_FLAG_TEST_AND_CLEAR (Flags
, EFI_IFR_FLAG_RESET_REQUIRED
)) {
382 mHeader
->Flags
|= EFI_IFR_FLAG_RESET_REQUIRED
;
386 // Set LateCheck Flag to compatible for framework flag
387 // but it uses 0x20 as its flag, if in the future UEFI may take this flag
389 if (_FLAG_TEST_AND_CLEAR (Flags
, 0x20)) {
390 mHeader
->Flags
|= 0x20;
393 if (_FLAG_TEST_AND_CLEAR (Flags
, EFI_IFR_FLAG_OPTIONS_ONLY
)) {
394 mHeader
->Flags
|= EFI_IFR_FLAG_OPTIONS_ONLY
;
397 return _FLAGS_ZERO (Flags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
402 * The definition of CIfrMinMaxStepData
404 class CIfrMinMaxStepData
{
406 MINMAXSTEP_DATA
*mMinMaxStepData
;
411 CIfrMinMaxStepData (MINMAXSTEP_DATA
*DataAddr
, BOOLEAN NumericOpcode
=FALSE
) : mMinMaxStepData (DataAddr
) {
412 mMinMaxStepData
->u64
.MinValue
= 0;
413 mMinMaxStepData
->u64
.MaxValue
= 0;
414 mMinMaxStepData
->u64
.Step
= 0;
416 IsNumeric
= NumericOpcode
;
419 VOID
SetMinMaxStepData (IN UINT64 MinValue
, IN UINT64 MaxValue
, IN UINT64 Step
) {
421 mMinMaxStepData
->u64
.MinValue
= MinValue
;
422 mMinMaxStepData
->u64
.MaxValue
= MaxValue
;
425 if (MinValue
< mMinMaxStepData
->u64
.MinValue
) {
426 mMinMaxStepData
->u64
.MinValue
= MinValue
;
428 if (MaxValue
> mMinMaxStepData
->u64
.MaxValue
) {
429 mMinMaxStepData
->u64
.MaxValue
= MaxValue
;
432 mMinMaxStepData
->u64
.Step
= Step
;
435 VOID
SetMinMaxStepData (IN UINT32 MinValue
, IN UINT32 MaxValue
, IN UINT32 Step
) {
437 mMinMaxStepData
->u32
.MinValue
= MinValue
;
438 mMinMaxStepData
->u32
.MaxValue
= MaxValue
;
441 if (MinValue
< mMinMaxStepData
->u32
.MinValue
) {
442 mMinMaxStepData
->u32
.MinValue
= MinValue
;
444 if (MaxValue
> mMinMaxStepData
->u32
.MaxValue
) {
445 mMinMaxStepData
->u32
.MaxValue
= MaxValue
;
448 mMinMaxStepData
->u32
.Step
= Step
;
451 VOID
SetMinMaxStepData (IN UINT16 MinValue
, IN UINT16 MaxValue
, IN UINT16 Step
) {
453 mMinMaxStepData
->u16
.MinValue
= MinValue
;
454 mMinMaxStepData
->u16
.MaxValue
= MaxValue
;
457 if (MinValue
< mMinMaxStepData
->u16
.MinValue
) {
458 mMinMaxStepData
->u16
.MinValue
= MinValue
;
460 if (MaxValue
> mMinMaxStepData
->u16
.MaxValue
) {
461 mMinMaxStepData
->u16
.MaxValue
= MaxValue
;
464 mMinMaxStepData
->u16
.Step
= Step
;
467 VOID
SetMinMaxStepData (IN UINT8 MinValue
, IN UINT8 MaxValue
, IN UINT8 Step
) {
469 mMinMaxStepData
->u8
.MinValue
= MinValue
;
470 mMinMaxStepData
->u8
.MaxValue
= MaxValue
;
473 if (MinValue
< mMinMaxStepData
->u8
.MinValue
) {
474 mMinMaxStepData
->u8
.MinValue
= MinValue
;
476 if (MaxValue
> mMinMaxStepData
->u8
.MaxValue
) {
477 mMinMaxStepData
->u8
.MaxValue
= MaxValue
;
480 mMinMaxStepData
->u8
.Step
= Step
;
483 UINT64
GetMinData (UINT8 VarType
) {
486 case EFI_IFR_TYPE_NUM_SIZE_64
:
487 MinValue
= mMinMaxStepData
->u64
.MinValue
;
489 case EFI_IFR_TYPE_NUM_SIZE_32
:
490 MinValue
= (UINT64
) mMinMaxStepData
->u32
.MinValue
;
492 case EFI_IFR_TYPE_NUM_SIZE_16
:
493 MinValue
= (UINT64
) mMinMaxStepData
->u16
.MinValue
;
495 case EFI_IFR_TYPE_NUM_SIZE_8
:
496 MinValue
= (UINT64
) mMinMaxStepData
->u8
.MinValue
;
504 UINT64
GetMaxData (UINT8 VarType
) {
507 case EFI_IFR_TYPE_NUM_SIZE_64
:
508 MaxValue
= mMinMaxStepData
->u64
.MaxValue
;
510 case EFI_IFR_TYPE_NUM_SIZE_32
:
511 MaxValue
= (UINT64
) mMinMaxStepData
->u32
.MaxValue
;
513 case EFI_IFR_TYPE_NUM_SIZE_16
:
514 MaxValue
= (UINT64
) mMinMaxStepData
->u16
.MaxValue
;
516 case EFI_IFR_TYPE_NUM_SIZE_8
:
517 MaxValue
= (UINT64
) mMinMaxStepData
->u8
.MaxValue
;
525 UINT64
GetStepData (UINT8 VarType
) {
528 case EFI_IFR_TYPE_NUM_SIZE_64
:
529 MaxValue
= mMinMaxStepData
->u64
.Step
;
531 case EFI_IFR_TYPE_NUM_SIZE_32
:
532 MaxValue
= (UINT64
) mMinMaxStepData
->u32
.Step
;
534 case EFI_IFR_TYPE_NUM_SIZE_16
:
535 MaxValue
= (UINT64
) mMinMaxStepData
->u16
.Step
;
537 case EFI_IFR_TYPE_NUM_SIZE_8
:
538 MaxValue
= (UINT64
) mMinMaxStepData
->u8
.Step
;
546 BOOLEAN
IsNumericOpcode () {
551 static CIfrQuestionHeader
*gCurrentQuestion
= NULL
;
552 static CIfrMinMaxStepData
*gCurrentMinMaxData
= NULL
;
555 * The definition of all of the UEFI IFR Objects
557 class CIfrFormSet
: public CIfrObj
, public CIfrOpHeader
{
559 EFI_IFR_FORM_SET
*mFormSet
;
560 EFI_GUID
*mClassGuid
;
563 CIfrFormSet (UINT8 Size
) : CIfrObj (EFI_IFR_FORM_SET_OP
, (CHAR8
**)&mFormSet
, Size
),
564 CIfrOpHeader (EFI_IFR_FORM_SET_OP
, &mFormSet
->Header
, Size
) {
565 mFormSet
->Help
= EFI_STRING_ID_INVALID
;
566 mFormSet
->FormSetTitle
= EFI_STRING_ID_INVALID
;
568 memset (&mFormSet
->Guid
, 0, sizeof (EFI_GUID
));
569 mClassGuid
= (EFI_GUID
*) (mFormSet
+ 1);
572 VOID
SetGuid (IN EFI_GUID
*Guid
) {
573 memcpy (&mFormSet
->Guid
, Guid
, sizeof (EFI_GUID
));
576 VOID
SetFormSetTitle (IN EFI_STRING_ID FormSetTitle
) {
577 mFormSet
->FormSetTitle
= FormSetTitle
;
580 VOID
SetHelp (IN EFI_STRING_ID Help
) {
581 mFormSet
->Help
= Help
;
584 VOID
SetClassGuid (IN EFI_GUID
*Guid
) {
585 memcpy (&(mClassGuid
[mFormSet
->Flags
++]), Guid
, sizeof (EFI_GUID
));
589 return mFormSet
->Flags
;
593 class CIfrEnd
: public CIfrObj
, public CIfrOpHeader
{
598 CIfrEnd () : CIfrObj (EFI_IFR_END_OP
, (CHAR8
**)&mEnd
),
599 CIfrOpHeader (EFI_IFR_END_OP
, &mEnd
->Header
) {}
602 class CIfrDefaultStore
: public CIfrObj
, public CIfrOpHeader
{
604 EFI_IFR_DEFAULTSTORE
*mDefaultStore
;
607 CIfrDefaultStore () : CIfrObj (EFI_IFR_DEFAULTSTORE_OP
, (CHAR8
**)&mDefaultStore
),
608 CIfrOpHeader (EFI_IFR_DEFAULTSTORE_OP
, &mDefaultStore
->Header
) {
609 mDefaultStore
->DefaultId
= EFI_VARSTORE_ID_INVALID
;
610 mDefaultStore
->DefaultName
= EFI_STRING_ID_INVALID
;
613 VOID
SetDefaultName (IN EFI_STRING_ID DefaultName
) {
614 mDefaultStore
->DefaultName
= DefaultName
;
617 VOID
SetDefaultId (IN UINT16 DefaultId
) {
618 mDefaultStore
->DefaultId
= DefaultId
;
622 #define EFI_FORM_ID_MAX 0xFFFF
623 #define EFI_FREE_FORM_ID_BITMAP_SIZE ((EFI_FORM_ID_MAX + 1) / EFI_BITS_PER_UINT32)
627 STATIC UINT32 FormIdBitMap
[EFI_FREE_FORM_ID_BITMAP_SIZE
];
629 STATIC BOOLEAN
ChekFormIdFree (IN EFI_FORM_ID FormId
) {
630 UINT32 Index
= (FormId
/ EFI_BITS_PER_UINT32
);
631 UINT32 Offset
= (FormId
% EFI_BITS_PER_UINT32
);
633 return (FormIdBitMap
[Index
] & (0x80000000 >> Offset
)) == 0;
636 STATIC VOID
MarkFormIdUsed (IN EFI_FORM_ID FormId
) {
637 UINT32 Index
= (FormId
/ EFI_BITS_PER_UINT32
);
638 UINT32 Offset
= (FormId
% EFI_BITS_PER_UINT32
);
640 FormIdBitMap
[Index
] |= (0x80000000 >> Offset
);
644 class CIfrForm
: public CIfrObj
, public CIfrOpHeader
{
649 CIfrForm () : CIfrObj (EFI_IFR_FORM_OP
, (CHAR8
**)&mForm
),
650 CIfrOpHeader (EFI_IFR_FORM_OP
, &mForm
->Header
) {
652 mForm
->FormTitle
= EFI_STRING_ID_INVALID
;
655 EFI_VFR_RETURN_CODE
SetFormId (IN EFI_FORM_ID FormId
) {
658 // FormId can't be 0.
660 return VFR_RETURN_INVALID_PARAMETER
;
662 if (CIfrFormId::ChekFormIdFree (FormId
) == FALSE
) {
663 return VFR_RETURN_FORMID_REDEFINED
;
665 mForm
->FormId
= FormId
;
666 CIfrFormId::MarkFormIdUsed (FormId
);
667 return VFR_RETURN_SUCCESS
;
670 VOID
SetFormTitle (IN EFI_STRING_ID FormTitle
) {
671 mForm
->FormTitle
= FormTitle
;
675 class CIfrFormMap
: public CIfrObj
, public CIfrOpHeader
{
677 EFI_IFR_FORM_MAP
*mFormMap
;
678 EFI_IFR_FORM_MAP_METHOD
*mMethodMap
;
681 CIfrFormMap () : CIfrObj (EFI_IFR_FORM_MAP_OP
, (CHAR8
**)&mFormMap
, sizeof (EFI_IFR_FORM_MAP
), TRUE
),
682 CIfrOpHeader (EFI_IFR_FORM_MAP_OP
, &mFormMap
->Header
) {
683 mFormMap
->FormId
= 0;
684 mMethodMap
= (EFI_IFR_FORM_MAP_METHOD
*) (mFormMap
+ 1);
687 EFI_VFR_RETURN_CODE
SetFormId (IN EFI_FORM_ID FormId
) {
690 // FormId can't be 0.
692 return VFR_RETURN_INVALID_PARAMETER
;
694 if (CIfrFormId::ChekFormIdFree (FormId
) == FALSE
) {
695 return VFR_RETURN_FORMID_REDEFINED
;
697 mFormMap
->FormId
= FormId
;
698 CIfrFormId::MarkFormIdUsed (FormId
);
699 return VFR_RETURN_SUCCESS
;
702 VOID
SetFormMapMethod (IN EFI_STRING_ID MethodTitle
, IN EFI_GUID
*MethodGuid
) {
703 if (ExpendObjBin (sizeof (EFI_IFR_FORM_MAP_METHOD
))) {
704 IncLength (sizeof (EFI_IFR_FORM_MAP_METHOD
));
706 mMethodMap
->MethodTitle
= MethodTitle
;
707 memcpy (&(mMethodMap
->MethodIdentifier
), MethodGuid
, sizeof (EFI_GUID
));
713 class CIfrVarStore
: public CIfrObj
, public CIfrOpHeader
{
715 EFI_IFR_VARSTORE
*mVarStore
;
718 CIfrVarStore () : CIfrObj (EFI_IFR_VARSTORE_OP
, (CHAR8
**)&mVarStore
, sizeof (EFI_IFR_VARSTORE
), TRUE
),
719 CIfrOpHeader (EFI_IFR_VARSTORE_OP
, &mVarStore
->Header
) {
720 mVarStore
->VarStoreId
= EFI_VARSTORE_ID_INVALID
;
722 memset (&mVarStore
->Guid
, 0, sizeof (EFI_GUID
));
723 mVarStore
->Name
[0] = '\0';
726 VOID
SetGuid (IN EFI_GUID
*Guid
) {
727 memcpy (&mVarStore
->Guid
, Guid
, sizeof (EFI_GUID
));
730 VOID
SetVarStoreId (IN EFI_VARSTORE_ID VarStoreId
) {
731 mVarStore
->VarStoreId
= VarStoreId
;
734 VOID
SetSize (IN UINT16 Size
) {
735 mVarStore
->Size
= Size
;
738 VOID
SetName (IN CHAR8
*Name
) {
742 Len
= (UINT8
) strlen (Name
);
744 if (ExpendObjBin (Len
) == TRUE
) {
746 strcpy ((CHAR8
*)(mVarStore
->Name
), Name
);
753 class CIfrVarStoreEfi
: public CIfrObj
, public CIfrOpHeader
{
755 EFI_IFR_VARSTORE_EFI
*mVarStoreEfi
;
758 CIfrVarStoreEfi () : CIfrObj (EFI_IFR_VARSTORE_EFI_OP
, (CHAR8
**)&mVarStoreEfi
),
759 CIfrOpHeader (EFI_IFR_VARSTORE_EFI_OP
, &mVarStoreEfi
->Header
) {
760 mVarStoreEfi
->VarStoreId
= EFI_VAROFFSET_INVALID
;
761 memset (&mVarStoreEfi
->Guid
, 0, sizeof (EFI_GUID
));
764 VOID
SetGuid (IN EFI_GUID
*Guid
) {
765 memcpy (&mVarStoreEfi
->Guid
, Guid
, sizeof (EFI_GUID
));
768 VOID
SetVarStoreId (IN UINT16 VarStoreId
) {
769 mVarStoreEfi
->VarStoreId
= VarStoreId
;
772 VOID
SetAttributes (IN UINT32 Attributes
) {
773 mVarStoreEfi
->Attributes
= Attributes
;
777 class CIfrVarStoreNameValue
: public CIfrObj
, public CIfrOpHeader
{
779 EFI_IFR_VARSTORE_NAME_VALUE
*mVarStoreNameValue
;
782 CIfrVarStoreNameValue () : CIfrObj (EFI_IFR_VARSTORE_NAME_VALUE_OP
, (CHAR8
**)&mVarStoreNameValue
),
783 CIfrOpHeader (EFI_IFR_VARSTORE_NAME_VALUE_OP
, &mVarStoreNameValue
->Header
) {
784 mVarStoreNameValue
->VarStoreId
= EFI_VAROFFSET_INVALID
;
785 memset (&mVarStoreNameValue
->Guid
, 0, sizeof (EFI_GUID
));
788 VOID
SetGuid (IN EFI_GUID
*Guid
) {
789 memcpy (&mVarStoreNameValue
->Guid
, Guid
, sizeof (EFI_GUID
));
792 VOID
SetVarStoreId (IN UINT16 VarStoreId
) {
793 mVarStoreNameValue
->VarStoreId
= VarStoreId
;
797 class CIfrImage
: public CIfrObj
, public CIfrOpHeader
{
799 EFI_IFR_IMAGE
*mImage
;
802 CIfrImage () : CIfrObj (EFI_IFR_IMAGE_OP
, (CHAR8
**)&mImage
),
803 CIfrOpHeader (EFI_IFR_FORM_OP
, &mImage
->Header
) {
804 mImage
->Id
= EFI_IMAGE_ID_INVALID
;
807 VOID
SetImageId (IN EFI_IMAGE_ID ImageId
) {
808 mImage
->Id
= ImageId
;
812 class CIfrLocked
: public CIfrObj
, public CIfrOpHeader
{
814 EFI_IFR_LOCKED
*mLocked
;
817 CIfrLocked () : CIfrObj (EFI_IFR_LOCKED_OP
, (CHAR8
**)&mLocked
),
818 CIfrOpHeader (EFI_IFR_LOCKED_OP
, &mLocked
->Header
) {}
821 class CIfrRule
: public CIfrObj
, public CIfrOpHeader
{
826 CIfrRule () : CIfrObj (EFI_IFR_RULE_OP
, (CHAR8
**)&mRule
),
827 mRule ((EFI_IFR_RULE
*)GetObjBinAddr()),
828 CIfrOpHeader (EFI_IFR_RULE_OP
, &mRule
->Header
) {
829 mRule
->RuleId
= EFI_RULE_ID_INVALID
;
832 VOID
SetRuleId (IN UINT8 RuleId
) {
833 mRule
->RuleId
= RuleId
;
837 static EFI_IFR_TYPE_VALUE gZeroEfiIfrTypeValue
= {0, };
839 class CIfrDefault
: public CIfrObj
, public CIfrOpHeader
{
841 EFI_IFR_DEFAULT
*mDefault
;
845 IN UINT16 DefaultId
= EFI_HII_DEFAULT_CLASS_STANDARD
,
846 IN UINT8 Type
= EFI_IFR_TYPE_OTHER
,
847 IN EFI_IFR_TYPE_VALUE Value
= gZeroEfiIfrTypeValue
848 ) : CIfrObj (EFI_IFR_DEFAULT_OP
, (CHAR8
**)&mDefault
),
849 CIfrOpHeader (EFI_IFR_DEFAULT_OP
, &mDefault
->Header
) {
850 mDefault
->Type
= Type
;
851 mDefault
->Value
= Value
;
852 mDefault
->DefaultId
= DefaultId
;
855 VOID
SetDefaultId (IN UINT16 DefaultId
) {
856 mDefault
->DefaultId
= DefaultId
;
859 VOID
SetType (IN UINT8 Type
) {
860 mDefault
->Type
= Type
;
863 VOID
SetValue (IN EFI_IFR_TYPE_VALUE Value
) {
864 mDefault
->Value
= Value
;
868 class CIfrValue
: public CIfrObj
, public CIfrOpHeader
{
870 EFI_IFR_VALUE
*mValue
;
873 CIfrValue () : CIfrObj (EFI_IFR_VALUE_OP
, (CHAR8
**)&mValue
),
874 CIfrOpHeader (EFI_IFR_VALUE_OP
, &mValue
->Header
) {}
878 class CIfrRead
: public CIfrObj
, public CIfrOpHeader
{
883 CIfrRead () : CIfrObj (EFI_IFR_READ_OP
, (CHAR8
**)&mRead
),
884 CIfrOpHeader (EFI_IFR_READ_OP
, &mRead
->Header
) {}
888 class CIfrWrite
: public CIfrObj
, public CIfrOpHeader
{
890 EFI_IFR_WRITE
*mWrite
;
893 CIfrWrite () : CIfrObj (EFI_IFR_WRITE_OP
, (CHAR8
**)&mWrite
),
894 CIfrOpHeader (EFI_IFR_WRITE_OP
, &mWrite
->Header
) {}
898 class CIfrGet
: public CIfrObj
, public CIfrOpHeader
{
905 ) : CIfrObj (EFI_IFR_GET_OP
, (CHAR8
**)&mGet
),
906 CIfrOpHeader (EFI_IFR_GET_OP
, &mGet
->Header
) {
910 VOID
SetVarInfo (IN EFI_VARSTORE_INFO
*Info
) {
911 mGet
->VarStoreId
= Info
->mVarStoreId
;
912 mGet
->VarStoreInfo
.VarName
= Info
->mInfo
.mVarName
;
913 mGet
->VarStoreInfo
.VarOffset
= Info
->mInfo
.mVarOffset
;
914 mGet
->VarStoreType
= Info
->mVarType
;
918 class CIfrSet
: public CIfrObj
, public CIfrOpHeader
{
925 ) : CIfrObj (EFI_IFR_SET_OP
, (CHAR8
**)&mSet
),
926 CIfrOpHeader (EFI_IFR_SET_OP
, &mSet
->Header
) {
930 VOID
SetVarInfo (IN EFI_VARSTORE_INFO
*Info
) {
931 mSet
->VarStoreId
= Info
->mVarStoreId
;
932 mSet
->VarStoreInfo
.VarName
= Info
->mInfo
.mVarName
;
933 mSet
->VarStoreInfo
.VarOffset
= Info
->mInfo
.mVarOffset
;
934 mSet
->VarStoreType
= Info
->mVarType
;
938 class CIfrSubtitle
: public CIfrObj
, public CIfrOpHeader
, public CIfrStatementHeader
{
940 EFI_IFR_SUBTITLE
*mSubtitle
;
943 CIfrSubtitle () : CIfrObj (EFI_IFR_SUBTITLE_OP
, (CHAR8
**)&mSubtitle
),
944 CIfrOpHeader (EFI_IFR_SUBTITLE_OP
, &mSubtitle
->Header
),
945 CIfrStatementHeader (&mSubtitle
->Statement
) {
946 mSubtitle
->Flags
= 0;
949 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 LFlags
) {
950 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_FLAGS_HORIZONTAL
)) {
951 mSubtitle
->Flags
|= EFI_IFR_FLAGS_HORIZONTAL
;
954 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
958 class CIfrText
: public CIfrObj
, public CIfrOpHeader
, public CIfrStatementHeader
{
963 CIfrText () : CIfrObj (EFI_IFR_TEXT_OP
, (CHAR8
**)&mText
),
964 CIfrOpHeader (EFI_IFR_TEXT_OP
, &mText
->Header
),
965 CIfrStatementHeader (&mText
->Statement
) {
966 mText
->TextTwo
= EFI_STRING_ID_INVALID
;
969 VOID
SetTextTwo (IN EFI_STRING_ID StringId
) {
970 mText
->TextTwo
= StringId
;
974 class CIfrRef
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
979 CIfrRef () : CIfrObj (EFI_IFR_REF_OP
, (CHAR8
**)&mRef
),
980 CIfrOpHeader (EFI_IFR_REF_OP
, &mRef
->Header
),
981 CIfrQuestionHeader (&mRef
->Question
) {
985 VOID
SetFormId (IN EFI_FORM_ID FormId
) {
986 mRef
->FormId
= FormId
;
990 class CIfrRef2
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
995 CIfrRef2 () : CIfrObj (EFI_IFR_REF_OP
, (CHAR8
**)&mRef2
, sizeof (EFI_IFR_REF2
)),
996 CIfrOpHeader (EFI_IFR_REF_OP
, &mRef2
->Header
, sizeof (EFI_IFR_REF2
)),
997 CIfrQuestionHeader (&mRef2
->Question
) {
999 mRef2
->QuestionId
= EFI_QUESTION_ID_INVALID
;
1002 VOID
SetFormId (IN EFI_FORM_ID FormId
) {
1003 mRef2
->FormId
= FormId
;
1006 EFI_VFR_RETURN_CODE
SetQuestionId (IN EFI_QUESTION_ID QuestionId
) {
1007 if (QuestionId
== EFI_QUESTION_ID_INVALID
) {
1008 return VFR_RETURN_UNDEFINED
;
1010 mRef2
->QuestionId
= QuestionId
;
1011 return VFR_RETURN_SUCCESS
;
1015 class CIfrRef3
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1017 EFI_IFR_REF3
*mRef3
;
1020 CIfrRef3 () : CIfrObj (EFI_IFR_REF_OP
, (CHAR8
**)&mRef3
, sizeof(EFI_IFR_REF3
)),
1021 CIfrOpHeader (EFI_IFR_REF_OP
, &mRef3
->Header
, sizeof (EFI_IFR_REF3
)),
1022 CIfrQuestionHeader (&mRef3
->Question
) {
1024 mRef3
->QuestionId
= EFI_QUESTION_ID_INVALID
;
1025 memset (&mRef3
->FormSetId
, 0, sizeof (EFI_GUID
));
1028 VOID
SetFormId (IN EFI_FORM_ID FormId
) {
1029 mRef3
->FormId
= FormId
;
1032 VOID
SetQuestionId (IN EFI_QUESTION_ID QuestionId
) {
1033 mRef3
->QuestionId
= QuestionId
;
1036 VOID
SetFormSetId (IN EFI_GUID FormSetId
) {
1037 mRef3
->FormSetId
= FormSetId
;
1041 class CIfrRef4
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1043 EFI_IFR_REF4
*mRef4
;
1046 CIfrRef4 () : CIfrObj (EFI_IFR_REF_OP
, (CHAR8
**)&mRef4
, sizeof(EFI_IFR_REF3
)),
1047 CIfrOpHeader (EFI_IFR_REF_OP
, &mRef4
->Header
, sizeof (EFI_IFR_REF3
)),
1048 CIfrQuestionHeader (&mRef4
->Question
) {
1050 mRef4
->QuestionId
= EFI_QUESTION_ID_INVALID
;
1051 memset (&mRef4
->FormSetId
, 0, sizeof (EFI_GUID
));
1052 mRef4
->DevicePath
= EFI_STRING_ID_INVALID
;
1055 VOID
SetFormId (IN EFI_FORM_ID FormId
) {
1056 mRef4
->FormId
= FormId
;
1059 VOID
SetQuestionId (IN EFI_QUESTION_ID QuestionId
) {
1060 mRef4
->QuestionId
= QuestionId
;
1063 VOID
SetFormSetId (IN EFI_GUID FormSetId
) {
1064 mRef4
->FormSetId
= FormSetId
;
1067 VOID
SetDevicePath (IN EFI_STRING_ID DevicePath
) {
1068 mRef4
->DevicePath
= DevicePath
;
1072 class CIfrResetButton
: public CIfrObj
, public CIfrOpHeader
, public CIfrStatementHeader
{
1074 EFI_IFR_RESET_BUTTON
*mResetButton
;
1077 CIfrResetButton () : CIfrObj (EFI_IFR_RESET_BUTTON_OP
, (CHAR8
**)&mResetButton
),
1078 CIfrOpHeader (EFI_IFR_RESET_BUTTON_OP
, &mResetButton
->Header
),
1079 CIfrStatementHeader (&mResetButton
->Statement
) {
1080 mResetButton
->DefaultId
= EFI_HII_DEFAULT_CLASS_STANDARD
;
1083 VOID
SetDefaultId (IN UINT16 DefaultId
) {
1084 mResetButton
->DefaultId
= DefaultId
;
1088 class CIfrCheckBox
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1090 EFI_IFR_CHECKBOX
*mCheckBox
;
1093 CIfrCheckBox () : CIfrObj (EFI_IFR_CHECKBOX_OP
, (CHAR8
**)&mCheckBox
),
1094 CIfrOpHeader (EFI_IFR_CHECKBOX_OP
, &mCheckBox
->Header
),
1095 CIfrQuestionHeader (&mCheckBox
->Question
) {
1096 mCheckBox
->Flags
= 0;
1097 gCurrentQuestion
= this;
1101 gCurrentQuestion
= NULL
;
1104 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, UINT8 LFlags
) {
1105 EFI_VFR_RETURN_CODE Ret
;
1107 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1108 if (Ret
!= VFR_RETURN_SUCCESS
) {
1112 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_CHECKBOX_DEFAULT
)) {
1113 mCheckBox
->Flags
|= EFI_IFR_CHECKBOX_DEFAULT
;
1116 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_CHECKBOX_DEFAULT_MFG
)) {
1117 mCheckBox
->Flags
|= EFI_IFR_CHECKBOX_DEFAULT_MFG
;
1120 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1123 UINT8
GetFlags (VOID
) {
1124 return mCheckBox
->Flags
;
1128 class CIfrAction
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1130 EFI_IFR_ACTION
*mAction
;
1133 CIfrAction () : CIfrObj (EFI_IFR_ACTION_OP
, (CHAR8
**)&mAction
),
1134 CIfrOpHeader (EFI_IFR_ACTION_OP
, &mAction
->Header
),
1135 CIfrQuestionHeader (&mAction
->Question
) {
1136 mAction
->QuestionConfig
= EFI_STRING_ID_INVALID
;
1139 VOID
SetQuestionConfig (IN EFI_STRING_ID QuestionConfig
) {
1140 mAction
->QuestionConfig
= QuestionConfig
;
1144 class CIfrDate
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1146 EFI_IFR_DATE
*mDate
;
1149 CIfrDate () : CIfrObj (EFI_IFR_DATE_OP
, (CHAR8
**)&mDate
),
1150 CIfrOpHeader (EFI_IFR_DATE_OP
, &mDate
->Header
),
1151 CIfrQuestionHeader (&mDate
->Question
) {
1155 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
) {
1156 EFI_VFR_RETURN_CODE Ret
;
1158 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1159 if (Ret
!= VFR_RETURN_SUCCESS
) {
1163 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_QF_DATE_YEAR_SUPPRESS
)) {
1164 mDate
->Flags
|= EFI_QF_DATE_YEAR_SUPPRESS
;
1167 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_QF_DATE_MONTH_SUPPRESS
)) {
1168 mDate
->Flags
|= EFI_QF_DATE_MONTH_SUPPRESS
;
1171 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_QF_DATE_DAY_SUPPRESS
)) {
1172 mDate
->Flags
|= EFI_QF_DATE_DAY_SUPPRESS
;
1175 if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_DATE_STORAGE_NORMAL
)) {
1176 mDate
->Flags
|= QF_DATE_STORAGE_NORMAL
;
1177 } else if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_DATE_STORAGE_TIME
)) {
1178 mDate
->Flags
|= QF_DATE_STORAGE_TIME
;
1179 } else if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_DATE_STORAGE_WAKEUP
)) {
1180 mDate
->Flags
|= QF_DATE_STORAGE_WAKEUP
;
1183 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1187 class CIfrNumeric
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
, public CIfrMinMaxStepData
{
1189 EFI_IFR_NUMERIC
*mNumeric
;
1192 CIfrNumeric () : CIfrObj (EFI_IFR_NUMERIC_OP
, (CHAR8
**)&mNumeric
),
1193 CIfrOpHeader (EFI_IFR_NUMERIC_OP
, &mNumeric
->Header
),
1194 CIfrQuestionHeader (&mNumeric
->Question
),
1195 CIfrMinMaxStepData (&mNumeric
->data
, TRUE
) {
1196 mNumeric
->Flags
= EFI_IFR_NUMERIC_SIZE_1
| EFI_IFR_DISPLAY_UINT_DEC
;
1197 gCurrentQuestion
= this;
1198 gCurrentMinMaxData
= this;
1202 gCurrentQuestion
= NULL
;
1203 gCurrentMinMaxData
= NULL
;
1206 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
) {
1207 EFI_VFR_RETURN_CODE Ret
;
1209 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1210 if (Ret
!= VFR_RETURN_SUCCESS
) {
1214 if (LFlags
& EFI_IFR_DISPLAY
) {
1215 mNumeric
->Flags
= LFlags
;
1217 mNumeric
->Flags
= LFlags
| EFI_IFR_DISPLAY_UINT_DEC
;
1219 return VFR_RETURN_SUCCESS
;
1223 class CIfrOneOf
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
, public CIfrMinMaxStepData
{
1225 EFI_IFR_ONE_OF
*mOneOf
;
1228 CIfrOneOf () : CIfrObj (EFI_IFR_ONE_OF_OP
, (CHAR8
**)&mOneOf
),
1229 CIfrOpHeader (EFI_IFR_ONE_OF_OP
, &mOneOf
->Header
),
1230 CIfrQuestionHeader (&mOneOf
->Question
),
1231 CIfrMinMaxStepData (&mOneOf
->data
) {
1233 gCurrentQuestion
= this;
1234 gCurrentMinMaxData
= this;
1238 gCurrentQuestion
= NULL
;
1239 gCurrentMinMaxData
= NULL
;
1242 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
) {
1243 EFI_VFR_RETURN_CODE Ret
;
1245 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1246 if (Ret
!= VFR_RETURN_SUCCESS
) {
1250 if (LFlags
& EFI_IFR_DISPLAY
) {
1251 mOneOf
->Flags
= LFlags
;
1253 mOneOf
->Flags
= LFlags
| EFI_IFR_DISPLAY_UINT_DEC
;
1255 return VFR_RETURN_SUCCESS
;
1259 class CIfrString
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1261 EFI_IFR_STRING
*mString
;
1264 CIfrString () : CIfrObj (EFI_IFR_STRING_OP
, (CHAR8
**)&mString
),
1265 CIfrOpHeader (EFI_IFR_STRING_OP
, &mString
->Header
),
1266 CIfrQuestionHeader (&mString
->Question
) {
1268 mString
->MinSize
= 0;
1269 mString
->MaxSize
= 0;
1270 gCurrentQuestion
= this;
1274 gCurrentQuestion
= NULL
;
1277 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
) {
1278 EFI_VFR_RETURN_CODE Ret
;
1280 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1281 if (Ret
!= VFR_RETURN_SUCCESS
) {
1285 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_STRING_MULTI_LINE
)) {
1286 mString
->Flags
|= EFI_IFR_STRING_MULTI_LINE
;
1289 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1292 VOID
SetMinSize (IN UINT8 Flags
) {
1293 mString
->MinSize
= Flags
;
1296 VOID
SetMaxSize (IN UINT8 MaxSize
) {
1297 mString
->MaxSize
= MaxSize
;
1301 class CIfrPassword
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1303 EFI_IFR_PASSWORD
*mPassword
;
1306 CIfrPassword () : CIfrObj (EFI_IFR_PASSWORD_OP
, (CHAR8
**)&mPassword
),
1307 CIfrOpHeader (EFI_IFR_PASSWORD_OP
, &mPassword
->Header
),
1308 CIfrQuestionHeader (&mPassword
->Question
) {
1309 mPassword
->MinSize
= 0;
1310 mPassword
->MaxSize
= 0;
1311 gCurrentQuestion
= this;
1315 gCurrentQuestion
= NULL
;
1318 VOID
SetMinSize (IN UINT16 MinSize
) {
1319 mPassword
->MinSize
= MinSize
;
1322 VOID
SetMaxSize (IN UINT16 MaxSize
) {
1323 mPassword
->MaxSize
= MaxSize
;
1327 class CIfrOrderedList
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1329 EFI_IFR_ORDERED_LIST
*mOrderedList
;
1332 CIfrOrderedList () : CIfrObj (EFI_IFR_ORDERED_LIST_OP
, (CHAR8
**)&mOrderedList
),
1333 CIfrOpHeader (EFI_IFR_ORDERED_LIST_OP
, &mOrderedList
->Header
),
1334 CIfrQuestionHeader (&mOrderedList
->Question
) {
1335 mOrderedList
->MaxContainers
= 0;
1336 mOrderedList
->Flags
= 0;
1337 gCurrentQuestion
= this;
1340 ~CIfrOrderedList () {
1341 gCurrentQuestion
= NULL
;
1344 VOID
SetMaxContainers (IN UINT8 MaxContainers
) {
1345 mOrderedList
->MaxContainers
= MaxContainers
;
1348 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
) {
1349 EFI_VFR_RETURN_CODE Ret
;
1351 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1352 if (Ret
!= VFR_RETURN_SUCCESS
) {
1356 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_UNIQUE_SET
)) {
1357 mOrderedList
->Flags
|= EFI_IFR_UNIQUE_SET
;
1360 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_NO_EMPTY_SET
)) {
1361 mOrderedList
->Flags
|= EFI_IFR_NO_EMPTY_SET
;
1364 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1368 class CIfrTime
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1370 EFI_IFR_TIME
*mTime
;
1373 CIfrTime () : CIfrObj (EFI_IFR_TIME_OP
, (CHAR8
**)&mTime
),
1374 CIfrOpHeader (EFI_IFR_TIME_OP
, &mTime
->Header
),
1375 CIfrQuestionHeader (&mTime
->Question
) {
1379 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
) {
1380 EFI_VFR_RETURN_CODE Ret
;
1382 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1383 if (Ret
!= VFR_RETURN_SUCCESS
) {
1387 if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_HOUR_SUPPRESS
)) {
1388 mTime
->Flags
|= QF_TIME_HOUR_SUPPRESS
;
1391 if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_MINUTE_SUPPRESS
)) {
1392 mTime
->Flags
|= QF_TIME_MINUTE_SUPPRESS
;
1395 if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_SECOND_SUPPRESS
)) {
1396 mTime
->Flags
|= QF_TIME_SECOND_SUPPRESS
;
1399 if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_STORAGE_NORMAL
)) {
1400 mTime
->Flags
|= QF_TIME_STORAGE_NORMAL
;
1401 } else if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_STORAGE_TIME
)) {
1402 mTime
->Flags
|= QF_TIME_STORAGE_TIME
;
1403 } else if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_STORAGE_WAKEUP
)) {
1404 mTime
->Flags
|= QF_TIME_STORAGE_WAKEUP
;
1407 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1411 class CIfrDisableIf
: public CIfrObj
, public CIfrOpHeader
{
1413 EFI_IFR_DISABLE_IF
*mDisableIf
;
1416 CIfrDisableIf () : CIfrObj (EFI_IFR_DISABLE_IF_OP
, (CHAR8
**)&mDisableIf
),
1417 mDisableIf ((EFI_IFR_DISABLE_IF
*) GetObjBinAddr()),
1418 CIfrOpHeader (EFI_IFR_DISABLE_IF_OP
, &mDisableIf
->Header
) {}
1421 class CIfrSuppressIf
: public CIfrObj
, public CIfrOpHeader
{
1423 EFI_IFR_SUPPRESS_IF
*mSuppressIf
;
1426 CIfrSuppressIf () : CIfrObj (EFI_IFR_SUPPRESS_IF_OP
, (CHAR8
**)&mSuppressIf
),
1427 CIfrOpHeader (EFI_IFR_SUPPRESS_IF_OP
, &mSuppressIf
->Header
) {}
1430 class CIfrGrayOutIf
: public CIfrObj
, public CIfrOpHeader
{
1432 EFI_IFR_GRAY_OUT_IF
*mGrayOutIf
;
1435 CIfrGrayOutIf () : CIfrObj (EFI_IFR_GRAY_OUT_IF_OP
, (CHAR8
**)&mGrayOutIf
),
1436 CIfrOpHeader (EFI_IFR_GRAY_OUT_IF_OP
, &mGrayOutIf
->Header
) {}
1439 class CIfrInconsistentIf
: public CIfrObj
, public CIfrOpHeader
{
1441 EFI_IFR_INCONSISTENT_IF
*mInconsistentIf
;
1444 CIfrInconsistentIf () : CIfrObj (EFI_IFR_INCONSISTENT_IF_OP
, (CHAR8
**)&mInconsistentIf
),
1445 CIfrOpHeader (EFI_IFR_INCONSISTENT_IF_OP
, &mInconsistentIf
->Header
) {
1446 mInconsistentIf
->Error
= EFI_STRING_ID_INVALID
;
1449 VOID
SetError (IN EFI_STRING_ID Error
) {
1450 mInconsistentIf
->Error
= Error
;
1454 class CIfrNoSubmitIf
: public CIfrObj
, public CIfrOpHeader
{
1456 EFI_IFR_NO_SUBMIT_IF
*mNoSubmitIf
;
1459 CIfrNoSubmitIf () : CIfrObj (EFI_IFR_NO_SUBMIT_IF_OP
, (CHAR8
**)&mNoSubmitIf
),
1460 CIfrOpHeader (EFI_IFR_NO_SUBMIT_IF_OP
, &mNoSubmitIf
->Header
) {
1461 mNoSubmitIf
->Error
= EFI_STRING_ID_INVALID
;
1464 VOID
SetError (IN EFI_STRING_ID Error
) {
1465 mNoSubmitIf
->Error
= Error
;
1469 class CIfrRefresh
: public CIfrObj
, public CIfrOpHeader
{
1471 EFI_IFR_REFRESH
*mRefresh
;
1474 CIfrRefresh () : CIfrObj (EFI_IFR_REFRESH_OP
, (CHAR8
**)&mRefresh
),
1475 CIfrOpHeader (EFI_IFR_REFRESH_OP
, &mRefresh
->Header
) {
1476 mRefresh
->RefreshInterval
= 0;
1479 VOID
SetRefreshInterval (IN UINT8 RefreshInterval
) {
1480 mRefresh
->RefreshInterval
= RefreshInterval
;
1484 class CIfrVarStoreDevice
: public CIfrObj
, public CIfrOpHeader
{
1486 EFI_IFR_VARSTORE_DEVICE
*mVarStoreDevice
;
1489 CIfrVarStoreDevice () : CIfrObj (EFI_IFR_VARSTORE_DEVICE_OP
, (CHAR8
**)&mVarStoreDevice
),
1490 CIfrOpHeader (EFI_IFR_VARSTORE_DEVICE_OP
, &mVarStoreDevice
->Header
) {
1491 mVarStoreDevice
->DevicePath
= EFI_STRING_ID_INVALID
;
1494 VOID
SetDevicePath (IN EFI_STRING_ID DevicePath
) {
1495 mVarStoreDevice
->DevicePath
= DevicePath
;
1499 class CIfrOneOfOption
: public CIfrObj
, public CIfrOpHeader
{
1501 EFI_IFR_ONE_OF_OPTION
*mOneOfOption
;
1504 CIfrOneOfOption () : CIfrObj (EFI_IFR_ONE_OF_OPTION_OP
, (CHAR8
**)&mOneOfOption
),
1505 CIfrOpHeader (EFI_IFR_ONE_OF_OPTION_OP
, &mOneOfOption
->Header
) {
1506 mOneOfOption
->Flags
= 0;
1507 mOneOfOption
->Option
= EFI_STRING_ID_INVALID
;
1508 mOneOfOption
->Type
= EFI_IFR_TYPE_OTHER
;
1509 memset (&mOneOfOption
->Value
, 0, sizeof (mOneOfOption
->Value
));
1512 VOID
SetOption (IN EFI_STRING_ID Option
) {
1513 mOneOfOption
->Option
= Option
;
1516 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 LFlags
) {
1517 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_OPTION_DEFAULT
)) {
1518 mOneOfOption
->Flags
|= EFI_IFR_OPTION_DEFAULT
;
1521 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_OPTION_DEFAULT_MFG
)) {
1522 mOneOfOption
->Flags
|= EFI_IFR_OPTION_DEFAULT_MFG
;
1525 if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_NUM_SIZE_8
)) {
1526 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_NUM_SIZE_8
);
1527 mOneOfOption
->Flags
|= EFI_IFR_TYPE_NUM_SIZE_8
;
1528 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_NUM_SIZE_16
)) {
1529 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_NUM_SIZE_16
);
1530 mOneOfOption
->Flags
|= EFI_IFR_TYPE_NUM_SIZE_16
;
1531 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_NUM_SIZE_32
)) {
1532 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_NUM_SIZE_32
);
1533 mOneOfOption
->Flags
|= EFI_IFR_TYPE_NUM_SIZE_32
;
1534 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_NUM_SIZE_64
)) {
1535 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_NUM_SIZE_64
);
1536 mOneOfOption
->Flags
|= EFI_IFR_TYPE_NUM_SIZE_64
;
1537 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_BOOLEAN
)) {
1538 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_BOOLEAN
);
1539 mOneOfOption
->Flags
|= EFI_IFR_TYPE_BOOLEAN
;
1540 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_TIME
)) {
1541 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_TIME
);
1542 mOneOfOption
->Flags
|= EFI_IFR_TYPE_TIME
;
1543 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_DATE
)) {
1544 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_DATE
);
1545 mOneOfOption
->Flags
|= EFI_IFR_TYPE_DATE
;
1546 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_STRING
)) {
1547 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_STRING
);
1548 mOneOfOption
->Flags
|= EFI_IFR_TYPE_STRING
;
1549 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_OTHER
)) {
1550 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_OTHER
);
1551 mOneOfOption
->Flags
|= EFI_IFR_TYPE_OTHER
;
1554 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1557 VOID
SetType (IN UINT8 Type
) {
1558 mOneOfOption
->Type
= Type
;
1561 VOID
SetValue (IN EFI_IFR_TYPE_VALUE Value
) {
1562 mOneOfOption
->Value
= Value
;
1565 UINT8
GetFlags (VOID
) {
1566 return mOneOfOption
->Flags
;
1570 static EFI_GUID IfrTianoGuid
= EFI_IFR_TIANO_GUID
;
1571 static EFI_GUID IfrFrameworkGuid
= EFI_IFR_FRAMEWORK_GUID
;
1573 class CIfrClass
: public CIfrObj
, public CIfrOpHeader
{
1575 EFI_IFR_GUID_CLASS
*mClass
;
1578 CIfrClass () : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mClass
, sizeof (EFI_IFR_GUID_CLASS
)),
1579 CIfrOpHeader (EFI_IFR_GUID_OP
, &mClass
->Header
, sizeof (EFI_IFR_GUID_CLASS
)) {
1580 mClass
->ExtendOpCode
= EFI_IFR_EXTEND_OP_CLASS
;
1581 mClass
->Guid
= IfrTianoGuid
;
1582 mClass
->Class
= EFI_NON_DEVICE_CLASS
;
1585 VOID
SetClass (IN UINT16 Class
) {
1586 mClass
->Class
= Class
;
1590 class CIfrSubClass
: public CIfrObj
, public CIfrOpHeader
{
1592 EFI_IFR_GUID_SUBCLASS
*mSubClass
;
1595 CIfrSubClass () : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mSubClass
, sizeof (EFI_IFR_GUID_SUBCLASS
)),
1596 CIfrOpHeader (EFI_IFR_GUID_OP
, &mSubClass
->Header
, sizeof (EFI_IFR_GUID_SUBCLASS
)) {
1597 mSubClass
->ExtendOpCode
= EFI_IFR_EXTEND_OP_SUBCLASS
;
1598 mSubClass
->Guid
= IfrTianoGuid
;
1599 mSubClass
->SubClass
= EFI_SETUP_APPLICATION_SUBCLASS
;
1602 VOID
SetSubClass (IN UINT16 SubClass
) {
1603 mSubClass
->SubClass
= SubClass
;
1607 class CIfrLabel
: public CIfrObj
, public CIfrOpHeader
{
1609 EFI_IFR_GUID_LABEL
*mLabel
;
1612 CIfrLabel () : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mLabel
, sizeof (EFI_IFR_GUID_LABEL
)),
1613 CIfrOpHeader (EFI_IFR_GUID_OP
, &mLabel
->Header
, sizeof (EFI_IFR_GUID_LABEL
)) {
1614 mLabel
->ExtendOpCode
= EFI_IFR_EXTEND_OP_LABEL
;
1615 mLabel
->Guid
= IfrTianoGuid
;
1618 VOID
SetNumber (IN UINT16 Number
) {
1619 mLabel
->Number
= Number
;
1623 class CIfrBanner
: public CIfrObj
, public CIfrOpHeader
{
1625 EFI_IFR_GUID_BANNER
*mBanner
;
1628 CIfrBanner () : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mBanner
, sizeof (EFI_IFR_GUID_BANNER
)),
1629 CIfrOpHeader (EFI_IFR_GUID_OP
, &mBanner
->Header
, sizeof (EFI_IFR_GUID_BANNER
)) {
1630 mBanner
->ExtendOpCode
= EFI_IFR_EXTEND_OP_BANNER
;
1631 mBanner
->Guid
= IfrTianoGuid
;
1634 VOID
SetTitle (IN EFI_STRING_ID StringId
) {
1635 mBanner
->Title
= StringId
;
1638 VOID
SetLine (IN UINT16 Line
) {
1639 mBanner
->LineNumber
= Line
;
1642 VOID
SetAlign (IN UINT8 Align
) {
1643 mBanner
->Alignment
= Align
;
1647 class CIfrOptionKey
: public CIfrObj
, public CIfrOpHeader
{
1649 EFI_IFR_GUID_OPTIONKEY
*mOptionKey
;
1653 IN EFI_QUESTION_ID QuestionId
,
1654 IN EFI_IFR_TYPE_VALUE
&OptionValue
,
1655 IN EFI_QUESTION_ID KeyValue
1656 ) : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mOptionKey
, sizeof (EFI_IFR_GUID_OPTIONKEY
)),
1657 CIfrOpHeader (EFI_IFR_GUID_OP
, &mOptionKey
->Header
, sizeof (EFI_IFR_GUID_OPTIONKEY
)) {
1658 mOptionKey
->ExtendOpCode
= EFI_IFR_EXTEND_OP_OPTIONKEY
;
1659 mOptionKey
->Guid
= IfrFrameworkGuid
;
1660 mOptionKey
->QuestionId
= QuestionId
;
1661 mOptionKey
->OptionValue
= OptionValue
;
1662 mOptionKey
->KeyValue
= KeyValue
;
1666 class CIfrVarEqName
: public CIfrObj
, public CIfrOpHeader
{
1668 EFI_IFR_GUID_VAREQNAME
*mVarEqName
;
1672 IN EFI_QUESTION_ID QuestionId
,
1673 IN EFI_STRING_ID NameId
1674 ) : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mVarEqName
, sizeof (EFI_IFR_GUID_VAREQNAME
)),
1675 CIfrOpHeader (EFI_IFR_GUID_OP
, &mVarEqName
->Header
, sizeof (EFI_IFR_GUID_VAREQNAME
)) {
1676 mVarEqName
->ExtendOpCode
= EFI_IFR_EXTEND_OP_VAREQNAME
;
1677 mVarEqName
->Guid
= IfrFrameworkGuid
;
1678 mVarEqName
->QuestionId
= QuestionId
;
1679 mVarEqName
->NameId
= NameId
;
1683 class CIfrTimeout
: public CIfrObj
, public CIfrOpHeader
{
1685 EFI_IFR_GUID_TIMEOUT
*mTimeout
;
1688 CIfrTimeout (IN UINT16 Timeout
= 0) : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mTimeout
, sizeof (EFI_IFR_GUID_TIMEOUT
)),
1689 CIfrOpHeader (EFI_IFR_GUID_OP
, &mTimeout
->Header
, sizeof (EFI_IFR_GUID_TIMEOUT
)) {
1690 mTimeout
->ExtendOpCode
= EFI_IFR_EXTEND_OP_TIMEOUT
;
1691 mTimeout
->Guid
= IfrTianoGuid
;
1692 mTimeout
->TimeOut
= Timeout
;
1695 VOID
SetTimeout (IN UINT16 Timeout
) {
1696 mTimeout
->TimeOut
= Timeout
;
1700 class CIfrGuid
: public CIfrObj
, public CIfrOpHeader
{
1702 EFI_IFR_GUID
*mGuid
;
1705 CIfrGuid (UINT8 Size
) : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mGuid
, sizeof (EFI_IFR_GUID
)+Size
),
1706 CIfrOpHeader (EFI_IFR_GUID_OP
, &mGuid
->Header
, sizeof (EFI_IFR_GUID
)+Size
) {
1707 memset (&mGuid
->Guid
, 0, sizeof (EFI_GUID
));
1710 VOID
SetGuid (IN EFI_GUID
*Guid
) {
1711 memcpy (&mGuid
->Guid
, Guid
, sizeof (EFI_GUID
));
1714 VOID
SetData (IN UINT8
* DataBuff
, IN UINT8 Size
) {
1715 memcpy ((UINT8
*)mGuid
+ sizeof (EFI_IFR_GUID
), DataBuff
, Size
);
1719 class CIfrDup
: public CIfrObj
, public CIfrOpHeader
{
1726 ) : CIfrObj (EFI_IFR_DUP_OP
, (CHAR8
**)&mDup
),
1727 CIfrOpHeader (EFI_IFR_DUP_OP
, &mDup
->Header
) {
1732 class CIfrEqIdId
: public CIfrObj
, public CIfrOpHeader
{
1734 EFI_IFR_EQ_ID_ID
*mEqIdId
;
1739 ) : CIfrObj (EFI_IFR_EQ_ID_ID_OP
, (CHAR8
**)&mEqIdId
),
1740 CIfrOpHeader (EFI_IFR_EQ_ID_ID_OP
, &mEqIdId
->Header
) {
1742 mEqIdId
->QuestionId1
= EFI_QUESTION_ID_INVALID
;
1743 mEqIdId
->QuestionId2
= EFI_QUESTION_ID_INVALID
;
1746 VOID
SetQuestionId1 (
1747 IN EFI_QUESTION_ID QuestionId
,
1751 if (QuestionId
!= EFI_QUESTION_ID_INVALID
) {
1752 mEqIdId
->QuestionId1
= QuestionId
;
1754 gCFormPkg
.AssignPending (VarIdStr
, (VOID
*)(&mEqIdId
->QuestionId1
), sizeof (EFI_QUESTION_ID
), LineNo
, NO_QST_REFED
);
1758 VOID
SetQuestionId2 (
1759 IN EFI_QUESTION_ID QuestionId
,
1763 if (QuestionId
!= EFI_QUESTION_ID_INVALID
) {
1764 mEqIdId
->QuestionId2
= QuestionId
;
1766 gCFormPkg
.AssignPending (VarIdStr
, (VOID
*)(&mEqIdId
->QuestionId2
), sizeof (EFI_QUESTION_ID
), LineNo
, NO_QST_REFED
);
1771 class CIfrEqIdVal
: public CIfrObj
, public CIfrOpHeader
{
1773 EFI_IFR_EQ_ID_VAL
*mEqIdVal
;
1778 ) : CIfrObj (EFI_IFR_EQ_ID_VAL_OP
, (CHAR8
**)&mEqIdVal
),
1779 CIfrOpHeader (EFI_IFR_EQ_ID_VAL_OP
, &mEqIdVal
->Header
) {
1781 mEqIdVal
->QuestionId
= EFI_QUESTION_ID_INVALID
;
1784 VOID
SetQuestionId (
1785 IN EFI_QUESTION_ID QuestionId
,
1789 if (QuestionId
!= EFI_QUESTION_ID_INVALID
) {
1790 mEqIdVal
->QuestionId
= QuestionId
;
1792 gCFormPkg
.AssignPending (VarIdStr
, (VOID
*)(&mEqIdVal
->QuestionId
), sizeof (EFI_QUESTION_ID
), LineNo
, NO_QST_REFED
);
1796 VOID
SetValue (IN UINT16 Value
) {
1797 mEqIdVal
->Value
= Value
;
1801 class CIfrEqIdList
: public CIfrObj
, public CIfrOpHeader
{
1803 EFI_IFR_EQ_ID_VAL_LIST
*mEqIdVList
;
1808 ) : CIfrObj (EFI_IFR_EQ_ID_LIST_OP
, (CHAR8
**)&mEqIdVList
, sizeof (EFI_IFR_EQ_ID_VAL_LIST
), TRUE
),
1809 CIfrOpHeader (EFI_IFR_EQ_ID_LIST_OP
, &mEqIdVList
->Header
) {
1811 mEqIdVList
->QuestionId
= EFI_QUESTION_ID_INVALID
;
1812 mEqIdVList
->ListLength
= 0;
1813 mEqIdVList
->ValueList
[0] = 0;
1816 VOID
UpdateIfrBuffer (
1818 _EMIT_PENDING_OBJ();
1819 mEqIdVList
= (EFI_IFR_EQ_ID_VAL_LIST
*) GetObjBinAddr();
1820 UpdateHeader (&mEqIdVList
->Header
);
1823 VOID
SetQuestionId (
1824 IN EFI_QUESTION_ID QuestionId
,
1828 if (QuestionId
!= EFI_QUESTION_ID_INVALID
) {
1829 mEqIdVList
->QuestionId
= QuestionId
;
1831 gCFormPkg
.AssignPending (VarIdStr
, (VOID
*)(&mEqIdVList
->QuestionId
), sizeof (EFI_QUESTION_ID
), LineNo
, NO_QST_REFED
);
1835 VOID
SetListLength (IN UINT16 ListLength
) {
1836 mEqIdVList
->ListLength
= ListLength
;
1839 VOID
SetValueList (IN UINT16 Index
, IN UINT16 Value
) {
1841 mEqIdVList
->ValueList
[0] = Value
;
1845 if (ExpendObjBin (sizeof (UINT16
)) ==TRUE
) {
1846 IncLength (sizeof (UINT16
));
1847 mEqIdVList
->ValueList
[Index
] = Value
;
1852 class CIfrQuestionRef1
: public CIfrObj
, public CIfrOpHeader
{
1854 EFI_IFR_QUESTION_REF1
*mQuestionRef1
;
1859 ) : CIfrObj (EFI_IFR_QUESTION_REF1_OP
, (CHAR8
**)&mQuestionRef1
),
1860 CIfrOpHeader (EFI_IFR_QUESTION_REF1_OP
, &mQuestionRef1
->Header
) {
1862 mQuestionRef1
->QuestionId
= EFI_QUESTION_ID_INVALID
;
1865 VOID
SetQuestionId (
1866 IN EFI_QUESTION_ID QuestionId
,
1870 if (QuestionId
!= EFI_QUESTION_ID_INVALID
) {
1871 mQuestionRef1
->QuestionId
= QuestionId
;
1873 gCFormPkg
.AssignPending (VarIdStr
, (VOID
*)(&mQuestionRef1
->QuestionId
), sizeof (EFI_QUESTION_ID
), LineNo
, NO_QST_REFED
);
1878 class CIfrQuestionRef2
: public CIfrObj
, public CIfrOpHeader
{
1880 EFI_IFR_QUESTION_REF2
*mQuestionRef2
;
1885 ) : CIfrObj (EFI_IFR_QUESTION_REF2_OP
, (CHAR8
**)&mQuestionRef2
),
1886 CIfrOpHeader (EFI_IFR_QUESTION_REF2_OP
, &mQuestionRef2
->Header
) {
1891 class CIfrQuestionRef3
: public CIfrObj
, public CIfrOpHeader
{
1893 EFI_IFR_QUESTION_REF3
*mQuestionRef3
;
1898 ) : CIfrObj (EFI_IFR_QUESTION_REF3_OP
, (CHAR8
**)&mQuestionRef3
),
1899 CIfrOpHeader (EFI_IFR_QUESTION_REF3_OP
, &mQuestionRef3
->Header
) {
1904 class CIfrQuestionRef3_2
: public CIfrObj
, public CIfrOpHeader
{
1906 EFI_IFR_QUESTION_REF3_2
*mQuestionRef3_2
;
1909 CIfrQuestionRef3_2 (
1911 ) : CIfrObj (EFI_IFR_QUESTION_REF3_OP
, (CHAR8
**)&mQuestionRef3_2
, sizeof (EFI_IFR_QUESTION_REF3_2
)),
1912 CIfrOpHeader (EFI_IFR_QUESTION_REF3_OP
, &mQuestionRef3_2
->Header
, sizeof (EFI_IFR_QUESTION_REF3_2
)) {
1914 mQuestionRef3_2
->DevicePath
= EFI_STRING_ID_INVALID
;
1917 VOID
SetDevicePath (IN EFI_STRING_ID DevicePath
) {
1918 mQuestionRef3_2
->DevicePath
= DevicePath
;
1922 class CIfrQuestionRef3_3
: public CIfrObj
, public CIfrOpHeader
{
1924 EFI_IFR_QUESTION_REF3_3
*mQuestionRef3_3
;
1927 CIfrQuestionRef3_3 (
1929 ) : CIfrObj (EFI_IFR_QUESTION_REF3_OP
, (CHAR8
**)&mQuestionRef3_3
, sizeof (EFI_IFR_QUESTION_REF3_3
)),
1930 CIfrOpHeader (EFI_IFR_QUESTION_REF3_OP
, &mQuestionRef3_3
->Header
, sizeof (EFI_IFR_QUESTION_REF3_3
)) {
1932 mQuestionRef3_3
->DevicePath
= EFI_STRING_ID_INVALID
;
1933 memset (&mQuestionRef3_3
->Guid
, 0, sizeof (EFI_GUID
));
1936 VOID
SetDevicePath (IN EFI_STRING_ID DevicePath
) {
1937 mQuestionRef3_3
->DevicePath
= DevicePath
;
1940 VOID
SetGuid (IN EFI_GUID
*Guid
) {
1941 mQuestionRef3_3
->Guid
= *Guid
;
1945 class CIfrRuleRef
: public CIfrObj
, public CIfrOpHeader
{
1947 EFI_IFR_RULE_REF
*mRuleRef
;
1952 ) : CIfrObj (EFI_IFR_RULE_REF_OP
, (CHAR8
**)&mRuleRef
),
1953 CIfrOpHeader (EFI_IFR_RULE_REF_OP
, &mRuleRef
->Header
) {
1955 mRuleRef
->RuleId
= EFI_RULE_ID_INVALID
;
1958 VOID
SetRuleId (IN UINT8 RuleId
) {
1959 mRuleRef
->RuleId
= RuleId
;
1963 class CIfrStringRef1
: public CIfrObj
, public CIfrOpHeader
{
1965 EFI_IFR_STRING_REF1
*mStringRef1
;
1970 ) : CIfrObj (EFI_IFR_STRING_REF1_OP
, (CHAR8
**)&mStringRef1
),
1971 CIfrOpHeader (EFI_IFR_STRING_REF1_OP
, &mStringRef1
->Header
) {
1973 mStringRef1
->StringId
= EFI_STRING_ID_INVALID
;
1976 VOID
SetStringId (IN EFI_STRING_ID StringId
) {
1977 mStringRef1
->StringId
= StringId
;
1981 class CIfrStringRef2
: public CIfrObj
, public CIfrOpHeader
{
1983 EFI_IFR_STRING_REF2
*mStringRef2
;
1988 ) : CIfrObj (EFI_IFR_STRING_REF2_OP
, (CHAR8
**)&mStringRef2
),
1989 CIfrOpHeader (EFI_IFR_STRING_REF2_OP
, &mStringRef2
->Header
) {
1994 class CIfrThis
: public CIfrObj
, public CIfrOpHeader
{
1996 EFI_IFR_THIS
*mThis
;
2001 ) : CIfrObj (EFI_IFR_THIS_OP
, (CHAR8
**)&mThis
),
2002 CIfrOpHeader (EFI_IFR_THIS_OP
, &mThis
->Header
) {
2007 class CIfrSecurity
: public CIfrObj
, public CIfrOpHeader
{
2009 EFI_IFR_SECURITY
*mSecurity
;
2014 ) : CIfrObj (EFI_IFR_SECURITY_OP
, (CHAR8
**)&mSecurity
),
2015 CIfrOpHeader (EFI_IFR_SECURITY_OP
, &mSecurity
->Header
) {
2017 memset (&mSecurity
->Permissions
, 0, sizeof (EFI_GUID
));
2020 VOID
SetPermissions (IN EFI_GUID
*Permissions
) {
2021 memcpy (&mSecurity
->Permissions
, Permissions
, sizeof (EFI_GUID
));
2025 class CIfrUint8
: public CIfrObj
, public CIfrOpHeader
{
2027 EFI_IFR_UINT8
*mUint8
;
2032 ) : CIfrObj (EFI_IFR_UINT8_OP
, (CHAR8
**)&mUint8
),
2033 CIfrOpHeader (EFI_IFR_UINT8_OP
, &mUint8
->Header
) {
2037 VOID
SetValue (IN UINT8 Value
) {
2038 mUint8
->Value
= Value
;
2042 class CIfrUint16
: public CIfrObj
, public CIfrOpHeader
{
2044 EFI_IFR_UINT16
*mUint16
;
2049 ) : CIfrObj (EFI_IFR_UINT16_OP
, (CHAR8
**)&mUint16
),
2050 CIfrOpHeader (EFI_IFR_UINT16_OP
, &mUint16
->Header
) {
2054 VOID
SetValue (IN UINT16 Value
) {
2055 mUint16
->Value
= Value
;
2059 class CIfrUint32
: public CIfrObj
, public CIfrOpHeader
{
2061 EFI_IFR_UINT32
*mUint32
;
2066 ) : CIfrObj (EFI_IFR_UINT32_OP
, (CHAR8
**)&mUint32
),
2067 CIfrOpHeader (EFI_IFR_UINT32_OP
, &mUint32
->Header
) {
2071 VOID
SetValue (IN UINT32 Value
) {
2072 mUint32
->Value
= Value
;
2076 class CIfrUint64
: public CIfrObj
, public CIfrOpHeader
{
2078 EFI_IFR_UINT64
*mUint64
;
2083 ) : CIfrObj (EFI_IFR_UINT64_OP
, (CHAR8
**)&mUint64
),
2084 CIfrOpHeader (EFI_IFR_UINT64_OP
, &mUint64
->Header
) {
2088 VOID
SetValue (IN UINT64 Value
) {
2089 mUint64
->Value
= Value
;
2093 class CIfrTrue
: public CIfrObj
, public CIfrOpHeader
{
2095 EFI_IFR_TRUE
*mTrue
;
2100 ) : CIfrObj (EFI_IFR_TRUE_OP
, (CHAR8
**)&mTrue
),
2101 CIfrOpHeader (EFI_IFR_TRUE_OP
, &mTrue
->Header
) {
2106 class CIfrFalse
: public CIfrObj
, public CIfrOpHeader
{
2108 EFI_IFR_FALSE
*mFalse
;
2113 ) : CIfrObj (EFI_IFR_FALSE_OP
, (CHAR8
**)&mFalse
),
2114 CIfrOpHeader (EFI_IFR_FALSE_OP
, &mFalse
->Header
) {
2119 class CIfrOne
: public CIfrObj
, public CIfrOpHeader
{
2126 ) : CIfrObj (EFI_IFR_ONE_OP
, (CHAR8
**)&mOne
),
2127 CIfrOpHeader (EFI_IFR_ONE_OP
, &mOne
->Header
) {
2132 class CIfrOnes
: public CIfrObj
, public CIfrOpHeader
{
2134 EFI_IFR_ONES
*mOnes
;
2139 ) : CIfrObj (EFI_IFR_ONES_OP
, (CHAR8
**)&mOnes
),
2140 CIfrOpHeader (EFI_IFR_ONES_OP
, &mOnes
->Header
) {
2145 class CIfrZero
: public CIfrObj
, public CIfrOpHeader
{
2147 EFI_IFR_ZERO
*mZero
;
2152 ) : CIfrObj (EFI_IFR_ZERO_OP
, (CHAR8
**)&mZero
),
2153 CIfrOpHeader (EFI_IFR_ZERO_OP
, &mZero
->Header
) {
2158 class CIfrUndefined
: public CIfrObj
, public CIfrOpHeader
{
2160 EFI_IFR_UNDEFINED
*mUndefined
;
2165 ) : CIfrObj (EFI_IFR_UNDEFINED_OP
, (CHAR8
**)&mUndefined
),
2166 CIfrOpHeader (EFI_IFR_UNDEFINED_OP
, &mUndefined
->Header
) {
2171 class CIfrVersion
: public CIfrObj
, public CIfrOpHeader
{
2173 EFI_IFR_VERSION
*mVersion
;
2178 ) : CIfrObj (EFI_IFR_VERSION_OP
, (CHAR8
**)&mVersion
),
2179 CIfrOpHeader (EFI_IFR_VERSION_OP
, &mVersion
->Header
) {
2184 class CIfrLength
: public CIfrObj
, public CIfrOpHeader
{
2186 EFI_IFR_LENGTH
*mLength
;
2191 ) : CIfrObj (EFI_IFR_LENGTH_OP
, (CHAR8
**)&mLength
),
2192 CIfrOpHeader (EFI_IFR_LENGTH_OP
, &mLength
->Header
) {
2197 class CIfrNot
: public CIfrObj
, public CIfrOpHeader
{
2204 ) : CIfrObj (EFI_IFR_NOT_OP
, (CHAR8
**)&mNot
),
2205 CIfrOpHeader (EFI_IFR_NOT_OP
, &mNot
->Header
) {
2210 class CIfrBitWiseNot
: public CIfrObj
, public CIfrOpHeader
{
2212 EFI_IFR_BITWISE_NOT
*mBitWise
;
2217 ) : CIfrObj (EFI_IFR_BITWISE_NOT_OP
, (CHAR8
**)&mBitWise
),
2218 CIfrOpHeader (EFI_IFR_BITWISE_NOT_OP
, &mBitWise
->Header
) {
2223 class CIfrToBoolean
: public CIfrObj
, public CIfrOpHeader
{
2225 EFI_IFR_TO_BOOLEAN
*mToBoolean
;
2230 ) : CIfrObj (EFI_IFR_TO_BOOLEAN_OP
, (CHAR8
**)&mToBoolean
),
2231 CIfrOpHeader (EFI_IFR_TO_BOOLEAN_OP
, &mToBoolean
->Header
) {
2236 class CIfrToString
: public CIfrObj
, public CIfrOpHeader
{
2238 EFI_IFR_TO_STRING
*mToString
;
2243 ) : CIfrObj (EFI_IFR_TO_STRING_OP
, (CHAR8
**)&mToString
),
2244 CIfrOpHeader (EFI_IFR_TO_STRING_OP
, &mToString
->Header
) {
2248 VOID
SetFormat (IN UINT8 Format
) {
2249 mToString
->Format
= Format
;
2253 class CIfrToUint
: public CIfrObj
, public CIfrOpHeader
{
2255 EFI_IFR_TO_UINT
*mToUint
;
2260 ) : CIfrObj (EFI_IFR_TO_UINT_OP
, (CHAR8
**)&mToUint
),
2261 CIfrOpHeader (EFI_IFR_TO_UINT_OP
, &mToUint
->Header
) {
2266 class CIfrToUpper
: public CIfrObj
, public CIfrOpHeader
{
2268 EFI_IFR_TO_UPPER
*mToUpper
;
2273 ) : CIfrObj (EFI_IFR_TO_UPPER_OP
, (CHAR8
**)&mToUpper
),
2274 CIfrOpHeader (EFI_IFR_TO_UPPER_OP
, &mToUpper
->Header
) {
2279 class CIfrToLower
: public CIfrObj
, public CIfrOpHeader
{
2281 EFI_IFR_TO_LOWER
*mToLower
;
2286 ) : CIfrObj (EFI_IFR_TO_LOWER_OP
, (CHAR8
**)&mToLower
),
2287 CIfrOpHeader (EFI_IFR_TO_LOWER_OP
, &mToLower
->Header
) {
2292 class CIfrAdd
: public CIfrObj
, public CIfrOpHeader
{
2299 ) : CIfrObj (EFI_IFR_ADD_OP
, (CHAR8
**)&mAdd
),
2300 CIfrOpHeader (EFI_IFR_ADD_OP
, &mAdd
->Header
) {
2305 class CIfrBitWiseAnd
: public CIfrObj
, public CIfrOpHeader
{
2307 EFI_IFR_BITWISE_AND
*mBitWiseAnd
;
2312 ) : CIfrObj (EFI_IFR_BITWISE_AND_OP
, (CHAR8
**)&mBitWiseAnd
),
2313 CIfrOpHeader (EFI_IFR_BITWISE_AND_OP
, &mBitWiseAnd
->Header
) {
2318 class CIfrBitWiseOr
: public CIfrObj
, public CIfrOpHeader
{
2320 EFI_IFR_BITWISE_OR
*mBitWiseOr
;
2325 ) : CIfrObj (EFI_IFR_BITWISE_OR_OP
, (CHAR8
**)&mBitWiseOr
),
2326 CIfrOpHeader (EFI_IFR_BITWISE_OR_OP
, &mBitWiseOr
->Header
) {
2331 class CIfrAnd
: public CIfrObj
, public CIfrOpHeader
{
2338 ) : CIfrObj (EFI_IFR_AND_OP
, (CHAR8
**)&mAnd
),
2339 CIfrOpHeader (EFI_IFR_AND_OP
, &mAnd
->Header
) {
2344 class CIfrCatenate
: public CIfrObj
, public CIfrOpHeader
{
2346 EFI_IFR_CATENATE
*mCatenate
;
2351 ) : CIfrObj (EFI_IFR_CATENATE_OP
, (CHAR8
**)&mCatenate
),
2352 CIfrOpHeader (EFI_IFR_CATENATE_OP
, &mCatenate
->Header
) {
2357 class CIfrDivide
: public CIfrObj
, public CIfrOpHeader
{
2359 EFI_IFR_DIVIDE
*mDivide
;
2364 ) : CIfrObj (EFI_IFR_DIVIDE_OP
, (CHAR8
**)&mDivide
),
2365 CIfrOpHeader (EFI_IFR_DIVIDE_OP
, &mDivide
->Header
) {
2370 class CIfrEqual
: public CIfrObj
, public CIfrOpHeader
{
2372 EFI_IFR_EQUAL
*mEqual
;
2377 ) : CIfrObj (EFI_IFR_EQUAL_OP
, (CHAR8
**)&mEqual
),
2378 CIfrOpHeader (EFI_IFR_EQUAL_OP
, &mEqual
->Header
) {
2383 class CIfrGreaterEqual
: public CIfrObj
, public CIfrOpHeader
{
2385 EFI_IFR_GREATER_EQUAL
*mGreaterEqual
;
2390 ) : CIfrObj (EFI_IFR_GREATER_EQUAL_OP
, (CHAR8
**)&mGreaterEqual
),
2391 CIfrOpHeader (EFI_IFR_GREATER_EQUAL_OP
, &mGreaterEqual
->Header
) {
2396 class CIfrGreaterThan
: public CIfrObj
, public CIfrOpHeader
{
2398 EFI_IFR_GREATER_THAN
*mGreaterThan
;
2403 ) : CIfrObj (EFI_IFR_GREATER_THAN_OP
, (CHAR8
**)&mGreaterThan
),
2404 CIfrOpHeader (EFI_IFR_GREATER_THAN_OP
, &mGreaterThan
->Header
) {
2409 class CIfrLessEqual
: public CIfrObj
, public CIfrOpHeader
{
2411 EFI_IFR_LESS_EQUAL
*mLessEqual
;
2416 ) : CIfrObj (EFI_IFR_LESS_EQUAL_OP
, (CHAR8
**)&mLessEqual
),
2417 CIfrOpHeader (EFI_IFR_LESS_EQUAL_OP
, &mLessEqual
->Header
) {
2422 class CIfrLessThan
: public CIfrObj
, public CIfrOpHeader
{
2424 EFI_IFR_LESS_THAN
*mLessThan
;
2429 ) : CIfrObj (EFI_IFR_LESS_THAN_OP
, (CHAR8
**)&mLessThan
),
2430 CIfrOpHeader (EFI_IFR_LESS_THAN_OP
, &mLessThan
->Header
) {
2435 class CIfrMap
: public CIfrObj
, public CIfrOpHeader
{
2442 ) : CIfrObj (EFI_IFR_MAP_OP
, (CHAR8
**)&mMap
),
2443 CIfrOpHeader (EFI_IFR_MAP_OP
, &mMap
->Header
) {
2448 class CIfrMatch
: public CIfrObj
, public CIfrOpHeader
{
2450 EFI_IFR_MATCH
*mMatch
;
2455 ) : CIfrObj (EFI_IFR_MATCH_OP
, (CHAR8
**)&mMatch
),
2456 CIfrOpHeader (EFI_IFR_MATCH_OP
, &mMatch
->Header
) {
2461 class CIfrMultiply
: public CIfrObj
, public CIfrOpHeader
{
2463 EFI_IFR_MULTIPLY
*mMultiply
;
2468 ) : CIfrObj (EFI_IFR_MULTIPLY_OP
, (CHAR8
**)&mMultiply
),
2469 CIfrOpHeader (EFI_IFR_MULTIPLY_OP
, &mMultiply
->Header
) {
2474 class CIfrModulo
: public CIfrObj
, public CIfrOpHeader
{
2476 EFI_IFR_MODULO
*mModulo
;
2481 ) : CIfrObj (EFI_IFR_MODULO_OP
, (CHAR8
**)&mModulo
),
2482 CIfrOpHeader (EFI_IFR_MODULO_OP
, &mModulo
->Header
) {
2487 class CIfrNotEqual
: public CIfrObj
, public CIfrOpHeader
{
2489 EFI_IFR_NOT_EQUAL
*mNotEqual
;
2494 ) : CIfrObj (EFI_IFR_NOT_EQUAL_OP
, (CHAR8
**)&mNotEqual
),
2495 CIfrOpHeader (EFI_IFR_NOT_EQUAL_OP
, &mNotEqual
->Header
) {
2500 class CIfrOr
: public CIfrObj
, public CIfrOpHeader
{
2507 ) : CIfrObj (EFI_IFR_OR_OP
, (CHAR8
**)&mOr
),
2508 CIfrOpHeader (EFI_IFR_OR_OP
, &mOr
->Header
) {
2513 class CIfrShiftLeft
: public CIfrObj
, public CIfrOpHeader
{
2515 EFI_IFR_SHIFT_LEFT
*mShiftLeft
;
2520 ) : CIfrObj (EFI_IFR_SHIFT_LEFT_OP
, (CHAR8
**)&mShiftLeft
),
2521 CIfrOpHeader (EFI_IFR_SHIFT_LEFT_OP
, &mShiftLeft
->Header
) {
2526 class CIfrShiftRight
: public CIfrObj
, public CIfrOpHeader
{
2528 EFI_IFR_SHIFT_RIGHT
*mShiftRight
;
2533 ) : CIfrObj (EFI_IFR_SHIFT_RIGHT_OP
, (CHAR8
**)&mShiftRight
),
2534 CIfrOpHeader (EFI_IFR_SHIFT_RIGHT_OP
, &mShiftRight
->Header
) {
2539 class CIfrSubtract
: public CIfrObj
, public CIfrOpHeader
{
2541 EFI_IFR_SUBTRACT
*mSubtract
;
2546 ) : CIfrObj (EFI_IFR_SUBTRACT_OP
, (CHAR8
**)&mSubtract
),
2547 CIfrOpHeader (EFI_IFR_SUBTRACT_OP
, &mSubtract
->Header
) {
2552 class CIfrConditional
: public CIfrObj
, public CIfrOpHeader
{
2554 EFI_IFR_CONDITIONAL
*mConditional
;
2559 ) : CIfrObj (EFI_IFR_CONDITIONAL_OP
, (CHAR8
**)&mConditional
),
2560 CIfrOpHeader (EFI_IFR_CONDITIONAL_OP
, &mConditional
->Header
) {
2565 class CIfrFind
: public CIfrObj
, public CIfrOpHeader
{
2567 EFI_IFR_FIND
*mFind
;
2572 ) : CIfrObj (EFI_IFR_FIND_OP
, (CHAR8
**)&mFind
),
2573 CIfrOpHeader (EFI_IFR_FIND_OP
, &mFind
->Header
) {
2577 VOID
SetFormat (IN UINT8 Format
) {
2578 mFind
->Format
= Format
;
2582 class CIfrMid
: public CIfrObj
, public CIfrOpHeader
{
2589 ) : CIfrObj (EFI_IFR_MID_OP
, (CHAR8
**)&mMid
),
2590 CIfrOpHeader (EFI_IFR_MID_OP
, &mMid
->Header
) {
2595 class CIfrToken
: public CIfrObj
, public CIfrOpHeader
{
2597 EFI_IFR_TOKEN
*mToken
;
2602 ) : CIfrObj (EFI_IFR_TOKEN_OP
, (CHAR8
**)&mToken
),
2603 CIfrOpHeader (EFI_IFR_TOKEN_OP
, &mToken
->Header
) {
2608 class CIfrSpan
: public CIfrObj
, public CIfrOpHeader
{
2610 EFI_IFR_SPAN
*mSpan
;
2615 ) : CIfrObj (EFI_IFR_SPAN_OP
, (CHAR8
**)&mSpan
),
2616 CIfrOpHeader (EFI_IFR_SPAN_OP
, &mSpan
->Header
) {
2618 mSpan
->Flags
= EFI_IFR_FLAGS_FIRST_MATCHING
;
2621 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 LFlags
) {
2622 if (_IS_EQUAL (LFlags
, EFI_IFR_FLAGS_FIRST_MATCHING
)) {
2623 mSpan
->Flags
|= EFI_IFR_FLAGS_FIRST_MATCHING
;
2624 } else if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_FLAGS_FIRST_NON_MATCHING
)) {
2625 mSpan
->Flags
|= EFI_IFR_FLAGS_FIRST_NON_MATCHING
;
2628 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;