3 The definition of CFormPkg's member function
5 Copyright (c) 2004 - 2015, 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
;
100 BOOLEAN CompatibleMode
;
101 EFI_GUID
*OverrideClassGuid
;
102 } INPUT_INFO_TO_SYNTAX
;
107 SBufferNode
*mBufferNodeQueueHead
;
108 SBufferNode
*mBufferNodeQueueTail
;
109 SBufferNode
*mCurrBufferNode
;
111 SBufferNode
*mReadBufferNode
;
112 UINT32 mReadBufferOffset
;
116 VOID
_WRITE_PKG_LINE (IN
FILE *, IN UINT32
, IN CONST CHAR8
*, IN CHAR8
*, IN UINT32
);
117 VOID
_WRITE_PKG_END (IN
FILE *, IN UINT32
, IN CONST CHAR8
*, IN CHAR8
*, IN UINT32
);
118 SBufferNode
* GetBinBufferNodeForAddr (IN CHAR8
*);
119 SBufferNode
* CreateNewNode ();
120 SBufferNode
* GetNodeBefore (IN SBufferNode
*);
121 EFI_VFR_RETURN_CODE
InsertNodeBefore (IN SBufferNode
*, IN SBufferNode
*);
124 SPendingAssign
*PendingAssignList
;
127 CFormPkg (IN UINT32 BufferSize
= 4096);
130 CHAR8
* IfrBinBufferGet (IN UINT32
);
131 inline UINT32
GetPkgLength (VOID
);
134 UINT32
Read (IN CHAR8
*, IN UINT32
);
137 EFI_VFR_RETURN_CODE
BuildPkgHdr (OUT EFI_HII_PACKAGE_HEADER
**);
138 EFI_VFR_RETURN_CODE
BuildPkg (IN
FILE *, IN PACKAGE_DATA
*PkgData
= NULL
);
139 EFI_VFR_RETURN_CODE
BuildPkg (OUT PACKAGE_DATA
&);
140 EFI_VFR_RETURN_CODE
GenCFile (IN CHAR8
*, IN
FILE *, IN PACKAGE_DATA
*PkgData
= NULL
);
143 EFI_VFR_RETURN_CODE
AssignPending (IN CHAR8
*, IN VOID
*, IN UINT32
, IN UINT32
, IN CONST CHAR8
*Msg
= NULL
);
144 VOID
DoPendingAssign (IN CHAR8
*, IN VOID
*, IN UINT32
);
145 bool HavePendingUnassigned (VOID
);
146 VOID
PendingAssignPrintAll (VOID
);
147 EFI_VFR_RETURN_CODE
DeclarePendingQuestion (
148 IN CVfrVarDataTypeDB
&lCVfrVarDataTypeDB
,
149 IN CVfrDataStorage
&lCVfrDataStorage
,
150 IN CVfrQuestionDB
&lCVfrQuestionDB
,
151 IN EFI_GUID
*LocalFormSetGuid
,
153 OUT CHAR8
**InsertOpcodeAddr
155 EFI_VFR_RETURN_CODE
AdjustDynamicInsertOpcode (
156 IN CHAR8
*LastFormEndAddr
,
157 IN CHAR8
*InsertOpcodeAddr
159 CHAR8
* GetBufAddrBaseOnOffset (
164 extern CFormPkg gCFormPkg
;
165 extern CVfrStringDB gCVfrStringDB
;
166 extern UINT32 gAdjustOpcodeOffset
;
167 extern BOOLEAN gNeedAdjustOpcode
;
180 #define EFI_IFR_RECORDINFO_IDX_INVALUD 0xFFFFFF
181 #define EFI_IFR_RECORDINFO_IDX_START 0x0
183 class CIfrRecordInfoDB
{
187 SIfrRecord
*mIfrRecordListHead
;
188 SIfrRecord
*mIfrRecordListTail
;
190 SIfrRecord
* GetRecordInfoFromIdx (IN UINT32
);
191 BOOLEAN
CheckQuestionOpCode (IN UINT8
);
192 BOOLEAN
CheckIdOpCode (IN UINT8
);
193 EFI_QUESTION_ID
GetOpcodeQuestionId (IN EFI_IFR_OP_HEADER
*);
195 CIfrRecordInfoDB (VOID
);
196 ~CIfrRecordInfoDB (VOID
);
198 inline VOID
TurnOn (VOID
) {
202 inline VOID
TurnOff (VOID
) {
206 SIfrRecord
* GetRecordInfoFromOffset (IN UINT32
);
207 VOID
IfrAdjustOffsetForRecord (VOID
);
208 BOOLEAN
IfrAdjustDynamicOpcodeInRecords (VOID
);
210 UINT32
IfrRecordRegister (IN UINT32
, IN CHAR8
*, IN UINT8
, IN UINT32
);
211 VOID
IfrRecordInfoUpdate (IN UINT32
, IN UINT32
, IN CHAR8
*, IN UINT8
, IN UINT32
);
212 VOID
IfrRecordOutput (IN
FILE *, IN UINT32 LineNo
);
213 VOID
IfrRecordOutput (OUT PACKAGE_DATA
&);
214 EFI_VFR_RETURN_CODE
IfrRecordAdjust (VOID
);
217 extern CIfrRecordInfoDB gCIfrRecordInfoDB
;
220 * The definition of CIfrObj
222 extern BOOLEAN gCreateOp
;
235 CIfrObj (IN UINT8 OpCode
, OUT CHAR8
**IfrObj
= NULL
, IN UINT8 ObjBinLen
= 0, IN BOOLEAN DelayEmit
= FALSE
);
236 virtual ~CIfrObj(VOID
);
238 VOID
_EMIT_PENDING_OBJ (VOID
);
240 inline VOID
SetLineNo (IN UINT32 LineNo
) {
244 inline CHAR8
* GetObjBinAddr (VOID
) {
248 inline UINT32
GetObjBinOffset (VOID
) {
252 inline UINT8
GetObjBinLen (VOID
) {
256 inline bool ExpendObjBin (IN UINT8 Size
) {
257 if ((mDelayEmit
== TRUE
) && ((mObjBinLen
+ Size
) > mObjBinLen
)) {
258 mObjBinLen
= mObjBinLen
+ Size
;
265 inline bool ShrinkObjBin (IN UINT8 Size
) {
266 if ((mDelayEmit
== TRUE
) && (mObjBinLen
> Size
)) {
276 * The definition of CIfrOpHeader
280 EFI_IFR_OP_HEADER
*mHeader
;
283 CIfrOpHeader (IN UINT8 OpCode
, IN VOID
*StartAddr
, IN UINT8 Length
= 0);
284 CIfrOpHeader (IN CIfrOpHeader
&);
286 VOID
IncLength (UINT8 Size
) {
287 if ((mHeader
->Length
+ Size
) > mHeader
->Length
) {
288 mHeader
->Length
= mHeader
->Length
+ Size
;
292 VOID
DecLength (UINT8 Size
) {
293 if (mHeader
->Length
>= Size
) {
294 mHeader
->Length
-= Size
;
299 return mHeader
->Length
;
303 return mHeader
->Scope
;
306 VOID
SetScope (IN UINT8 Scope
) {
307 mHeader
->Scope
= Scope
;
310 VOID
UpdateHeader (IN EFI_IFR_OP_HEADER
*Header
) {
315 return mHeader
->OpCode
;
319 extern UINT8 gScopeCount
;
322 * The definition of CIfrStatementHeader
324 class CIfrStatementHeader
{
326 EFI_IFR_STATEMENT_HEADER
*mHeader
;
329 CIfrStatementHeader (
330 IN EFI_IFR_STATEMENT_HEADER
*StartAddr
331 ) : mHeader ((EFI_IFR_STATEMENT_HEADER
*)StartAddr
) {
333 mHeader
->Help
= EFI_STRING_ID_INVALID
;
334 mHeader
->Prompt
= EFI_STRING_ID_INVALID
;
337 EFI_IFR_STATEMENT_HEADER
*GetStatementHeader () {
341 VOID
SetPrompt (IN EFI_STRING_ID Prompt
) {
342 mHeader
->Prompt
= Prompt
;
345 VOID
SetHelp (IN EFI_STRING_ID Help
) {
346 mHeader
->Help
= Help
;
351 * The definition of CIfrQuestionHeader
353 #define EFI_IFR_QUESTION_FLAG_DEFAULT 0
355 class CIfrQuestionHeader
: public CIfrStatementHeader
{
357 EFI_IFR_QUESTION_HEADER
*mHeader
;
359 EFI_IFR_STATEMENT_HEADER
* QH2SH (EFI_IFR_QUESTION_HEADER
*Qheader
) {
360 return &(Qheader
)->Header
;
364 EFI_QUESTION_ID
QUESTION_ID (VOID
) {
365 return mHeader
->QuestionId
;
368 EFI_VARSTORE_ID
VARSTORE_ID (VOID
) {
369 return mHeader
->VarStoreId
;
372 VOID
VARSTORE_INFO (OUT EFI_VARSTORE_INFO
*Info
) {
374 Info
->mVarStoreId
= mHeader
->VarStoreId
;
375 memmove (&Info
->mVarStoreId
, &mHeader
->VarStoreInfo
, sizeof (Info
->mVarStoreId
));
380 return mHeader
->Flags
;
385 IN EFI_IFR_QUESTION_HEADER
*StartAddr
,
386 IN UINT8 Flags
= EFI_IFR_QUESTION_FLAG_DEFAULT
387 ) : CIfrStatementHeader (QH2SH(StartAddr
)) {
389 mHeader
->QuestionId
= EFI_QUESTION_ID_INVALID
;
390 mHeader
->VarStoreId
= EFI_VARSTORE_ID_INVALID
;
391 mHeader
->VarStoreInfo
.VarName
= EFI_STRING_ID_INVALID
;
392 mHeader
->VarStoreInfo
.VarOffset
= EFI_VAROFFSET_INVALID
;
393 mHeader
->Flags
= Flags
;
396 VOID
SetQuestionId (IN EFI_QUESTION_ID QuestionId
) {
397 mHeader
->QuestionId
= QuestionId
;
400 VOID
SetVarStoreInfo (IN EFI_VARSTORE_INFO
*Info
) {
401 mHeader
->VarStoreId
= Info
->mVarStoreId
;
402 mHeader
->VarStoreInfo
.VarName
= Info
->mInfo
.mVarName
;
403 mHeader
->VarStoreInfo
.VarOffset
= Info
->mInfo
.mVarOffset
;
406 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 Flags
) {
407 if (_FLAG_TEST_AND_CLEAR (Flags
, EFI_IFR_FLAG_READ_ONLY
)) {
408 mHeader
->Flags
|= EFI_IFR_FLAG_READ_ONLY
;
411 _FLAG_CLEAR (Flags
, 0x02);
413 if (_FLAG_TEST_AND_CLEAR (Flags
, EFI_IFR_FLAG_CALLBACK
)) {
414 mHeader
->Flags
|= EFI_IFR_FLAG_CALLBACK
;
418 // ignore NVAccessFlag
420 _FLAG_CLEAR (Flags
, 0x08);
422 if (_FLAG_TEST_AND_CLEAR (Flags
, EFI_IFR_FLAG_RESET_REQUIRED
)) {
423 mHeader
->Flags
|= EFI_IFR_FLAG_RESET_REQUIRED
;
427 // Set LateCheck Flag to compatible for framework flag
428 // but it uses 0x20 as its flag, if in the future UEFI may take this flag
430 if (_FLAG_TEST_AND_CLEAR (Flags
, 0x20)) {
431 mHeader
->Flags
|= 0x20;
434 if (_FLAG_TEST_AND_CLEAR (Flags
, EFI_IFR_FLAG_OPTIONS_ONLY
)) {
435 mHeader
->Flags
|= EFI_IFR_FLAG_OPTIONS_ONLY
;
438 return _FLAGS_ZERO (Flags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
441 VOID
UpdateCIfrQuestionHeader (IN EFI_IFR_QUESTION_HEADER
*Header
) {
447 * The definition of CIfrMinMaxStepData
449 class CIfrMinMaxStepData
{
451 MINMAXSTEP_DATA
*mMinMaxStepData
;
456 CIfrMinMaxStepData (MINMAXSTEP_DATA
*DataAddr
, BOOLEAN NumericOpcode
=FALSE
) : mMinMaxStepData (DataAddr
) {
457 mMinMaxStepData
->u64
.MinValue
= 0;
458 mMinMaxStepData
->u64
.MaxValue
= 0;
459 mMinMaxStepData
->u64
.Step
= 0;
461 IsNumeric
= NumericOpcode
;
464 VOID
SetMinMaxStepData (IN UINT64 MinValue
, IN UINT64 MaxValue
, IN UINT64 Step
) {
466 mMinMaxStepData
->u64
.MinValue
= MinValue
;
467 mMinMaxStepData
->u64
.MaxValue
= MaxValue
;
470 if (MinValue
< mMinMaxStepData
->u64
.MinValue
) {
471 mMinMaxStepData
->u64
.MinValue
= MinValue
;
473 if (MaxValue
> mMinMaxStepData
->u64
.MaxValue
) {
474 mMinMaxStepData
->u64
.MaxValue
= MaxValue
;
477 mMinMaxStepData
->u64
.Step
= Step
;
480 VOID
SetMinMaxStepData (IN UINT32 MinValue
, IN UINT32 MaxValue
, IN UINT32 Step
) {
482 mMinMaxStepData
->u32
.MinValue
= MinValue
;
483 mMinMaxStepData
->u32
.MaxValue
= MaxValue
;
486 if (MinValue
< mMinMaxStepData
->u32
.MinValue
) {
487 mMinMaxStepData
->u32
.MinValue
= MinValue
;
489 if (MaxValue
> mMinMaxStepData
->u32
.MaxValue
) {
490 mMinMaxStepData
->u32
.MaxValue
= MaxValue
;
493 mMinMaxStepData
->u32
.Step
= Step
;
496 VOID
SetMinMaxStepData (IN UINT16 MinValue
, IN UINT16 MaxValue
, IN UINT16 Step
) {
498 mMinMaxStepData
->u16
.MinValue
= MinValue
;
499 mMinMaxStepData
->u16
.MaxValue
= MaxValue
;
502 if (MinValue
< mMinMaxStepData
->u16
.MinValue
) {
503 mMinMaxStepData
->u16
.MinValue
= MinValue
;
505 if (MaxValue
> mMinMaxStepData
->u16
.MaxValue
) {
506 mMinMaxStepData
->u16
.MaxValue
= MaxValue
;
509 mMinMaxStepData
->u16
.Step
= Step
;
512 VOID
SetMinMaxStepData (IN UINT8 MinValue
, IN UINT8 MaxValue
, IN UINT8 Step
) {
514 mMinMaxStepData
->u8
.MinValue
= MinValue
;
515 mMinMaxStepData
->u8
.MaxValue
= MaxValue
;
518 if (MinValue
< mMinMaxStepData
->u8
.MinValue
) {
519 mMinMaxStepData
->u8
.MinValue
= MinValue
;
521 if (MaxValue
> mMinMaxStepData
->u8
.MaxValue
) {
522 mMinMaxStepData
->u8
.MaxValue
= MaxValue
;
525 mMinMaxStepData
->u8
.Step
= Step
;
528 UINT64
GetMinData (UINT8 VarType
) {
531 case EFI_IFR_TYPE_NUM_SIZE_64
:
532 MinValue
= mMinMaxStepData
->u64
.MinValue
;
534 case EFI_IFR_TYPE_NUM_SIZE_32
:
535 MinValue
= (UINT64
) mMinMaxStepData
->u32
.MinValue
;
537 case EFI_IFR_TYPE_NUM_SIZE_16
:
538 MinValue
= (UINT64
) mMinMaxStepData
->u16
.MinValue
;
540 case EFI_IFR_TYPE_NUM_SIZE_8
:
541 MinValue
= (UINT64
) mMinMaxStepData
->u8
.MinValue
;
549 UINT64
GetMaxData (UINT8 VarType
) {
552 case EFI_IFR_TYPE_NUM_SIZE_64
:
553 MaxValue
= mMinMaxStepData
->u64
.MaxValue
;
555 case EFI_IFR_TYPE_NUM_SIZE_32
:
556 MaxValue
= (UINT64
) mMinMaxStepData
->u32
.MaxValue
;
558 case EFI_IFR_TYPE_NUM_SIZE_16
:
559 MaxValue
= (UINT64
) mMinMaxStepData
->u16
.MaxValue
;
561 case EFI_IFR_TYPE_NUM_SIZE_8
:
562 MaxValue
= (UINT64
) mMinMaxStepData
->u8
.MaxValue
;
570 UINT64
GetStepData (UINT8 VarType
) {
573 case EFI_IFR_TYPE_NUM_SIZE_64
:
574 MaxValue
= mMinMaxStepData
->u64
.Step
;
576 case EFI_IFR_TYPE_NUM_SIZE_32
:
577 MaxValue
= (UINT64
) mMinMaxStepData
->u32
.Step
;
579 case EFI_IFR_TYPE_NUM_SIZE_16
:
580 MaxValue
= (UINT64
) mMinMaxStepData
->u16
.Step
;
582 case EFI_IFR_TYPE_NUM_SIZE_8
:
583 MaxValue
= (UINT64
) mMinMaxStepData
->u8
.Step
;
591 BOOLEAN
IsNumericOpcode () {
595 VOID
UpdateCIfrMinMaxStepData (IN MINMAXSTEP_DATA
*MinMaxStepData
) {
596 mMinMaxStepData
= MinMaxStepData
;
600 static CIfrQuestionHeader
*gCurrentQuestion
= NULL
;
601 static CIfrMinMaxStepData
*gCurrentMinMaxData
= NULL
;
602 static BOOLEAN gIsOrderedList
= FALSE
;
605 * The definition of all of the UEFI IFR Objects
607 class CIfrFormSet
: public CIfrObj
, public CIfrOpHeader
{
609 EFI_IFR_FORM_SET
*mFormSet
;
610 EFI_GUID
*mClassGuid
;
613 CIfrFormSet (UINT8 Size
) : CIfrObj (EFI_IFR_FORM_SET_OP
, (CHAR8
**)&mFormSet
, Size
),
614 CIfrOpHeader (EFI_IFR_FORM_SET_OP
, &mFormSet
->Header
, Size
) {
615 mFormSet
->Help
= EFI_STRING_ID_INVALID
;
616 mFormSet
->FormSetTitle
= EFI_STRING_ID_INVALID
;
618 memset (&mFormSet
->Guid
, 0, sizeof (EFI_GUID
));
619 mClassGuid
= (EFI_GUID
*) (mFormSet
+ 1);
622 VOID
SetGuid (IN EFI_GUID
*Guid
) {
623 memmove (&mFormSet
->Guid
, Guid
, sizeof (EFI_GUID
));
626 VOID
SetFormSetTitle (IN EFI_STRING_ID FormSetTitle
) {
627 mFormSet
->FormSetTitle
= FormSetTitle
;
630 VOID
SetHelp (IN EFI_STRING_ID Help
) {
631 mFormSet
->Help
= Help
;
634 VOID
SetClassGuid (IN EFI_GUID
*Guid
) {
635 memmove (&(mClassGuid
[mFormSet
->Flags
++]), Guid
, sizeof (EFI_GUID
));
639 return mFormSet
->Flags
;
643 class CIfrEnd
: public CIfrObj
, public CIfrOpHeader
{
648 CIfrEnd () : CIfrObj (EFI_IFR_END_OP
, (CHAR8
**)&mEnd
),
649 CIfrOpHeader (EFI_IFR_END_OP
, &mEnd
->Header
) {}
652 class CIfrDefaultStore
: public CIfrObj
, public CIfrOpHeader
{
654 EFI_IFR_DEFAULTSTORE
*mDefaultStore
;
657 CIfrDefaultStore () : CIfrObj (EFI_IFR_DEFAULTSTORE_OP
, (CHAR8
**)&mDefaultStore
),
658 CIfrOpHeader (EFI_IFR_DEFAULTSTORE_OP
, &mDefaultStore
->Header
) {
659 mDefaultStore
->DefaultId
= EFI_VARSTORE_ID_INVALID
;
660 mDefaultStore
->DefaultName
= EFI_STRING_ID_INVALID
;
663 VOID
SetDefaultName (IN EFI_STRING_ID DefaultName
) {
664 mDefaultStore
->DefaultName
= DefaultName
;
667 VOID
SetDefaultId (IN UINT16 DefaultId
) {
668 mDefaultStore
->DefaultId
= DefaultId
;
672 #define EFI_FORM_ID_MAX 0xFFFF
673 #define EFI_FREE_FORM_ID_BITMAP_SIZE ((EFI_FORM_ID_MAX + 1) / EFI_BITS_PER_UINT32)
677 STATIC UINT32 FormIdBitMap
[EFI_FREE_FORM_ID_BITMAP_SIZE
];
679 STATIC BOOLEAN
ChekFormIdFree (IN EFI_FORM_ID FormId
) {
680 UINT32 Index
= (FormId
/ EFI_BITS_PER_UINT32
);
681 UINT32 Offset
= (FormId
% EFI_BITS_PER_UINT32
);
683 return (FormIdBitMap
[Index
] & (0x80000000 >> Offset
)) == 0;
686 STATIC VOID
MarkFormIdUsed (IN EFI_FORM_ID FormId
) {
687 UINT32 Index
= (FormId
/ EFI_BITS_PER_UINT32
);
688 UINT32 Offset
= (FormId
% EFI_BITS_PER_UINT32
);
690 FormIdBitMap
[Index
] |= (0x80000000 >> Offset
);
694 class CIfrForm
: public CIfrObj
, public CIfrOpHeader
{
699 CIfrForm () : CIfrObj (EFI_IFR_FORM_OP
, (CHAR8
**)&mForm
),
700 CIfrOpHeader (EFI_IFR_FORM_OP
, &mForm
->Header
) {
702 mForm
->FormTitle
= EFI_STRING_ID_INVALID
;
705 EFI_VFR_RETURN_CODE
SetFormId (IN EFI_FORM_ID FormId
) {
708 // FormId can't be 0.
710 return VFR_RETURN_INVALID_PARAMETER
;
712 if (CIfrFormId::ChekFormIdFree (FormId
) == FALSE
) {
713 return VFR_RETURN_FORMID_REDEFINED
;
715 mForm
->FormId
= FormId
;
716 CIfrFormId::MarkFormIdUsed (FormId
);
717 return VFR_RETURN_SUCCESS
;
720 VOID
SetFormTitle (IN EFI_STRING_ID FormTitle
) {
721 mForm
->FormTitle
= FormTitle
;
725 class CIfrFormMap
: public CIfrObj
, public CIfrOpHeader
{
727 EFI_IFR_FORM_MAP
*mFormMap
;
728 EFI_IFR_FORM_MAP_METHOD
*mMethodMap
;
731 CIfrFormMap () : CIfrObj (EFI_IFR_FORM_MAP_OP
, (CHAR8
**)&mFormMap
, sizeof (EFI_IFR_FORM_MAP
), TRUE
),
732 CIfrOpHeader (EFI_IFR_FORM_MAP_OP
, &mFormMap
->Header
) {
733 mFormMap
->FormId
= 0;
734 mMethodMap
= (EFI_IFR_FORM_MAP_METHOD
*) (mFormMap
+ 1);
737 EFI_VFR_RETURN_CODE
SetFormId (IN EFI_FORM_ID FormId
) {
740 // FormId can't be 0.
742 return VFR_RETURN_INVALID_PARAMETER
;
744 if (CIfrFormId::ChekFormIdFree (FormId
) == FALSE
) {
745 return VFR_RETURN_FORMID_REDEFINED
;
747 mFormMap
->FormId
= FormId
;
748 CIfrFormId::MarkFormIdUsed (FormId
);
749 return VFR_RETURN_SUCCESS
;
752 VOID
SetFormMapMethod (IN EFI_STRING_ID MethodTitle
, IN EFI_GUID
*MethodGuid
) {
753 if (ExpendObjBin (sizeof (EFI_IFR_FORM_MAP_METHOD
))) {
754 IncLength (sizeof (EFI_IFR_FORM_MAP_METHOD
));
756 mMethodMap
->MethodTitle
= MethodTitle
;
757 memmove (&(mMethodMap
->MethodIdentifier
), MethodGuid
, sizeof (EFI_GUID
));
763 class CIfrVarStore
: public CIfrObj
, public CIfrOpHeader
{
765 EFI_IFR_VARSTORE
*mVarStore
;
768 CIfrVarStore () : CIfrObj (EFI_IFR_VARSTORE_OP
, (CHAR8
**)&mVarStore
, sizeof (EFI_IFR_VARSTORE
), TRUE
),
769 CIfrOpHeader (EFI_IFR_VARSTORE_OP
, &mVarStore
->Header
) {
770 mVarStore
->VarStoreId
= EFI_VARSTORE_ID_INVALID
;
772 memset (&mVarStore
->Guid
, 0, sizeof (EFI_GUID
));
773 mVarStore
->Name
[0] = '\0';
776 VOID
SetGuid (IN EFI_GUID
*Guid
) {
777 memmove (&mVarStore
->Guid
, Guid
, sizeof (EFI_GUID
));
780 VOID
SetVarStoreId (IN EFI_VARSTORE_ID VarStoreId
) {
781 mVarStore
->VarStoreId
= VarStoreId
;
784 VOID
SetSize (IN UINT16 Size
) {
785 mVarStore
->Size
= Size
;
788 VOID
SetName (IN CHAR8
*Name
) {
792 Len
= (UINT8
) strlen (Name
);
794 if (ExpendObjBin (Len
) == TRUE
) {
796 strcpy ((CHAR8
*)(mVarStore
->Name
), Name
);
803 class CIfrVarStoreEfi
: public CIfrObj
, public CIfrOpHeader
{
805 EFI_IFR_VARSTORE_EFI
*mVarStoreEfi
;
808 CIfrVarStoreEfi () : CIfrObj (EFI_IFR_VARSTORE_EFI_OP
, (CHAR8
**)&mVarStoreEfi
, sizeof (EFI_IFR_VARSTORE_EFI
), TRUE
),
809 CIfrOpHeader (EFI_IFR_VARSTORE_EFI_OP
, &mVarStoreEfi
->Header
) {
810 mVarStoreEfi
->VarStoreId
= EFI_VAROFFSET_INVALID
;
811 mVarStoreEfi
->Size
= 0;
812 memset (&mVarStoreEfi
->Guid
, 0, sizeof (EFI_GUID
));
813 mVarStoreEfi
->Name
[0] = '\0';
816 VOID
SetGuid (IN EFI_GUID
*Guid
) {
817 memmove (&mVarStoreEfi
->Guid
, Guid
, sizeof (EFI_GUID
));
820 VOID
SetVarStoreId (IN UINT16 VarStoreId
) {
821 mVarStoreEfi
->VarStoreId
= VarStoreId
;
824 VOID
SetAttributes (IN UINT32 Attributes
) {
825 mVarStoreEfi
->Attributes
= Attributes
;
827 VOID
SetSize (IN UINT16 Size
) {
828 mVarStoreEfi
->Size
= Size
;
831 VOID
SetName (IN CHAR8
*Name
) {
835 Len
= (UINT8
) strlen (Name
);
837 if (ExpendObjBin (Len
) == TRUE
) {
839 strcpy ((CHAR8
*)(mVarStoreEfi
->Name
), Name
);
845 VOID
SetBinaryLength (IN UINT16 Size
) {
848 Len
= sizeof (EFI_IFR_VARSTORE_EFI
);
850 ExpendObjBin(Size
- Len
);
851 IncLength(Size
- Len
);
853 ShrinkObjBin(Len
- Size
);
854 DecLength(Len
- Size
);
859 class CIfrVarStoreNameValue
: public CIfrObj
, public CIfrOpHeader
{
861 EFI_IFR_VARSTORE_NAME_VALUE
*mVarStoreNameValue
;
864 CIfrVarStoreNameValue () : CIfrObj (EFI_IFR_VARSTORE_NAME_VALUE_OP
, (CHAR8
**)&mVarStoreNameValue
),
865 CIfrOpHeader (EFI_IFR_VARSTORE_NAME_VALUE_OP
, &mVarStoreNameValue
->Header
) {
866 mVarStoreNameValue
->VarStoreId
= EFI_VAROFFSET_INVALID
;
867 memset (&mVarStoreNameValue
->Guid
, 0, sizeof (EFI_GUID
));
870 VOID
SetGuid (IN EFI_GUID
*Guid
) {
871 memmove (&mVarStoreNameValue
->Guid
, Guid
, sizeof (EFI_GUID
));
874 VOID
SetVarStoreId (IN UINT16 VarStoreId
) {
875 mVarStoreNameValue
->VarStoreId
= VarStoreId
;
879 class CIfrImage
: public CIfrObj
, public CIfrOpHeader
{
881 EFI_IFR_IMAGE
*mImage
;
884 CIfrImage () : CIfrObj (EFI_IFR_IMAGE_OP
, (CHAR8
**)&mImage
),
885 CIfrOpHeader (EFI_IFR_IMAGE_OP
, &mImage
->Header
) {
886 mImage
->Id
= EFI_IMAGE_ID_INVALID
;
889 VOID
SetImageId (IN EFI_IMAGE_ID ImageId
) {
890 mImage
->Id
= ImageId
;
894 class CIfrModal
: public CIfrObj
, public CIfrOpHeader
{
896 EFI_IFR_MODAL_TAG
*mModal
;
899 CIfrModal () : CIfrObj (EFI_IFR_MODAL_TAG_OP
, (CHAR8
**)&mModal
),
900 CIfrOpHeader (EFI_IFR_MODAL_TAG_OP
, &mModal
->Header
) {
905 class CIfrLocked
: public CIfrObj
, public CIfrOpHeader
{
907 EFI_IFR_LOCKED
*mLocked
;
910 CIfrLocked () : CIfrObj (EFI_IFR_LOCKED_OP
, (CHAR8
**)&mLocked
),
911 CIfrOpHeader (EFI_IFR_LOCKED_OP
, &mLocked
->Header
) {}
914 class CIfrRule
: public CIfrObj
, public CIfrOpHeader
{
919 CIfrRule () : CIfrObj (EFI_IFR_RULE_OP
, (CHAR8
**)&mRule
),
920 mRule ((EFI_IFR_RULE
*)GetObjBinAddr()),
921 CIfrOpHeader (EFI_IFR_RULE_OP
, &mRule
->Header
) {
922 mRule
->RuleId
= EFI_RULE_ID_INVALID
;
925 VOID
SetRuleId (IN UINT8 RuleId
) {
926 mRule
->RuleId
= RuleId
;
930 static EFI_IFR_TYPE_VALUE gZeroEfiIfrTypeValue
= {0, };
932 class CIfrDefault
: public CIfrObj
, public CIfrOpHeader
{
934 EFI_IFR_DEFAULT
*mDefault
;
939 IN UINT16 DefaultId
= EFI_HII_DEFAULT_CLASS_STANDARD
,
940 IN UINT8 Type
= EFI_IFR_TYPE_OTHER
,
941 IN EFI_IFR_TYPE_VALUE Value
= gZeroEfiIfrTypeValue
942 ) : CIfrObj (EFI_IFR_DEFAULT_OP
, (CHAR8
**)&mDefault
, Size
),
943 CIfrOpHeader (EFI_IFR_DEFAULT_OP
, &mDefault
->Header
, Size
) {
944 mDefault
->Type
= Type
;
945 mDefault
->DefaultId
= DefaultId
;
946 memmove (&(mDefault
->Value
), &Value
, Size
- OFFSET_OF (EFI_IFR_DEFAULT
, Value
));
949 VOID
SetDefaultId (IN UINT16 DefaultId
) {
950 mDefault
->DefaultId
= DefaultId
;
953 VOID
SetType (IN UINT8 Type
) {
954 mDefault
->Type
= Type
;
957 VOID
SetValue (IN EFI_IFR_TYPE_VALUE Value
) {
958 memmove (&mDefault
->Value
, &Value
, mDefault
->Header
.Length
- OFFSET_OF (EFI_IFR_DEFAULT
, Value
));
962 class CIfrDefault2
: public CIfrObj
, public CIfrOpHeader
{
964 EFI_IFR_DEFAULT_2
*mDefault
;
968 IN UINT16 DefaultId
= EFI_HII_DEFAULT_CLASS_STANDARD
,
969 IN UINT8 Type
= EFI_IFR_TYPE_OTHER
970 ) : CIfrObj (EFI_IFR_DEFAULT_OP
, (CHAR8
**)&mDefault
, sizeof (EFI_IFR_DEFAULT_2
)),
971 CIfrOpHeader (EFI_IFR_DEFAULT_OP
, &mDefault
->Header
, sizeof (EFI_IFR_DEFAULT_2
)) {
972 mDefault
->Type
= Type
;
973 mDefault
->DefaultId
= DefaultId
;
976 VOID
SetDefaultId (IN UINT16 DefaultId
) {
977 mDefault
->DefaultId
= DefaultId
;
980 VOID
SetType (IN UINT8 Type
) {
981 mDefault
->Type
= Type
;
985 class CIfrValue
: public CIfrObj
, public CIfrOpHeader
{
987 EFI_IFR_VALUE
*mValue
;
990 CIfrValue () : CIfrObj (EFI_IFR_VALUE_OP
, (CHAR8
**)&mValue
),
991 CIfrOpHeader (EFI_IFR_VALUE_OP
, &mValue
->Header
) {}
995 class CIfrRead
: public CIfrObj
, public CIfrOpHeader
{
1000 CIfrRead () : CIfrObj (EFI_IFR_READ_OP
, (CHAR8
**)&mRead
),
1001 CIfrOpHeader (EFI_IFR_READ_OP
, &mRead
->Header
) {}
1005 class CIfrWrite
: public CIfrObj
, public CIfrOpHeader
{
1007 EFI_IFR_WRITE
*mWrite
;
1010 CIfrWrite () : CIfrObj (EFI_IFR_WRITE_OP
, (CHAR8
**)&mWrite
),
1011 CIfrOpHeader (EFI_IFR_WRITE_OP
, &mWrite
->Header
) {}
1015 class CIfrGet
: public CIfrObj
, public CIfrOpHeader
{
1022 ) : CIfrObj (EFI_IFR_GET_OP
, (CHAR8
**)&mGet
),
1023 CIfrOpHeader (EFI_IFR_GET_OP
, &mGet
->Header
) {
1027 VOID
SetVarInfo (IN EFI_VARSTORE_INFO
*Info
) {
1028 mGet
->VarStoreId
= Info
->mVarStoreId
;
1029 mGet
->VarStoreInfo
.VarName
= Info
->mInfo
.mVarName
;
1030 mGet
->VarStoreInfo
.VarOffset
= Info
->mInfo
.mVarOffset
;
1031 mGet
->VarStoreType
= Info
->mVarType
;
1035 class CIfrSet
: public CIfrObj
, public CIfrOpHeader
{
1042 ) : CIfrObj (EFI_IFR_SET_OP
, (CHAR8
**)&mSet
),
1043 CIfrOpHeader (EFI_IFR_SET_OP
, &mSet
->Header
) {
1047 VOID
SetVarInfo (IN EFI_VARSTORE_INFO
*Info
) {
1048 mSet
->VarStoreId
= Info
->mVarStoreId
;
1049 mSet
->VarStoreInfo
.VarName
= Info
->mInfo
.mVarName
;
1050 mSet
->VarStoreInfo
.VarOffset
= Info
->mInfo
.mVarOffset
;
1051 mSet
->VarStoreType
= Info
->mVarType
;
1055 class CIfrSubtitle
: public CIfrObj
, public CIfrOpHeader
, public CIfrStatementHeader
{
1057 EFI_IFR_SUBTITLE
*mSubtitle
;
1060 CIfrSubtitle () : CIfrObj (EFI_IFR_SUBTITLE_OP
, (CHAR8
**)&mSubtitle
),
1061 CIfrOpHeader (EFI_IFR_SUBTITLE_OP
, &mSubtitle
->Header
),
1062 CIfrStatementHeader (&mSubtitle
->Statement
) {
1063 mSubtitle
->Flags
= 0;
1066 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 LFlags
) {
1067 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_FLAGS_HORIZONTAL
)) {
1068 mSubtitle
->Flags
|= EFI_IFR_FLAGS_HORIZONTAL
;
1071 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1075 class CIfrText
: public CIfrObj
, public CIfrOpHeader
, public CIfrStatementHeader
{
1077 EFI_IFR_TEXT
*mText
;
1080 CIfrText () : CIfrObj (EFI_IFR_TEXT_OP
, (CHAR8
**)&mText
),
1081 CIfrOpHeader (EFI_IFR_TEXT_OP
, &mText
->Header
),
1082 CIfrStatementHeader (&mText
->Statement
) {
1083 mText
->TextTwo
= EFI_STRING_ID_INVALID
;
1086 VOID
SetTextTwo (IN EFI_STRING_ID StringId
) {
1087 mText
->TextTwo
= StringId
;
1091 class CIfrRef
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1096 CIfrRef () : CIfrObj (EFI_IFR_REF_OP
, (CHAR8
**)&mRef
),
1097 CIfrOpHeader (EFI_IFR_REF_OP
, &mRef
->Header
),
1098 CIfrQuestionHeader (&mRef
->Question
) {
1102 VOID
SetFormId (IN EFI_FORM_ID FormId
) {
1103 mRef
->FormId
= FormId
;
1107 class CIfrRef2
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1109 EFI_IFR_REF2
*mRef2
;
1112 CIfrRef2 () : CIfrObj (EFI_IFR_REF_OP
, (CHAR8
**)&mRef2
, sizeof (EFI_IFR_REF2
)),
1113 CIfrOpHeader (EFI_IFR_REF_OP
, &mRef2
->Header
, sizeof (EFI_IFR_REF2
)),
1114 CIfrQuestionHeader (&mRef2
->Question
) {
1116 mRef2
->QuestionId
= EFI_QUESTION_ID_INVALID
;
1119 VOID
SetFormId (IN EFI_FORM_ID FormId
) {
1120 mRef2
->FormId
= FormId
;
1123 VOID
SetQuestionId (IN EFI_QUESTION_ID QuestionId
) {
1124 mRef2
->QuestionId
= QuestionId
;
1128 class CIfrRef3
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1130 EFI_IFR_REF3
*mRef3
;
1133 CIfrRef3 () : CIfrObj (EFI_IFR_REF_OP
, (CHAR8
**)&mRef3
, sizeof(EFI_IFR_REF3
)),
1134 CIfrOpHeader (EFI_IFR_REF_OP
, &mRef3
->Header
, sizeof (EFI_IFR_REF3
)),
1135 CIfrQuestionHeader (&mRef3
->Question
) {
1137 mRef3
->QuestionId
= EFI_QUESTION_ID_INVALID
;
1138 memset (&mRef3
->FormSetId
, 0, sizeof (EFI_GUID
));
1141 VOID
SetFormId (IN EFI_FORM_ID FormId
) {
1142 mRef3
->FormId
= FormId
;
1145 VOID
SetQuestionId (IN EFI_QUESTION_ID QuestionId
) {
1146 mRef3
->QuestionId
= QuestionId
;
1149 VOID
SetFormSetId (IN EFI_GUID FormSetId
) {
1150 mRef3
->FormSetId
= FormSetId
;
1154 class CIfrRef4
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1156 EFI_IFR_REF4
*mRef4
;
1159 CIfrRef4 () : CIfrObj (EFI_IFR_REF_OP
, (CHAR8
**)&mRef4
, sizeof(EFI_IFR_REF4
)),
1160 CIfrOpHeader (EFI_IFR_REF_OP
, &mRef4
->Header
, sizeof(EFI_IFR_REF4
)),
1161 CIfrQuestionHeader (&mRef4
->Question
) {
1163 mRef4
->QuestionId
= EFI_QUESTION_ID_INVALID
;
1164 memset (&mRef4
->FormSetId
, 0, sizeof (EFI_GUID
));
1165 mRef4
->DevicePath
= EFI_STRING_ID_INVALID
;
1168 VOID
SetFormId (IN EFI_FORM_ID FormId
) {
1169 mRef4
->FormId
= FormId
;
1172 VOID
SetQuestionId (IN EFI_QUESTION_ID QuestionId
) {
1173 mRef4
->QuestionId
= QuestionId
;
1176 VOID
SetFormSetId (IN EFI_GUID FormSetId
) {
1177 mRef4
->FormSetId
= FormSetId
;
1180 VOID
SetDevicePath (IN EFI_STRING_ID DevicePath
) {
1181 mRef4
->DevicePath
= DevicePath
;
1185 class CIfrRef5
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1187 EFI_IFR_REF5
*mRef5
;
1190 CIfrRef5 () : CIfrObj (EFI_IFR_REF_OP
, (CHAR8
**)&mRef5
, sizeof (EFI_IFR_REF5
)),
1191 CIfrOpHeader (EFI_IFR_REF_OP
, &mRef5
->Header
, sizeof (EFI_IFR_REF5
)),
1192 CIfrQuestionHeader (&mRef5
->Question
) {
1196 class CIfrResetButton
: public CIfrObj
, public CIfrOpHeader
, public CIfrStatementHeader
{
1198 EFI_IFR_RESET_BUTTON
*mResetButton
;
1201 CIfrResetButton () : CIfrObj (EFI_IFR_RESET_BUTTON_OP
, (CHAR8
**)&mResetButton
),
1202 CIfrOpHeader (EFI_IFR_RESET_BUTTON_OP
, &mResetButton
->Header
),
1203 CIfrStatementHeader (&mResetButton
->Statement
) {
1204 mResetButton
->DefaultId
= EFI_HII_DEFAULT_CLASS_STANDARD
;
1207 VOID
SetDefaultId (IN UINT16 DefaultId
) {
1208 mResetButton
->DefaultId
= DefaultId
;
1212 class CIfrCheckBox
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1214 EFI_IFR_CHECKBOX
*mCheckBox
;
1217 CIfrCheckBox () : CIfrObj (EFI_IFR_CHECKBOX_OP
, (CHAR8
**)&mCheckBox
),
1218 CIfrOpHeader (EFI_IFR_CHECKBOX_OP
, &mCheckBox
->Header
),
1219 CIfrQuestionHeader (&mCheckBox
->Question
) {
1220 mCheckBox
->Flags
= 0;
1221 gCurrentQuestion
= this;
1225 gCurrentQuestion
= NULL
;
1228 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, UINT8 LFlags
) {
1229 EFI_VFR_RETURN_CODE Ret
;
1231 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1232 if (Ret
!= VFR_RETURN_SUCCESS
) {
1236 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_CHECKBOX_DEFAULT
)) {
1237 mCheckBox
->Flags
|= EFI_IFR_CHECKBOX_DEFAULT
;
1240 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_CHECKBOX_DEFAULT_MFG
)) {
1241 mCheckBox
->Flags
|= EFI_IFR_CHECKBOX_DEFAULT_MFG
;
1244 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1247 UINT8
GetFlags (VOID
) {
1248 return mCheckBox
->Flags
;
1252 class CIfrAction
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1254 EFI_IFR_ACTION
*mAction
;
1257 CIfrAction () : CIfrObj (EFI_IFR_ACTION_OP
, (CHAR8
**)&mAction
),
1258 CIfrOpHeader (EFI_IFR_ACTION_OP
, &mAction
->Header
),
1259 CIfrQuestionHeader (&mAction
->Question
) {
1260 mAction
->QuestionConfig
= EFI_STRING_ID_INVALID
;
1263 VOID
SetQuestionConfig (IN EFI_STRING_ID QuestionConfig
) {
1264 mAction
->QuestionConfig
= QuestionConfig
;
1268 class CIfrDate
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1270 EFI_IFR_DATE
*mDate
;
1273 CIfrDate () : CIfrObj (EFI_IFR_DATE_OP
, (CHAR8
**)&mDate
),
1274 CIfrOpHeader (EFI_IFR_DATE_OP
, &mDate
->Header
),
1275 CIfrQuestionHeader (&mDate
->Question
) {
1279 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
) {
1280 EFI_VFR_RETURN_CODE Ret
;
1282 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1283 if (Ret
!= VFR_RETURN_SUCCESS
) {
1287 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_QF_DATE_YEAR_SUPPRESS
)) {
1288 mDate
->Flags
|= EFI_QF_DATE_YEAR_SUPPRESS
;
1291 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_QF_DATE_MONTH_SUPPRESS
)) {
1292 mDate
->Flags
|= EFI_QF_DATE_MONTH_SUPPRESS
;
1295 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_QF_DATE_DAY_SUPPRESS
)) {
1296 mDate
->Flags
|= EFI_QF_DATE_DAY_SUPPRESS
;
1299 if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_DATE_STORAGE_NORMAL
)) {
1300 mDate
->Flags
|= QF_DATE_STORAGE_NORMAL
;
1301 } else if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_DATE_STORAGE_TIME
)) {
1302 mDate
->Flags
|= QF_DATE_STORAGE_TIME
;
1303 } else if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_DATE_STORAGE_WAKEUP
)) {
1304 mDate
->Flags
|= QF_DATE_STORAGE_WAKEUP
;
1307 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1311 class CIfrNumeric
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
, public CIfrMinMaxStepData
{
1313 EFI_IFR_NUMERIC
*mNumeric
;
1316 CIfrNumeric () : CIfrObj (EFI_IFR_NUMERIC_OP
, (CHAR8
**)&mNumeric
, sizeof (EFI_IFR_NUMERIC
), TRUE
),
1317 CIfrOpHeader (EFI_IFR_NUMERIC_OP
, &mNumeric
->Header
),
1318 CIfrQuestionHeader (&mNumeric
->Question
),
1319 CIfrMinMaxStepData (&mNumeric
->data
, TRUE
) {
1320 mNumeric
->Flags
= EFI_IFR_NUMERIC_SIZE_1
| EFI_IFR_DISPLAY_UINT_DEC
;
1321 gCurrentQuestion
= this;
1322 gCurrentMinMaxData
= this;
1326 gCurrentQuestion
= NULL
;
1327 gCurrentMinMaxData
= NULL
;
1330 VOID
ShrinkBinSize (IN UINT16 Size
) {
1332 // Update the buffer size which is truly be used later.
1338 // Allocate buffer in gCFormPkg.
1340 _EMIT_PENDING_OBJ();
1343 // Update the buffer pointer used by other class.
1345 mNumeric
= (EFI_IFR_NUMERIC
*) GetObjBinAddr();
1346 UpdateHeader (&mNumeric
->Header
);
1347 UpdateCIfrQuestionHeader(&mNumeric
->Question
);
1348 UpdateCIfrMinMaxStepData(&mNumeric
->data
);
1351 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
, BOOLEAN DisplaySettingsSpecified
= FALSE
) {
1352 EFI_VFR_RETURN_CODE Ret
;
1354 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1355 if (Ret
!= VFR_RETURN_SUCCESS
) {
1359 if (DisplaySettingsSpecified
== FALSE
) {
1360 mNumeric
->Flags
= LFlags
| EFI_IFR_DISPLAY_UINT_DEC
;
1362 mNumeric
->Flags
= LFlags
;
1364 return VFR_RETURN_SUCCESS
;
1367 UINT8
GetNumericFlags () {
1368 return mNumeric
->Flags
;
1372 class CIfrOneOf
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
, public CIfrMinMaxStepData
{
1374 EFI_IFR_ONE_OF
*mOneOf
;
1377 CIfrOneOf () : CIfrObj (EFI_IFR_ONE_OF_OP
, (CHAR8
**)&mOneOf
, sizeof (EFI_IFR_ONE_OF
), TRUE
),
1378 CIfrOpHeader (EFI_IFR_ONE_OF_OP
, &mOneOf
->Header
),
1379 CIfrQuestionHeader (&mOneOf
->Question
),
1380 CIfrMinMaxStepData (&mOneOf
->data
) {
1382 gCurrentQuestion
= this;
1383 gCurrentMinMaxData
= this;
1387 gCurrentQuestion
= NULL
;
1388 gCurrentMinMaxData
= NULL
;
1391 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
) {
1392 EFI_VFR_RETURN_CODE Ret
;
1394 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1395 if (Ret
!= VFR_RETURN_SUCCESS
) {
1399 if (LFlags
& EFI_IFR_DISPLAY
) {
1400 mOneOf
->Flags
= LFlags
;
1402 mOneOf
->Flags
= LFlags
| EFI_IFR_DISPLAY_UINT_DEC
;
1404 return VFR_RETURN_SUCCESS
;
1407 VOID
ShrinkBinSize (IN UINT16 Size
) {
1409 // Update the buffer size which is truly be used later.
1415 // Allocate buffer in gCFormPkg.
1417 _EMIT_PENDING_OBJ();
1420 // Update the buffer pointer used by other class.
1422 mOneOf
= (EFI_IFR_ONE_OF
*) GetObjBinAddr();
1423 UpdateHeader (&mOneOf
->Header
);
1424 UpdateCIfrQuestionHeader(&mOneOf
->Question
);
1425 UpdateCIfrMinMaxStepData(&mOneOf
->data
);
1429 class CIfrString
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1431 EFI_IFR_STRING
*mString
;
1434 CIfrString () : CIfrObj (EFI_IFR_STRING_OP
, (CHAR8
**)&mString
),
1435 CIfrOpHeader (EFI_IFR_STRING_OP
, &mString
->Header
),
1436 CIfrQuestionHeader (&mString
->Question
) {
1438 mString
->MinSize
= 0;
1439 mString
->MaxSize
= 0;
1440 gCurrentQuestion
= this;
1444 gCurrentQuestion
= NULL
;
1447 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
) {
1448 EFI_VFR_RETURN_CODE Ret
;
1450 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1451 if (Ret
!= VFR_RETURN_SUCCESS
) {
1455 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_STRING_MULTI_LINE
)) {
1456 mString
->Flags
|= EFI_IFR_STRING_MULTI_LINE
;
1459 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1462 VOID
SetMinSize (IN UINT8 Flags
) {
1463 mString
->MinSize
= Flags
;
1466 VOID
SetMaxSize (IN UINT8 MaxSize
) {
1467 mString
->MaxSize
= MaxSize
;
1471 class CIfrPassword
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1473 EFI_IFR_PASSWORD
*mPassword
;
1476 CIfrPassword () : CIfrObj (EFI_IFR_PASSWORD_OP
, (CHAR8
**)&mPassword
),
1477 CIfrOpHeader (EFI_IFR_PASSWORD_OP
, &mPassword
->Header
),
1478 CIfrQuestionHeader (&mPassword
->Question
) {
1479 mPassword
->MinSize
= 0;
1480 mPassword
->MaxSize
= 0;
1481 gCurrentQuestion
= this;
1485 gCurrentQuestion
= NULL
;
1488 VOID
SetMinSize (IN UINT16 MinSize
) {
1489 mPassword
->MinSize
= MinSize
;
1492 VOID
SetMaxSize (IN UINT16 MaxSize
) {
1493 mPassword
->MaxSize
= MaxSize
;
1497 class CIfrOrderedList
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1499 EFI_IFR_ORDERED_LIST
*mOrderedList
;
1502 CIfrOrderedList () : CIfrObj (EFI_IFR_ORDERED_LIST_OP
, (CHAR8
**)&mOrderedList
),
1503 CIfrOpHeader (EFI_IFR_ORDERED_LIST_OP
, &mOrderedList
->Header
),
1504 CIfrQuestionHeader (&mOrderedList
->Question
) {
1505 mOrderedList
->MaxContainers
= 0;
1506 mOrderedList
->Flags
= 0;
1507 gCurrentQuestion
= this;
1510 ~CIfrOrderedList () {
1511 gCurrentQuestion
= NULL
;
1514 VOID
SetMaxContainers (IN UINT8 MaxContainers
) {
1515 mOrderedList
->MaxContainers
= MaxContainers
;
1518 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
) {
1519 EFI_VFR_RETURN_CODE Ret
;
1521 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1522 if (Ret
!= VFR_RETURN_SUCCESS
) {
1526 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_UNIQUE_SET
)) {
1527 mOrderedList
->Flags
|= EFI_IFR_UNIQUE_SET
;
1530 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_NO_EMPTY_SET
)) {
1531 mOrderedList
->Flags
|= EFI_IFR_NO_EMPTY_SET
;
1534 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1538 class CIfrTime
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1540 EFI_IFR_TIME
*mTime
;
1543 CIfrTime () : CIfrObj (EFI_IFR_TIME_OP
, (CHAR8
**)&mTime
),
1544 CIfrOpHeader (EFI_IFR_TIME_OP
, &mTime
->Header
),
1545 CIfrQuestionHeader (&mTime
->Question
) {
1549 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
) {
1550 EFI_VFR_RETURN_CODE Ret
;
1552 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1553 if (Ret
!= VFR_RETURN_SUCCESS
) {
1557 if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_HOUR_SUPPRESS
)) {
1558 mTime
->Flags
|= QF_TIME_HOUR_SUPPRESS
;
1561 if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_MINUTE_SUPPRESS
)) {
1562 mTime
->Flags
|= QF_TIME_MINUTE_SUPPRESS
;
1565 if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_SECOND_SUPPRESS
)) {
1566 mTime
->Flags
|= QF_TIME_SECOND_SUPPRESS
;
1569 if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_STORAGE_NORMAL
)) {
1570 mTime
->Flags
|= QF_TIME_STORAGE_NORMAL
;
1571 } else if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_STORAGE_TIME
)) {
1572 mTime
->Flags
|= QF_TIME_STORAGE_TIME
;
1573 } else if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_STORAGE_WAKEUP
)) {
1574 mTime
->Flags
|= QF_TIME_STORAGE_WAKEUP
;
1577 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1581 class CIfrDisableIf
: public CIfrObj
, public CIfrOpHeader
{
1583 EFI_IFR_DISABLE_IF
*mDisableIf
;
1586 CIfrDisableIf () : CIfrObj (EFI_IFR_DISABLE_IF_OP
, (CHAR8
**)&mDisableIf
),
1587 mDisableIf ((EFI_IFR_DISABLE_IF
*) GetObjBinAddr()),
1588 CIfrOpHeader (EFI_IFR_DISABLE_IF_OP
, &mDisableIf
->Header
) {}
1591 class CIfrSuppressIf
: public CIfrObj
, public CIfrOpHeader
{
1593 EFI_IFR_SUPPRESS_IF
*mSuppressIf
;
1596 CIfrSuppressIf () : CIfrObj (EFI_IFR_SUPPRESS_IF_OP
, (CHAR8
**)&mSuppressIf
),
1597 CIfrOpHeader (EFI_IFR_SUPPRESS_IF_OP
, &mSuppressIf
->Header
) {}
1600 class CIfrGrayOutIf
: public CIfrObj
, public CIfrOpHeader
{
1602 EFI_IFR_GRAY_OUT_IF
*mGrayOutIf
;
1605 CIfrGrayOutIf () : CIfrObj (EFI_IFR_GRAY_OUT_IF_OP
, (CHAR8
**)&mGrayOutIf
),
1606 CIfrOpHeader (EFI_IFR_GRAY_OUT_IF_OP
, &mGrayOutIf
->Header
) {}
1609 class CIfrInconsistentIf
: public CIfrObj
, public CIfrOpHeader
{
1611 EFI_IFR_INCONSISTENT_IF
*mInconsistentIf
;
1614 CIfrInconsistentIf () : CIfrObj (EFI_IFR_INCONSISTENT_IF_OP
, (CHAR8
**)&mInconsistentIf
),
1615 CIfrOpHeader (EFI_IFR_INCONSISTENT_IF_OP
, &mInconsistentIf
->Header
) {
1616 mInconsistentIf
->Error
= EFI_STRING_ID_INVALID
;
1619 VOID
SetError (IN EFI_STRING_ID Error
) {
1620 mInconsistentIf
->Error
= Error
;
1624 class CIfrWarningIf
: public CIfrObj
, public CIfrOpHeader
{
1626 EFI_IFR_WARNING_IF
*mWarningIf
;
1629 CIfrWarningIf () : CIfrObj (EFI_IFR_WARNING_IF_OP
, (CHAR8
**)&mWarningIf
),
1630 CIfrOpHeader (EFI_IFR_WARNING_IF_OP
, &mWarningIf
->Header
) {
1631 mWarningIf
->Warning
= EFI_STRING_ID_INVALID
;
1632 mWarningIf
->TimeOut
= 0;
1635 VOID
SetWarning (IN EFI_STRING_ID Warning
) {
1636 mWarningIf
->Warning
= Warning
;
1639 VOID
SetTimeOut (IN UINT8 TimeOut
) {
1640 mWarningIf
->TimeOut
= TimeOut
;
1644 class CIfrNoSubmitIf
: public CIfrObj
, public CIfrOpHeader
{
1646 EFI_IFR_NO_SUBMIT_IF
*mNoSubmitIf
;
1649 CIfrNoSubmitIf () : CIfrObj (EFI_IFR_NO_SUBMIT_IF_OP
, (CHAR8
**)&mNoSubmitIf
),
1650 CIfrOpHeader (EFI_IFR_NO_SUBMIT_IF_OP
, &mNoSubmitIf
->Header
) {
1651 mNoSubmitIf
->Error
= EFI_STRING_ID_INVALID
;
1654 VOID
SetError (IN EFI_STRING_ID Error
) {
1655 mNoSubmitIf
->Error
= Error
;
1659 class CIfrRefresh
: public CIfrObj
, public CIfrOpHeader
{
1661 EFI_IFR_REFRESH
*mRefresh
;
1664 CIfrRefresh () : CIfrObj (EFI_IFR_REFRESH_OP
, (CHAR8
**)&mRefresh
),
1665 CIfrOpHeader (EFI_IFR_REFRESH_OP
, &mRefresh
->Header
) {
1666 mRefresh
->RefreshInterval
= 0;
1669 VOID
SetRefreshInterval (IN UINT8 RefreshInterval
) {
1670 mRefresh
->RefreshInterval
= RefreshInterval
;
1674 class CIfrRefreshId
: public CIfrObj
, public CIfrOpHeader
{
1676 EFI_IFR_REFRESH_ID
*mRefreshId
;
1679 CIfrRefreshId () : CIfrObj (EFI_IFR_REFRESH_ID_OP
, (CHAR8
**)&mRefreshId
),
1680 CIfrOpHeader (EFI_IFR_REFRESH_ID_OP
, &mRefreshId
->Header
) {
1681 memset (&mRefreshId
->RefreshEventGroupId
, 0, sizeof (EFI_GUID
));
1684 VOID
SetRefreshEventGroutId (IN EFI_GUID
*RefreshEventGroupId
) {
1685 memmove (&mRefreshId
->RefreshEventGroupId
, RefreshEventGroupId
, sizeof (EFI_GUID
));
1689 class CIfrVarStoreDevice
: public CIfrObj
, public CIfrOpHeader
{
1691 EFI_IFR_VARSTORE_DEVICE
*mVarStoreDevice
;
1694 CIfrVarStoreDevice () : CIfrObj (EFI_IFR_VARSTORE_DEVICE_OP
, (CHAR8
**)&mVarStoreDevice
),
1695 CIfrOpHeader (EFI_IFR_VARSTORE_DEVICE_OP
, &mVarStoreDevice
->Header
) {
1696 mVarStoreDevice
->DevicePath
= EFI_STRING_ID_INVALID
;
1699 VOID
SetDevicePath (IN EFI_STRING_ID DevicePath
) {
1700 mVarStoreDevice
->DevicePath
= DevicePath
;
1704 class CIfrOneOfOption
: public CIfrObj
, public CIfrOpHeader
{
1706 EFI_IFR_ONE_OF_OPTION
*mOneOfOption
;
1709 CIfrOneOfOption (UINT8 Size
) : CIfrObj (EFI_IFR_ONE_OF_OPTION_OP
, (CHAR8
**)&mOneOfOption
, Size
),
1710 CIfrOpHeader (EFI_IFR_ONE_OF_OPTION_OP
, &mOneOfOption
->Header
, Size
) {
1711 mOneOfOption
->Flags
= 0;
1712 mOneOfOption
->Option
= EFI_STRING_ID_INVALID
;
1713 mOneOfOption
->Type
= EFI_IFR_TYPE_OTHER
;
1714 memset (&mOneOfOption
->Value
, 0, Size
- OFFSET_OF (EFI_IFR_ONE_OF_OPTION
, Value
));
1717 VOID
SetOption (IN EFI_STRING_ID Option
) {
1718 mOneOfOption
->Option
= Option
;
1721 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 LFlags
) {
1722 mOneOfOption
->Flags
= 0;
1723 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_OPTION_DEFAULT
)) {
1724 mOneOfOption
->Flags
|= EFI_IFR_OPTION_DEFAULT
;
1727 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_OPTION_DEFAULT_MFG
)) {
1728 mOneOfOption
->Flags
|= EFI_IFR_OPTION_DEFAULT_MFG
;
1731 if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_NUM_SIZE_8
)) {
1732 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_NUM_SIZE_8
);
1733 mOneOfOption
->Flags
|= EFI_IFR_TYPE_NUM_SIZE_8
;
1734 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_NUM_SIZE_16
)) {
1735 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_NUM_SIZE_16
);
1736 mOneOfOption
->Flags
|= EFI_IFR_TYPE_NUM_SIZE_16
;
1737 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_NUM_SIZE_32
)) {
1738 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_NUM_SIZE_32
);
1739 mOneOfOption
->Flags
|= EFI_IFR_TYPE_NUM_SIZE_32
;
1740 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_NUM_SIZE_64
)) {
1741 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_NUM_SIZE_64
);
1742 mOneOfOption
->Flags
|= EFI_IFR_TYPE_NUM_SIZE_64
;
1743 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_BOOLEAN
)) {
1744 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_BOOLEAN
);
1745 mOneOfOption
->Flags
|= EFI_IFR_TYPE_BOOLEAN
;
1746 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_TIME
)) {
1747 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_TIME
);
1748 mOneOfOption
->Flags
|= EFI_IFR_TYPE_TIME
;
1749 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_DATE
)) {
1750 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_DATE
);
1751 mOneOfOption
->Flags
|= EFI_IFR_TYPE_DATE
;
1752 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_STRING
)) {
1753 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_STRING
);
1754 mOneOfOption
->Flags
|= EFI_IFR_TYPE_STRING
;
1755 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_OTHER
)) {
1756 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_OTHER
);
1757 mOneOfOption
->Flags
|= EFI_IFR_TYPE_OTHER
;
1760 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1763 VOID
SetType (IN UINT8 Type
) {
1764 mOneOfOption
->Type
= Type
;
1767 VOID
SetValue (IN EFI_IFR_TYPE_VALUE Value
) {
1768 memmove (&mOneOfOption
->Value
, &Value
, mOneOfOption
->Header
.Length
- OFFSET_OF (EFI_IFR_ONE_OF_OPTION
, Value
));
1771 UINT8
GetFlags (VOID
) {
1772 return mOneOfOption
->Flags
;
1776 static EFI_GUID IfrTianoGuid
= EFI_IFR_TIANO_GUID
;
1777 static EFI_GUID IfrFrameworkGuid
= EFI_IFR_FRAMEWORK_GUID
;
1779 class CIfrClass
: public CIfrObj
, public CIfrOpHeader
{
1781 EFI_IFR_GUID_CLASS
*mClass
;
1784 CIfrClass () : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mClass
, sizeof (EFI_IFR_GUID_CLASS
)),
1785 CIfrOpHeader (EFI_IFR_GUID_OP
, &mClass
->Header
, sizeof (EFI_IFR_GUID_CLASS
)) {
1786 mClass
->ExtendOpCode
= EFI_IFR_EXTEND_OP_CLASS
;
1787 mClass
->Guid
= IfrTianoGuid
;
1788 mClass
->Class
= EFI_NON_DEVICE_CLASS
;
1791 VOID
SetClass (IN UINT16 Class
) {
1792 mClass
->Class
= Class
;
1796 class CIfrSubClass
: public CIfrObj
, public CIfrOpHeader
{
1798 EFI_IFR_GUID_SUBCLASS
*mSubClass
;
1801 CIfrSubClass () : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mSubClass
, sizeof (EFI_IFR_GUID_SUBCLASS
)),
1802 CIfrOpHeader (EFI_IFR_GUID_OP
, &mSubClass
->Header
, sizeof (EFI_IFR_GUID_SUBCLASS
)) {
1803 mSubClass
->ExtendOpCode
= EFI_IFR_EXTEND_OP_SUBCLASS
;
1804 mSubClass
->Guid
= IfrTianoGuid
;
1805 mSubClass
->SubClass
= EFI_SETUP_APPLICATION_SUBCLASS
;
1808 VOID
SetSubClass (IN UINT16 SubClass
) {
1809 mSubClass
->SubClass
= SubClass
;
1813 class CIfrLabel
: public CIfrObj
, public CIfrOpHeader
{
1815 EFI_IFR_GUID_LABEL
*mLabel
;
1818 CIfrLabel () : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mLabel
, sizeof (EFI_IFR_GUID_LABEL
)),
1819 CIfrOpHeader (EFI_IFR_GUID_OP
, &mLabel
->Header
, sizeof (EFI_IFR_GUID_LABEL
)) {
1820 mLabel
->ExtendOpCode
= EFI_IFR_EXTEND_OP_LABEL
;
1821 mLabel
->Guid
= IfrTianoGuid
;
1824 VOID
SetNumber (IN UINT16 Number
) {
1825 mLabel
->Number
= Number
;
1829 class CIfrBanner
: public CIfrObj
, public CIfrOpHeader
{
1831 EFI_IFR_GUID_BANNER
*mBanner
;
1834 CIfrBanner () : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mBanner
, sizeof (EFI_IFR_GUID_BANNER
)),
1835 CIfrOpHeader (EFI_IFR_GUID_OP
, &mBanner
->Header
, sizeof (EFI_IFR_GUID_BANNER
)) {
1836 mBanner
->ExtendOpCode
= EFI_IFR_EXTEND_OP_BANNER
;
1837 mBanner
->Guid
= IfrTianoGuid
;
1840 VOID
SetTitle (IN EFI_STRING_ID StringId
) {
1841 mBanner
->Title
= StringId
;
1844 VOID
SetLine (IN UINT16 Line
) {
1845 mBanner
->LineNumber
= Line
;
1848 VOID
SetAlign (IN UINT8 Align
) {
1849 mBanner
->Alignment
= Align
;
1853 class CIfrOptionKey
: public CIfrObj
, public CIfrOpHeader
{
1855 EFI_IFR_GUID_OPTIONKEY
*mOptionKey
;
1859 IN EFI_QUESTION_ID QuestionId
,
1860 IN EFI_IFR_TYPE_VALUE
&OptionValue
,
1861 IN EFI_QUESTION_ID KeyValue
1862 ) : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mOptionKey
, sizeof (EFI_IFR_GUID_OPTIONKEY
)),
1863 CIfrOpHeader (EFI_IFR_GUID_OP
, &mOptionKey
->Header
, sizeof (EFI_IFR_GUID_OPTIONKEY
)) {
1864 mOptionKey
->ExtendOpCode
= EFI_IFR_EXTEND_OP_OPTIONKEY
;
1865 mOptionKey
->Guid
= IfrFrameworkGuid
;
1866 mOptionKey
->QuestionId
= QuestionId
;
1867 mOptionKey
->OptionValue
= OptionValue
;
1868 mOptionKey
->KeyValue
= KeyValue
;
1872 class CIfrVarEqName
: public CIfrObj
, public CIfrOpHeader
{
1874 EFI_IFR_GUID_VAREQNAME
*mVarEqName
;
1878 IN EFI_QUESTION_ID QuestionId
,
1879 IN EFI_STRING_ID NameId
1880 ) : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mVarEqName
, sizeof (EFI_IFR_GUID_VAREQNAME
)),
1881 CIfrOpHeader (EFI_IFR_GUID_OP
, &mVarEqName
->Header
, sizeof (EFI_IFR_GUID_VAREQNAME
)) {
1882 mVarEqName
->ExtendOpCode
= EFI_IFR_EXTEND_OP_VAREQNAME
;
1883 mVarEqName
->Guid
= IfrFrameworkGuid
;
1884 mVarEqName
->QuestionId
= QuestionId
;
1885 mVarEqName
->NameId
= NameId
;
1889 class CIfrTimeout
: public CIfrObj
, public CIfrOpHeader
{
1891 EFI_IFR_GUID_TIMEOUT
*mTimeout
;
1894 CIfrTimeout (IN UINT16 Timeout
= 0) : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mTimeout
, sizeof (EFI_IFR_GUID_TIMEOUT
)),
1895 CIfrOpHeader (EFI_IFR_GUID_OP
, &mTimeout
->Header
, sizeof (EFI_IFR_GUID_TIMEOUT
)) {
1896 mTimeout
->ExtendOpCode
= EFI_IFR_EXTEND_OP_TIMEOUT
;
1897 mTimeout
->Guid
= IfrTianoGuid
;
1898 mTimeout
->TimeOut
= Timeout
;
1901 VOID
SetTimeout (IN UINT16 Timeout
) {
1902 mTimeout
->TimeOut
= Timeout
;
1906 class CIfrGuid
: public CIfrObj
, public CIfrOpHeader
{
1908 EFI_IFR_GUID
*mGuid
;
1911 CIfrGuid (UINT8 Size
) : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mGuid
, sizeof (EFI_IFR_GUID
)+Size
),
1912 CIfrOpHeader (EFI_IFR_GUID_OP
, &mGuid
->Header
, sizeof (EFI_IFR_GUID
)+Size
) {
1913 memset (&mGuid
->Guid
, 0, sizeof (EFI_GUID
));
1916 VOID
SetGuid (IN EFI_GUID
*Guid
) {
1917 memmove (&mGuid
->Guid
, Guid
, sizeof (EFI_GUID
));
1920 VOID
SetData (IN UINT8
* DataBuff
, IN UINT8 Size
) {
1921 memmove ((UINT8
*)mGuid
+ sizeof (EFI_IFR_GUID
), DataBuff
, Size
);
1925 class CIfrDup
: public CIfrObj
, public CIfrOpHeader
{
1932 ) : CIfrObj (EFI_IFR_DUP_OP
, (CHAR8
**)&mDup
),
1933 CIfrOpHeader (EFI_IFR_DUP_OP
, &mDup
->Header
) {
1938 class CIfrEqIdId
: public CIfrObj
, public CIfrOpHeader
{
1940 EFI_IFR_EQ_ID_ID
*mEqIdId
;
1945 ) : CIfrObj (EFI_IFR_EQ_ID_ID_OP
, (CHAR8
**)&mEqIdId
),
1946 CIfrOpHeader (EFI_IFR_EQ_ID_ID_OP
, &mEqIdId
->Header
) {
1948 mEqIdId
->QuestionId1
= EFI_QUESTION_ID_INVALID
;
1949 mEqIdId
->QuestionId2
= EFI_QUESTION_ID_INVALID
;
1952 VOID
SetQuestionId1 (
1953 IN EFI_QUESTION_ID QuestionId
,
1957 if (QuestionId
!= EFI_QUESTION_ID_INVALID
) {
1958 mEqIdId
->QuestionId1
= QuestionId
;
1960 gCFormPkg
.AssignPending (VarIdStr
, (VOID
*)(&mEqIdId
->QuestionId1
), sizeof (EFI_QUESTION_ID
), LineNo
, NO_QST_REFED
);
1964 VOID
SetQuestionId2 (
1965 IN EFI_QUESTION_ID QuestionId
,
1969 if (QuestionId
!= EFI_QUESTION_ID_INVALID
) {
1970 mEqIdId
->QuestionId2
= QuestionId
;
1972 gCFormPkg
.AssignPending (VarIdStr
, (VOID
*)(&mEqIdId
->QuestionId2
), sizeof (EFI_QUESTION_ID
), LineNo
, NO_QST_REFED
);
1977 class CIfrEqIdVal
: public CIfrObj
, public CIfrOpHeader
{
1979 EFI_IFR_EQ_ID_VAL
*mEqIdVal
;
1984 ) : CIfrObj (EFI_IFR_EQ_ID_VAL_OP
, (CHAR8
**)&mEqIdVal
),
1985 CIfrOpHeader (EFI_IFR_EQ_ID_VAL_OP
, &mEqIdVal
->Header
) {
1987 mEqIdVal
->QuestionId
= EFI_QUESTION_ID_INVALID
;
1990 VOID
SetQuestionId (
1991 IN EFI_QUESTION_ID QuestionId
,
1995 if (QuestionId
!= EFI_QUESTION_ID_INVALID
) {
1996 mEqIdVal
->QuestionId
= QuestionId
;
1998 gCFormPkg
.AssignPending (VarIdStr
, (VOID
*)(&mEqIdVal
->QuestionId
), sizeof (EFI_QUESTION_ID
), LineNo
, NO_QST_REFED
);
2002 VOID
SetValue (IN UINT16 Value
) {
2003 mEqIdVal
->Value
= Value
;
2007 class CIfrEqIdList
: public CIfrObj
, public CIfrOpHeader
{
2009 EFI_IFR_EQ_ID_VAL_LIST
*mEqIdVList
;
2014 ) : CIfrObj (EFI_IFR_EQ_ID_VAL_LIST_OP
, (CHAR8
**)&mEqIdVList
, sizeof (EFI_IFR_EQ_ID_VAL_LIST
), TRUE
),
2015 CIfrOpHeader (EFI_IFR_EQ_ID_VAL_LIST_OP
, &mEqIdVList
->Header
) {
2017 mEqIdVList
->QuestionId
= EFI_QUESTION_ID_INVALID
;
2018 mEqIdVList
->ListLength
= 0;
2019 mEqIdVList
->ValueList
[0] = 0;
2022 VOID
UpdateIfrBuffer (
2024 _EMIT_PENDING_OBJ();
2025 mEqIdVList
= (EFI_IFR_EQ_ID_VAL_LIST
*) GetObjBinAddr();
2026 UpdateHeader (&mEqIdVList
->Header
);
2029 VOID
SetQuestionId (
2030 IN EFI_QUESTION_ID QuestionId
,
2034 if (QuestionId
!= EFI_QUESTION_ID_INVALID
) {
2035 mEqIdVList
->QuestionId
= QuestionId
;
2037 gCFormPkg
.AssignPending (VarIdStr
, (VOID
*)(&mEqIdVList
->QuestionId
), sizeof (EFI_QUESTION_ID
), LineNo
, NO_QST_REFED
);
2041 VOID
SetListLength (IN UINT16 ListLength
) {
2042 mEqIdVList
->ListLength
= ListLength
;
2045 VOID
SetValueList (IN UINT16 Index
, IN UINT16 Value
) {
2047 mEqIdVList
->ValueList
[0] = Value
;
2051 if (ExpendObjBin (sizeof (UINT16
)) ==TRUE
) {
2052 IncLength (sizeof (UINT16
));
2053 mEqIdVList
->ValueList
[Index
] = Value
;
2058 class CIfrQuestionRef1
: public CIfrObj
, public CIfrOpHeader
{
2060 EFI_IFR_QUESTION_REF1
*mQuestionRef1
;
2065 ) : CIfrObj (EFI_IFR_QUESTION_REF1_OP
, (CHAR8
**)&mQuestionRef1
),
2066 CIfrOpHeader (EFI_IFR_QUESTION_REF1_OP
, &mQuestionRef1
->Header
) {
2068 mQuestionRef1
->QuestionId
= EFI_QUESTION_ID_INVALID
;
2071 VOID
SetQuestionId (
2072 IN EFI_QUESTION_ID QuestionId
,
2076 if (QuestionId
!= EFI_QUESTION_ID_INVALID
) {
2077 mQuestionRef1
->QuestionId
= QuestionId
;
2079 gCFormPkg
.AssignPending (VarIdStr
, (VOID
*)(&mQuestionRef1
->QuestionId
), sizeof (EFI_QUESTION_ID
), LineNo
, NO_QST_REFED
);
2084 class CIfrQuestionRef2
: public CIfrObj
, public CIfrOpHeader
{
2086 EFI_IFR_QUESTION_REF2
*mQuestionRef2
;
2091 ) : CIfrObj (EFI_IFR_QUESTION_REF2_OP
, (CHAR8
**)&mQuestionRef2
),
2092 CIfrOpHeader (EFI_IFR_QUESTION_REF2_OP
, &mQuestionRef2
->Header
) {
2097 class CIfrQuestionRef3
: public CIfrObj
, public CIfrOpHeader
{
2099 EFI_IFR_QUESTION_REF3
*mQuestionRef3
;
2104 ) : CIfrObj (EFI_IFR_QUESTION_REF3_OP
, (CHAR8
**)&mQuestionRef3
),
2105 CIfrOpHeader (EFI_IFR_QUESTION_REF3_OP
, &mQuestionRef3
->Header
) {
2110 class CIfrQuestionRef3_2
: public CIfrObj
, public CIfrOpHeader
{
2112 EFI_IFR_QUESTION_REF3_2
*mQuestionRef3_2
;
2115 CIfrQuestionRef3_2 (
2117 ) : CIfrObj (EFI_IFR_QUESTION_REF3_OP
, (CHAR8
**)&mQuestionRef3_2
, sizeof (EFI_IFR_QUESTION_REF3_2
)),
2118 CIfrOpHeader (EFI_IFR_QUESTION_REF3_OP
, &mQuestionRef3_2
->Header
, sizeof (EFI_IFR_QUESTION_REF3_2
)) {
2120 mQuestionRef3_2
->DevicePath
= EFI_STRING_ID_INVALID
;
2123 VOID
SetDevicePath (IN EFI_STRING_ID DevicePath
) {
2124 mQuestionRef3_2
->DevicePath
= DevicePath
;
2128 class CIfrQuestionRef3_3
: public CIfrObj
, public CIfrOpHeader
{
2130 EFI_IFR_QUESTION_REF3_3
*mQuestionRef3_3
;
2133 CIfrQuestionRef3_3 (
2135 ) : CIfrObj (EFI_IFR_QUESTION_REF3_OP
, (CHAR8
**)&mQuestionRef3_3
, sizeof (EFI_IFR_QUESTION_REF3_3
)),
2136 CIfrOpHeader (EFI_IFR_QUESTION_REF3_OP
, &mQuestionRef3_3
->Header
, sizeof (EFI_IFR_QUESTION_REF3_3
)) {
2138 mQuestionRef3_3
->DevicePath
= EFI_STRING_ID_INVALID
;
2139 memset (&mQuestionRef3_3
->Guid
, 0, sizeof (EFI_GUID
));
2142 VOID
SetDevicePath (IN EFI_STRING_ID DevicePath
) {
2143 mQuestionRef3_3
->DevicePath
= DevicePath
;
2146 VOID
SetGuid (IN EFI_GUID
*Guid
) {
2147 mQuestionRef3_3
->Guid
= *Guid
;
2151 class CIfrRuleRef
: public CIfrObj
, public CIfrOpHeader
{
2153 EFI_IFR_RULE_REF
*mRuleRef
;
2158 ) : CIfrObj (EFI_IFR_RULE_REF_OP
, (CHAR8
**)&mRuleRef
),
2159 CIfrOpHeader (EFI_IFR_RULE_REF_OP
, &mRuleRef
->Header
) {
2161 mRuleRef
->RuleId
= EFI_RULE_ID_INVALID
;
2164 VOID
SetRuleId (IN UINT8 RuleId
) {
2165 mRuleRef
->RuleId
= RuleId
;
2169 class CIfrStringRef1
: public CIfrObj
, public CIfrOpHeader
{
2171 EFI_IFR_STRING_REF1
*mStringRef1
;
2176 ) : CIfrObj (EFI_IFR_STRING_REF1_OP
, (CHAR8
**)&mStringRef1
),
2177 CIfrOpHeader (EFI_IFR_STRING_REF1_OP
, &mStringRef1
->Header
) {
2179 mStringRef1
->StringId
= EFI_STRING_ID_INVALID
;
2182 VOID
SetStringId (IN EFI_STRING_ID StringId
) {
2183 mStringRef1
->StringId
= StringId
;
2187 class CIfrStringRef2
: public CIfrObj
, public CIfrOpHeader
{
2189 EFI_IFR_STRING_REF2
*mStringRef2
;
2194 ) : CIfrObj (EFI_IFR_STRING_REF2_OP
, (CHAR8
**)&mStringRef2
),
2195 CIfrOpHeader (EFI_IFR_STRING_REF2_OP
, &mStringRef2
->Header
) {
2200 class CIfrThis
: public CIfrObj
, public CIfrOpHeader
{
2202 EFI_IFR_THIS
*mThis
;
2207 ) : CIfrObj (EFI_IFR_THIS_OP
, (CHAR8
**)&mThis
),
2208 CIfrOpHeader (EFI_IFR_THIS_OP
, &mThis
->Header
) {
2213 class CIfrSecurity
: public CIfrObj
, public CIfrOpHeader
{
2215 EFI_IFR_SECURITY
*mSecurity
;
2220 ) : CIfrObj (EFI_IFR_SECURITY_OP
, (CHAR8
**)&mSecurity
),
2221 CIfrOpHeader (EFI_IFR_SECURITY_OP
, &mSecurity
->Header
) {
2223 memset (&mSecurity
->Permissions
, 0, sizeof (EFI_GUID
));
2226 VOID
SetPermissions (IN EFI_GUID
*Permissions
) {
2227 memmove (&mSecurity
->Permissions
, Permissions
, sizeof (EFI_GUID
));
2231 class CIfrUint8
: public CIfrObj
, public CIfrOpHeader
{
2233 EFI_IFR_UINT8
*mUint8
;
2238 ) : CIfrObj (EFI_IFR_UINT8_OP
, (CHAR8
**)&mUint8
),
2239 CIfrOpHeader (EFI_IFR_UINT8_OP
, &mUint8
->Header
) {
2243 VOID
SetValue (IN UINT8 Value
) {
2244 mUint8
->Value
= Value
;
2248 class CIfrUint16
: public CIfrObj
, public CIfrOpHeader
{
2250 EFI_IFR_UINT16
*mUint16
;
2255 ) : CIfrObj (EFI_IFR_UINT16_OP
, (CHAR8
**)&mUint16
),
2256 CIfrOpHeader (EFI_IFR_UINT16_OP
, &mUint16
->Header
) {
2260 VOID
SetValue (IN UINT16 Value
) {
2261 mUint16
->Value
= Value
;
2265 class CIfrUint32
: public CIfrObj
, public CIfrOpHeader
{
2267 EFI_IFR_UINT32
*mUint32
;
2272 ) : CIfrObj (EFI_IFR_UINT32_OP
, (CHAR8
**)&mUint32
),
2273 CIfrOpHeader (EFI_IFR_UINT32_OP
, &mUint32
->Header
) {
2277 VOID
SetValue (IN UINT32 Value
) {
2278 mUint32
->Value
= Value
;
2282 class CIfrUint64
: public CIfrObj
, public CIfrOpHeader
{
2284 EFI_IFR_UINT64
*mUint64
;
2289 ) : CIfrObj (EFI_IFR_UINT64_OP
, (CHAR8
**)&mUint64
),
2290 CIfrOpHeader (EFI_IFR_UINT64_OP
, &mUint64
->Header
) {
2294 VOID
SetValue (IN UINT64 Value
) {
2295 mUint64
->Value
= Value
;
2299 class CIfrTrue
: public CIfrObj
, public CIfrOpHeader
{
2301 EFI_IFR_TRUE
*mTrue
;
2306 ) : CIfrObj (EFI_IFR_TRUE_OP
, (CHAR8
**)&mTrue
),
2307 CIfrOpHeader (EFI_IFR_TRUE_OP
, &mTrue
->Header
) {
2312 class CIfrFalse
: public CIfrObj
, public CIfrOpHeader
{
2314 EFI_IFR_FALSE
*mFalse
;
2319 ) : CIfrObj (EFI_IFR_FALSE_OP
, (CHAR8
**)&mFalse
),
2320 CIfrOpHeader (EFI_IFR_FALSE_OP
, &mFalse
->Header
) {
2325 class CIfrOne
: public CIfrObj
, public CIfrOpHeader
{
2332 ) : CIfrObj (EFI_IFR_ONE_OP
, (CHAR8
**)&mOne
),
2333 CIfrOpHeader (EFI_IFR_ONE_OP
, &mOne
->Header
) {
2338 class CIfrOnes
: public CIfrObj
, public CIfrOpHeader
{
2340 EFI_IFR_ONES
*mOnes
;
2345 ) : CIfrObj (EFI_IFR_ONES_OP
, (CHAR8
**)&mOnes
),
2346 CIfrOpHeader (EFI_IFR_ONES_OP
, &mOnes
->Header
) {
2351 class CIfrZero
: public CIfrObj
, public CIfrOpHeader
{
2353 EFI_IFR_ZERO
*mZero
;
2358 ) : CIfrObj (EFI_IFR_ZERO_OP
, (CHAR8
**)&mZero
),
2359 CIfrOpHeader (EFI_IFR_ZERO_OP
, &mZero
->Header
) {
2364 class CIfrUndefined
: public CIfrObj
, public CIfrOpHeader
{
2366 EFI_IFR_UNDEFINED
*mUndefined
;
2371 ) : CIfrObj (EFI_IFR_UNDEFINED_OP
, (CHAR8
**)&mUndefined
),
2372 CIfrOpHeader (EFI_IFR_UNDEFINED_OP
, &mUndefined
->Header
) {
2377 class CIfrVersion
: public CIfrObj
, public CIfrOpHeader
{
2379 EFI_IFR_VERSION
*mVersion
;
2384 ) : CIfrObj (EFI_IFR_VERSION_OP
, (CHAR8
**)&mVersion
),
2385 CIfrOpHeader (EFI_IFR_VERSION_OP
, &mVersion
->Header
) {
2390 class CIfrLength
: public CIfrObj
, public CIfrOpHeader
{
2392 EFI_IFR_LENGTH
*mLength
;
2397 ) : CIfrObj (EFI_IFR_LENGTH_OP
, (CHAR8
**)&mLength
),
2398 CIfrOpHeader (EFI_IFR_LENGTH_OP
, &mLength
->Header
) {
2403 class CIfrNot
: public CIfrObj
, public CIfrOpHeader
{
2410 ) : CIfrObj (EFI_IFR_NOT_OP
, (CHAR8
**)&mNot
),
2411 CIfrOpHeader (EFI_IFR_NOT_OP
, &mNot
->Header
) {
2416 class CIfrBitWiseNot
: public CIfrObj
, public CIfrOpHeader
{
2418 EFI_IFR_BITWISE_NOT
*mBitWise
;
2423 ) : CIfrObj (EFI_IFR_BITWISE_NOT_OP
, (CHAR8
**)&mBitWise
),
2424 CIfrOpHeader (EFI_IFR_BITWISE_NOT_OP
, &mBitWise
->Header
) {
2429 class CIfrToBoolean
: public CIfrObj
, public CIfrOpHeader
{
2431 EFI_IFR_TO_BOOLEAN
*mToBoolean
;
2436 ) : CIfrObj (EFI_IFR_TO_BOOLEAN_OP
, (CHAR8
**)&mToBoolean
),
2437 CIfrOpHeader (EFI_IFR_TO_BOOLEAN_OP
, &mToBoolean
->Header
) {
2442 class CIfrToString
: public CIfrObj
, public CIfrOpHeader
{
2444 EFI_IFR_TO_STRING
*mToString
;
2449 ) : CIfrObj (EFI_IFR_TO_STRING_OP
, (CHAR8
**)&mToString
),
2450 CIfrOpHeader (EFI_IFR_TO_STRING_OP
, &mToString
->Header
) {
2454 VOID
SetFormat (IN UINT8 Format
) {
2455 mToString
->Format
= Format
;
2459 class CIfrToUint
: public CIfrObj
, public CIfrOpHeader
{
2461 EFI_IFR_TO_UINT
*mToUint
;
2466 ) : CIfrObj (EFI_IFR_TO_UINT_OP
, (CHAR8
**)&mToUint
),
2467 CIfrOpHeader (EFI_IFR_TO_UINT_OP
, &mToUint
->Header
) {
2472 class CIfrToUpper
: public CIfrObj
, public CIfrOpHeader
{
2474 EFI_IFR_TO_UPPER
*mToUpper
;
2479 ) : CIfrObj (EFI_IFR_TO_UPPER_OP
, (CHAR8
**)&mToUpper
),
2480 CIfrOpHeader (EFI_IFR_TO_UPPER_OP
, &mToUpper
->Header
) {
2485 class CIfrToLower
: public CIfrObj
, public CIfrOpHeader
{
2487 EFI_IFR_TO_LOWER
*mToLower
;
2492 ) : CIfrObj (EFI_IFR_TO_LOWER_OP
, (CHAR8
**)&mToLower
),
2493 CIfrOpHeader (EFI_IFR_TO_LOWER_OP
, &mToLower
->Header
) {
2498 class CIfrAdd
: public CIfrObj
, public CIfrOpHeader
{
2505 ) : CIfrObj (EFI_IFR_ADD_OP
, (CHAR8
**)&mAdd
),
2506 CIfrOpHeader (EFI_IFR_ADD_OP
, &mAdd
->Header
) {
2511 class CIfrBitWiseAnd
: public CIfrObj
, public CIfrOpHeader
{
2513 EFI_IFR_BITWISE_AND
*mBitWiseAnd
;
2518 ) : CIfrObj (EFI_IFR_BITWISE_AND_OP
, (CHAR8
**)&mBitWiseAnd
),
2519 CIfrOpHeader (EFI_IFR_BITWISE_AND_OP
, &mBitWiseAnd
->Header
) {
2524 class CIfrBitWiseOr
: public CIfrObj
, public CIfrOpHeader
{
2526 EFI_IFR_BITWISE_OR
*mBitWiseOr
;
2531 ) : CIfrObj (EFI_IFR_BITWISE_OR_OP
, (CHAR8
**)&mBitWiseOr
),
2532 CIfrOpHeader (EFI_IFR_BITWISE_OR_OP
, &mBitWiseOr
->Header
) {
2537 class CIfrAnd
: public CIfrObj
, public CIfrOpHeader
{
2544 ) : CIfrObj (EFI_IFR_AND_OP
, (CHAR8
**)&mAnd
),
2545 CIfrOpHeader (EFI_IFR_AND_OP
, &mAnd
->Header
) {
2550 class CIfrCatenate
: public CIfrObj
, public CIfrOpHeader
{
2552 EFI_IFR_CATENATE
*mCatenate
;
2557 ) : CIfrObj (EFI_IFR_CATENATE_OP
, (CHAR8
**)&mCatenate
),
2558 CIfrOpHeader (EFI_IFR_CATENATE_OP
, &mCatenate
->Header
) {
2563 class CIfrDivide
: public CIfrObj
, public CIfrOpHeader
{
2565 EFI_IFR_DIVIDE
*mDivide
;
2570 ) : CIfrObj (EFI_IFR_DIVIDE_OP
, (CHAR8
**)&mDivide
),
2571 CIfrOpHeader (EFI_IFR_DIVIDE_OP
, &mDivide
->Header
) {
2576 class CIfrEqual
: public CIfrObj
, public CIfrOpHeader
{
2578 EFI_IFR_EQUAL
*mEqual
;
2583 ) : CIfrObj (EFI_IFR_EQUAL_OP
, (CHAR8
**)&mEqual
),
2584 CIfrOpHeader (EFI_IFR_EQUAL_OP
, &mEqual
->Header
) {
2589 class CIfrGreaterEqual
: public CIfrObj
, public CIfrOpHeader
{
2591 EFI_IFR_GREATER_EQUAL
*mGreaterEqual
;
2596 ) : CIfrObj (EFI_IFR_GREATER_EQUAL_OP
, (CHAR8
**)&mGreaterEqual
),
2597 CIfrOpHeader (EFI_IFR_GREATER_EQUAL_OP
, &mGreaterEqual
->Header
) {
2602 class CIfrGreaterThan
: public CIfrObj
, public CIfrOpHeader
{
2604 EFI_IFR_GREATER_THAN
*mGreaterThan
;
2609 ) : CIfrObj (EFI_IFR_GREATER_THAN_OP
, (CHAR8
**)&mGreaterThan
),
2610 CIfrOpHeader (EFI_IFR_GREATER_THAN_OP
, &mGreaterThan
->Header
) {
2615 class CIfrLessEqual
: public CIfrObj
, public CIfrOpHeader
{
2617 EFI_IFR_LESS_EQUAL
*mLessEqual
;
2622 ) : CIfrObj (EFI_IFR_LESS_EQUAL_OP
, (CHAR8
**)&mLessEqual
),
2623 CIfrOpHeader (EFI_IFR_LESS_EQUAL_OP
, &mLessEqual
->Header
) {
2628 class CIfrLessThan
: public CIfrObj
, public CIfrOpHeader
{
2630 EFI_IFR_LESS_THAN
*mLessThan
;
2635 ) : CIfrObj (EFI_IFR_LESS_THAN_OP
, (CHAR8
**)&mLessThan
),
2636 CIfrOpHeader (EFI_IFR_LESS_THAN_OP
, &mLessThan
->Header
) {
2641 class CIfrMap
: public CIfrObj
, public CIfrOpHeader
{
2648 ) : CIfrObj (EFI_IFR_MAP_OP
, (CHAR8
**)&mMap
),
2649 CIfrOpHeader (EFI_IFR_MAP_OP
, &mMap
->Header
) {
2654 class CIfrMatch
: public CIfrObj
, public CIfrOpHeader
{
2656 EFI_IFR_MATCH
*mMatch
;
2661 ) : CIfrObj (EFI_IFR_MATCH_OP
, (CHAR8
**)&mMatch
),
2662 CIfrOpHeader (EFI_IFR_MATCH_OP
, &mMatch
->Header
) {
2667 class CIfrMatch2
: public CIfrObj
, public CIfrOpHeader
{
2669 EFI_IFR_MATCH2
*mMatch2
;
2675 ) : CIfrObj (EFI_IFR_MATCH2_OP
, (CHAR8
**)&mMatch2
),
2676 CIfrOpHeader (EFI_IFR_MATCH2_OP
, &mMatch2
->Header
) {
2678 memmove (&mMatch2
->SyntaxType
, Guid
, sizeof (EFI_GUID
));
2682 class CIfrMultiply
: public CIfrObj
, public CIfrOpHeader
{
2684 EFI_IFR_MULTIPLY
*mMultiply
;
2689 ) : CIfrObj (EFI_IFR_MULTIPLY_OP
, (CHAR8
**)&mMultiply
),
2690 CIfrOpHeader (EFI_IFR_MULTIPLY_OP
, &mMultiply
->Header
) {
2695 class CIfrModulo
: public CIfrObj
, public CIfrOpHeader
{
2697 EFI_IFR_MODULO
*mModulo
;
2702 ) : CIfrObj (EFI_IFR_MODULO_OP
, (CHAR8
**)&mModulo
),
2703 CIfrOpHeader (EFI_IFR_MODULO_OP
, &mModulo
->Header
) {
2708 class CIfrNotEqual
: public CIfrObj
, public CIfrOpHeader
{
2710 EFI_IFR_NOT_EQUAL
*mNotEqual
;
2715 ) : CIfrObj (EFI_IFR_NOT_EQUAL_OP
, (CHAR8
**)&mNotEqual
),
2716 CIfrOpHeader (EFI_IFR_NOT_EQUAL_OP
, &mNotEqual
->Header
) {
2721 class CIfrOr
: public CIfrObj
, public CIfrOpHeader
{
2728 ) : CIfrObj (EFI_IFR_OR_OP
, (CHAR8
**)&mOr
),
2729 CIfrOpHeader (EFI_IFR_OR_OP
, &mOr
->Header
) {
2734 class CIfrShiftLeft
: public CIfrObj
, public CIfrOpHeader
{
2736 EFI_IFR_SHIFT_LEFT
*mShiftLeft
;
2741 ) : CIfrObj (EFI_IFR_SHIFT_LEFT_OP
, (CHAR8
**)&mShiftLeft
),
2742 CIfrOpHeader (EFI_IFR_SHIFT_LEFT_OP
, &mShiftLeft
->Header
) {
2747 class CIfrShiftRight
: public CIfrObj
, public CIfrOpHeader
{
2749 EFI_IFR_SHIFT_RIGHT
*mShiftRight
;
2754 ) : CIfrObj (EFI_IFR_SHIFT_RIGHT_OP
, (CHAR8
**)&mShiftRight
),
2755 CIfrOpHeader (EFI_IFR_SHIFT_RIGHT_OP
, &mShiftRight
->Header
) {
2760 class CIfrSubtract
: public CIfrObj
, public CIfrOpHeader
{
2762 EFI_IFR_SUBTRACT
*mSubtract
;
2767 ) : CIfrObj (EFI_IFR_SUBTRACT_OP
, (CHAR8
**)&mSubtract
),
2768 CIfrOpHeader (EFI_IFR_SUBTRACT_OP
, &mSubtract
->Header
) {
2773 class CIfrConditional
: public CIfrObj
, public CIfrOpHeader
{
2775 EFI_IFR_CONDITIONAL
*mConditional
;
2780 ) : CIfrObj (EFI_IFR_CONDITIONAL_OP
, (CHAR8
**)&mConditional
),
2781 CIfrOpHeader (EFI_IFR_CONDITIONAL_OP
, &mConditional
->Header
) {
2786 class CIfrFind
: public CIfrObj
, public CIfrOpHeader
{
2788 EFI_IFR_FIND
*mFind
;
2793 ) : CIfrObj (EFI_IFR_FIND_OP
, (CHAR8
**)&mFind
),
2794 CIfrOpHeader (EFI_IFR_FIND_OP
, &mFind
->Header
) {
2798 VOID
SetFormat (IN UINT8 Format
) {
2799 mFind
->Format
= Format
;
2803 class CIfrMid
: public CIfrObj
, public CIfrOpHeader
{
2810 ) : CIfrObj (EFI_IFR_MID_OP
, (CHAR8
**)&mMid
),
2811 CIfrOpHeader (EFI_IFR_MID_OP
, &mMid
->Header
) {
2816 class CIfrToken
: public CIfrObj
, public CIfrOpHeader
{
2818 EFI_IFR_TOKEN
*mToken
;
2823 ) : CIfrObj (EFI_IFR_TOKEN_OP
, (CHAR8
**)&mToken
),
2824 CIfrOpHeader (EFI_IFR_TOKEN_OP
, &mToken
->Header
) {
2829 class CIfrSpan
: public CIfrObj
, public CIfrOpHeader
{
2831 EFI_IFR_SPAN
*mSpan
;
2836 ) : CIfrObj (EFI_IFR_SPAN_OP
, (CHAR8
**)&mSpan
),
2837 CIfrOpHeader (EFI_IFR_SPAN_OP
, &mSpan
->Header
) {
2839 mSpan
->Flags
= EFI_IFR_FLAGS_FIRST_MATCHING
;
2842 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 LFlags
) {
2843 if (_IS_EQUAL (LFlags
, EFI_IFR_FLAGS_FIRST_MATCHING
)) {
2844 mSpan
->Flags
|= EFI_IFR_FLAGS_FIRST_MATCHING
;
2845 } else if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_FLAGS_FIRST_NON_MATCHING
)) {
2846 mSpan
->Flags
|= EFI_IFR_FLAGS_FIRST_NON_MATCHING
;
2849 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;