3 The definition of CFormPkg's member function
5 Copyright (c) 2004 - 2012, 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
);
120 SPendingAssign
*PendingAssignList
;
123 CFormPkg (IN UINT32 BufferSize
);
126 CHAR8
* IfrBinBufferGet (IN UINT32
);
127 inline UINT32
GetPkgLength (VOID
);
130 UINT32
Read (IN CHAR8
*, IN UINT32
);
133 EFI_VFR_RETURN_CODE
BuildPkgHdr (OUT EFI_HII_PACKAGE_HEADER
**);
134 EFI_VFR_RETURN_CODE
BuildPkg (IN
FILE *, IN PACKAGE_DATA
*PkgData
= NULL
);
135 EFI_VFR_RETURN_CODE
BuildPkg (OUT PACKAGE_DATA
&);
136 EFI_VFR_RETURN_CODE
GenCFile (IN CHAR8
*, IN
FILE *, IN PACKAGE_DATA
*PkgData
= NULL
);
139 EFI_VFR_RETURN_CODE
AssignPending (IN CHAR8
*, IN VOID
*, IN UINT32
, IN UINT32
, IN CONST CHAR8
*Msg
= NULL
);
140 VOID
DoPendingAssign (IN CHAR8
*, IN VOID
*, IN UINT32
);
141 bool HavePendingUnassigned (VOID
);
142 VOID
PendingAssignPrintAll (VOID
);
143 EFI_VFR_RETURN_CODE
DeclarePendingQuestion (
144 IN CVfrVarDataTypeDB
&lCVfrVarDataTypeDB
,
145 IN CVfrDataStorage
&lCVfrDataStorage
,
146 IN CVfrQuestionDB
&lCVfrQuestionDB
,
147 IN EFI_GUID
*LocalFormSetGuid
,
152 extern CFormPkg gCFormPkg
;
153 extern CVfrStringDB gCVfrStringDB
;
166 #define EFI_IFR_RECORDINFO_IDX_INVALUD 0xFFFFFF
167 #define EFI_IFR_RECORDINFO_IDX_START 0x0
169 class CIfrRecordInfoDB
{
173 SIfrRecord
*mIfrRecordListHead
;
174 SIfrRecord
*mIfrRecordListTail
;
176 SIfrRecord
* GetRecordInfoFromIdx (IN UINT32
);
177 BOOLEAN
CheckQuestionOpCode (IN UINT8
);
178 BOOLEAN
CheckIdOpCode (IN UINT8
);
179 EFI_QUESTION_ID
GetOpcodeQuestionId (IN EFI_IFR_OP_HEADER
*);
181 CIfrRecordInfoDB (VOID
);
182 ~CIfrRecordInfoDB (VOID
);
184 inline VOID
TurnOn (VOID
) {
188 inline VOID
TurnOff (VOID
) {
192 UINT32
IfrRecordRegister (IN UINT32
, IN CHAR8
*, IN UINT8
, IN UINT32
);
193 VOID
IfrRecordInfoUpdate (IN UINT32
, IN UINT32
, IN CHAR8
*, IN UINT8
, IN UINT32
);
194 VOID
IfrRecordOutput (IN
FILE *, IN UINT32 LineNo
);
195 VOID
IfrRecordOutput (OUT PACKAGE_DATA
&);
196 EFI_VFR_RETURN_CODE
IfrRecordAdjust (VOID
);
199 extern CIfrRecordInfoDB gCIfrRecordInfoDB
;
202 * The definition of CIfrObj
204 extern BOOLEAN gCreateOp
;
217 CIfrObj (IN UINT8 OpCode
, OUT CHAR8
**IfrObj
= NULL
, IN UINT8 ObjBinLen
= 0, IN BOOLEAN DelayEmit
= FALSE
);
218 virtual ~CIfrObj(VOID
);
220 VOID
_EMIT_PENDING_OBJ (VOID
);
222 inline VOID
SetLineNo (IN UINT32 LineNo
) {
226 inline CHAR8
* GetObjBinAddr (VOID
) {
230 inline UINT8
GetObjBinLen (VOID
) {
234 inline bool ExpendObjBin (IN UINT8 Size
) {
235 if ((mDelayEmit
== TRUE
) && ((mObjBinLen
+ Size
) > mObjBinLen
)) {
236 mObjBinLen
= mObjBinLen
+ Size
;
243 inline bool ShrinkObjBin (IN UINT8 Size
) {
244 if ((mDelayEmit
== TRUE
) && (mObjBinLen
> Size
)) {
254 * The definition of CIfrOpHeader
258 EFI_IFR_OP_HEADER
*mHeader
;
261 CIfrOpHeader (IN UINT8 OpCode
, IN VOID
*StartAddr
, IN UINT8 Length
= 0);
262 CIfrOpHeader (IN CIfrOpHeader
&);
264 VOID
IncLength (UINT8 Size
) {
265 if ((mHeader
->Length
+ Size
) > mHeader
->Length
) {
266 mHeader
->Length
= mHeader
->Length
+ Size
;
270 VOID
DecLength (UINT8 Size
) {
271 if (mHeader
->Length
>= Size
) {
272 mHeader
->Length
-= Size
;
277 return mHeader
->Length
;
281 return mHeader
->Scope
;
284 VOID
SetScope (IN UINT8 Scope
) {
285 mHeader
->Scope
= Scope
;
288 VOID
UpdateHeader (IN EFI_IFR_OP_HEADER
*Header
) {
293 extern UINT8 gScopeCount
;
296 * The definition of CIfrStatementHeader
298 class CIfrStatementHeader
{
300 EFI_IFR_STATEMENT_HEADER
*mHeader
;
303 CIfrStatementHeader (
304 IN EFI_IFR_STATEMENT_HEADER
*StartAddr
305 ) : mHeader ((EFI_IFR_STATEMENT_HEADER
*)StartAddr
) {
307 mHeader
->Help
= EFI_STRING_ID_INVALID
;
308 mHeader
->Prompt
= EFI_STRING_ID_INVALID
;
311 EFI_IFR_STATEMENT_HEADER
*GetStatementHeader () {
315 VOID
SetPrompt (IN EFI_STRING_ID Prompt
) {
316 mHeader
->Prompt
= Prompt
;
319 VOID
SetHelp (IN EFI_STRING_ID Help
) {
320 mHeader
->Help
= Help
;
325 * The definition of CIfrQuestionHeader
327 #define EFI_IFR_QUESTION_FLAG_DEFAULT 0
329 class CIfrQuestionHeader
: public CIfrStatementHeader
{
331 EFI_IFR_QUESTION_HEADER
*mHeader
;
333 EFI_IFR_STATEMENT_HEADER
* QH2SH (EFI_IFR_QUESTION_HEADER
*Qheader
) {
334 return &(Qheader
)->Header
;
338 EFI_QUESTION_ID
QUESTION_ID (VOID
) {
339 return mHeader
->QuestionId
;
342 EFI_VARSTORE_ID
VARSTORE_ID (VOID
) {
343 return mHeader
->VarStoreId
;
346 VOID
VARSTORE_INFO (OUT EFI_VARSTORE_INFO
*Info
) {
348 Info
->mVarStoreId
= mHeader
->VarStoreId
;
349 memcpy (&Info
->mVarStoreId
, &mHeader
->VarStoreInfo
, sizeof (Info
->mVarStoreId
));
354 return mHeader
->Flags
;
359 IN EFI_IFR_QUESTION_HEADER
*StartAddr
,
360 IN UINT8 Flags
= EFI_IFR_QUESTION_FLAG_DEFAULT
361 ) : CIfrStatementHeader (QH2SH(StartAddr
)) {
363 mHeader
->QuestionId
= EFI_QUESTION_ID_INVALID
;
364 mHeader
->VarStoreId
= EFI_VARSTORE_ID_INVALID
;
365 mHeader
->VarStoreInfo
.VarName
= EFI_STRING_ID_INVALID
;
366 mHeader
->VarStoreInfo
.VarOffset
= EFI_VAROFFSET_INVALID
;
367 mHeader
->Flags
= Flags
;
370 VOID
SetQuestionId (IN EFI_QUESTION_ID QuestionId
) {
371 mHeader
->QuestionId
= QuestionId
;
374 VOID
SetVarStoreInfo (IN EFI_VARSTORE_INFO
*Info
) {
375 mHeader
->VarStoreId
= Info
->mVarStoreId
;
376 mHeader
->VarStoreInfo
.VarName
= Info
->mInfo
.mVarName
;
377 mHeader
->VarStoreInfo
.VarOffset
= Info
->mInfo
.mVarOffset
;
380 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 Flags
) {
381 if (_FLAG_TEST_AND_CLEAR (Flags
, EFI_IFR_FLAG_READ_ONLY
)) {
382 mHeader
->Flags
|= EFI_IFR_FLAG_READ_ONLY
;
385 _FLAG_CLEAR (Flags
, 0x02);
387 if (_FLAG_TEST_AND_CLEAR (Flags
, EFI_IFR_FLAG_CALLBACK
)) {
388 mHeader
->Flags
|= EFI_IFR_FLAG_CALLBACK
;
392 // ignore NVAccessFlag
394 _FLAG_CLEAR (Flags
, 0x08);
396 if (_FLAG_TEST_AND_CLEAR (Flags
, EFI_IFR_FLAG_RESET_REQUIRED
)) {
397 mHeader
->Flags
|= EFI_IFR_FLAG_RESET_REQUIRED
;
401 // Set LateCheck Flag to compatible for framework flag
402 // but it uses 0x20 as its flag, if in the future UEFI may take this flag
404 if (_FLAG_TEST_AND_CLEAR (Flags
, 0x20)) {
405 mHeader
->Flags
|= 0x20;
408 if (_FLAG_TEST_AND_CLEAR (Flags
, EFI_IFR_FLAG_OPTIONS_ONLY
)) {
409 mHeader
->Flags
|= EFI_IFR_FLAG_OPTIONS_ONLY
;
412 return _FLAGS_ZERO (Flags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
417 * The definition of CIfrMinMaxStepData
419 class CIfrMinMaxStepData
{
421 MINMAXSTEP_DATA
*mMinMaxStepData
;
426 CIfrMinMaxStepData (MINMAXSTEP_DATA
*DataAddr
, BOOLEAN NumericOpcode
=FALSE
) : mMinMaxStepData (DataAddr
) {
427 mMinMaxStepData
->u64
.MinValue
= 0;
428 mMinMaxStepData
->u64
.MaxValue
= 0;
429 mMinMaxStepData
->u64
.Step
= 0;
431 IsNumeric
= NumericOpcode
;
434 VOID
SetMinMaxStepData (IN UINT64 MinValue
, IN UINT64 MaxValue
, IN UINT64 Step
) {
436 mMinMaxStepData
->u64
.MinValue
= MinValue
;
437 mMinMaxStepData
->u64
.MaxValue
= MaxValue
;
440 if (MinValue
< mMinMaxStepData
->u64
.MinValue
) {
441 mMinMaxStepData
->u64
.MinValue
= MinValue
;
443 if (MaxValue
> mMinMaxStepData
->u64
.MaxValue
) {
444 mMinMaxStepData
->u64
.MaxValue
= MaxValue
;
447 mMinMaxStepData
->u64
.Step
= Step
;
450 VOID
SetMinMaxStepData (IN UINT32 MinValue
, IN UINT32 MaxValue
, IN UINT32 Step
) {
452 mMinMaxStepData
->u32
.MinValue
= MinValue
;
453 mMinMaxStepData
->u32
.MaxValue
= MaxValue
;
456 if (MinValue
< mMinMaxStepData
->u32
.MinValue
) {
457 mMinMaxStepData
->u32
.MinValue
= MinValue
;
459 if (MaxValue
> mMinMaxStepData
->u32
.MaxValue
) {
460 mMinMaxStepData
->u32
.MaxValue
= MaxValue
;
463 mMinMaxStepData
->u32
.Step
= Step
;
466 VOID
SetMinMaxStepData (IN UINT16 MinValue
, IN UINT16 MaxValue
, IN UINT16 Step
) {
468 mMinMaxStepData
->u16
.MinValue
= MinValue
;
469 mMinMaxStepData
->u16
.MaxValue
= MaxValue
;
472 if (MinValue
< mMinMaxStepData
->u16
.MinValue
) {
473 mMinMaxStepData
->u16
.MinValue
= MinValue
;
475 if (MaxValue
> mMinMaxStepData
->u16
.MaxValue
) {
476 mMinMaxStepData
->u16
.MaxValue
= MaxValue
;
479 mMinMaxStepData
->u16
.Step
= Step
;
482 VOID
SetMinMaxStepData (IN UINT8 MinValue
, IN UINT8 MaxValue
, IN UINT8 Step
) {
484 mMinMaxStepData
->u8
.MinValue
= MinValue
;
485 mMinMaxStepData
->u8
.MaxValue
= MaxValue
;
488 if (MinValue
< mMinMaxStepData
->u8
.MinValue
) {
489 mMinMaxStepData
->u8
.MinValue
= MinValue
;
491 if (MaxValue
> mMinMaxStepData
->u8
.MaxValue
) {
492 mMinMaxStepData
->u8
.MaxValue
= MaxValue
;
495 mMinMaxStepData
->u8
.Step
= Step
;
498 UINT64
GetMinData (UINT8 VarType
) {
501 case EFI_IFR_TYPE_NUM_SIZE_64
:
502 MinValue
= mMinMaxStepData
->u64
.MinValue
;
504 case EFI_IFR_TYPE_NUM_SIZE_32
:
505 MinValue
= (UINT64
) mMinMaxStepData
->u32
.MinValue
;
507 case EFI_IFR_TYPE_NUM_SIZE_16
:
508 MinValue
= (UINT64
) mMinMaxStepData
->u16
.MinValue
;
510 case EFI_IFR_TYPE_NUM_SIZE_8
:
511 MinValue
= (UINT64
) mMinMaxStepData
->u8
.MinValue
;
519 UINT64
GetMaxData (UINT8 VarType
) {
522 case EFI_IFR_TYPE_NUM_SIZE_64
:
523 MaxValue
= mMinMaxStepData
->u64
.MaxValue
;
525 case EFI_IFR_TYPE_NUM_SIZE_32
:
526 MaxValue
= (UINT64
) mMinMaxStepData
->u32
.MaxValue
;
528 case EFI_IFR_TYPE_NUM_SIZE_16
:
529 MaxValue
= (UINT64
) mMinMaxStepData
->u16
.MaxValue
;
531 case EFI_IFR_TYPE_NUM_SIZE_8
:
532 MaxValue
= (UINT64
) mMinMaxStepData
->u8
.MaxValue
;
540 UINT64
GetStepData (UINT8 VarType
) {
543 case EFI_IFR_TYPE_NUM_SIZE_64
:
544 MaxValue
= mMinMaxStepData
->u64
.Step
;
546 case EFI_IFR_TYPE_NUM_SIZE_32
:
547 MaxValue
= (UINT64
) mMinMaxStepData
->u32
.Step
;
549 case EFI_IFR_TYPE_NUM_SIZE_16
:
550 MaxValue
= (UINT64
) mMinMaxStepData
->u16
.Step
;
552 case EFI_IFR_TYPE_NUM_SIZE_8
:
553 MaxValue
= (UINT64
) mMinMaxStepData
->u8
.Step
;
561 BOOLEAN
IsNumericOpcode () {
566 static CIfrQuestionHeader
*gCurrentQuestion
= NULL
;
567 static CIfrMinMaxStepData
*gCurrentMinMaxData
= NULL
;
570 * The definition of all of the UEFI IFR Objects
572 class CIfrFormSet
: public CIfrObj
, public CIfrOpHeader
{
574 EFI_IFR_FORM_SET
*mFormSet
;
575 EFI_GUID
*mClassGuid
;
578 CIfrFormSet (UINT8 Size
) : CIfrObj (EFI_IFR_FORM_SET_OP
, (CHAR8
**)&mFormSet
, Size
),
579 CIfrOpHeader (EFI_IFR_FORM_SET_OP
, &mFormSet
->Header
, Size
) {
580 mFormSet
->Help
= EFI_STRING_ID_INVALID
;
581 mFormSet
->FormSetTitle
= EFI_STRING_ID_INVALID
;
583 memset (&mFormSet
->Guid
, 0, sizeof (EFI_GUID
));
584 mClassGuid
= (EFI_GUID
*) (mFormSet
+ 1);
587 VOID
SetGuid (IN EFI_GUID
*Guid
) {
588 memcpy (&mFormSet
->Guid
, Guid
, sizeof (EFI_GUID
));
591 VOID
SetFormSetTitle (IN EFI_STRING_ID FormSetTitle
) {
592 mFormSet
->FormSetTitle
= FormSetTitle
;
595 VOID
SetHelp (IN EFI_STRING_ID Help
) {
596 mFormSet
->Help
= Help
;
599 VOID
SetClassGuid (IN EFI_GUID
*Guid
) {
600 memcpy (&(mClassGuid
[mFormSet
->Flags
++]), Guid
, sizeof (EFI_GUID
));
604 return mFormSet
->Flags
;
608 class CIfrEnd
: public CIfrObj
, public CIfrOpHeader
{
613 CIfrEnd () : CIfrObj (EFI_IFR_END_OP
, (CHAR8
**)&mEnd
),
614 CIfrOpHeader (EFI_IFR_END_OP
, &mEnd
->Header
) {}
617 class CIfrDefaultStore
: public CIfrObj
, public CIfrOpHeader
{
619 EFI_IFR_DEFAULTSTORE
*mDefaultStore
;
622 CIfrDefaultStore () : CIfrObj (EFI_IFR_DEFAULTSTORE_OP
, (CHAR8
**)&mDefaultStore
),
623 CIfrOpHeader (EFI_IFR_DEFAULTSTORE_OP
, &mDefaultStore
->Header
) {
624 mDefaultStore
->DefaultId
= EFI_VARSTORE_ID_INVALID
;
625 mDefaultStore
->DefaultName
= EFI_STRING_ID_INVALID
;
628 VOID
SetDefaultName (IN EFI_STRING_ID DefaultName
) {
629 mDefaultStore
->DefaultName
= DefaultName
;
632 VOID
SetDefaultId (IN UINT16 DefaultId
) {
633 mDefaultStore
->DefaultId
= DefaultId
;
637 #define EFI_FORM_ID_MAX 0xFFFF
638 #define EFI_FREE_FORM_ID_BITMAP_SIZE ((EFI_FORM_ID_MAX + 1) / EFI_BITS_PER_UINT32)
642 STATIC UINT32 FormIdBitMap
[EFI_FREE_FORM_ID_BITMAP_SIZE
];
644 STATIC BOOLEAN
ChekFormIdFree (IN EFI_FORM_ID FormId
) {
645 UINT32 Index
= (FormId
/ EFI_BITS_PER_UINT32
);
646 UINT32 Offset
= (FormId
% EFI_BITS_PER_UINT32
);
648 return (FormIdBitMap
[Index
] & (0x80000000 >> Offset
)) == 0;
651 STATIC VOID
MarkFormIdUsed (IN EFI_FORM_ID FormId
) {
652 UINT32 Index
= (FormId
/ EFI_BITS_PER_UINT32
);
653 UINT32 Offset
= (FormId
% EFI_BITS_PER_UINT32
);
655 FormIdBitMap
[Index
] |= (0x80000000 >> Offset
);
659 class CIfrForm
: public CIfrObj
, public CIfrOpHeader
{
664 CIfrForm () : CIfrObj (EFI_IFR_FORM_OP
, (CHAR8
**)&mForm
),
665 CIfrOpHeader (EFI_IFR_FORM_OP
, &mForm
->Header
) {
667 mForm
->FormTitle
= EFI_STRING_ID_INVALID
;
670 EFI_VFR_RETURN_CODE
SetFormId (IN EFI_FORM_ID FormId
) {
673 // FormId can't be 0.
675 return VFR_RETURN_INVALID_PARAMETER
;
677 if (CIfrFormId::ChekFormIdFree (FormId
) == FALSE
) {
678 return VFR_RETURN_FORMID_REDEFINED
;
680 mForm
->FormId
= FormId
;
681 CIfrFormId::MarkFormIdUsed (FormId
);
682 return VFR_RETURN_SUCCESS
;
685 VOID
SetFormTitle (IN EFI_STRING_ID FormTitle
) {
686 mForm
->FormTitle
= FormTitle
;
690 class CIfrFormMap
: public CIfrObj
, public CIfrOpHeader
{
692 EFI_IFR_FORM_MAP
*mFormMap
;
693 EFI_IFR_FORM_MAP_METHOD
*mMethodMap
;
696 CIfrFormMap () : CIfrObj (EFI_IFR_FORM_MAP_OP
, (CHAR8
**)&mFormMap
, sizeof (EFI_IFR_FORM_MAP
), TRUE
),
697 CIfrOpHeader (EFI_IFR_FORM_MAP_OP
, &mFormMap
->Header
) {
698 mFormMap
->FormId
= 0;
699 mMethodMap
= (EFI_IFR_FORM_MAP_METHOD
*) (mFormMap
+ 1);
702 EFI_VFR_RETURN_CODE
SetFormId (IN EFI_FORM_ID FormId
) {
705 // FormId can't be 0.
707 return VFR_RETURN_INVALID_PARAMETER
;
709 if (CIfrFormId::ChekFormIdFree (FormId
) == FALSE
) {
710 return VFR_RETURN_FORMID_REDEFINED
;
712 mFormMap
->FormId
= FormId
;
713 CIfrFormId::MarkFormIdUsed (FormId
);
714 return VFR_RETURN_SUCCESS
;
717 VOID
SetFormMapMethod (IN EFI_STRING_ID MethodTitle
, IN EFI_GUID
*MethodGuid
) {
718 if (ExpendObjBin (sizeof (EFI_IFR_FORM_MAP_METHOD
))) {
719 IncLength (sizeof (EFI_IFR_FORM_MAP_METHOD
));
721 mMethodMap
->MethodTitle
= MethodTitle
;
722 memcpy (&(mMethodMap
->MethodIdentifier
), MethodGuid
, sizeof (EFI_GUID
));
728 class CIfrVarStore
: public CIfrObj
, public CIfrOpHeader
{
730 EFI_IFR_VARSTORE
*mVarStore
;
733 CIfrVarStore () : CIfrObj (EFI_IFR_VARSTORE_OP
, (CHAR8
**)&mVarStore
, sizeof (EFI_IFR_VARSTORE
), TRUE
),
734 CIfrOpHeader (EFI_IFR_VARSTORE_OP
, &mVarStore
->Header
) {
735 mVarStore
->VarStoreId
= EFI_VARSTORE_ID_INVALID
;
737 memset (&mVarStore
->Guid
, 0, sizeof (EFI_GUID
));
738 mVarStore
->Name
[0] = '\0';
741 VOID
SetGuid (IN EFI_GUID
*Guid
) {
742 memcpy (&mVarStore
->Guid
, Guid
, sizeof (EFI_GUID
));
745 VOID
SetVarStoreId (IN EFI_VARSTORE_ID VarStoreId
) {
746 mVarStore
->VarStoreId
= VarStoreId
;
749 VOID
SetSize (IN UINT16 Size
) {
750 mVarStore
->Size
= Size
;
753 VOID
SetName (IN CHAR8
*Name
) {
757 Len
= (UINT8
) strlen (Name
);
759 if (ExpendObjBin (Len
) == TRUE
) {
761 strcpy ((CHAR8
*)(mVarStore
->Name
), Name
);
768 class CIfrVarStoreEfi
: public CIfrObj
, public CIfrOpHeader
{
770 EFI_IFR_VARSTORE_EFI
*mVarStoreEfi
;
773 CIfrVarStoreEfi () : CIfrObj (EFI_IFR_VARSTORE_EFI_OP
, (CHAR8
**)&mVarStoreEfi
, sizeof (EFI_IFR_VARSTORE_EFI
), TRUE
),
774 CIfrOpHeader (EFI_IFR_VARSTORE_EFI_OP
, &mVarStoreEfi
->Header
) {
775 mVarStoreEfi
->VarStoreId
= EFI_VAROFFSET_INVALID
;
776 mVarStoreEfi
->Size
= 0;
777 memset (&mVarStoreEfi
->Guid
, 0, sizeof (EFI_GUID
));
778 mVarStoreEfi
->Name
[0] = '\0';
781 VOID
SetGuid (IN EFI_GUID
*Guid
) {
782 memcpy (&mVarStoreEfi
->Guid
, Guid
, sizeof (EFI_GUID
));
785 VOID
SetVarStoreId (IN UINT16 VarStoreId
) {
786 mVarStoreEfi
->VarStoreId
= VarStoreId
;
789 VOID
SetAttributes (IN UINT32 Attributes
) {
790 mVarStoreEfi
->Attributes
= Attributes
;
792 VOID
SetSize (IN UINT16 Size
) {
793 mVarStoreEfi
->Size
= Size
;
796 VOID
SetName (IN CHAR8
*Name
) {
800 Len
= (UINT8
) strlen (Name
);
802 if (ExpendObjBin (Len
) == TRUE
) {
804 strcpy ((CHAR8
*)(mVarStoreEfi
->Name
), Name
);
810 VOID
SetBinaryLength (IN UINT16 Size
) {
813 Len
= sizeof (EFI_IFR_VARSTORE_EFI
);
815 ExpendObjBin(Size
- Len
);
816 IncLength(Size
- Len
);
818 ShrinkObjBin(Len
- Size
);
819 DecLength(Len
- Size
);
824 class CIfrVarStoreNameValue
: public CIfrObj
, public CIfrOpHeader
{
826 EFI_IFR_VARSTORE_NAME_VALUE
*mVarStoreNameValue
;
829 CIfrVarStoreNameValue () : CIfrObj (EFI_IFR_VARSTORE_NAME_VALUE_OP
, (CHAR8
**)&mVarStoreNameValue
),
830 CIfrOpHeader (EFI_IFR_VARSTORE_NAME_VALUE_OP
, &mVarStoreNameValue
->Header
) {
831 mVarStoreNameValue
->VarStoreId
= EFI_VAROFFSET_INVALID
;
832 memset (&mVarStoreNameValue
->Guid
, 0, sizeof (EFI_GUID
));
835 VOID
SetGuid (IN EFI_GUID
*Guid
) {
836 memcpy (&mVarStoreNameValue
->Guid
, Guid
, sizeof (EFI_GUID
));
839 VOID
SetVarStoreId (IN UINT16 VarStoreId
) {
840 mVarStoreNameValue
->VarStoreId
= VarStoreId
;
844 class CIfrImage
: public CIfrObj
, public CIfrOpHeader
{
846 EFI_IFR_IMAGE
*mImage
;
849 CIfrImage () : CIfrObj (EFI_IFR_IMAGE_OP
, (CHAR8
**)&mImage
),
850 CIfrOpHeader (EFI_IFR_IMAGE_OP
, &mImage
->Header
) {
851 mImage
->Id
= EFI_IMAGE_ID_INVALID
;
854 VOID
SetImageId (IN EFI_IMAGE_ID ImageId
) {
855 mImage
->Id
= ImageId
;
859 class CIfrModal
: public CIfrObj
, public CIfrOpHeader
{
861 EFI_IFR_MODAL
*mModal
;
864 CIfrModal () : CIfrObj (EFI_IFR_MODAL_TAG_OP
, (CHAR8
**)&mModal
),
865 CIfrOpHeader (EFI_IFR_MODAL_TAG_OP
, &mModal
->Header
) {
870 class CIfrLocked
: public CIfrObj
, public CIfrOpHeader
{
872 EFI_IFR_LOCKED
*mLocked
;
875 CIfrLocked () : CIfrObj (EFI_IFR_LOCKED_OP
, (CHAR8
**)&mLocked
),
876 CIfrOpHeader (EFI_IFR_LOCKED_OP
, &mLocked
->Header
) {}
879 class CIfrRule
: public CIfrObj
, public CIfrOpHeader
{
884 CIfrRule () : CIfrObj (EFI_IFR_RULE_OP
, (CHAR8
**)&mRule
),
885 mRule ((EFI_IFR_RULE
*)GetObjBinAddr()),
886 CIfrOpHeader (EFI_IFR_RULE_OP
, &mRule
->Header
) {
887 mRule
->RuleId
= EFI_RULE_ID_INVALID
;
890 VOID
SetRuleId (IN UINT8 RuleId
) {
891 mRule
->RuleId
= RuleId
;
895 static EFI_IFR_TYPE_VALUE gZeroEfiIfrTypeValue
= {0, };
897 class CIfrDefault
: public CIfrObj
, public CIfrOpHeader
{
899 EFI_IFR_DEFAULT
*mDefault
;
903 IN UINT16 DefaultId
= EFI_HII_DEFAULT_CLASS_STANDARD
,
904 IN UINT8 Type
= EFI_IFR_TYPE_OTHER
,
905 IN EFI_IFR_TYPE_VALUE Value
= gZeroEfiIfrTypeValue
906 ) : CIfrObj (EFI_IFR_DEFAULT_OP
, (CHAR8
**)&mDefault
),
907 CIfrOpHeader (EFI_IFR_DEFAULT_OP
, &mDefault
->Header
) {
908 mDefault
->Type
= Type
;
909 mDefault
->Value
= Value
;
910 mDefault
->DefaultId
= DefaultId
;
913 VOID
SetDefaultId (IN UINT16 DefaultId
) {
914 mDefault
->DefaultId
= DefaultId
;
917 VOID
SetType (IN UINT8 Type
) {
918 mDefault
->Type
= Type
;
921 VOID
SetValue (IN EFI_IFR_TYPE_VALUE Value
) {
922 mDefault
->Value
= Value
;
926 class CIfrValue
: public CIfrObj
, public CIfrOpHeader
{
928 EFI_IFR_VALUE
*mValue
;
931 CIfrValue () : CIfrObj (EFI_IFR_VALUE_OP
, (CHAR8
**)&mValue
),
932 CIfrOpHeader (EFI_IFR_VALUE_OP
, &mValue
->Header
) {}
936 class CIfrRead
: public CIfrObj
, public CIfrOpHeader
{
941 CIfrRead () : CIfrObj (EFI_IFR_READ_OP
, (CHAR8
**)&mRead
),
942 CIfrOpHeader (EFI_IFR_READ_OP
, &mRead
->Header
) {}
946 class CIfrWrite
: public CIfrObj
, public CIfrOpHeader
{
948 EFI_IFR_WRITE
*mWrite
;
951 CIfrWrite () : CIfrObj (EFI_IFR_WRITE_OP
, (CHAR8
**)&mWrite
),
952 CIfrOpHeader (EFI_IFR_WRITE_OP
, &mWrite
->Header
) {}
956 class CIfrGet
: public CIfrObj
, public CIfrOpHeader
{
963 ) : CIfrObj (EFI_IFR_GET_OP
, (CHAR8
**)&mGet
),
964 CIfrOpHeader (EFI_IFR_GET_OP
, &mGet
->Header
) {
968 VOID
SetVarInfo (IN EFI_VARSTORE_INFO
*Info
) {
969 mGet
->VarStoreId
= Info
->mVarStoreId
;
970 mGet
->VarStoreInfo
.VarName
= Info
->mInfo
.mVarName
;
971 mGet
->VarStoreInfo
.VarOffset
= Info
->mInfo
.mVarOffset
;
972 mGet
->VarStoreType
= Info
->mVarType
;
976 class CIfrSet
: public CIfrObj
, public CIfrOpHeader
{
983 ) : CIfrObj (EFI_IFR_SET_OP
, (CHAR8
**)&mSet
),
984 CIfrOpHeader (EFI_IFR_SET_OP
, &mSet
->Header
) {
988 VOID
SetVarInfo (IN EFI_VARSTORE_INFO
*Info
) {
989 mSet
->VarStoreId
= Info
->mVarStoreId
;
990 mSet
->VarStoreInfo
.VarName
= Info
->mInfo
.mVarName
;
991 mSet
->VarStoreInfo
.VarOffset
= Info
->mInfo
.mVarOffset
;
992 mSet
->VarStoreType
= Info
->mVarType
;
996 class CIfrSubtitle
: public CIfrObj
, public CIfrOpHeader
, public CIfrStatementHeader
{
998 EFI_IFR_SUBTITLE
*mSubtitle
;
1001 CIfrSubtitle () : CIfrObj (EFI_IFR_SUBTITLE_OP
, (CHAR8
**)&mSubtitle
),
1002 CIfrOpHeader (EFI_IFR_SUBTITLE_OP
, &mSubtitle
->Header
),
1003 CIfrStatementHeader (&mSubtitle
->Statement
) {
1004 mSubtitle
->Flags
= 0;
1007 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 LFlags
) {
1008 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_FLAGS_HORIZONTAL
)) {
1009 mSubtitle
->Flags
|= EFI_IFR_FLAGS_HORIZONTAL
;
1012 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1016 class CIfrText
: public CIfrObj
, public CIfrOpHeader
, public CIfrStatementHeader
{
1018 EFI_IFR_TEXT
*mText
;
1021 CIfrText () : CIfrObj (EFI_IFR_TEXT_OP
, (CHAR8
**)&mText
),
1022 CIfrOpHeader (EFI_IFR_TEXT_OP
, &mText
->Header
),
1023 CIfrStatementHeader (&mText
->Statement
) {
1024 mText
->TextTwo
= EFI_STRING_ID_INVALID
;
1027 VOID
SetTextTwo (IN EFI_STRING_ID StringId
) {
1028 mText
->TextTwo
= StringId
;
1032 class CIfrRef
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1037 CIfrRef () : CIfrObj (EFI_IFR_REF_OP
, (CHAR8
**)&mRef
),
1038 CIfrOpHeader (EFI_IFR_REF_OP
, &mRef
->Header
),
1039 CIfrQuestionHeader (&mRef
->Question
) {
1043 VOID
SetFormId (IN EFI_FORM_ID FormId
) {
1044 mRef
->FormId
= FormId
;
1048 class CIfrRef2
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1050 EFI_IFR_REF2
*mRef2
;
1053 CIfrRef2 () : CIfrObj (EFI_IFR_REF_OP
, (CHAR8
**)&mRef2
, sizeof (EFI_IFR_REF2
)),
1054 CIfrOpHeader (EFI_IFR_REF_OP
, &mRef2
->Header
, sizeof (EFI_IFR_REF2
)),
1055 CIfrQuestionHeader (&mRef2
->Question
) {
1057 mRef2
->QuestionId
= EFI_QUESTION_ID_INVALID
;
1060 VOID
SetFormId (IN EFI_FORM_ID FormId
) {
1061 mRef2
->FormId
= FormId
;
1064 VOID
SetQuestionId (IN EFI_QUESTION_ID QuestionId
) {
1065 mRef2
->QuestionId
= QuestionId
;
1069 class CIfrRef3
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1071 EFI_IFR_REF3
*mRef3
;
1074 CIfrRef3 () : CIfrObj (EFI_IFR_REF_OP
, (CHAR8
**)&mRef3
, sizeof(EFI_IFR_REF3
)),
1075 CIfrOpHeader (EFI_IFR_REF_OP
, &mRef3
->Header
, sizeof (EFI_IFR_REF3
)),
1076 CIfrQuestionHeader (&mRef3
->Question
) {
1078 mRef3
->QuestionId
= EFI_QUESTION_ID_INVALID
;
1079 memset (&mRef3
->FormSetId
, 0, sizeof (EFI_GUID
));
1082 VOID
SetFormId (IN EFI_FORM_ID FormId
) {
1083 mRef3
->FormId
= FormId
;
1086 VOID
SetQuestionId (IN EFI_QUESTION_ID QuestionId
) {
1087 mRef3
->QuestionId
= QuestionId
;
1090 VOID
SetFormSetId (IN EFI_GUID FormSetId
) {
1091 mRef3
->FormSetId
= FormSetId
;
1095 class CIfrRef4
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1097 EFI_IFR_REF4
*mRef4
;
1100 CIfrRef4 () : CIfrObj (EFI_IFR_REF_OP
, (CHAR8
**)&mRef4
, sizeof(EFI_IFR_REF4
)),
1101 CIfrOpHeader (EFI_IFR_REF_OP
, &mRef4
->Header
, sizeof(EFI_IFR_REF4
)),
1102 CIfrQuestionHeader (&mRef4
->Question
) {
1104 mRef4
->QuestionId
= EFI_QUESTION_ID_INVALID
;
1105 memset (&mRef4
->FormSetId
, 0, sizeof (EFI_GUID
));
1106 mRef4
->DevicePath
= EFI_STRING_ID_INVALID
;
1109 VOID
SetFormId (IN EFI_FORM_ID FormId
) {
1110 mRef4
->FormId
= FormId
;
1113 VOID
SetQuestionId (IN EFI_QUESTION_ID QuestionId
) {
1114 mRef4
->QuestionId
= QuestionId
;
1117 VOID
SetFormSetId (IN EFI_GUID FormSetId
) {
1118 mRef4
->FormSetId
= FormSetId
;
1121 VOID
SetDevicePath (IN EFI_STRING_ID DevicePath
) {
1122 mRef4
->DevicePath
= DevicePath
;
1126 class CIfrRef5
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1128 EFI_IFR_REF5
*mRef5
;
1131 CIfrRef5 () : CIfrObj (EFI_IFR_REF_OP
, (CHAR8
**)&mRef5
, sizeof (EFI_IFR_REF5
)),
1132 CIfrOpHeader (EFI_IFR_REF_OP
, &mRef5
->Header
, sizeof (EFI_IFR_REF5
)),
1133 CIfrQuestionHeader (&mRef5
->Question
) {
1137 class CIfrResetButton
: public CIfrObj
, public CIfrOpHeader
, public CIfrStatementHeader
{
1139 EFI_IFR_RESET_BUTTON
*mResetButton
;
1142 CIfrResetButton () : CIfrObj (EFI_IFR_RESET_BUTTON_OP
, (CHAR8
**)&mResetButton
),
1143 CIfrOpHeader (EFI_IFR_RESET_BUTTON_OP
, &mResetButton
->Header
),
1144 CIfrStatementHeader (&mResetButton
->Statement
) {
1145 mResetButton
->DefaultId
= EFI_HII_DEFAULT_CLASS_STANDARD
;
1148 VOID
SetDefaultId (IN UINT16 DefaultId
) {
1149 mResetButton
->DefaultId
= DefaultId
;
1153 class CIfrCheckBox
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1155 EFI_IFR_CHECKBOX
*mCheckBox
;
1158 CIfrCheckBox () : CIfrObj (EFI_IFR_CHECKBOX_OP
, (CHAR8
**)&mCheckBox
),
1159 CIfrOpHeader (EFI_IFR_CHECKBOX_OP
, &mCheckBox
->Header
),
1160 CIfrQuestionHeader (&mCheckBox
->Question
) {
1161 mCheckBox
->Flags
= 0;
1162 gCurrentQuestion
= this;
1166 gCurrentQuestion
= NULL
;
1169 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, UINT8 LFlags
) {
1170 EFI_VFR_RETURN_CODE Ret
;
1172 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1173 if (Ret
!= VFR_RETURN_SUCCESS
) {
1177 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_CHECKBOX_DEFAULT
)) {
1178 mCheckBox
->Flags
|= EFI_IFR_CHECKBOX_DEFAULT
;
1181 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_CHECKBOX_DEFAULT_MFG
)) {
1182 mCheckBox
->Flags
|= EFI_IFR_CHECKBOX_DEFAULT_MFG
;
1185 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1188 UINT8
GetFlags (VOID
) {
1189 return mCheckBox
->Flags
;
1193 class CIfrAction
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1195 EFI_IFR_ACTION
*mAction
;
1198 CIfrAction () : CIfrObj (EFI_IFR_ACTION_OP
, (CHAR8
**)&mAction
),
1199 CIfrOpHeader (EFI_IFR_ACTION_OP
, &mAction
->Header
),
1200 CIfrQuestionHeader (&mAction
->Question
) {
1201 mAction
->QuestionConfig
= EFI_STRING_ID_INVALID
;
1204 VOID
SetQuestionConfig (IN EFI_STRING_ID QuestionConfig
) {
1205 mAction
->QuestionConfig
= QuestionConfig
;
1209 class CIfrDate
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1211 EFI_IFR_DATE
*mDate
;
1214 CIfrDate () : CIfrObj (EFI_IFR_DATE_OP
, (CHAR8
**)&mDate
),
1215 CIfrOpHeader (EFI_IFR_DATE_OP
, &mDate
->Header
),
1216 CIfrQuestionHeader (&mDate
->Question
) {
1220 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
) {
1221 EFI_VFR_RETURN_CODE Ret
;
1223 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1224 if (Ret
!= VFR_RETURN_SUCCESS
) {
1228 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_QF_DATE_YEAR_SUPPRESS
)) {
1229 mDate
->Flags
|= EFI_QF_DATE_YEAR_SUPPRESS
;
1232 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_QF_DATE_MONTH_SUPPRESS
)) {
1233 mDate
->Flags
|= EFI_QF_DATE_MONTH_SUPPRESS
;
1236 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_QF_DATE_DAY_SUPPRESS
)) {
1237 mDate
->Flags
|= EFI_QF_DATE_DAY_SUPPRESS
;
1240 if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_DATE_STORAGE_NORMAL
)) {
1241 mDate
->Flags
|= QF_DATE_STORAGE_NORMAL
;
1242 } else if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_DATE_STORAGE_TIME
)) {
1243 mDate
->Flags
|= QF_DATE_STORAGE_TIME
;
1244 } else if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_DATE_STORAGE_WAKEUP
)) {
1245 mDate
->Flags
|= QF_DATE_STORAGE_WAKEUP
;
1248 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1252 class CIfrNumeric
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
, public CIfrMinMaxStepData
{
1254 EFI_IFR_NUMERIC
*mNumeric
;
1257 CIfrNumeric () : CIfrObj (EFI_IFR_NUMERIC_OP
, (CHAR8
**)&mNumeric
),
1258 CIfrOpHeader (EFI_IFR_NUMERIC_OP
, &mNumeric
->Header
),
1259 CIfrQuestionHeader (&mNumeric
->Question
),
1260 CIfrMinMaxStepData (&mNumeric
->data
, TRUE
) {
1261 mNumeric
->Flags
= EFI_IFR_NUMERIC_SIZE_1
| EFI_IFR_DISPLAY_UINT_DEC
;
1262 gCurrentQuestion
= this;
1263 gCurrentMinMaxData
= this;
1267 gCurrentQuestion
= NULL
;
1268 gCurrentMinMaxData
= NULL
;
1271 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
) {
1272 EFI_VFR_RETURN_CODE Ret
;
1274 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1275 if (Ret
!= VFR_RETURN_SUCCESS
) {
1279 if (LFlags
& EFI_IFR_DISPLAY
) {
1280 mNumeric
->Flags
= LFlags
;
1282 mNumeric
->Flags
= LFlags
| EFI_IFR_DISPLAY_UINT_DEC
;
1284 return VFR_RETURN_SUCCESS
;
1288 class CIfrOneOf
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
, public CIfrMinMaxStepData
{
1290 EFI_IFR_ONE_OF
*mOneOf
;
1293 CIfrOneOf () : CIfrObj (EFI_IFR_ONE_OF_OP
, (CHAR8
**)&mOneOf
),
1294 CIfrOpHeader (EFI_IFR_ONE_OF_OP
, &mOneOf
->Header
),
1295 CIfrQuestionHeader (&mOneOf
->Question
),
1296 CIfrMinMaxStepData (&mOneOf
->data
) {
1298 gCurrentQuestion
= this;
1299 gCurrentMinMaxData
= this;
1303 gCurrentQuestion
= NULL
;
1304 gCurrentMinMaxData
= NULL
;
1307 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
) {
1308 EFI_VFR_RETURN_CODE Ret
;
1310 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1311 if (Ret
!= VFR_RETURN_SUCCESS
) {
1315 if (LFlags
& EFI_IFR_DISPLAY
) {
1316 mOneOf
->Flags
= LFlags
;
1318 mOneOf
->Flags
= LFlags
| EFI_IFR_DISPLAY_UINT_DEC
;
1320 return VFR_RETURN_SUCCESS
;
1324 class CIfrString
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1326 EFI_IFR_STRING
*mString
;
1329 CIfrString () : CIfrObj (EFI_IFR_STRING_OP
, (CHAR8
**)&mString
),
1330 CIfrOpHeader (EFI_IFR_STRING_OP
, &mString
->Header
),
1331 CIfrQuestionHeader (&mString
->Question
) {
1333 mString
->MinSize
= 0;
1334 mString
->MaxSize
= 0;
1335 gCurrentQuestion
= this;
1339 gCurrentQuestion
= NULL
;
1342 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
) {
1343 EFI_VFR_RETURN_CODE Ret
;
1345 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1346 if (Ret
!= VFR_RETURN_SUCCESS
) {
1350 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_STRING_MULTI_LINE
)) {
1351 mString
->Flags
|= EFI_IFR_STRING_MULTI_LINE
;
1354 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1357 VOID
SetMinSize (IN UINT8 Flags
) {
1358 mString
->MinSize
= Flags
;
1361 VOID
SetMaxSize (IN UINT8 MaxSize
) {
1362 mString
->MaxSize
= MaxSize
;
1366 class CIfrPassword
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1368 EFI_IFR_PASSWORD
*mPassword
;
1371 CIfrPassword () : CIfrObj (EFI_IFR_PASSWORD_OP
, (CHAR8
**)&mPassword
),
1372 CIfrOpHeader (EFI_IFR_PASSWORD_OP
, &mPassword
->Header
),
1373 CIfrQuestionHeader (&mPassword
->Question
) {
1374 mPassword
->MinSize
= 0;
1375 mPassword
->MaxSize
= 0;
1376 gCurrentQuestion
= this;
1380 gCurrentQuestion
= NULL
;
1383 VOID
SetMinSize (IN UINT16 MinSize
) {
1384 mPassword
->MinSize
= MinSize
;
1387 VOID
SetMaxSize (IN UINT16 MaxSize
) {
1388 mPassword
->MaxSize
= MaxSize
;
1392 class CIfrOrderedList
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1394 EFI_IFR_ORDERED_LIST
*mOrderedList
;
1397 CIfrOrderedList () : CIfrObj (EFI_IFR_ORDERED_LIST_OP
, (CHAR8
**)&mOrderedList
),
1398 CIfrOpHeader (EFI_IFR_ORDERED_LIST_OP
, &mOrderedList
->Header
),
1399 CIfrQuestionHeader (&mOrderedList
->Question
) {
1400 mOrderedList
->MaxContainers
= 0;
1401 mOrderedList
->Flags
= 0;
1402 gCurrentQuestion
= this;
1405 ~CIfrOrderedList () {
1406 gCurrentQuestion
= NULL
;
1409 VOID
SetMaxContainers (IN UINT8 MaxContainers
) {
1410 mOrderedList
->MaxContainers
= MaxContainers
;
1413 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
) {
1414 EFI_VFR_RETURN_CODE Ret
;
1416 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1417 if (Ret
!= VFR_RETURN_SUCCESS
) {
1421 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_UNIQUE_SET
)) {
1422 mOrderedList
->Flags
|= EFI_IFR_UNIQUE_SET
;
1425 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_NO_EMPTY_SET
)) {
1426 mOrderedList
->Flags
|= EFI_IFR_NO_EMPTY_SET
;
1429 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1433 class CIfrTime
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1435 EFI_IFR_TIME
*mTime
;
1438 CIfrTime () : CIfrObj (EFI_IFR_TIME_OP
, (CHAR8
**)&mTime
),
1439 CIfrOpHeader (EFI_IFR_TIME_OP
, &mTime
->Header
),
1440 CIfrQuestionHeader (&mTime
->Question
) {
1444 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
) {
1445 EFI_VFR_RETURN_CODE Ret
;
1447 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1448 if (Ret
!= VFR_RETURN_SUCCESS
) {
1452 if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_HOUR_SUPPRESS
)) {
1453 mTime
->Flags
|= QF_TIME_HOUR_SUPPRESS
;
1456 if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_MINUTE_SUPPRESS
)) {
1457 mTime
->Flags
|= QF_TIME_MINUTE_SUPPRESS
;
1460 if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_SECOND_SUPPRESS
)) {
1461 mTime
->Flags
|= QF_TIME_SECOND_SUPPRESS
;
1464 if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_STORAGE_NORMAL
)) {
1465 mTime
->Flags
|= QF_TIME_STORAGE_NORMAL
;
1466 } else if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_STORAGE_TIME
)) {
1467 mTime
->Flags
|= QF_TIME_STORAGE_TIME
;
1468 } else if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_STORAGE_WAKEUP
)) {
1469 mTime
->Flags
|= QF_TIME_STORAGE_WAKEUP
;
1472 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1476 class CIfrDisableIf
: public CIfrObj
, public CIfrOpHeader
{
1478 EFI_IFR_DISABLE_IF
*mDisableIf
;
1481 CIfrDisableIf () : CIfrObj (EFI_IFR_DISABLE_IF_OP
, (CHAR8
**)&mDisableIf
),
1482 mDisableIf ((EFI_IFR_DISABLE_IF
*) GetObjBinAddr()),
1483 CIfrOpHeader (EFI_IFR_DISABLE_IF_OP
, &mDisableIf
->Header
) {}
1486 class CIfrSuppressIf
: public CIfrObj
, public CIfrOpHeader
{
1488 EFI_IFR_SUPPRESS_IF
*mSuppressIf
;
1491 CIfrSuppressIf () : CIfrObj (EFI_IFR_SUPPRESS_IF_OP
, (CHAR8
**)&mSuppressIf
),
1492 CIfrOpHeader (EFI_IFR_SUPPRESS_IF_OP
, &mSuppressIf
->Header
) {}
1495 class CIfrGrayOutIf
: public CIfrObj
, public CIfrOpHeader
{
1497 EFI_IFR_GRAY_OUT_IF
*mGrayOutIf
;
1500 CIfrGrayOutIf () : CIfrObj (EFI_IFR_GRAY_OUT_IF_OP
, (CHAR8
**)&mGrayOutIf
),
1501 CIfrOpHeader (EFI_IFR_GRAY_OUT_IF_OP
, &mGrayOutIf
->Header
) {}
1504 class CIfrInconsistentIf
: public CIfrObj
, public CIfrOpHeader
{
1506 EFI_IFR_INCONSISTENT_IF
*mInconsistentIf
;
1509 CIfrInconsistentIf () : CIfrObj (EFI_IFR_INCONSISTENT_IF_OP
, (CHAR8
**)&mInconsistentIf
),
1510 CIfrOpHeader (EFI_IFR_INCONSISTENT_IF_OP
, &mInconsistentIf
->Header
) {
1511 mInconsistentIf
->Error
= EFI_STRING_ID_INVALID
;
1514 VOID
SetError (IN EFI_STRING_ID Error
) {
1515 mInconsistentIf
->Error
= Error
;
1519 class CIfrNoSubmitIf
: public CIfrObj
, public CIfrOpHeader
{
1521 EFI_IFR_NO_SUBMIT_IF
*mNoSubmitIf
;
1524 CIfrNoSubmitIf () : CIfrObj (EFI_IFR_NO_SUBMIT_IF_OP
, (CHAR8
**)&mNoSubmitIf
),
1525 CIfrOpHeader (EFI_IFR_NO_SUBMIT_IF_OP
, &mNoSubmitIf
->Header
) {
1526 mNoSubmitIf
->Error
= EFI_STRING_ID_INVALID
;
1529 VOID
SetError (IN EFI_STRING_ID Error
) {
1530 mNoSubmitIf
->Error
= Error
;
1534 class CIfrRefresh
: public CIfrObj
, public CIfrOpHeader
{
1536 EFI_IFR_REFRESH
*mRefresh
;
1539 CIfrRefresh () : CIfrObj (EFI_IFR_REFRESH_OP
, (CHAR8
**)&mRefresh
),
1540 CIfrOpHeader (EFI_IFR_REFRESH_OP
, &mRefresh
->Header
) {
1541 mRefresh
->RefreshInterval
= 0;
1544 VOID
SetRefreshInterval (IN UINT8 RefreshInterval
) {
1545 mRefresh
->RefreshInterval
= RefreshInterval
;
1549 class CIfrRefreshId
: public CIfrObj
, public CIfrOpHeader
{
1551 EFI_IFR_REFRESH_ID
*mRefreshId
;
1554 CIfrRefreshId () : CIfrObj (EFI_IFR_REFRESH_ID_OP
, (CHAR8
**)&mRefreshId
),
1555 CIfrOpHeader (EFI_IFR_REFRESH_ID_OP
, &mRefreshId
->Header
) {
1556 memset (&mRefreshId
->RefreshEventGroupId
, 0, sizeof (EFI_GUID
));
1559 VOID
SetRefreshEventGroutId (IN EFI_GUID
*RefreshEventGroupId
) {
1560 memcpy (&mRefreshId
->RefreshEventGroupId
, RefreshEventGroupId
, sizeof (EFI_GUID
));
1564 class CIfrVarStoreDevice
: public CIfrObj
, public CIfrOpHeader
{
1566 EFI_IFR_VARSTORE_DEVICE
*mVarStoreDevice
;
1569 CIfrVarStoreDevice () : CIfrObj (EFI_IFR_VARSTORE_DEVICE_OP
, (CHAR8
**)&mVarStoreDevice
),
1570 CIfrOpHeader (EFI_IFR_VARSTORE_DEVICE_OP
, &mVarStoreDevice
->Header
) {
1571 mVarStoreDevice
->DevicePath
= EFI_STRING_ID_INVALID
;
1574 VOID
SetDevicePath (IN EFI_STRING_ID DevicePath
) {
1575 mVarStoreDevice
->DevicePath
= DevicePath
;
1579 class CIfrOneOfOption
: public CIfrObj
, public CIfrOpHeader
{
1581 EFI_IFR_ONE_OF_OPTION
*mOneOfOption
;
1584 CIfrOneOfOption () : CIfrObj (EFI_IFR_ONE_OF_OPTION_OP
, (CHAR8
**)&mOneOfOption
),
1585 CIfrOpHeader (EFI_IFR_ONE_OF_OPTION_OP
, &mOneOfOption
->Header
) {
1586 mOneOfOption
->Flags
= 0;
1587 mOneOfOption
->Option
= EFI_STRING_ID_INVALID
;
1588 mOneOfOption
->Type
= EFI_IFR_TYPE_OTHER
;
1589 memset (&mOneOfOption
->Value
, 0, sizeof (mOneOfOption
->Value
));
1592 VOID
SetOption (IN EFI_STRING_ID Option
) {
1593 mOneOfOption
->Option
= Option
;
1596 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 LFlags
) {
1597 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_OPTION_DEFAULT
)) {
1598 mOneOfOption
->Flags
|= EFI_IFR_OPTION_DEFAULT
;
1601 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_OPTION_DEFAULT_MFG
)) {
1602 mOneOfOption
->Flags
|= EFI_IFR_OPTION_DEFAULT_MFG
;
1605 if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_NUM_SIZE_8
)) {
1606 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_NUM_SIZE_8
);
1607 mOneOfOption
->Flags
|= EFI_IFR_TYPE_NUM_SIZE_8
;
1608 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_NUM_SIZE_16
)) {
1609 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_NUM_SIZE_16
);
1610 mOneOfOption
->Flags
|= EFI_IFR_TYPE_NUM_SIZE_16
;
1611 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_NUM_SIZE_32
)) {
1612 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_NUM_SIZE_32
);
1613 mOneOfOption
->Flags
|= EFI_IFR_TYPE_NUM_SIZE_32
;
1614 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_NUM_SIZE_64
)) {
1615 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_NUM_SIZE_64
);
1616 mOneOfOption
->Flags
|= EFI_IFR_TYPE_NUM_SIZE_64
;
1617 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_BOOLEAN
)) {
1618 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_BOOLEAN
);
1619 mOneOfOption
->Flags
|= EFI_IFR_TYPE_BOOLEAN
;
1620 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_TIME
)) {
1621 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_TIME
);
1622 mOneOfOption
->Flags
|= EFI_IFR_TYPE_TIME
;
1623 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_DATE
)) {
1624 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_DATE
);
1625 mOneOfOption
->Flags
|= EFI_IFR_TYPE_DATE
;
1626 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_STRING
)) {
1627 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_STRING
);
1628 mOneOfOption
->Flags
|= EFI_IFR_TYPE_STRING
;
1629 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_OTHER
)) {
1630 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_OTHER
);
1631 mOneOfOption
->Flags
|= EFI_IFR_TYPE_OTHER
;
1634 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1637 VOID
SetType (IN UINT8 Type
) {
1638 mOneOfOption
->Type
= Type
;
1641 VOID
SetValue (IN EFI_IFR_TYPE_VALUE Value
) {
1642 mOneOfOption
->Value
= Value
;
1645 UINT8
GetFlags (VOID
) {
1646 return mOneOfOption
->Flags
;
1650 static EFI_GUID IfrTianoGuid
= EFI_IFR_TIANO_GUID
;
1651 static EFI_GUID IfrFrameworkGuid
= EFI_IFR_FRAMEWORK_GUID
;
1653 class CIfrClass
: public CIfrObj
, public CIfrOpHeader
{
1655 EFI_IFR_GUID_CLASS
*mClass
;
1658 CIfrClass () : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mClass
, sizeof (EFI_IFR_GUID_CLASS
)),
1659 CIfrOpHeader (EFI_IFR_GUID_OP
, &mClass
->Header
, sizeof (EFI_IFR_GUID_CLASS
)) {
1660 mClass
->ExtendOpCode
= EFI_IFR_EXTEND_OP_CLASS
;
1661 mClass
->Guid
= IfrTianoGuid
;
1662 mClass
->Class
= EFI_NON_DEVICE_CLASS
;
1665 VOID
SetClass (IN UINT16 Class
) {
1666 mClass
->Class
= Class
;
1670 class CIfrSubClass
: public CIfrObj
, public CIfrOpHeader
{
1672 EFI_IFR_GUID_SUBCLASS
*mSubClass
;
1675 CIfrSubClass () : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mSubClass
, sizeof (EFI_IFR_GUID_SUBCLASS
)),
1676 CIfrOpHeader (EFI_IFR_GUID_OP
, &mSubClass
->Header
, sizeof (EFI_IFR_GUID_SUBCLASS
)) {
1677 mSubClass
->ExtendOpCode
= EFI_IFR_EXTEND_OP_SUBCLASS
;
1678 mSubClass
->Guid
= IfrTianoGuid
;
1679 mSubClass
->SubClass
= EFI_SETUP_APPLICATION_SUBCLASS
;
1682 VOID
SetSubClass (IN UINT16 SubClass
) {
1683 mSubClass
->SubClass
= SubClass
;
1687 class CIfrLabel
: public CIfrObj
, public CIfrOpHeader
{
1689 EFI_IFR_GUID_LABEL
*mLabel
;
1692 CIfrLabel () : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mLabel
, sizeof (EFI_IFR_GUID_LABEL
)),
1693 CIfrOpHeader (EFI_IFR_GUID_OP
, &mLabel
->Header
, sizeof (EFI_IFR_GUID_LABEL
)) {
1694 mLabel
->ExtendOpCode
= EFI_IFR_EXTEND_OP_LABEL
;
1695 mLabel
->Guid
= IfrTianoGuid
;
1698 VOID
SetNumber (IN UINT16 Number
) {
1699 mLabel
->Number
= Number
;
1703 class CIfrBanner
: public CIfrObj
, public CIfrOpHeader
{
1705 EFI_IFR_GUID_BANNER
*mBanner
;
1708 CIfrBanner () : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mBanner
, sizeof (EFI_IFR_GUID_BANNER
)),
1709 CIfrOpHeader (EFI_IFR_GUID_OP
, &mBanner
->Header
, sizeof (EFI_IFR_GUID_BANNER
)) {
1710 mBanner
->ExtendOpCode
= EFI_IFR_EXTEND_OP_BANNER
;
1711 mBanner
->Guid
= IfrTianoGuid
;
1714 VOID
SetTitle (IN EFI_STRING_ID StringId
) {
1715 mBanner
->Title
= StringId
;
1718 VOID
SetLine (IN UINT16 Line
) {
1719 mBanner
->LineNumber
= Line
;
1722 VOID
SetAlign (IN UINT8 Align
) {
1723 mBanner
->Alignment
= Align
;
1727 class CIfrOptionKey
: public CIfrObj
, public CIfrOpHeader
{
1729 EFI_IFR_GUID_OPTIONKEY
*mOptionKey
;
1733 IN EFI_QUESTION_ID QuestionId
,
1734 IN EFI_IFR_TYPE_VALUE
&OptionValue
,
1735 IN EFI_QUESTION_ID KeyValue
1736 ) : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mOptionKey
, sizeof (EFI_IFR_GUID_OPTIONKEY
)),
1737 CIfrOpHeader (EFI_IFR_GUID_OP
, &mOptionKey
->Header
, sizeof (EFI_IFR_GUID_OPTIONKEY
)) {
1738 mOptionKey
->ExtendOpCode
= EFI_IFR_EXTEND_OP_OPTIONKEY
;
1739 mOptionKey
->Guid
= IfrFrameworkGuid
;
1740 mOptionKey
->QuestionId
= QuestionId
;
1741 mOptionKey
->OptionValue
= OptionValue
;
1742 mOptionKey
->KeyValue
= KeyValue
;
1746 class CIfrVarEqName
: public CIfrObj
, public CIfrOpHeader
{
1748 EFI_IFR_GUID_VAREQNAME
*mVarEqName
;
1752 IN EFI_QUESTION_ID QuestionId
,
1753 IN EFI_STRING_ID NameId
1754 ) : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mVarEqName
, sizeof (EFI_IFR_GUID_VAREQNAME
)),
1755 CIfrOpHeader (EFI_IFR_GUID_OP
, &mVarEqName
->Header
, sizeof (EFI_IFR_GUID_VAREQNAME
)) {
1756 mVarEqName
->ExtendOpCode
= EFI_IFR_EXTEND_OP_VAREQNAME
;
1757 mVarEqName
->Guid
= IfrFrameworkGuid
;
1758 mVarEqName
->QuestionId
= QuestionId
;
1759 mVarEqName
->NameId
= NameId
;
1763 class CIfrTimeout
: public CIfrObj
, public CIfrOpHeader
{
1765 EFI_IFR_GUID_TIMEOUT
*mTimeout
;
1768 CIfrTimeout (IN UINT16 Timeout
= 0) : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mTimeout
, sizeof (EFI_IFR_GUID_TIMEOUT
)),
1769 CIfrOpHeader (EFI_IFR_GUID_OP
, &mTimeout
->Header
, sizeof (EFI_IFR_GUID_TIMEOUT
)) {
1770 mTimeout
->ExtendOpCode
= EFI_IFR_EXTEND_OP_TIMEOUT
;
1771 mTimeout
->Guid
= IfrTianoGuid
;
1772 mTimeout
->TimeOut
= Timeout
;
1775 VOID
SetTimeout (IN UINT16 Timeout
) {
1776 mTimeout
->TimeOut
= Timeout
;
1780 class CIfrGuid
: public CIfrObj
, public CIfrOpHeader
{
1782 EFI_IFR_GUID
*mGuid
;
1785 CIfrGuid (UINT8 Size
) : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mGuid
, sizeof (EFI_IFR_GUID
)+Size
),
1786 CIfrOpHeader (EFI_IFR_GUID_OP
, &mGuid
->Header
, sizeof (EFI_IFR_GUID
)+Size
) {
1787 memset (&mGuid
->Guid
, 0, sizeof (EFI_GUID
));
1790 VOID
SetGuid (IN EFI_GUID
*Guid
) {
1791 memcpy (&mGuid
->Guid
, Guid
, sizeof (EFI_GUID
));
1794 VOID
SetData (IN UINT8
* DataBuff
, IN UINT8 Size
) {
1795 memcpy ((UINT8
*)mGuid
+ sizeof (EFI_IFR_GUID
), DataBuff
, Size
);
1799 class CIfrDup
: public CIfrObj
, public CIfrOpHeader
{
1806 ) : CIfrObj (EFI_IFR_DUP_OP
, (CHAR8
**)&mDup
),
1807 CIfrOpHeader (EFI_IFR_DUP_OP
, &mDup
->Header
) {
1812 class CIfrEqIdId
: public CIfrObj
, public CIfrOpHeader
{
1814 EFI_IFR_EQ_ID_ID
*mEqIdId
;
1819 ) : CIfrObj (EFI_IFR_EQ_ID_ID_OP
, (CHAR8
**)&mEqIdId
),
1820 CIfrOpHeader (EFI_IFR_EQ_ID_ID_OP
, &mEqIdId
->Header
) {
1822 mEqIdId
->QuestionId1
= EFI_QUESTION_ID_INVALID
;
1823 mEqIdId
->QuestionId2
= EFI_QUESTION_ID_INVALID
;
1826 VOID
SetQuestionId1 (
1827 IN EFI_QUESTION_ID QuestionId
,
1831 if (QuestionId
!= EFI_QUESTION_ID_INVALID
) {
1832 mEqIdId
->QuestionId1
= QuestionId
;
1834 gCFormPkg
.AssignPending (VarIdStr
, (VOID
*)(&mEqIdId
->QuestionId1
), sizeof (EFI_QUESTION_ID
), LineNo
, NO_QST_REFED
);
1838 VOID
SetQuestionId2 (
1839 IN EFI_QUESTION_ID QuestionId
,
1843 if (QuestionId
!= EFI_QUESTION_ID_INVALID
) {
1844 mEqIdId
->QuestionId2
= QuestionId
;
1846 gCFormPkg
.AssignPending (VarIdStr
, (VOID
*)(&mEqIdId
->QuestionId2
), sizeof (EFI_QUESTION_ID
), LineNo
, NO_QST_REFED
);
1851 class CIfrEqIdVal
: public CIfrObj
, public CIfrOpHeader
{
1853 EFI_IFR_EQ_ID_VAL
*mEqIdVal
;
1858 ) : CIfrObj (EFI_IFR_EQ_ID_VAL_OP
, (CHAR8
**)&mEqIdVal
),
1859 CIfrOpHeader (EFI_IFR_EQ_ID_VAL_OP
, &mEqIdVal
->Header
) {
1861 mEqIdVal
->QuestionId
= EFI_QUESTION_ID_INVALID
;
1864 VOID
SetQuestionId (
1865 IN EFI_QUESTION_ID QuestionId
,
1869 if (QuestionId
!= EFI_QUESTION_ID_INVALID
) {
1870 mEqIdVal
->QuestionId
= QuestionId
;
1872 gCFormPkg
.AssignPending (VarIdStr
, (VOID
*)(&mEqIdVal
->QuestionId
), sizeof (EFI_QUESTION_ID
), LineNo
, NO_QST_REFED
);
1876 VOID
SetValue (IN UINT16 Value
) {
1877 mEqIdVal
->Value
= Value
;
1881 class CIfrEqIdList
: public CIfrObj
, public CIfrOpHeader
{
1883 EFI_IFR_EQ_ID_VAL_LIST
*mEqIdVList
;
1888 ) : CIfrObj (EFI_IFR_EQ_ID_VAL_LIST_OP
, (CHAR8
**)&mEqIdVList
, sizeof (EFI_IFR_EQ_ID_VAL_LIST
), TRUE
),
1889 CIfrOpHeader (EFI_IFR_EQ_ID_VAL_LIST_OP
, &mEqIdVList
->Header
) {
1891 mEqIdVList
->QuestionId
= EFI_QUESTION_ID_INVALID
;
1892 mEqIdVList
->ListLength
= 0;
1893 mEqIdVList
->ValueList
[0] = 0;
1896 VOID
UpdateIfrBuffer (
1898 _EMIT_PENDING_OBJ();
1899 mEqIdVList
= (EFI_IFR_EQ_ID_VAL_LIST
*) GetObjBinAddr();
1900 UpdateHeader (&mEqIdVList
->Header
);
1903 VOID
SetQuestionId (
1904 IN EFI_QUESTION_ID QuestionId
,
1908 if (QuestionId
!= EFI_QUESTION_ID_INVALID
) {
1909 mEqIdVList
->QuestionId
= QuestionId
;
1911 gCFormPkg
.AssignPending (VarIdStr
, (VOID
*)(&mEqIdVList
->QuestionId
), sizeof (EFI_QUESTION_ID
), LineNo
, NO_QST_REFED
);
1915 VOID
SetListLength (IN UINT16 ListLength
) {
1916 mEqIdVList
->ListLength
= ListLength
;
1919 VOID
SetValueList (IN UINT16 Index
, IN UINT16 Value
) {
1921 mEqIdVList
->ValueList
[0] = Value
;
1925 if (ExpendObjBin (sizeof (UINT16
)) ==TRUE
) {
1926 IncLength (sizeof (UINT16
));
1927 mEqIdVList
->ValueList
[Index
] = Value
;
1932 class CIfrQuestionRef1
: public CIfrObj
, public CIfrOpHeader
{
1934 EFI_IFR_QUESTION_REF1
*mQuestionRef1
;
1939 ) : CIfrObj (EFI_IFR_QUESTION_REF1_OP
, (CHAR8
**)&mQuestionRef1
),
1940 CIfrOpHeader (EFI_IFR_QUESTION_REF1_OP
, &mQuestionRef1
->Header
) {
1942 mQuestionRef1
->QuestionId
= EFI_QUESTION_ID_INVALID
;
1945 VOID
SetQuestionId (
1946 IN EFI_QUESTION_ID QuestionId
,
1950 if (QuestionId
!= EFI_QUESTION_ID_INVALID
) {
1951 mQuestionRef1
->QuestionId
= QuestionId
;
1953 gCFormPkg
.AssignPending (VarIdStr
, (VOID
*)(&mQuestionRef1
->QuestionId
), sizeof (EFI_QUESTION_ID
), LineNo
, NO_QST_REFED
);
1958 class CIfrQuestionRef2
: public CIfrObj
, public CIfrOpHeader
{
1960 EFI_IFR_QUESTION_REF2
*mQuestionRef2
;
1965 ) : CIfrObj (EFI_IFR_QUESTION_REF2_OP
, (CHAR8
**)&mQuestionRef2
),
1966 CIfrOpHeader (EFI_IFR_QUESTION_REF2_OP
, &mQuestionRef2
->Header
) {
1971 class CIfrQuestionRef3
: public CIfrObj
, public CIfrOpHeader
{
1973 EFI_IFR_QUESTION_REF3
*mQuestionRef3
;
1978 ) : CIfrObj (EFI_IFR_QUESTION_REF3_OP
, (CHAR8
**)&mQuestionRef3
),
1979 CIfrOpHeader (EFI_IFR_QUESTION_REF3_OP
, &mQuestionRef3
->Header
) {
1984 class CIfrQuestionRef3_2
: public CIfrObj
, public CIfrOpHeader
{
1986 EFI_IFR_QUESTION_REF3_2
*mQuestionRef3_2
;
1989 CIfrQuestionRef3_2 (
1991 ) : CIfrObj (EFI_IFR_QUESTION_REF3_OP
, (CHAR8
**)&mQuestionRef3_2
, sizeof (EFI_IFR_QUESTION_REF3_2
)),
1992 CIfrOpHeader (EFI_IFR_QUESTION_REF3_OP
, &mQuestionRef3_2
->Header
, sizeof (EFI_IFR_QUESTION_REF3_2
)) {
1994 mQuestionRef3_2
->DevicePath
= EFI_STRING_ID_INVALID
;
1997 VOID
SetDevicePath (IN EFI_STRING_ID DevicePath
) {
1998 mQuestionRef3_2
->DevicePath
= DevicePath
;
2002 class CIfrQuestionRef3_3
: public CIfrObj
, public CIfrOpHeader
{
2004 EFI_IFR_QUESTION_REF3_3
*mQuestionRef3_3
;
2007 CIfrQuestionRef3_3 (
2009 ) : CIfrObj (EFI_IFR_QUESTION_REF3_OP
, (CHAR8
**)&mQuestionRef3_3
, sizeof (EFI_IFR_QUESTION_REF3_3
)),
2010 CIfrOpHeader (EFI_IFR_QUESTION_REF3_OP
, &mQuestionRef3_3
->Header
, sizeof (EFI_IFR_QUESTION_REF3_3
)) {
2012 mQuestionRef3_3
->DevicePath
= EFI_STRING_ID_INVALID
;
2013 memset (&mQuestionRef3_3
->Guid
, 0, sizeof (EFI_GUID
));
2016 VOID
SetDevicePath (IN EFI_STRING_ID DevicePath
) {
2017 mQuestionRef3_3
->DevicePath
= DevicePath
;
2020 VOID
SetGuid (IN EFI_GUID
*Guid
) {
2021 mQuestionRef3_3
->Guid
= *Guid
;
2025 class CIfrRuleRef
: public CIfrObj
, public CIfrOpHeader
{
2027 EFI_IFR_RULE_REF
*mRuleRef
;
2032 ) : CIfrObj (EFI_IFR_RULE_REF_OP
, (CHAR8
**)&mRuleRef
),
2033 CIfrOpHeader (EFI_IFR_RULE_REF_OP
, &mRuleRef
->Header
) {
2035 mRuleRef
->RuleId
= EFI_RULE_ID_INVALID
;
2038 VOID
SetRuleId (IN UINT8 RuleId
) {
2039 mRuleRef
->RuleId
= RuleId
;
2043 class CIfrStringRef1
: public CIfrObj
, public CIfrOpHeader
{
2045 EFI_IFR_STRING_REF1
*mStringRef1
;
2050 ) : CIfrObj (EFI_IFR_STRING_REF1_OP
, (CHAR8
**)&mStringRef1
),
2051 CIfrOpHeader (EFI_IFR_STRING_REF1_OP
, &mStringRef1
->Header
) {
2053 mStringRef1
->StringId
= EFI_STRING_ID_INVALID
;
2056 VOID
SetStringId (IN EFI_STRING_ID StringId
) {
2057 mStringRef1
->StringId
= StringId
;
2061 class CIfrStringRef2
: public CIfrObj
, public CIfrOpHeader
{
2063 EFI_IFR_STRING_REF2
*mStringRef2
;
2068 ) : CIfrObj (EFI_IFR_STRING_REF2_OP
, (CHAR8
**)&mStringRef2
),
2069 CIfrOpHeader (EFI_IFR_STRING_REF2_OP
, &mStringRef2
->Header
) {
2074 class CIfrThis
: public CIfrObj
, public CIfrOpHeader
{
2076 EFI_IFR_THIS
*mThis
;
2081 ) : CIfrObj (EFI_IFR_THIS_OP
, (CHAR8
**)&mThis
),
2082 CIfrOpHeader (EFI_IFR_THIS_OP
, &mThis
->Header
) {
2087 class CIfrSecurity
: public CIfrObj
, public CIfrOpHeader
{
2089 EFI_IFR_SECURITY
*mSecurity
;
2094 ) : CIfrObj (EFI_IFR_SECURITY_OP
, (CHAR8
**)&mSecurity
),
2095 CIfrOpHeader (EFI_IFR_SECURITY_OP
, &mSecurity
->Header
) {
2097 memset (&mSecurity
->Permissions
, 0, sizeof (EFI_GUID
));
2100 VOID
SetPermissions (IN EFI_GUID
*Permissions
) {
2101 memcpy (&mSecurity
->Permissions
, Permissions
, sizeof (EFI_GUID
));
2105 class CIfrUint8
: public CIfrObj
, public CIfrOpHeader
{
2107 EFI_IFR_UINT8
*mUint8
;
2112 ) : CIfrObj (EFI_IFR_UINT8_OP
, (CHAR8
**)&mUint8
),
2113 CIfrOpHeader (EFI_IFR_UINT8_OP
, &mUint8
->Header
) {
2117 VOID
SetValue (IN UINT8 Value
) {
2118 mUint8
->Value
= Value
;
2122 class CIfrUint16
: public CIfrObj
, public CIfrOpHeader
{
2124 EFI_IFR_UINT16
*mUint16
;
2129 ) : CIfrObj (EFI_IFR_UINT16_OP
, (CHAR8
**)&mUint16
),
2130 CIfrOpHeader (EFI_IFR_UINT16_OP
, &mUint16
->Header
) {
2134 VOID
SetValue (IN UINT16 Value
) {
2135 mUint16
->Value
= Value
;
2139 class CIfrUint32
: public CIfrObj
, public CIfrOpHeader
{
2141 EFI_IFR_UINT32
*mUint32
;
2146 ) : CIfrObj (EFI_IFR_UINT32_OP
, (CHAR8
**)&mUint32
),
2147 CIfrOpHeader (EFI_IFR_UINT32_OP
, &mUint32
->Header
) {
2151 VOID
SetValue (IN UINT32 Value
) {
2152 mUint32
->Value
= Value
;
2156 class CIfrUint64
: public CIfrObj
, public CIfrOpHeader
{
2158 EFI_IFR_UINT64
*mUint64
;
2163 ) : CIfrObj (EFI_IFR_UINT64_OP
, (CHAR8
**)&mUint64
),
2164 CIfrOpHeader (EFI_IFR_UINT64_OP
, &mUint64
->Header
) {
2168 VOID
SetValue (IN UINT64 Value
) {
2169 mUint64
->Value
= Value
;
2173 class CIfrTrue
: public CIfrObj
, public CIfrOpHeader
{
2175 EFI_IFR_TRUE
*mTrue
;
2180 ) : CIfrObj (EFI_IFR_TRUE_OP
, (CHAR8
**)&mTrue
),
2181 CIfrOpHeader (EFI_IFR_TRUE_OP
, &mTrue
->Header
) {
2186 class CIfrFalse
: public CIfrObj
, public CIfrOpHeader
{
2188 EFI_IFR_FALSE
*mFalse
;
2193 ) : CIfrObj (EFI_IFR_FALSE_OP
, (CHAR8
**)&mFalse
),
2194 CIfrOpHeader (EFI_IFR_FALSE_OP
, &mFalse
->Header
) {
2199 class CIfrOne
: public CIfrObj
, public CIfrOpHeader
{
2206 ) : CIfrObj (EFI_IFR_ONE_OP
, (CHAR8
**)&mOne
),
2207 CIfrOpHeader (EFI_IFR_ONE_OP
, &mOne
->Header
) {
2212 class CIfrOnes
: public CIfrObj
, public CIfrOpHeader
{
2214 EFI_IFR_ONES
*mOnes
;
2219 ) : CIfrObj (EFI_IFR_ONES_OP
, (CHAR8
**)&mOnes
),
2220 CIfrOpHeader (EFI_IFR_ONES_OP
, &mOnes
->Header
) {
2225 class CIfrZero
: public CIfrObj
, public CIfrOpHeader
{
2227 EFI_IFR_ZERO
*mZero
;
2232 ) : CIfrObj (EFI_IFR_ZERO_OP
, (CHAR8
**)&mZero
),
2233 CIfrOpHeader (EFI_IFR_ZERO_OP
, &mZero
->Header
) {
2238 class CIfrUndefined
: public CIfrObj
, public CIfrOpHeader
{
2240 EFI_IFR_UNDEFINED
*mUndefined
;
2245 ) : CIfrObj (EFI_IFR_UNDEFINED_OP
, (CHAR8
**)&mUndefined
),
2246 CIfrOpHeader (EFI_IFR_UNDEFINED_OP
, &mUndefined
->Header
) {
2251 class CIfrVersion
: public CIfrObj
, public CIfrOpHeader
{
2253 EFI_IFR_VERSION
*mVersion
;
2258 ) : CIfrObj (EFI_IFR_VERSION_OP
, (CHAR8
**)&mVersion
),
2259 CIfrOpHeader (EFI_IFR_VERSION_OP
, &mVersion
->Header
) {
2264 class CIfrLength
: public CIfrObj
, public CIfrOpHeader
{
2266 EFI_IFR_LENGTH
*mLength
;
2271 ) : CIfrObj (EFI_IFR_LENGTH_OP
, (CHAR8
**)&mLength
),
2272 CIfrOpHeader (EFI_IFR_LENGTH_OP
, &mLength
->Header
) {
2277 class CIfrNot
: public CIfrObj
, public CIfrOpHeader
{
2284 ) : CIfrObj (EFI_IFR_NOT_OP
, (CHAR8
**)&mNot
),
2285 CIfrOpHeader (EFI_IFR_NOT_OP
, &mNot
->Header
) {
2290 class CIfrBitWiseNot
: public CIfrObj
, public CIfrOpHeader
{
2292 EFI_IFR_BITWISE_NOT
*mBitWise
;
2297 ) : CIfrObj (EFI_IFR_BITWISE_NOT_OP
, (CHAR8
**)&mBitWise
),
2298 CIfrOpHeader (EFI_IFR_BITWISE_NOT_OP
, &mBitWise
->Header
) {
2303 class CIfrToBoolean
: public CIfrObj
, public CIfrOpHeader
{
2305 EFI_IFR_TO_BOOLEAN
*mToBoolean
;
2310 ) : CIfrObj (EFI_IFR_TO_BOOLEAN_OP
, (CHAR8
**)&mToBoolean
),
2311 CIfrOpHeader (EFI_IFR_TO_BOOLEAN_OP
, &mToBoolean
->Header
) {
2316 class CIfrToString
: public CIfrObj
, public CIfrOpHeader
{
2318 EFI_IFR_TO_STRING
*mToString
;
2323 ) : CIfrObj (EFI_IFR_TO_STRING_OP
, (CHAR8
**)&mToString
),
2324 CIfrOpHeader (EFI_IFR_TO_STRING_OP
, &mToString
->Header
) {
2328 VOID
SetFormat (IN UINT8 Format
) {
2329 mToString
->Format
= Format
;
2333 class CIfrToUint
: public CIfrObj
, public CIfrOpHeader
{
2335 EFI_IFR_TO_UINT
*mToUint
;
2340 ) : CIfrObj (EFI_IFR_TO_UINT_OP
, (CHAR8
**)&mToUint
),
2341 CIfrOpHeader (EFI_IFR_TO_UINT_OP
, &mToUint
->Header
) {
2346 class CIfrToUpper
: public CIfrObj
, public CIfrOpHeader
{
2348 EFI_IFR_TO_UPPER
*mToUpper
;
2353 ) : CIfrObj (EFI_IFR_TO_UPPER_OP
, (CHAR8
**)&mToUpper
),
2354 CIfrOpHeader (EFI_IFR_TO_UPPER_OP
, &mToUpper
->Header
) {
2359 class CIfrToLower
: public CIfrObj
, public CIfrOpHeader
{
2361 EFI_IFR_TO_LOWER
*mToLower
;
2366 ) : CIfrObj (EFI_IFR_TO_LOWER_OP
, (CHAR8
**)&mToLower
),
2367 CIfrOpHeader (EFI_IFR_TO_LOWER_OP
, &mToLower
->Header
) {
2372 class CIfrAdd
: public CIfrObj
, public CIfrOpHeader
{
2379 ) : CIfrObj (EFI_IFR_ADD_OP
, (CHAR8
**)&mAdd
),
2380 CIfrOpHeader (EFI_IFR_ADD_OP
, &mAdd
->Header
) {
2385 class CIfrBitWiseAnd
: public CIfrObj
, public CIfrOpHeader
{
2387 EFI_IFR_BITWISE_AND
*mBitWiseAnd
;
2392 ) : CIfrObj (EFI_IFR_BITWISE_AND_OP
, (CHAR8
**)&mBitWiseAnd
),
2393 CIfrOpHeader (EFI_IFR_BITWISE_AND_OP
, &mBitWiseAnd
->Header
) {
2398 class CIfrBitWiseOr
: public CIfrObj
, public CIfrOpHeader
{
2400 EFI_IFR_BITWISE_OR
*mBitWiseOr
;
2405 ) : CIfrObj (EFI_IFR_BITWISE_OR_OP
, (CHAR8
**)&mBitWiseOr
),
2406 CIfrOpHeader (EFI_IFR_BITWISE_OR_OP
, &mBitWiseOr
->Header
) {
2411 class CIfrAnd
: public CIfrObj
, public CIfrOpHeader
{
2418 ) : CIfrObj (EFI_IFR_AND_OP
, (CHAR8
**)&mAnd
),
2419 CIfrOpHeader (EFI_IFR_AND_OP
, &mAnd
->Header
) {
2424 class CIfrCatenate
: public CIfrObj
, public CIfrOpHeader
{
2426 EFI_IFR_CATENATE
*mCatenate
;
2431 ) : CIfrObj (EFI_IFR_CATENATE_OP
, (CHAR8
**)&mCatenate
),
2432 CIfrOpHeader (EFI_IFR_CATENATE_OP
, &mCatenate
->Header
) {
2437 class CIfrDivide
: public CIfrObj
, public CIfrOpHeader
{
2439 EFI_IFR_DIVIDE
*mDivide
;
2444 ) : CIfrObj (EFI_IFR_DIVIDE_OP
, (CHAR8
**)&mDivide
),
2445 CIfrOpHeader (EFI_IFR_DIVIDE_OP
, &mDivide
->Header
) {
2450 class CIfrEqual
: public CIfrObj
, public CIfrOpHeader
{
2452 EFI_IFR_EQUAL
*mEqual
;
2457 ) : CIfrObj (EFI_IFR_EQUAL_OP
, (CHAR8
**)&mEqual
),
2458 CIfrOpHeader (EFI_IFR_EQUAL_OP
, &mEqual
->Header
) {
2463 class CIfrGreaterEqual
: public CIfrObj
, public CIfrOpHeader
{
2465 EFI_IFR_GREATER_EQUAL
*mGreaterEqual
;
2470 ) : CIfrObj (EFI_IFR_GREATER_EQUAL_OP
, (CHAR8
**)&mGreaterEqual
),
2471 CIfrOpHeader (EFI_IFR_GREATER_EQUAL_OP
, &mGreaterEqual
->Header
) {
2476 class CIfrGreaterThan
: public CIfrObj
, public CIfrOpHeader
{
2478 EFI_IFR_GREATER_THAN
*mGreaterThan
;
2483 ) : CIfrObj (EFI_IFR_GREATER_THAN_OP
, (CHAR8
**)&mGreaterThan
),
2484 CIfrOpHeader (EFI_IFR_GREATER_THAN_OP
, &mGreaterThan
->Header
) {
2489 class CIfrLessEqual
: public CIfrObj
, public CIfrOpHeader
{
2491 EFI_IFR_LESS_EQUAL
*mLessEqual
;
2496 ) : CIfrObj (EFI_IFR_LESS_EQUAL_OP
, (CHAR8
**)&mLessEqual
),
2497 CIfrOpHeader (EFI_IFR_LESS_EQUAL_OP
, &mLessEqual
->Header
) {
2502 class CIfrLessThan
: public CIfrObj
, public CIfrOpHeader
{
2504 EFI_IFR_LESS_THAN
*mLessThan
;
2509 ) : CIfrObj (EFI_IFR_LESS_THAN_OP
, (CHAR8
**)&mLessThan
),
2510 CIfrOpHeader (EFI_IFR_LESS_THAN_OP
, &mLessThan
->Header
) {
2515 class CIfrMap
: public CIfrObj
, public CIfrOpHeader
{
2522 ) : CIfrObj (EFI_IFR_MAP_OP
, (CHAR8
**)&mMap
),
2523 CIfrOpHeader (EFI_IFR_MAP_OP
, &mMap
->Header
) {
2528 class CIfrMatch
: public CIfrObj
, public CIfrOpHeader
{
2530 EFI_IFR_MATCH
*mMatch
;
2535 ) : CIfrObj (EFI_IFR_MATCH_OP
, (CHAR8
**)&mMatch
),
2536 CIfrOpHeader (EFI_IFR_MATCH_OP
, &mMatch
->Header
) {
2541 class CIfrMultiply
: public CIfrObj
, public CIfrOpHeader
{
2543 EFI_IFR_MULTIPLY
*mMultiply
;
2548 ) : CIfrObj (EFI_IFR_MULTIPLY_OP
, (CHAR8
**)&mMultiply
),
2549 CIfrOpHeader (EFI_IFR_MULTIPLY_OP
, &mMultiply
->Header
) {
2554 class CIfrModulo
: public CIfrObj
, public CIfrOpHeader
{
2556 EFI_IFR_MODULO
*mModulo
;
2561 ) : CIfrObj (EFI_IFR_MODULO_OP
, (CHAR8
**)&mModulo
),
2562 CIfrOpHeader (EFI_IFR_MODULO_OP
, &mModulo
->Header
) {
2567 class CIfrNotEqual
: public CIfrObj
, public CIfrOpHeader
{
2569 EFI_IFR_NOT_EQUAL
*mNotEqual
;
2574 ) : CIfrObj (EFI_IFR_NOT_EQUAL_OP
, (CHAR8
**)&mNotEqual
),
2575 CIfrOpHeader (EFI_IFR_NOT_EQUAL_OP
, &mNotEqual
->Header
) {
2580 class CIfrOr
: public CIfrObj
, public CIfrOpHeader
{
2587 ) : CIfrObj (EFI_IFR_OR_OP
, (CHAR8
**)&mOr
),
2588 CIfrOpHeader (EFI_IFR_OR_OP
, &mOr
->Header
) {
2593 class CIfrShiftLeft
: public CIfrObj
, public CIfrOpHeader
{
2595 EFI_IFR_SHIFT_LEFT
*mShiftLeft
;
2600 ) : CIfrObj (EFI_IFR_SHIFT_LEFT_OP
, (CHAR8
**)&mShiftLeft
),
2601 CIfrOpHeader (EFI_IFR_SHIFT_LEFT_OP
, &mShiftLeft
->Header
) {
2606 class CIfrShiftRight
: public CIfrObj
, public CIfrOpHeader
{
2608 EFI_IFR_SHIFT_RIGHT
*mShiftRight
;
2613 ) : CIfrObj (EFI_IFR_SHIFT_RIGHT_OP
, (CHAR8
**)&mShiftRight
),
2614 CIfrOpHeader (EFI_IFR_SHIFT_RIGHT_OP
, &mShiftRight
->Header
) {
2619 class CIfrSubtract
: public CIfrObj
, public CIfrOpHeader
{
2621 EFI_IFR_SUBTRACT
*mSubtract
;
2626 ) : CIfrObj (EFI_IFR_SUBTRACT_OP
, (CHAR8
**)&mSubtract
),
2627 CIfrOpHeader (EFI_IFR_SUBTRACT_OP
, &mSubtract
->Header
) {
2632 class CIfrConditional
: public CIfrObj
, public CIfrOpHeader
{
2634 EFI_IFR_CONDITIONAL
*mConditional
;
2639 ) : CIfrObj (EFI_IFR_CONDITIONAL_OP
, (CHAR8
**)&mConditional
),
2640 CIfrOpHeader (EFI_IFR_CONDITIONAL_OP
, &mConditional
->Header
) {
2645 class CIfrFind
: public CIfrObj
, public CIfrOpHeader
{
2647 EFI_IFR_FIND
*mFind
;
2652 ) : CIfrObj (EFI_IFR_FIND_OP
, (CHAR8
**)&mFind
),
2653 CIfrOpHeader (EFI_IFR_FIND_OP
, &mFind
->Header
) {
2657 VOID
SetFormat (IN UINT8 Format
) {
2658 mFind
->Format
= Format
;
2662 class CIfrMid
: public CIfrObj
, public CIfrOpHeader
{
2669 ) : CIfrObj (EFI_IFR_MID_OP
, (CHAR8
**)&mMid
),
2670 CIfrOpHeader (EFI_IFR_MID_OP
, &mMid
->Header
) {
2675 class CIfrToken
: public CIfrObj
, public CIfrOpHeader
{
2677 EFI_IFR_TOKEN
*mToken
;
2682 ) : CIfrObj (EFI_IFR_TOKEN_OP
, (CHAR8
**)&mToken
),
2683 CIfrOpHeader (EFI_IFR_TOKEN_OP
, &mToken
->Header
) {
2688 class CIfrSpan
: public CIfrObj
, public CIfrOpHeader
{
2690 EFI_IFR_SPAN
*mSpan
;
2695 ) : CIfrObj (EFI_IFR_SPAN_OP
, (CHAR8
**)&mSpan
),
2696 CIfrOpHeader (EFI_IFR_SPAN_OP
, &mSpan
->Header
) {
2698 mSpan
->Flags
= EFI_IFR_FLAGS_FIRST_MATCHING
;
2701 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 LFlags
) {
2702 if (_IS_EQUAL (LFlags
, EFI_IFR_FLAGS_FIRST_MATCHING
)) {
2703 mSpan
->Flags
|= EFI_IFR_FLAGS_FIRST_MATCHING
;
2704 } else if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_FLAGS_FIRST_NON_MATCHING
)) {
2705 mSpan
->Flags
|= EFI_IFR_FLAGS_FIRST_NON_MATCHING
;
2708 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;