3 The definition of CFormPkg's member function
5 Copyright (c) 2004 - 2008, Intel Corporation
6 All rights reserved. This program and the accompanying materials
7 are licensed and made available under the terms and conditions of the BSD License
8 which accompanies this distribution. The full text of the license may be found at
9 http://opensource.org/licenses/bsd-license.php
11 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
12 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
16 #ifndef _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 CHAR8
*);
87 VOID
SetAddrAndLen (IN VOID
*, IN UINT32
);
88 VOID
AssignValue (IN VOID
*, IN UINT32
);
89 CHAR8
* GetKey (VOID
);
96 struct SBufferNode
*mNext
;
102 SBufferNode
*mBufferNodeQueueHead
;
103 SBufferNode
*mBufferNodeQueueTail
;
104 SBufferNode
*mCurrBufferNode
;
106 SBufferNode
*mReadBufferNode
;
107 UINT32 mReadBufferOffset
;
111 VOID
_WRITE_PKG_LINE (IN
FILE *, IN UINT32
, IN CHAR8
*, IN CHAR8
*, IN UINT32
);
112 VOID
_WRITE_PKG_END (IN
FILE *, IN UINT32
, IN CHAR8
*, IN CHAR8
*, IN UINT32
);
115 SPendingAssign
*PendingAssignList
;
118 CFormPkg (IN UINT32 BufferSize
);
121 CHAR8
* IfrBinBufferGet (IN UINT32
);
122 inline UINT32
GetPkgLength (VOID
);
125 UINT32
Read (IN CHAR8
*, IN UINT32
);
128 EFI_VFR_RETURN_CODE
BuildPkgHdr (OUT EFI_HII_PACKAGE_HEADER
**);
129 EFI_VFR_RETURN_CODE
BuildPkg (IN
FILE *, IN PACKAGE_DATA
*PkgData
= NULL
);
130 EFI_VFR_RETURN_CODE
BuildPkg (OUT PACKAGE_DATA
&);
131 EFI_VFR_RETURN_CODE
GenCFile (IN CHAR8
*, IN
FILE *, IN PACKAGE_DATA
*PkgData
= NULL
);
134 EFI_VFR_RETURN_CODE
AssignPending (IN CHAR8
*, IN VOID
*, IN UINT32
, IN UINT32
, IN CHAR8
*Msg
= NULL
);
135 VOID
DoPendingAssign (IN CHAR8
*, IN VOID
*, IN UINT32
);
136 bool HavePendingUnassigned (VOID
);
137 VOID
PendingAssignPrintAll (VOID
);
138 EFI_VFR_RETURN_CODE
DeclarePendingQuestion (
139 IN CVfrVarDataTypeDB
&lCVfrVarDataTypeDB
,
140 IN CVfrDataStorage
&lCVfrDataStorage
,
141 IN CVfrQuestionDB
&lCVfrQuestionDB
,
142 IN EFI_GUID
*LocalFormSetGuid
,
147 extern CFormPkg gCFormPkg
;
160 #define EFI_IFR_RECORDINFO_IDX_INVALUD 0xFFFFFF
161 #define EFI_IFR_RECORDINFO_IDX_START 0x0
163 class CIfrRecordInfoDB
{
167 SIfrRecord
*mIfrRecordListHead
;
168 SIfrRecord
*mIfrRecordListTail
;
170 SIfrRecord
* GetRecordInfoFromIdx (IN UINT32
);
171 BOOLEAN
CheckQuestionOpCode (IN UINT8
);
172 BOOLEAN
CheckIdOpCode (IN UINT8
);
173 EFI_QUESTION_ID
GetOpcodeQuestionId (IN EFI_IFR_OP_HEADER
*);
175 CIfrRecordInfoDB (VOID
);
176 ~CIfrRecordInfoDB (VOID
);
178 inline VOID
TurnOn (VOID
) {
182 inline VOID
TurnOff (VOID
) {
186 UINT32
IfrRecordRegister (IN UINT32
, IN CHAR8
*, IN UINT8
, IN UINT32
);
187 VOID
IfrRecordInfoUpdate (IN UINT32
, IN UINT32
, IN CHAR8
*, IN UINT8
, IN UINT32
);
188 VOID
IfrRecordOutput (IN
FILE *, IN UINT32 LineNo
);
189 VOID
IfrRecordOutput (OUT PACKAGE_DATA
&);
190 EFI_VFR_RETURN_CODE
IfrRecordAdjust (VOID
);
193 extern CIfrRecordInfoDB gCIfrRecordInfoDB
;
196 * The definition of CIfrObj
198 extern bool gCreateOp
;
211 CIfrObj (IN UINT8 OpCode
, OUT CHAR8
**IfrObj
= NULL
, IN UINT8 ObjBinLen
= 0, IN BOOLEAN DelayEmit
= FALSE
);
212 virtual ~CIfrObj(VOID
);
214 VOID
_EMIT_PENDING_OBJ (VOID
);
216 inline VOID
SetLineNo (IN UINT32 LineNo
) {
220 inline CHAR8
* GetObjBinAddr (VOID
) {
224 inline UINT8
GetObjBinLen (VOID
) {
228 inline bool ExpendObjBin (IN UINT8 Size
) {
229 if ((mDelayEmit
== TRUE
) && ((mObjBinLen
+ Size
) > mObjBinLen
)) {
239 * The definition of CIfrOpHeader
243 EFI_IFR_OP_HEADER
*mHeader
;
246 CIfrOpHeader (IN UINT8 OpCode
, IN VOID
*StartAddr
, IN UINT8 Length
= 0);
247 CIfrOpHeader (IN CIfrOpHeader
&);
249 VOID
IncLength (UINT8 Size
) {
250 if ((mHeader
->Length
+ Size
) > mHeader
->Length
) {
251 mHeader
->Length
+= Size
;
255 VOID
DecLength (UINT8 Size
) {
256 if (mHeader
->Length
>= Size
) {
262 return mHeader
->Length
;
266 return mHeader
->Scope
;
269 VOID
SetScope (IN UINT8 Scope
) {
270 mHeader
->Scope
= Scope
;
273 VOID
UpdateHeader (IN EFI_IFR_OP_HEADER
*Header
) {
278 extern UINT8 gScopeCount
;
281 * The definition of CIfrStatementHeader
283 class CIfrStatementHeader
{
285 EFI_IFR_STATEMENT_HEADER
*mHeader
;
288 CIfrStatementHeader (
289 IN EFI_IFR_STATEMENT_HEADER
*StartAddr
290 ) : mHeader ((EFI_IFR_STATEMENT_HEADER
*)StartAddr
) {
292 mHeader
->Help
= EFI_STRING_ID_INVALID
;
293 mHeader
->Prompt
= EFI_STRING_ID_INVALID
;
296 EFI_IFR_STATEMENT_HEADER
*GetStatementHeader () {
300 VOID
SetPrompt (IN EFI_STRING_ID Prompt
) {
301 mHeader
->Prompt
= Prompt
;
304 VOID
SetHelp (IN EFI_STRING_ID Help
) {
305 mHeader
->Help
= Help
;
310 * The definition of CIfrQuestionHeader
312 #define EFI_IFR_QUESTION_FLAG_DEFAULT 0
314 class CIfrQuestionHeader
: public CIfrStatementHeader
{
316 EFI_IFR_QUESTION_HEADER
*mHeader
;
318 EFI_IFR_STATEMENT_HEADER
* QH2SH (EFI_IFR_QUESTION_HEADER
*Qheader
) {
319 return &(Qheader
)->Header
;
323 EFI_QUESTION_ID
QUESTION_ID (VOID
) {
324 return mHeader
->QuestionId
;
327 EFI_VARSTORE_ID
VARSTORE_ID (VOID
) {
328 return mHeader
->VarStoreId
;
331 VOID
VARSTORE_INFO (OUT EFI_VARSTORE_INFO
*Info
) {
333 Info
->mVarStoreId
= mHeader
->VarStoreId
;
334 memcpy (&Info
->mVarStoreId
, &mHeader
->VarStoreInfo
, sizeof (Info
->mVarStoreId
));
339 return mHeader
->Flags
;
344 IN EFI_IFR_QUESTION_HEADER
*StartAddr
,
345 IN UINT8 Flags
= EFI_IFR_QUESTION_FLAG_DEFAULT
346 ) : CIfrStatementHeader (QH2SH(StartAddr
)) {
348 mHeader
->QuestionId
= EFI_QUESTION_ID_INVALID
;
349 mHeader
->VarStoreId
= EFI_VARSTORE_ID_INVALID
;
350 mHeader
->VarStoreInfo
.VarName
= EFI_STRING_ID_INVALID
;
351 mHeader
->VarStoreInfo
.VarOffset
= EFI_VAROFFSET_INVALID
;
352 mHeader
->Flags
= Flags
;
355 VOID
SetQuestionId (IN EFI_QUESTION_ID QuestionId
) {
356 mHeader
->QuestionId
= QuestionId
;
359 VOID
SetVarStoreInfo (IN EFI_VARSTORE_INFO
*Info
) {
360 mHeader
->VarStoreId
= Info
->mVarStoreId
;
361 mHeader
->VarStoreInfo
.VarName
= Info
->mInfo
.mVarName
;
362 mHeader
->VarStoreInfo
.VarOffset
= Info
->mInfo
.mVarOffset
;
365 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 Flags
) {
366 if (_FLAG_TEST_AND_CLEAR (Flags
, EFI_IFR_FLAG_READ_ONLY
)) {
367 mHeader
->Flags
|= EFI_IFR_FLAG_READ_ONLY
;
370 _FLAG_CLEAR (Flags
, 0x02);
372 if (_FLAG_TEST_AND_CLEAR (Flags
, EFI_IFR_FLAG_CALLBACK
)) {
373 mHeader
->Flags
|= EFI_IFR_FLAG_CALLBACK
;
377 // ignore NVAccessFlag
379 _FLAG_CLEAR (Flags
, 0x08);
381 if (_FLAG_TEST_AND_CLEAR (Flags
, EFI_IFR_FLAG_RESET_REQUIRED
)) {
382 mHeader
->Flags
|= EFI_IFR_FLAG_RESET_REQUIRED
;
386 // Set LateCheck Flag to compatible for framework flag
387 // but it uses 0x20 as its flag, if in the future UEFI may take this flag
389 if (_FLAG_TEST_AND_CLEAR (Flags
, 0x20)) {
390 mHeader
->Flags
|= 0x20;
393 if (_FLAG_TEST_AND_CLEAR (Flags
, EFI_IFR_FLAG_OPTIONS_ONLY
)) {
394 mHeader
->Flags
|= EFI_IFR_FLAG_OPTIONS_ONLY
;
397 return _FLAGS_ZERO (Flags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
401 static CIfrQuestionHeader
*gCurrentQuestion
= NULL
;
404 * The definition of CIfrMinMaxStepData
406 class CIfrMinMaxStepData
{
408 MINMAXSTEP_DATA
*mMinMaxStepData
;
411 CIfrMinMaxStepData (MINMAXSTEP_DATA
*DataAddr
) : mMinMaxStepData (DataAddr
) {
412 mMinMaxStepData
->u64
.MinValue
= 0;
413 mMinMaxStepData
->u64
.MaxValue
= 0;
414 mMinMaxStepData
->u64
.Step
= 0;
417 VOID
SetMinMaxStepData (IN UINT64 MinValue
, IN UINT64 MaxValue
, IN UINT64 Step
) {
418 mMinMaxStepData
->u64
.MinValue
= MinValue
;
419 mMinMaxStepData
->u64
.MaxValue
= MaxValue
;
420 mMinMaxStepData
->u64
.Step
= Step
;
423 VOID
SetMinMaxStepData (IN UINT32 MinValue
, IN UINT32 MaxValue
, IN UINT32 Step
) {
424 mMinMaxStepData
->u32
.MinValue
= MinValue
;
425 mMinMaxStepData
->u32
.MaxValue
= MaxValue
;
426 mMinMaxStepData
->u32
.Step
= Step
;
429 VOID
SetMinMaxStepData (IN UINT16 MinValue
, IN UINT16 MaxValue
, IN UINT16 Step
) {
430 mMinMaxStepData
->u16
.MinValue
= MinValue
;
431 mMinMaxStepData
->u16
.MaxValue
= MaxValue
;
432 mMinMaxStepData
->u16
.Step
= Step
;
435 VOID
SetMinMaxStepData (IN UINT8 MinValue
, IN UINT8 MaxValue
, IN UINT8 Step
) {
436 mMinMaxStepData
->u8
.MinValue
= MinValue
;
437 mMinMaxStepData
->u8
.MaxValue
= MaxValue
;
438 mMinMaxStepData
->u8
.Step
= Step
;
444 * The definition of all of the UEFI IFR Objects
446 class CIfrFormSet
: public CIfrObj
, public CIfrOpHeader
{
448 EFI_IFR_FORM_SET
*mFormSet
;
451 CIfrFormSet (UINT8 Size
) : CIfrObj (EFI_IFR_FORM_SET_OP
, (CHAR8
**)&mFormSet
, Size
),
452 CIfrOpHeader (EFI_IFR_FORM_SET_OP
, &mFormSet
->Header
, Size
) {
453 mFormSet
->Help
= EFI_STRING_ID_INVALID
;
454 mFormSet
->FormSetTitle
= EFI_STRING_ID_INVALID
;
456 memset (&mFormSet
->Guid
, 0, sizeof (EFI_GUID
));
459 VOID
SetGuid (IN EFI_GUID
*Guid
) {
460 memcpy (&mFormSet
->Guid
, Guid
, sizeof (EFI_GUID
));
463 VOID
SetFormSetTitle (IN EFI_STRING_ID FormSetTitle
) {
464 mFormSet
->FormSetTitle
= FormSetTitle
;
467 VOID
SetHelp (IN EFI_STRING_ID Help
) {
468 mFormSet
->Help
= Help
;
471 VOID
SetClassGuid (IN EFI_GUID
*Guid
) {
472 memcpy (&(mFormSet
->ClassGuid
[mFormSet
->Flags
++]), Guid
, sizeof (EFI_GUID
));
476 return mFormSet
->Flags
;
480 class CIfrEnd
: public CIfrObj
, public CIfrOpHeader
{
485 CIfrEnd () : CIfrObj (EFI_IFR_END_OP
, (CHAR8
**)&mEnd
),
486 CIfrOpHeader (EFI_IFR_END_OP
, &mEnd
->Header
) {}
489 class CIfrDefaultStore
: public CIfrObj
, public CIfrOpHeader
{
491 EFI_IFR_DEFAULTSTORE
*mDefaultStore
;
494 CIfrDefaultStore () : CIfrObj (EFI_IFR_DEFAULTSTORE_OP
, (CHAR8
**)&mDefaultStore
),
495 CIfrOpHeader (EFI_IFR_DEFAULTSTORE_OP
, &mDefaultStore
->Header
) {
496 mDefaultStore
->DefaultId
= EFI_VARSTORE_ID_INVALID
;
497 mDefaultStore
->DefaultName
= EFI_STRING_ID_INVALID
;
500 VOID
SetDefaultName (IN EFI_STRING_ID DefaultName
) {
501 mDefaultStore
->DefaultName
= DefaultName
;
504 VOID
SetDefaultId (IN UINT16 DefaultId
) {
505 mDefaultStore
->DefaultId
= DefaultId
;
509 #define EFI_FORM_ID_MAX 0xFFFF
510 #define EFI_FREE_FORM_ID_BITMAP_SIZE ((EFI_FORM_ID_MAX + 1) / EFI_BITS_PER_UINT32)
512 class CIfrForm
: public CIfrObj
, public CIfrOpHeader
{
516 STATIC UINT32 FormIdBitMap
[EFI_FREE_FORM_ID_BITMAP_SIZE
];
518 STATIC BOOLEAN
ChekFormIdFree (IN EFI_FORM_ID FormId
) {
519 UINT32 Index
= (FormId
/ EFI_BITS_PER_UINT32
);
520 UINT32 Offset
= (FormId
% EFI_BITS_PER_UINT32
);
522 return (FormIdBitMap
[Index
] & (0x80000000 >> Offset
)) == 0;
525 STATIC VOID
MarkFormIdUsed (IN EFI_FORM_ID FormId
) {
526 UINT32 Index
= (FormId
/ EFI_BITS_PER_UINT32
);
527 UINT32 Offset
= (FormId
% EFI_BITS_PER_UINT32
);
529 FormIdBitMap
[Index
] |= (0x80000000 >> Offset
);
533 CIfrForm () : CIfrObj (EFI_IFR_FORM_OP
, (CHAR8
**)&mForm
),
534 CIfrOpHeader (EFI_IFR_FORM_OP
, &mForm
->Header
) {
536 mForm
->FormTitle
= EFI_STRING_ID_INVALID
;
539 EFI_VFR_RETURN_CODE
SetFormId (IN EFI_FORM_ID FormId
) {
540 if (CIfrForm::ChekFormIdFree (FormId
) == FALSE
) {
541 return VFR_RETURN_FORMID_REDEFINED
;
543 mForm
->FormId
= FormId
;
544 CIfrForm::MarkFormIdUsed (FormId
);
545 return VFR_RETURN_SUCCESS
;
548 VOID
SetFormTitle (IN EFI_STRING_ID FormTitle
) {
549 mForm
->FormTitle
= FormTitle
;
553 class CIfrVarStore
: public CIfrObj
, public CIfrOpHeader
{
555 EFI_IFR_VARSTORE
*mVarStore
;
558 CIfrVarStore () : CIfrObj (EFI_IFR_VARSTORE_OP
, (CHAR8
**)&mVarStore
, sizeof (EFI_IFR_VARSTORE
), TRUE
),
559 CIfrOpHeader (EFI_IFR_VARSTORE_OP
, &mVarStore
->Header
) {
560 mVarStore
->VarStoreId
= EFI_VARSTORE_ID_INVALID
;
562 memset (&mVarStore
->Guid
, 0, sizeof (EFI_GUID
));
563 mVarStore
->Name
[0] = '\0';
566 VOID
SetGuid (IN EFI_GUID
*Guid
) {
567 memcpy (&mVarStore
->Guid
, Guid
, sizeof (EFI_GUID
));
570 VOID
SetVarStoreId (IN EFI_VARSTORE_ID VarStoreId
) {
571 mVarStore
->VarStoreId
= VarStoreId
;
574 VOID
SetSize (IN UINT16 Size
) {
575 mVarStore
->Size
= Size
;
578 VOID
SetName (IN CHAR8
*Name
) {
584 if (ExpendObjBin (Len
) == TRUE
) {
586 strcpy ((CHAR8
*)(mVarStore
->Name
), Name
);
593 class CIfrVarStoreEfi
: public CIfrObj
, public CIfrOpHeader
{
595 EFI_IFR_VARSTORE_EFI
*mVarStoreEfi
;
598 CIfrVarStoreEfi () : CIfrObj (EFI_IFR_VARSTORE_EFI_OP
, (CHAR8
**)&mVarStoreEfi
),
599 CIfrOpHeader (EFI_IFR_VARSTORE_EFI_OP
, &mVarStoreEfi
->Header
) {
600 mVarStoreEfi
->VarStoreId
= EFI_VAROFFSET_INVALID
;
601 memset (&mVarStoreEfi
->Guid
, 0, sizeof (EFI_GUID
));
604 VOID
SetGuid (IN EFI_GUID
*Guid
) {
605 memcpy (&mVarStoreEfi
->Guid
, Guid
, sizeof (EFI_GUID
));
608 VOID
SetVarStoreId (IN UINT16 VarStoreId
) {
609 mVarStoreEfi
->VarStoreId
= VarStoreId
;
612 VOID
SetAttributes (IN UINT32 Attributes
) {
613 mVarStoreEfi
->Attributes
= Attributes
;
617 class CIfrVarStoreNameValue
: public CIfrObj
, public CIfrOpHeader
{
619 EFI_IFR_VARSTORE_NAME_VALUE
*mVarStoreNameValue
;
622 CIfrVarStoreNameValue () : CIfrObj (EFI_IFR_VARSTORE_NAME_VALUE_OP
, (CHAR8
**)&mVarStoreNameValue
),
623 CIfrOpHeader (EFI_IFR_VARSTORE_NAME_VALUE_OP
, &mVarStoreNameValue
->Header
) {
624 mVarStoreNameValue
->VarStoreId
= EFI_VAROFFSET_INVALID
;
625 memset (&mVarStoreNameValue
->Guid
, 0, sizeof (EFI_GUID
));
628 VOID
SetGuid (IN EFI_GUID
*Guid
) {
629 memcpy (&mVarStoreNameValue
->Guid
, Guid
, sizeof (EFI_GUID
));
632 VOID
SetVarStoreId (IN UINT16 VarStoreId
) {
633 mVarStoreNameValue
->VarStoreId
= VarStoreId
;
637 class CIfrImage
: public CIfrObj
, public CIfrOpHeader
{
639 EFI_IFR_IMAGE
*mImage
;
642 CIfrImage () : CIfrObj (EFI_IFR_IMAGE_OP
, (CHAR8
**)&mImage
),
643 CIfrOpHeader (EFI_IFR_FORM_OP
, &mImage
->Header
) {
644 mImage
->Id
= EFI_IMAGE_ID_INVALID
;
647 VOID
SetImageId (IN EFI_IMAGE_ID ImageId
) {
648 mImage
->Id
= ImageId
;
652 class CIfrLocked
: public CIfrObj
, public CIfrOpHeader
{
654 EFI_IFR_LOCKED
*mLocked
;
657 CIfrLocked () : CIfrObj (EFI_IFR_LOCKED_OP
, (CHAR8
**)&mLocked
),
658 CIfrOpHeader (EFI_IFR_LOCKED_OP
, &mLocked
->Header
) {}
661 class CIfrRule
: public CIfrObj
, public CIfrOpHeader
{
666 CIfrRule () : CIfrObj (EFI_IFR_RULE_OP
, (CHAR8
**)&mRule
),
667 mRule ((EFI_IFR_RULE
*)GetObjBinAddr()),
668 CIfrOpHeader (EFI_IFR_RULE_OP
, &mRule
->Header
) {
669 mRule
->RuleId
= EFI_RULE_ID_INVALID
;
672 VOID
SetRuleId (IN UINT8 RuleId
) {
673 mRule
->RuleId
= RuleId
;
677 static EFI_IFR_TYPE_VALUE gZeroEfiIfrTypeValue
= {0, };
679 class CIfrDefault
: public CIfrObj
, public CIfrOpHeader
{
681 EFI_IFR_DEFAULT
*mDefault
;
685 IN UINT16 DefaultId
= EFI_HII_DEFAULT_CLASS_STANDARD
,
686 IN UINT8 Type
= EFI_IFR_TYPE_OTHER
,
687 IN EFI_IFR_TYPE_VALUE Value
= gZeroEfiIfrTypeValue
688 ) : CIfrObj (EFI_IFR_DEFAULT_OP
, (CHAR8
**)&mDefault
),
689 CIfrOpHeader (EFI_IFR_DEFAULT_OP
, &mDefault
->Header
) {
690 mDefault
->Type
= Type
;
691 mDefault
->Value
= Value
;
692 mDefault
->DefaultId
= DefaultId
;
695 VOID
SetDefaultId (IN UINT16 DefaultId
) {
696 mDefault
->DefaultId
= DefaultId
;
699 VOID
SetType (IN UINT8 Type
) {
700 mDefault
->Type
= Type
;
703 VOID
SetValue (IN EFI_IFR_TYPE_VALUE Value
) {
704 mDefault
->Value
= Value
;
708 class CIfrValue
: public CIfrObj
, public CIfrOpHeader
{
710 EFI_IFR_VALUE
*mValue
;
713 CIfrValue () : CIfrObj (EFI_IFR_VALUE_OP
, (CHAR8
**)&mValue
),
714 CIfrOpHeader (EFI_IFR_VALUE_OP
, &mValue
->Header
) {}
718 class CIfrSubtitle
: public CIfrObj
, public CIfrOpHeader
, public CIfrStatementHeader
{
720 EFI_IFR_SUBTITLE
*mSubtitle
;
723 CIfrSubtitle () : CIfrObj (EFI_IFR_SUBTITLE_OP
, (CHAR8
**)&mSubtitle
),
724 CIfrOpHeader (EFI_IFR_SUBTITLE_OP
, &mSubtitle
->Header
),
725 CIfrStatementHeader (&mSubtitle
->Statement
) {
726 mSubtitle
->Flags
= 0;
729 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 LFlags
) {
730 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_FLAGS_HORIZONTAL
)) {
731 mSubtitle
->Flags
|= EFI_IFR_FLAGS_HORIZONTAL
;
734 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
738 class CIfrText
: public CIfrObj
, public CIfrOpHeader
, public CIfrStatementHeader
{
743 CIfrText () : CIfrObj (EFI_IFR_TEXT_OP
, (CHAR8
**)&mText
),
744 CIfrOpHeader (EFI_IFR_TEXT_OP
, &mText
->Header
),
745 CIfrStatementHeader (&mText
->Statement
) {
746 mText
->TextTwo
= EFI_STRING_ID_INVALID
;
749 VOID
SetTextTwo (IN EFI_STRING_ID StringId
) {
750 mText
->TextTwo
= StringId
;
754 class CIfrRef
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
759 CIfrRef () : CIfrObj (EFI_IFR_REF_OP
, (CHAR8
**)&mRef
),
760 CIfrOpHeader (EFI_IFR_REF_OP
, &mRef
->Header
),
761 CIfrQuestionHeader (&mRef
->Question
) {
765 VOID
SetFormId (IN EFI_FORM_ID FormId
) {
766 mRef
->FormId
= FormId
;
770 class CIfrRef2
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
775 CIfrRef2 () : CIfrObj (EFI_IFR_REF_OP
, (CHAR8
**)&mRef2
, sizeof (EFI_IFR_REF2
)),
776 CIfrOpHeader (EFI_IFR_REF_OP
, &mRef2
->Header
, sizeof (EFI_IFR_REF2
)),
777 CIfrQuestionHeader (&mRef2
->Question
) {
779 mRef2
->QuestionId
= EFI_QUESTION_ID_INVALID
;
782 VOID
SetFormId (IN EFI_FORM_ID FormId
) {
783 mRef2
->FormId
= FormId
;
786 EFI_VFR_RETURN_CODE
SetQuestionId (IN EFI_QUESTION_ID QuestionId
) {
787 if (QuestionId
== EFI_QUESTION_ID_INVALID
) {
788 return VFR_RETURN_UNDEFINED
;
790 mRef2
->QuestionId
= QuestionId
;
791 return VFR_RETURN_SUCCESS
;
795 class CIfrRef3
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
800 CIfrRef3 () : CIfrObj (EFI_IFR_REF_OP
, (CHAR8
**)&mRef3
, sizeof(EFI_IFR_REF3
)),
801 CIfrOpHeader (EFI_IFR_REF_OP
, &mRef3
->Header
, sizeof (EFI_IFR_REF3
)),
802 CIfrQuestionHeader (&mRef3
->Question
) {
804 mRef3
->QuestionId
= EFI_QUESTION_ID_INVALID
;
805 memset (&mRef3
->FormSetId
, 0, sizeof (EFI_GUID
));
808 VOID
SetFormId (IN EFI_FORM_ID FormId
) {
809 mRef3
->FormId
= FormId
;
812 VOID
SetQuestionId (IN EFI_QUESTION_ID QuestionId
) {
813 mRef3
->QuestionId
= QuestionId
;
816 VOID
SetFormSetId (IN EFI_GUID FormSetId
) {
817 mRef3
->FormSetId
= FormSetId
;
821 class CIfrRef4
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
826 CIfrRef4 () : CIfrObj (EFI_IFR_REF_OP
, (CHAR8
**)&mRef4
, sizeof(EFI_IFR_REF3
)),
827 CIfrOpHeader (EFI_IFR_REF_OP
, &mRef4
->Header
, sizeof (EFI_IFR_REF3
)),
828 CIfrQuestionHeader (&mRef4
->Question
) {
830 mRef4
->QuestionId
= EFI_QUESTION_ID_INVALID
;
831 memset (&mRef4
->FormSetId
, 0, sizeof (EFI_GUID
));
832 mRef4
->DevicePath
= EFI_STRING_ID_INVALID
;
835 VOID
SetFormId (IN EFI_FORM_ID FormId
) {
836 mRef4
->FormId
= FormId
;
839 VOID
SetQuestionId (IN EFI_QUESTION_ID QuestionId
) {
840 mRef4
->QuestionId
= QuestionId
;
843 VOID
SetFormSetId (IN EFI_GUID FormSetId
) {
844 mRef4
->FormSetId
= FormSetId
;
847 VOID
SetDevicePath (IN EFI_STRING_ID DevicePath
) {
848 mRef4
->DevicePath
= DevicePath
;
852 class CIfrResetButton
: public CIfrObj
, public CIfrOpHeader
, public CIfrStatementHeader
{
854 EFI_IFR_RESET_BUTTON
*mResetButton
;
857 CIfrResetButton () : CIfrObj (EFI_IFR_RESET_BUTTON_OP
, (CHAR8
**)&mResetButton
),
858 CIfrOpHeader (EFI_IFR_RESET_BUTTON_OP
, &mResetButton
->Header
),
859 CIfrStatementHeader (&mResetButton
->Question
.Header
) {
860 mResetButton
->DefaultId
= EFI_HII_DEFAULT_CLASS_STANDARD
;
863 VOID
SetDefaultId (IN UINT16 DefaultId
) {
864 mResetButton
->DefaultId
= DefaultId
;
868 class CIfrCheckBox
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
870 EFI_IFR_CHECKBOX
*mCheckBox
;
873 CIfrCheckBox () : CIfrObj (EFI_IFR_CHECKBOX_OP
, (CHAR8
**)&mCheckBox
),
874 CIfrOpHeader (EFI_IFR_CHECKBOX_OP
, &mCheckBox
->Header
),
875 CIfrQuestionHeader (&mCheckBox
->Question
) {
876 mCheckBox
->Flags
= 0;
877 gCurrentQuestion
= this;
881 gCurrentQuestion
= NULL
;
884 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, UINT8 LFlags
) {
885 EFI_VFR_RETURN_CODE Ret
;
887 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
888 if (Ret
!= VFR_RETURN_SUCCESS
) {
892 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_CHECKBOX_DEFAULT
)) {
893 mCheckBox
->Flags
|= EFI_IFR_CHECKBOX_DEFAULT
;
896 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_CHECKBOX_DEFAULT_MFG
)) {
897 mCheckBox
->Flags
|= EFI_IFR_CHECKBOX_DEFAULT_MFG
;
900 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
903 UINT8
GetFlags (VOID
) {
904 return mCheckBox
->Flags
;
908 class CIfrAction
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
910 EFI_IFR_ACTION
*mAction
;
913 CIfrAction () : CIfrObj (EFI_IFR_ACTION_OP
, (CHAR8
**)&mAction
),
914 CIfrOpHeader (EFI_IFR_ACTION_OP
, &mAction
->Header
),
915 CIfrQuestionHeader (&mAction
->Question
) {
916 mAction
->QuestionConfig
= EFI_STRING_ID_INVALID
;
919 VOID
SetQuestionConfig (IN EFI_STRING_ID QuestionConfig
) {
920 mAction
->QuestionConfig
= QuestionConfig
;
924 class CIfrDate
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
929 CIfrDate () : CIfrObj (EFI_IFR_DATE_OP
, (CHAR8
**)&mDate
),
930 CIfrOpHeader (EFI_IFR_DATE_OP
, &mDate
->Header
),
931 CIfrQuestionHeader (&mDate
->Question
) {
935 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
) {
936 EFI_VFR_RETURN_CODE Ret
;
938 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
939 if (Ret
!= VFR_RETURN_SUCCESS
) {
943 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_QF_DATE_YEAR_SUPPRESS
)) {
944 mDate
->Flags
|= EFI_QF_DATE_YEAR_SUPPRESS
;
947 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_QF_DATE_MONTH_SUPPRESS
)) {
948 mDate
->Flags
|= EFI_QF_DATE_MONTH_SUPPRESS
;
951 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_QF_DATE_DAY_SUPPRESS
)) {
952 mDate
->Flags
|= EFI_QF_DATE_DAY_SUPPRESS
;
955 if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_DATE_STORAGE_NORMAL
)) {
956 mDate
->Flags
|= QF_DATE_STORAGE_NORMAL
;
957 } else if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_DATE_STORAGE_TIME
)) {
958 mDate
->Flags
|= QF_DATE_STORAGE_TIME
;
959 } else if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_DATE_STORAGE_WAKEUP
)) {
960 mDate
->Flags
|= QF_DATE_STORAGE_WAKEUP
;
963 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
967 class CIfrNumeric
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
, public CIfrMinMaxStepData
{
969 EFI_IFR_NUMERIC
*mNumeric
;
972 CIfrNumeric () : CIfrObj (EFI_IFR_NUMERIC_OP
, (CHAR8
**)&mNumeric
),
973 CIfrOpHeader (EFI_IFR_NUMERIC_OP
, &mNumeric
->Header
),
974 CIfrQuestionHeader (&mNumeric
->Question
),
975 CIfrMinMaxStepData (&mNumeric
->data
) {
976 mNumeric
->Flags
= EFI_IFR_NUMERIC_SIZE_1
| EFI_IFR_DISPLAY_UINT_DEC
;
977 gCurrentQuestion
= this;
981 gCurrentQuestion
= NULL
;
984 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
) {
985 EFI_VFR_RETURN_CODE Ret
;
987 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
988 if (Ret
!= VFR_RETURN_SUCCESS
) {
992 if (LFlags
& EFI_IFR_DISPLAY
) {
993 mNumeric
->Flags
= LFlags
;
995 mNumeric
->Flags
= LFlags
| EFI_IFR_DISPLAY_UINT_DEC
;
997 return VFR_RETURN_SUCCESS
;
1001 class CIfrOneOf
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
, public CIfrMinMaxStepData
{
1003 EFI_IFR_ONE_OF
*mOneOf
;
1006 CIfrOneOf () : CIfrObj (EFI_IFR_ONE_OF_OP
, (CHAR8
**)&mOneOf
),
1007 CIfrOpHeader (EFI_IFR_ONE_OF_OP
, &mOneOf
->Header
),
1008 CIfrQuestionHeader (&mOneOf
->Question
),
1009 CIfrMinMaxStepData (&mOneOf
->data
) {
1011 gCurrentQuestion
= this;
1015 gCurrentQuestion
= NULL
;
1018 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
) {
1019 EFI_VFR_RETURN_CODE Ret
;
1021 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1022 if (Ret
!= VFR_RETURN_SUCCESS
) {
1026 if (LFlags
& EFI_IFR_DISPLAY
) {
1027 mOneOf
->Flags
= LFlags
;
1029 mOneOf
->Flags
= LFlags
| EFI_IFR_DISPLAY_UINT_DEC
;
1031 return VFR_RETURN_SUCCESS
;
1035 class CIfrString
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1037 EFI_IFR_STRING
*mString
;
1040 CIfrString () : CIfrObj (EFI_IFR_STRING_OP
, (CHAR8
**)&mString
),
1041 CIfrOpHeader (EFI_IFR_STRING_OP
, &mString
->Header
),
1042 CIfrQuestionHeader (&mString
->Question
) {
1044 mString
->MinSize
= 0;
1045 mString
->MaxSize
= 0;
1046 gCurrentQuestion
= this;
1050 gCurrentQuestion
= NULL
;
1053 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
) {
1054 EFI_VFR_RETURN_CODE Ret
;
1056 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1057 if (Ret
!= VFR_RETURN_SUCCESS
) {
1061 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_STRING_MULTI_LINE
)) {
1062 mString
->Flags
|= EFI_IFR_STRING_MULTI_LINE
;
1065 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1068 VOID
SetMinSize (IN UINT8 Flags
) {
1069 mString
->MinSize
= Flags
;
1072 VOID
SetMaxSize (IN UINT8 MaxSize
) {
1073 mString
->MaxSize
= MaxSize
;
1077 class CIfrPassword
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1079 EFI_IFR_PASSWORD
*mPassword
;
1082 CIfrPassword () : CIfrObj (EFI_IFR_PASSWORD_OP
, (CHAR8
**)&mPassword
),
1083 CIfrOpHeader (EFI_IFR_PASSWORD_OP
, &mPassword
->Header
),
1084 CIfrQuestionHeader (&mPassword
->Question
) {
1085 mPassword
->MinSize
= 0;
1086 mPassword
->MaxSize
= 0;
1087 gCurrentQuestion
= this;
1091 gCurrentQuestion
= NULL
;
1094 VOID
SetMinSize (IN UINT16 MinSize
) {
1095 mPassword
->MinSize
= MinSize
;
1098 VOID
SetMaxSize (IN UINT16 MaxSize
) {
1099 mPassword
->MaxSize
= MaxSize
;
1103 class CIfrOrderedList
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1105 EFI_IFR_ORDERED_LIST
*mOrderedList
;
1108 CIfrOrderedList () : CIfrObj (EFI_IFR_ORDERED_LIST_OP
, (CHAR8
**)&mOrderedList
),
1109 CIfrOpHeader (EFI_IFR_ORDERED_LIST_OP
, &mOrderedList
->Header
),
1110 CIfrQuestionHeader (&mOrderedList
->Question
) {
1111 mOrderedList
->MaxContainers
= 0;
1112 mOrderedList
->Flags
= 0;
1113 gCurrentQuestion
= this;
1116 ~CIfrOrderedList () {
1117 gCurrentQuestion
= NULL
;
1120 VOID
SetMaxContainers (IN UINT8 MaxContainers
) {
1121 mOrderedList
->MaxContainers
= MaxContainers
;
1124 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
) {
1125 EFI_VFR_RETURN_CODE Ret
;
1127 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1128 if (Ret
!= VFR_RETURN_SUCCESS
) {
1132 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_UNIQUE_SET
)) {
1133 mOrderedList
->Flags
|= EFI_IFR_UNIQUE_SET
;
1136 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_NO_EMPTY_SET
)) {
1137 mOrderedList
->Flags
|= EFI_IFR_NO_EMPTY_SET
;
1140 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1144 class CIfrTime
: public CIfrObj
, public CIfrOpHeader
, public CIfrQuestionHeader
{
1146 EFI_IFR_TIME
*mTime
;
1149 CIfrTime () : CIfrObj (EFI_IFR_TIME_OP
, (CHAR8
**)&mTime
),
1150 CIfrOpHeader (EFI_IFR_TIME_OP
, &mTime
->Header
),
1151 CIfrQuestionHeader (&mTime
->Question
) {
1155 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 HFlags
, IN UINT8 LFlags
) {
1156 EFI_VFR_RETURN_CODE Ret
;
1158 Ret
= CIfrQuestionHeader::SetFlags (HFlags
);
1159 if (Ret
!= VFR_RETURN_SUCCESS
) {
1163 if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_HOUR_SUPPRESS
)) {
1164 mTime
->Flags
|= QF_TIME_HOUR_SUPPRESS
;
1167 if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_MINUTE_SUPPRESS
)) {
1168 mTime
->Flags
|= QF_TIME_MINUTE_SUPPRESS
;
1171 if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_SECOND_SUPPRESS
)) {
1172 mTime
->Flags
|= QF_TIME_SECOND_SUPPRESS
;
1175 if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_STORAGE_NORMAL
)) {
1176 mTime
->Flags
|= QF_TIME_STORAGE_NORMAL
;
1177 } else if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_STORAGE_TIME
)) {
1178 mTime
->Flags
|= QF_TIME_STORAGE_TIME
;
1179 } else if (_FLAG_TEST_AND_CLEAR (LFlags
, QF_TIME_STORAGE_WAKEUP
)) {
1180 mTime
->Flags
|= QF_TIME_STORAGE_WAKEUP
;
1183 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1187 class CIfrDisableIf
: public CIfrObj
, public CIfrOpHeader
{
1189 EFI_IFR_DISABLE_IF
*mDisableIf
;
1192 CIfrDisableIf () : CIfrObj (EFI_IFR_DISABLE_IF_OP
, (CHAR8
**)&mDisableIf
),
1193 mDisableIf ((EFI_IFR_DISABLE_IF
*) GetObjBinAddr()),
1194 CIfrOpHeader (EFI_IFR_DISABLE_IF_OP
, &mDisableIf
->Header
) {}
1197 class CIfrSuppressIf
: public CIfrObj
, public CIfrOpHeader
{
1199 EFI_IFR_SUPPRESS_IF
*mSuppressIf
;
1202 CIfrSuppressIf () : CIfrObj (EFI_IFR_SUPPRESS_IF_OP
, (CHAR8
**)&mSuppressIf
),
1203 CIfrOpHeader (EFI_IFR_SUPPRESS_IF_OP
, &mSuppressIf
->Header
) {}
1206 class CIfrGrayOutIf
: public CIfrObj
, public CIfrOpHeader
{
1208 EFI_IFR_GRAY_OUT_IF
*mGrayOutIf
;
1211 CIfrGrayOutIf () : CIfrObj (EFI_IFR_GRAY_OUT_IF_OP
, (CHAR8
**)&mGrayOutIf
),
1212 CIfrOpHeader (EFI_IFR_GRAY_OUT_IF_OP
, &mGrayOutIf
->Header
) {}
1215 class CIfrInconsistentIf
: public CIfrObj
, public CIfrOpHeader
{
1217 EFI_IFR_INCONSISTENT_IF
*mInconsistentIf
;
1220 CIfrInconsistentIf () : CIfrObj (EFI_IFR_INCONSISTENT_IF_OP
, (CHAR8
**)&mInconsistentIf
),
1221 CIfrOpHeader (EFI_IFR_INCONSISTENT_IF_OP
, &mInconsistentIf
->Header
) {
1222 mInconsistentIf
->Error
= EFI_STRING_ID_INVALID
;
1225 VOID
SetError (IN EFI_STRING_ID Error
) {
1226 mInconsistentIf
->Error
= Error
;
1230 class CIfrNoSubmitIf
: public CIfrObj
, public CIfrOpHeader
{
1232 EFI_IFR_NO_SUBMIT_IF
*mNoSubmitIf
;
1235 CIfrNoSubmitIf () : CIfrObj (EFI_IFR_NO_SUBMIT_IF_OP
, (CHAR8
**)&mNoSubmitIf
),
1236 CIfrOpHeader (EFI_IFR_NO_SUBMIT_IF_OP
, &mNoSubmitIf
->Header
) {
1237 mNoSubmitIf
->Error
= EFI_STRING_ID_INVALID
;
1240 VOID
SetError (IN EFI_STRING_ID Error
) {
1241 mNoSubmitIf
->Error
= Error
;
1245 class CIfrRefresh
: public CIfrObj
, public CIfrOpHeader
{
1247 EFI_IFR_REFRESH
*mRefresh
;
1250 CIfrRefresh () : CIfrObj (EFI_IFR_REFRESH_OP
, (CHAR8
**)&mRefresh
),
1251 CIfrOpHeader (EFI_IFR_REFRESH_OP
, &mRefresh
->Header
) {
1252 mRefresh
->RefreshInterval
= 0;
1255 VOID
SetRefreshInterval (IN UINT8 RefreshInterval
) {
1256 mRefresh
->RefreshInterval
= RefreshInterval
;
1260 class CIfrVarStoreDevice
: public CIfrObj
, public CIfrOpHeader
{
1262 EFI_IFR_VARSTORE_DEVICE
*mVarStoreDevice
;
1265 CIfrVarStoreDevice () : CIfrObj (EFI_IFR_VARSTORE_DEVICE_OP
, (CHAR8
**)&mVarStoreDevice
),
1266 CIfrOpHeader (EFI_IFR_VARSTORE_DEVICE_OP
, &mVarStoreDevice
->Header
) {
1267 mVarStoreDevice
->DevicePath
= EFI_STRING_ID_INVALID
;
1270 VOID
SetDevicePath (IN EFI_STRING_ID DevicePath
) {
1271 mVarStoreDevice
->DevicePath
= DevicePath
;
1275 class CIfrOneOfOption
: public CIfrObj
, public CIfrOpHeader
{
1277 EFI_IFR_ONE_OF_OPTION
*mOneOfOption
;
1280 CIfrOneOfOption () : CIfrObj (EFI_IFR_ONE_OF_OPTION_OP
, (CHAR8
**)&mOneOfOption
),
1281 CIfrOpHeader (EFI_IFR_ONE_OF_OPTION_OP
, &mOneOfOption
->Header
) {
1282 mOneOfOption
->Flags
= 0;
1283 mOneOfOption
->Option
= EFI_STRING_ID_INVALID
;
1284 mOneOfOption
->Type
= EFI_IFR_TYPE_OTHER
;
1285 memset (&mOneOfOption
->Value
, 0, sizeof (mOneOfOption
->Value
));
1288 VOID
SetOption (IN EFI_STRING_ID Option
) {
1289 mOneOfOption
->Option
= Option
;
1292 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 LFlags
) {
1293 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_OPTION_DEFAULT
)) {
1294 mOneOfOption
->Flags
|= EFI_IFR_OPTION_DEFAULT
;
1297 if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_OPTION_DEFAULT_MFG
)) {
1298 mOneOfOption
->Flags
|= EFI_IFR_OPTION_DEFAULT_MFG
;
1301 if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_NUM_SIZE_8
)) {
1302 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_NUM_SIZE_8
);
1303 mOneOfOption
->Flags
|= EFI_IFR_TYPE_NUM_SIZE_8
;
1304 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_NUM_SIZE_16
)) {
1305 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_NUM_SIZE_16
);
1306 mOneOfOption
->Flags
|= EFI_IFR_TYPE_NUM_SIZE_16
;
1307 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_NUM_SIZE_32
)) {
1308 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_NUM_SIZE_32
);
1309 mOneOfOption
->Flags
|= EFI_IFR_TYPE_NUM_SIZE_32
;
1310 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_NUM_SIZE_64
)) {
1311 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_NUM_SIZE_64
);
1312 mOneOfOption
->Flags
|= EFI_IFR_TYPE_NUM_SIZE_64
;
1313 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_BOOLEAN
)) {
1314 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_BOOLEAN
);
1315 mOneOfOption
->Flags
|= EFI_IFR_TYPE_BOOLEAN
;
1316 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_TIME
)) {
1317 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_TIME
);
1318 mOneOfOption
->Flags
|= EFI_IFR_TYPE_TIME
;
1319 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_DATE
)) {
1320 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_DATE
);
1321 mOneOfOption
->Flags
|= EFI_IFR_TYPE_DATE
;
1322 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_STRING
)) {
1323 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_STRING
);
1324 mOneOfOption
->Flags
|= EFI_IFR_TYPE_STRING
;
1325 } else if (_IS_EQUAL (LFlags
, EFI_IFR_TYPE_OTHER
)) {
1326 _FLAG_CLEAR (LFlags
, EFI_IFR_TYPE_OTHER
);
1327 mOneOfOption
->Flags
|= EFI_IFR_TYPE_OTHER
;
1330 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;
1333 VOID
SetType (IN UINT8 Type
) {
1334 mOneOfOption
->Type
= Type
;
1337 VOID
SetValue (IN EFI_IFR_TYPE_VALUE Value
) {
1338 mOneOfOption
->Value
= Value
;
1341 UINT8
GetFlags (VOID
) {
1342 return mOneOfOption
->Flags
;
1346 static EFI_GUID IfrTianoGuid
= EFI_IFR_TIANO_GUID
;
1347 static EFI_GUID IfrFrameworkGuid
= EFI_IFR_FRAMEWORK_GUID
;
1349 class CIfrClass
: public CIfrObj
, public CIfrOpHeader
{
1351 EFI_IFR_GUID_CLASS
*mClass
;
1354 CIfrClass () : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mClass
, sizeof (EFI_IFR_GUID_CLASS
)),
1355 CIfrOpHeader (EFI_IFR_GUID_OP
, &mClass
->Header
, sizeof (EFI_IFR_GUID_CLASS
)) {
1356 mClass
->ExtendOpCode
= EFI_IFR_EXTEND_OP_CLASS
;
1357 mClass
->Guid
= IfrTianoGuid
;
1358 mClass
->Class
= EFI_NON_DEVICE_CLASS
;
1361 VOID
SetClass (IN UINT16 Class
) {
1362 mClass
->Class
= Class
;
1366 class CIfrSubClass
: public CIfrObj
, public CIfrOpHeader
{
1368 EFI_IFR_GUID_SUBCLASS
*mSubClass
;
1371 CIfrSubClass () : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mSubClass
, sizeof (EFI_IFR_GUID_SUBCLASS
)),
1372 CIfrOpHeader (EFI_IFR_GUID_OP
, &mSubClass
->Header
, sizeof (EFI_IFR_GUID_SUBCLASS
)) {
1373 mSubClass
->ExtendOpCode
= EFI_IFR_EXTEND_OP_SUBCLASS
;
1374 mSubClass
->Guid
= IfrTianoGuid
;
1375 mSubClass
->SubClass
= EFI_SETUP_APPLICATION_SUBCLASS
;
1378 VOID
SetSubClass (IN UINT16 SubClass
) {
1379 mSubClass
->SubClass
= SubClass
;
1383 class CIfrLabel
: public CIfrObj
, public CIfrOpHeader
{
1385 EFI_IFR_GUID_LABEL
*mLabel
;
1388 CIfrLabel () : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mLabel
, sizeof (EFI_IFR_GUID_LABEL
)),
1389 CIfrOpHeader (EFI_IFR_GUID_OP
, &mLabel
->Header
, sizeof (EFI_IFR_GUID_LABEL
)) {
1390 mLabel
->ExtendOpCode
= EFI_IFR_EXTEND_OP_LABEL
;
1391 mLabel
->Guid
= IfrTianoGuid
;
1394 VOID
SetNumber (IN UINT16 Number
) {
1395 mLabel
->Number
= Number
;
1399 class CIfrBanner
: public CIfrObj
, public CIfrOpHeader
{
1401 EFI_IFR_GUID_BANNER
*mBanner
;
1404 CIfrBanner () : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mBanner
, sizeof (EFI_IFR_GUID_BANNER
)),
1405 CIfrOpHeader (EFI_IFR_GUID_OP
, &mBanner
->Header
, sizeof (EFI_IFR_GUID_BANNER
)) {
1406 mBanner
->ExtendOpCode
= EFI_IFR_EXTEND_OP_BANNER
;
1407 mBanner
->Guid
= IfrTianoGuid
;
1410 VOID
SetTitle (IN EFI_STRING_ID StringId
) {
1411 mBanner
->Title
= StringId
;
1414 VOID
SetLine (IN UINT16 Line
) {
1415 mBanner
->LineNumber
= Line
;
1418 VOID
SetAlign (IN UINT8 Align
) {
1419 mBanner
->Alignment
= Align
;
1423 class CIfrOptionKey
: public CIfrObj
, public CIfrOpHeader
{
1425 EFI_IFR_GUID_OPTIONKEY
*mOptionKey
;
1429 IN EFI_QUESTION_ID QuestionId
,
1430 IN EFI_IFR_TYPE_VALUE
&OptionValue
,
1431 IN EFI_QUESTION_ID KeyValue
1432 ) : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mOptionKey
, sizeof (EFI_IFR_GUID_OPTIONKEY
)),
1433 CIfrOpHeader (EFI_IFR_GUID_OP
, &mOptionKey
->Header
, sizeof (EFI_IFR_GUID_OPTIONKEY
)) {
1434 mOptionKey
->ExtendOpCode
= EFI_IFR_EXTEND_OP_OPTIONKEY
;
1435 mOptionKey
->Guid
= IfrFrameworkGuid
;
1436 mOptionKey
->QuestionId
= QuestionId
;
1437 mOptionKey
->OptionValue
= OptionValue
;
1438 mOptionKey
->KeyValue
= KeyValue
;
1442 class CIfrVarEqName
: public CIfrObj
, public CIfrOpHeader
{
1444 EFI_IFR_GUID_VAREQNAME
*mVarEqName
;
1448 IN EFI_QUESTION_ID QuestionId
,
1449 IN EFI_STRING_ID NameId
1450 ) : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mVarEqName
, sizeof (EFI_IFR_GUID_VAREQNAME
)),
1451 CIfrOpHeader (EFI_IFR_GUID_OP
, &mVarEqName
->Header
, sizeof (EFI_IFR_GUID_VAREQNAME
)) {
1452 mVarEqName
->ExtendOpCode
= EFI_IFR_EXTEND_OP_VAREQNAME
;
1453 mVarEqName
->Guid
= IfrFrameworkGuid
;
1454 mVarEqName
->QuestionId
= QuestionId
;
1455 mVarEqName
->NameId
= NameId
;
1459 class CIfrTimeout
: public CIfrObj
, public CIfrOpHeader
{
1461 EFI_IFR_GUID_TIMEOUT
*mTimeout
;
1464 CIfrTimeout (IN UINT16 Timeout
= 0) : CIfrObj (EFI_IFR_GUID_OP
, (CHAR8
**)&mTimeout
, sizeof (EFI_IFR_GUID_TIMEOUT
)),
1465 CIfrOpHeader (EFI_IFR_GUID_OP
, &mTimeout
->Header
, sizeof (EFI_IFR_GUID_TIMEOUT
)) {
1466 mTimeout
->ExtendOpCode
= EFI_IFR_EXTEND_OP_TIMEOUT
;
1467 mTimeout
->Guid
= IfrTianoGuid
;
1468 mTimeout
->TimeOut
= Timeout
;
1471 VOID
SetTimeout (IN UINT16 Timeout
) {
1472 mTimeout
->TimeOut
= Timeout
;
1476 class CIfrDup
: public CIfrObj
, public CIfrOpHeader
{
1483 ) : CIfrObj (EFI_IFR_DUP_OP
, (CHAR8
**)&mDup
),
1484 CIfrOpHeader (EFI_IFR_DUP_OP
, &mDup
->Header
) {
1489 class CIfrEqIdId
: public CIfrObj
, public CIfrOpHeader
{
1491 EFI_IFR_EQ_ID_ID
*mEqIdId
;
1496 ) : CIfrObj (EFI_IFR_EQ_ID_ID_OP
, (CHAR8
**)&mEqIdId
),
1497 CIfrOpHeader (EFI_IFR_EQ_ID_ID_OP
, &mEqIdId
->Header
) {
1499 mEqIdId
->QuestionId1
= EFI_QUESTION_ID_INVALID
;
1500 mEqIdId
->QuestionId2
= EFI_QUESTION_ID_INVALID
;
1503 VOID
SetQuestionId1 (
1504 IN EFI_QUESTION_ID QuestionId
,
1508 if (QuestionId
!= EFI_QUESTION_ID_INVALID
) {
1509 mEqIdId
->QuestionId1
= QuestionId
;
1511 gCFormPkg
.AssignPending (VarIdStr
, (VOID
*)(&mEqIdId
->QuestionId1
), sizeof (EFI_QUESTION_ID
), LineNo
, NO_QST_REFED
);
1515 VOID
SetQuestionId2 (
1516 IN EFI_QUESTION_ID QuestionId
,
1520 if (QuestionId
!= EFI_QUESTION_ID_INVALID
) {
1521 mEqIdId
->QuestionId2
= QuestionId
;
1523 gCFormPkg
.AssignPending (VarIdStr
, (VOID
*)(&mEqIdId
->QuestionId2
), sizeof (EFI_QUESTION_ID
), LineNo
, NO_QST_REFED
);
1528 class CIfrEqIdVal
: public CIfrObj
, public CIfrOpHeader
{
1530 EFI_IFR_EQ_ID_VAL
*mEqIdVal
;
1535 ) : CIfrObj (EFI_IFR_EQ_ID_VAL_OP
, (CHAR8
**)&mEqIdVal
),
1536 CIfrOpHeader (EFI_IFR_EQ_ID_VAL_OP
, &mEqIdVal
->Header
) {
1538 mEqIdVal
->QuestionId
= EFI_QUESTION_ID_INVALID
;
1541 VOID
SetQuestionId (
1542 IN EFI_QUESTION_ID QuestionId
,
1546 if (QuestionId
!= EFI_QUESTION_ID_INVALID
) {
1547 mEqIdVal
->QuestionId
= QuestionId
;
1549 gCFormPkg
.AssignPending (VarIdStr
, (VOID
*)(&mEqIdVal
->QuestionId
), sizeof (EFI_QUESTION_ID
), LineNo
, NO_QST_REFED
);
1553 VOID
SetValue (IN UINT16 Value
) {
1554 mEqIdVal
->Value
= Value
;
1558 class CIfrEqIdList
: public CIfrObj
, public CIfrOpHeader
{
1560 EFI_IFR_EQ_ID_LIST
*mEqIdVList
;
1565 ) : CIfrObj (EFI_IFR_EQ_ID_LIST_OP
, (CHAR8
**)&mEqIdVList
, sizeof (EFI_IFR_EQ_ID_LIST
), TRUE
),
1566 CIfrOpHeader (EFI_IFR_EQ_ID_LIST_OP
, &mEqIdVList
->Header
) {
1568 mEqIdVList
->QuestionId
= EFI_QUESTION_ID_INVALID
;
1569 mEqIdVList
->ListLength
= 0;
1570 mEqIdVList
->ValueList
[0] = 0;
1573 VOID
UpdateIfrBuffer (
1575 _EMIT_PENDING_OBJ();
1576 mEqIdVList
= (EFI_IFR_EQ_ID_LIST
*) GetObjBinAddr();
1577 UpdateHeader (&mEqIdVList
->Header
);
1580 VOID
SetQuestionId (
1581 IN EFI_QUESTION_ID QuestionId
,
1585 if (QuestionId
!= EFI_QUESTION_ID_INVALID
) {
1586 mEqIdVList
->QuestionId
= QuestionId
;
1588 gCFormPkg
.AssignPending (VarIdStr
, (VOID
*)(&mEqIdVList
->QuestionId
), sizeof (EFI_QUESTION_ID
), LineNo
, NO_QST_REFED
);
1592 VOID
SetListLength (IN UINT16 ListLength
) {
1593 mEqIdVList
->ListLength
= ListLength
;
1596 VOID
SetValueList (IN UINT16 Index
, IN UINT16 Value
) {
1598 mEqIdVList
->ValueList
[0] = Value
;
1602 if (ExpendObjBin (sizeof (UINT16
)) ==TRUE
) {
1603 IncLength (sizeof (UINT16
));
1604 mEqIdVList
->ValueList
[Index
] = Value
;
1609 class CIfrQuestionRef1
: public CIfrObj
, public CIfrOpHeader
{
1611 EFI_IFR_QUESTION_REF1
*mQuestionRef1
;
1616 ) : CIfrObj (EFI_IFR_QUESTION_REF1_OP
, (CHAR8
**)&mQuestionRef1
),
1617 CIfrOpHeader (EFI_IFR_QUESTION_REF1_OP
, &mQuestionRef1
->Header
) {
1619 mQuestionRef1
->QuestionId
= EFI_QUESTION_ID_INVALID
;
1622 VOID
SetQuestionId (
1623 IN EFI_QUESTION_ID QuestionId
,
1627 if (QuestionId
!= EFI_QUESTION_ID_INVALID
) {
1628 mQuestionRef1
->QuestionId
= QuestionId
;
1630 gCFormPkg
.AssignPending (VarIdStr
, (VOID
*)(&mQuestionRef1
->QuestionId
), sizeof (EFI_QUESTION_ID
), LineNo
, NO_QST_REFED
);
1635 class CIfrQuestionRef2
: public CIfrObj
, public CIfrOpHeader
{
1637 EFI_IFR_QUESTION_REF2
*mQuestionRef2
;
1642 ) : CIfrObj (EFI_IFR_QUESTION_REF2_OP
, (CHAR8
**)&mQuestionRef2
),
1643 CIfrOpHeader (EFI_IFR_QUESTION_REF2_OP
, &mQuestionRef2
->Header
) {
1648 class CIfrQuestionRef3
: public CIfrObj
, public CIfrOpHeader
{
1650 EFI_IFR_QUESTION_REF3
*mQuestionRef3
;
1655 ) : CIfrObj (EFI_IFR_QUESTION_REF3_OP
, (CHAR8
**)&mQuestionRef3
),
1656 CIfrOpHeader (EFI_IFR_QUESTION_REF3_OP
, &mQuestionRef3
->Header
) {
1661 class CIfrQuestionRef3_2
: public CIfrObj
, public CIfrOpHeader
{
1663 EFI_IFR_QUESTION_REF3_2
*mQuestionRef3_2
;
1666 CIfrQuestionRef3_2 (
1668 ) : CIfrObj (EFI_IFR_QUESTION_REF3_OP
, (CHAR8
**)&mQuestionRef3_2
, sizeof (EFI_IFR_QUESTION_REF3_2
)),
1669 CIfrOpHeader (EFI_IFR_QUESTION_REF3_OP
, &mQuestionRef3_2
->Header
, sizeof (EFI_IFR_QUESTION_REF3_2
)) {
1671 mQuestionRef3_2
->DevicePath
= EFI_STRING_ID_INVALID
;
1674 VOID
SetDevicePath (IN EFI_STRING_ID DevicePath
) {
1675 mQuestionRef3_2
->DevicePath
= DevicePath
;
1679 class CIfrQuestionRef3_3
: public CIfrObj
, public CIfrOpHeader
{
1681 EFI_IFR_QUESTION_REF3_3
*mQuestionRef3_3
;
1684 CIfrQuestionRef3_3 (
1686 ) : CIfrObj (EFI_IFR_QUESTION_REF3_OP
, (CHAR8
**)&mQuestionRef3_3
, sizeof (EFI_IFR_QUESTION_REF3_3
)),
1687 CIfrOpHeader (EFI_IFR_QUESTION_REF3_OP
, &mQuestionRef3_3
->Header
, sizeof (EFI_IFR_QUESTION_REF3_3
)) {
1689 mQuestionRef3_3
->DevicePath
= EFI_STRING_ID_INVALID
;
1690 memset (&mQuestionRef3_3
->Guid
, 0, sizeof (EFI_GUID
));
1693 VOID
SetDevicePath (IN EFI_STRING_ID DevicePath
) {
1694 mQuestionRef3_3
->DevicePath
= DevicePath
;
1697 VOID
SetGuid (IN EFI_GUID
*Guid
) {
1698 mQuestionRef3_3
->Guid
= *Guid
;
1702 class CIfrRuleRef
: public CIfrObj
, public CIfrOpHeader
{
1704 EFI_IFR_RULE_REF
*mRuleRef
;
1709 ) : CIfrObj (EFI_IFR_RULE_REF_OP
, (CHAR8
**)&mRuleRef
),
1710 CIfrOpHeader (EFI_IFR_RULE_REF_OP
, &mRuleRef
->Header
) {
1712 mRuleRef
->RuleId
= EFI_RULE_ID_INVALID
;
1715 VOID
SetRuleId (IN UINT8 RuleId
) {
1716 mRuleRef
->RuleId
= RuleId
;
1720 class CIfrStringRef1
: public CIfrObj
, public CIfrOpHeader
{
1722 EFI_IFR_STRING_REF1
*mStringRef1
;
1727 ) : CIfrObj (EFI_IFR_STRING_REF1_OP
, (CHAR8
**)&mStringRef1
),
1728 CIfrOpHeader (EFI_IFR_STRING_REF1_OP
, &mStringRef1
->Header
) {
1730 mStringRef1
->StringId
= EFI_STRING_ID_INVALID
;
1733 VOID
SetStringId (IN EFI_STRING_ID StringId
) {
1734 mStringRef1
->StringId
= StringId
;
1738 class CIfrStringRef2
: public CIfrObj
, public CIfrOpHeader
{
1740 EFI_IFR_STRING_REF2
*mStringRef2
;
1745 ) : CIfrObj (EFI_IFR_STRING_REF2_OP
, (CHAR8
**)&mStringRef2
),
1746 CIfrOpHeader (EFI_IFR_STRING_REF2_OP
, &mStringRef2
->Header
) {
1751 class CIfrThis
: public CIfrObj
, public CIfrOpHeader
{
1753 EFI_IFR_THIS
*mThis
;
1758 ) : CIfrObj (EFI_IFR_THIS_OP
, (CHAR8
**)&mThis
),
1759 CIfrOpHeader (EFI_IFR_THIS_OP
, &mThis
->Header
) {
1764 class CIfrUint8
: public CIfrObj
, public CIfrOpHeader
{
1766 EFI_IFR_UINT8
*mUint8
;
1771 ) : CIfrObj (EFI_IFR_UINT8_OP
, (CHAR8
**)&mUint8
),
1772 CIfrOpHeader (EFI_IFR_UINT8_OP
, &mUint8
->Header
) {
1776 VOID
SetValue (IN UINT8 Value
) {
1777 mUint8
->Value
= Value
;
1781 class CIfrUint16
: public CIfrObj
, public CIfrOpHeader
{
1783 EFI_IFR_UINT16
*mUint16
;
1788 ) : CIfrObj (EFI_IFR_UINT16_OP
, (CHAR8
**)&mUint16
),
1789 CIfrOpHeader (EFI_IFR_UINT16_OP
, &mUint16
->Header
) {
1793 VOID
SetValue (IN UINT16 Value
) {
1794 mUint16
->Value
= Value
;
1798 class CIfrUint32
: public CIfrObj
, public CIfrOpHeader
{
1800 EFI_IFR_UINT32
*mUint32
;
1805 ) : CIfrObj (EFI_IFR_UINT32_OP
, (CHAR8
**)&mUint32
),
1806 CIfrOpHeader (EFI_IFR_UINT32_OP
, &mUint32
->Header
) {
1810 VOID
SetValue (IN UINT32 Value
) {
1811 mUint32
->Value
= Value
;
1815 class CIfrUint64
: public CIfrObj
, public CIfrOpHeader
{
1817 EFI_IFR_UINT64
*mUint64
;
1822 ) : CIfrObj (EFI_IFR_UINT64_OP
, (CHAR8
**)&mUint64
),
1823 CIfrOpHeader (EFI_IFR_UINT64_OP
, &mUint64
->Header
) {
1827 VOID
SetValue (IN UINT64 Value
) {
1828 mUint64
->Value
= Value
;
1832 class CIfrTrue
: public CIfrObj
, public CIfrOpHeader
{
1834 EFI_IFR_TRUE
*mTrue
;
1839 ) : CIfrObj (EFI_IFR_TRUE_OP
, (CHAR8
**)&mTrue
),
1840 CIfrOpHeader (EFI_IFR_TRUE_OP
, &mTrue
->Header
) {
1845 class CIfrFalse
: public CIfrObj
, public CIfrOpHeader
{
1847 EFI_IFR_FALSE
*mFalse
;
1852 ) : CIfrObj (EFI_IFR_FALSE_OP
, (CHAR8
**)&mFalse
),
1853 CIfrOpHeader (EFI_IFR_FALSE_OP
, &mFalse
->Header
) {
1858 class CIfrOne
: public CIfrObj
, public CIfrOpHeader
{
1865 ) : CIfrObj (EFI_IFR_ONE_OP
, (CHAR8
**)&mOne
),
1866 CIfrOpHeader (EFI_IFR_ONE_OP
, &mOne
->Header
) {
1871 class CIfrOnes
: public CIfrObj
, public CIfrOpHeader
{
1873 EFI_IFR_ONES
*mOnes
;
1878 ) : CIfrObj (EFI_IFR_ONES_OP
, (CHAR8
**)&mOnes
),
1879 CIfrOpHeader (EFI_IFR_ONES_OP
, &mOnes
->Header
) {
1884 class CIfrZero
: public CIfrObj
, public CIfrOpHeader
{
1886 EFI_IFR_ZERO
*mZero
;
1891 ) : CIfrObj (EFI_IFR_ZERO_OP
, (CHAR8
**)&mZero
),
1892 CIfrOpHeader (EFI_IFR_ZERO_OP
, &mZero
->Header
) {
1897 class CIfrUndefined
: public CIfrObj
, public CIfrOpHeader
{
1899 EFI_IFR_UNDEFINED
*mUndefined
;
1904 ) : CIfrObj (EFI_IFR_UNDEFINED_OP
, (CHAR8
**)&mUndefined
),
1905 CIfrOpHeader (EFI_IFR_UNDEFINED_OP
, &mUndefined
->Header
) {
1910 class CIfrVersion
: public CIfrObj
, public CIfrOpHeader
{
1912 EFI_IFR_VERSION
*mVersion
;
1917 ) : CIfrObj (EFI_IFR_VERSION_OP
, (CHAR8
**)&mVersion
),
1918 CIfrOpHeader (EFI_IFR_VERSION_OP
, &mVersion
->Header
) {
1923 class CIfrLength
: public CIfrObj
, public CIfrOpHeader
{
1925 EFI_IFR_LENGTH
*mLength
;
1930 ) : CIfrObj (EFI_IFR_LENGTH_OP
, (CHAR8
**)&mLength
),
1931 CIfrOpHeader (EFI_IFR_LENGTH_OP
, &mLength
->Header
) {
1936 class CIfrNot
: public CIfrObj
, public CIfrOpHeader
{
1943 ) : CIfrObj (EFI_IFR_NOT_OP
, (CHAR8
**)&mNot
),
1944 CIfrOpHeader (EFI_IFR_NOT_OP
, &mNot
->Header
) {
1949 class CIfrBitWiseNot
: public CIfrObj
, public CIfrOpHeader
{
1951 EFI_IFR_BITWISE_NOT
*mBitWise
;
1956 ) : CIfrObj (EFI_IFR_BITWISE_NOT_OP
, (CHAR8
**)&mBitWise
),
1957 CIfrOpHeader (EFI_IFR_BITWISE_NOT_OP
, &mBitWise
->Header
) {
1962 class CIfrToBoolean
: public CIfrObj
, public CIfrOpHeader
{
1964 EFI_IFR_TO_BOOLEAN
*mToBoolean
;
1969 ) : CIfrObj (EFI_IFR_TO_BOOLEAN_OP
, (CHAR8
**)&mToBoolean
),
1970 CIfrOpHeader (EFI_IFR_TO_BOOLEAN_OP
, &mToBoolean
->Header
) {
1975 class CIfrToString
: public CIfrObj
, public CIfrOpHeader
{
1977 EFI_IFR_TO_STRING
*mToString
;
1982 ) : CIfrObj (EFI_IFR_TO_STRING_OP
, (CHAR8
**)&mToString
),
1983 CIfrOpHeader (EFI_IFR_TO_STRING_OP
, &mToString
->Header
) {
1987 VOID
SetFormat (IN UINT8 Format
) {
1988 mToString
->Format
= Format
;
1992 class CIfrToUint
: public CIfrObj
, public CIfrOpHeader
{
1994 EFI_IFR_TO_UINT
*mToUint
;
1999 ) : CIfrObj (EFI_IFR_TO_UINT_OP
, (CHAR8
**)&mToUint
),
2000 CIfrOpHeader (EFI_IFR_TO_UINT_OP
, &mToUint
->Header
) {
2005 class CIfrToUpper
: public CIfrObj
, public CIfrOpHeader
{
2007 EFI_IFR_TO_UPPER
*mToUpper
;
2012 ) : CIfrObj (EFI_IFR_TO_UPPER_OP
, (CHAR8
**)&mToUpper
),
2013 CIfrOpHeader (EFI_IFR_TO_UPPER_OP
, &mToUpper
->Header
) {
2018 class CIfrToLower
: public CIfrObj
, public CIfrOpHeader
{
2020 EFI_IFR_TO_LOWER
*mToLower
;
2025 ) : CIfrObj (EFI_IFR_TO_LOWER_OP
, (CHAR8
**)&mToLower
),
2026 CIfrOpHeader (EFI_IFR_TO_LOWER_OP
, &mToLower
->Header
) {
2031 class CIfrAdd
: public CIfrObj
, public CIfrOpHeader
{
2038 ) : CIfrObj (EFI_IFR_ADD_OP
, (CHAR8
**)&mAdd
),
2039 CIfrOpHeader (EFI_IFR_ADD_OP
, &mAdd
->Header
) {
2044 class CIfrBitWiseAnd
: public CIfrObj
, public CIfrOpHeader
{
2046 EFI_IFR_BITWISE_AND
*mBitWiseAnd
;
2051 ) : CIfrObj (EFI_IFR_BITWISE_AND_OP
, (CHAR8
**)&mBitWiseAnd
),
2052 CIfrOpHeader (EFI_IFR_BITWISE_AND_OP
, &mBitWiseAnd
->Header
) {
2057 class CIfrBitWiseOr
: public CIfrObj
, public CIfrOpHeader
{
2059 EFI_IFR_BITWISE_OR
*mBitWiseOr
;
2064 ) : CIfrObj (EFI_IFR_BITWISE_OR_OP
, (CHAR8
**)&mBitWiseOr
),
2065 CIfrOpHeader (EFI_IFR_BITWISE_OR_OP
, &mBitWiseOr
->Header
) {
2070 class CIfrAnd
: public CIfrObj
, public CIfrOpHeader
{
2077 ) : CIfrObj (EFI_IFR_AND_OP
, (CHAR8
**)&mAnd
),
2078 CIfrOpHeader (EFI_IFR_AND_OP
, &mAnd
->Header
) {
2083 class CIfrCatenate
: public CIfrObj
, public CIfrOpHeader
{
2085 EFI_IFR_CATENATE
*mCatenate
;
2090 ) : CIfrObj (EFI_IFR_CATENATE_OP
, (CHAR8
**)&mCatenate
),
2091 CIfrOpHeader (EFI_IFR_CATENATE_OP
, &mCatenate
->Header
) {
2096 class CIfrDivide
: public CIfrObj
, public CIfrOpHeader
{
2098 EFI_IFR_DIVIDE
*mDivide
;
2103 ) : CIfrObj (EFI_IFR_DIVIDE_OP
, (CHAR8
**)&mDivide
),
2104 CIfrOpHeader (EFI_IFR_DIVIDE_OP
, &mDivide
->Header
) {
2109 class CIfrEqual
: public CIfrObj
, public CIfrOpHeader
{
2111 EFI_IFR_EQUAL
*mEqual
;
2116 ) : CIfrObj (EFI_IFR_EQUAL_OP
, (CHAR8
**)&mEqual
),
2117 CIfrOpHeader (EFI_IFR_EQUAL_OP
, &mEqual
->Header
) {
2122 class CIfrGreaterEqual
: public CIfrObj
, public CIfrOpHeader
{
2124 EFI_IFR_GREATER_EQUAL
*mGreaterEqual
;
2129 ) : CIfrObj (EFI_IFR_GREATER_EQUAL_OP
, (CHAR8
**)&mGreaterEqual
),
2130 CIfrOpHeader (EFI_IFR_GREATER_EQUAL_OP
, &mGreaterEqual
->Header
) {
2135 class CIfrGreaterThan
: public CIfrObj
, public CIfrOpHeader
{
2137 EFI_IFR_GREATER_THAN
*mGreaterThan
;
2142 ) : CIfrObj (EFI_IFR_GREATER_THAN_OP
, (CHAR8
**)&mGreaterThan
),
2143 CIfrOpHeader (EFI_IFR_GREATER_THAN_OP
, &mGreaterThan
->Header
) {
2148 class CIfrLessEqual
: public CIfrObj
, public CIfrOpHeader
{
2150 EFI_IFR_LESS_EQUAL
*mLessEqual
;
2155 ) : CIfrObj (EFI_IFR_LESS_EQUAL_OP
, (CHAR8
**)&mLessEqual
),
2156 CIfrOpHeader (EFI_IFR_LESS_EQUAL_OP
, &mLessEqual
->Header
) {
2161 class CIfrLessThan
: public CIfrObj
, public CIfrOpHeader
{
2163 EFI_IFR_LESS_THAN
*mLessThan
;
2168 ) : CIfrObj (EFI_IFR_LESS_THAN_OP
, (CHAR8
**)&mLessThan
),
2169 CIfrOpHeader (EFI_IFR_LESS_THAN_OP
, &mLessThan
->Header
) {
2174 class CIfrMatch
: public CIfrObj
, public CIfrOpHeader
{
2176 EFI_IFR_MATCH
*mMatch
;
2181 ) : CIfrObj (EFI_IFR_MATCH_OP
, (CHAR8
**)&mMatch
),
2182 CIfrOpHeader (EFI_IFR_MATCH_OP
, &mMatch
->Header
) {
2187 class CIfrMultiply
: public CIfrObj
, public CIfrOpHeader
{
2189 EFI_IFR_MULTIPLY
*mMultiply
;
2194 ) : CIfrObj (EFI_IFR_MULTIPLY_OP
, (CHAR8
**)&mMultiply
),
2195 CIfrOpHeader (EFI_IFR_MULTIPLY_OP
, &mMultiply
->Header
) {
2200 class CIfrModulo
: public CIfrObj
, public CIfrOpHeader
{
2202 EFI_IFR_MODULO
*mModulo
;
2207 ) : CIfrObj (EFI_IFR_MODULO_OP
, (CHAR8
**)&mModulo
),
2208 CIfrOpHeader (EFI_IFR_MODULO_OP
, &mModulo
->Header
) {
2213 class CIfrNotEqual
: public CIfrObj
, public CIfrOpHeader
{
2215 EFI_IFR_NOT_EQUAL
*mNotEqual
;
2220 ) : CIfrObj (EFI_IFR_NOT_EQUAL_OP
, (CHAR8
**)&mNotEqual
),
2221 CIfrOpHeader (EFI_IFR_NOT_EQUAL_OP
, &mNotEqual
->Header
) {
2226 class CIfrOr
: public CIfrObj
, public CIfrOpHeader
{
2233 ) : CIfrObj (EFI_IFR_OR_OP
, (CHAR8
**)&mOr
),
2234 CIfrOpHeader (EFI_IFR_OR_OP
, &mOr
->Header
) {
2239 class CIfrShiftLeft
: public CIfrObj
, public CIfrOpHeader
{
2241 EFI_IFR_SHIFT_LEFT
*mShiftLeft
;
2246 ) : CIfrObj (EFI_IFR_SHIFT_LEFT_OP
, (CHAR8
**)&mShiftLeft
),
2247 CIfrOpHeader (EFI_IFR_SHIFT_LEFT_OP
, &mShiftLeft
->Header
) {
2252 class CIfrShiftRight
: public CIfrObj
, public CIfrOpHeader
{
2254 EFI_IFR_SHIFT_RIGHT
*mShiftRight
;
2259 ) : CIfrObj (EFI_IFR_SHIFT_RIGHT_OP
, (CHAR8
**)&mShiftRight
),
2260 CIfrOpHeader (EFI_IFR_SHIFT_RIGHT_OP
, &mShiftRight
->Header
) {
2265 class CIfrSubtract
: public CIfrObj
, public CIfrOpHeader
{
2267 EFI_IFR_SUBTRACT
*mSubtract
;
2272 ) : CIfrObj (EFI_IFR_SUBTRACT_OP
, (CHAR8
**)&mSubtract
),
2273 CIfrOpHeader (EFI_IFR_SUBTRACT_OP
, &mSubtract
->Header
) {
2278 class CIfrConditional
: public CIfrObj
, public CIfrOpHeader
{
2280 EFI_IFR_CONDITIONAL
*mConditional
;
2285 ) : CIfrObj (EFI_IFR_CONDITIONAL_OP
, (CHAR8
**)&mConditional
),
2286 CIfrOpHeader (EFI_IFR_CONDITIONAL_OP
, &mConditional
->Header
) {
2291 class CIfrFind
: public CIfrObj
, public CIfrOpHeader
{
2293 EFI_IFR_FIND
*mFind
;
2298 ) : CIfrObj (EFI_IFR_FIND_OP
, (CHAR8
**)&mFind
),
2299 CIfrOpHeader (EFI_IFR_FIND_OP
, &mFind
->Header
) {
2303 VOID
SetFormat (IN UINT8 Format
) {
2304 mFind
->Format
= Format
;
2308 class CIfrMid
: public CIfrObj
, public CIfrOpHeader
{
2315 ) : CIfrObj (EFI_IFR_MID_OP
, (CHAR8
**)&mMid
),
2316 CIfrOpHeader (EFI_IFR_MID_OP
, &mMid
->Header
) {
2321 class CIfrToken
: public CIfrObj
, public CIfrOpHeader
{
2323 EFI_IFR_TOKEN
*mToken
;
2328 ) : CIfrObj (EFI_IFR_TOKEN_OP
, (CHAR8
**)&mToken
),
2329 CIfrOpHeader (EFI_IFR_TOKEN_OP
, &mToken
->Header
) {
2334 class CIfrSpan
: public CIfrObj
, public CIfrOpHeader
{
2336 EFI_IFR_SPAN
*mSpan
;
2341 ) : CIfrObj (EFI_IFR_SPAN_OP
, (CHAR8
**)&mSpan
),
2342 CIfrOpHeader (EFI_IFR_SPAN_OP
, &mSpan
->Header
) {
2344 mSpan
->Flags
= EFI_IFR_FLAGS_FIRST_MATCHING
;
2347 EFI_VFR_RETURN_CODE
SetFlags (IN UINT8 LFlags
) {
2348 if (_IS_EQUAL (LFlags
, EFI_IFR_FLAGS_FIRST_MATCHING
)) {
2349 mSpan
->Flags
|= EFI_IFR_FLAGS_FIRST_MATCHING
;
2350 } else if (_FLAG_TEST_AND_CLEAR (LFlags
, EFI_IFR_FLAGS_FIRST_NON_MATCHING
)) {
2351 mSpan
->Flags
|= EFI_IFR_FLAGS_FIRST_NON_MATCHING
;
2354 return _FLAGS_ZERO (LFlags
) ? VFR_RETURN_SUCCESS
: VFR_RETURN_FLAGS_UNSUPPORTED
;