mirror of https://github.com/acidanthera/audk.git
2941 lines
81 KiB
C++
2941 lines
81 KiB
C++
/** @file
|
|
|
|
The definition of CFormPkg's member function
|
|
|
|
Copyright (c) 2004 - 2017, Intel Corporation. All rights reserved.<BR>
|
|
This program and the accompanying materials
|
|
are licensed and made available under the terms and conditions of the BSD License
|
|
which accompanies this distribution. The full text of the license may be found at
|
|
http://opensource.org/licenses/bsd-license.php
|
|
|
|
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
|
|
|
**/
|
|
|
|
#ifndef _EFIIFRCLASS_H_
|
|
#define _EFIIFRCLASS_H_
|
|
|
|
#include "string.h"
|
|
#include "EfiVfr.h"
|
|
#include "VfrError.h"
|
|
#include "VfrUtilityLib.h"
|
|
|
|
#define NO_QST_REFED "no question refered"
|
|
|
|
struct PACKAGE_DATA {
|
|
CHAR8 *Buffer;
|
|
UINT32 Size;
|
|
};
|
|
|
|
/*
|
|
* The functions below are used for flags setting
|
|
*/
|
|
static inline BOOLEAN _FLAGS_ZERO (
|
|
IN UINT8 &Flags
|
|
)
|
|
{
|
|
return Flags == 0;
|
|
}
|
|
|
|
static inline VOID _FLAG_CLEAR (
|
|
IN UINT8 &Flags,
|
|
IN UINT8 Mask
|
|
)
|
|
{
|
|
Flags &= (~Mask);
|
|
}
|
|
|
|
static inline UINT8 _FLAG_TEST_AND_CLEAR (
|
|
IN UINT8 &Flags,
|
|
IN UINT8 Mask
|
|
)
|
|
{
|
|
UINT8 Ret = Flags & Mask;
|
|
Flags &= (~Mask);
|
|
return Ret;
|
|
}
|
|
|
|
static inline UINT8 _IS_EQUAL (
|
|
IN UINT8 &Flags,
|
|
IN UINT8 Value
|
|
)
|
|
{
|
|
return Flags == Value;
|
|
}
|
|
|
|
/*
|
|
* The definition of CIfrBin
|
|
*/
|
|
typedef enum {
|
|
PENDING,
|
|
ASSIGNED
|
|
} ASSIGN_FLAG;
|
|
|
|
struct SPendingAssign {
|
|
CHAR8 *mKey; // key ! unique
|
|
VOID *mAddr;
|
|
UINT32 mLen;
|
|
ASSIGN_FLAG mFlag;
|
|
UINT32 mLineNo;
|
|
CHAR8 *mMsg;
|
|
struct SPendingAssign *mNext;
|
|
|
|
SPendingAssign (IN CHAR8 *, IN VOID *, IN UINT32, IN UINT32, IN CONST CHAR8 *);
|
|
~SPendingAssign ();
|
|
|
|
VOID SetAddrAndLen (IN VOID *, IN UINT32);
|
|
VOID AssignValue (IN VOID *, IN UINT32);
|
|
CHAR8 * GetKey (VOID);
|
|
|
|
private:
|
|
SPendingAssign (IN CONST SPendingAssign&); // Prevent copy-construction
|
|
SPendingAssign& operator= (IN CONST SPendingAssign&); // Prevent assignment
|
|
};
|
|
|
|
struct SBufferNode {
|
|
CHAR8 *mBufferStart;
|
|
CHAR8 *mBufferEnd;
|
|
CHAR8 *mBufferFree;
|
|
struct SBufferNode *mNext;
|
|
};
|
|
|
|
typedef struct {
|
|
BOOLEAN CompatibleMode;
|
|
EFI_GUID *OverrideClassGuid;
|
|
} INPUT_INFO_TO_SYNTAX;
|
|
|
|
class CFormPkg {
|
|
private:
|
|
UINT32 mBufferSize;
|
|
SBufferNode *mBufferNodeQueueHead;
|
|
SBufferNode *mBufferNodeQueueTail;
|
|
SBufferNode *mCurrBufferNode;
|
|
|
|
SBufferNode *mReadBufferNode;
|
|
UINT32 mReadBufferOffset;
|
|
|
|
UINT32 mPkgLength;
|
|
|
|
VOID _WRITE_PKG_LINE (IN FILE *, IN UINT32 , IN CONST CHAR8 *, IN CHAR8 *, IN UINT32);
|
|
VOID _WRITE_PKG_END (IN FILE *, IN UINT32 , IN CONST CHAR8 *, IN CHAR8 *, IN UINT32);
|
|
SBufferNode * GetBinBufferNodeForAddr (IN CHAR8 *);
|
|
SBufferNode * CreateNewNode ();
|
|
SBufferNode * GetNodeBefore (IN SBufferNode *);
|
|
EFI_VFR_RETURN_CODE InsertNodeBefore (IN SBufferNode *, IN SBufferNode *);
|
|
|
|
private:
|
|
SPendingAssign *PendingAssignList;
|
|
|
|
public:
|
|
CFormPkg (IN UINT32 BufferSize = 4096);
|
|
~CFormPkg ();
|
|
|
|
CHAR8 * IfrBinBufferGet (IN UINT32);
|
|
inline UINT32 GetPkgLength (VOID);
|
|
|
|
VOID Open ();
|
|
UINT32 Read (IN CHAR8 *, IN UINT32);
|
|
VOID Close ();
|
|
|
|
EFI_VFR_RETURN_CODE BuildPkgHdr (OUT EFI_HII_PACKAGE_HEADER **);
|
|
EFI_VFR_RETURN_CODE BuildPkg (IN FILE *, IN PACKAGE_DATA *PkgData = NULL);
|
|
EFI_VFR_RETURN_CODE BuildPkg (OUT PACKAGE_DATA &);
|
|
EFI_VFR_RETURN_CODE GenCFile (IN CHAR8 *, IN FILE *, IN PACKAGE_DATA *PkgData = NULL);
|
|
|
|
private:
|
|
CFormPkg (IN CONST CFormPkg&); // Prevent copy-construction
|
|
CFormPkg& operator= (IN CONST CFormPkg&); // Prevent assignment
|
|
|
|
public:
|
|
EFI_VFR_RETURN_CODE AssignPending (IN CHAR8 *, IN VOID *, IN UINT32, IN UINT32, IN CONST CHAR8 *Msg = NULL);
|
|
VOID DoPendingAssign (IN CHAR8 *, IN VOID *, IN UINT32);
|
|
bool HavePendingUnassigned (VOID);
|
|
VOID PendingAssignPrintAll (VOID);
|
|
EFI_VFR_RETURN_CODE DeclarePendingQuestion (
|
|
IN CVfrVarDataTypeDB &lCVfrVarDataTypeDB,
|
|
IN CVfrDataStorage &lCVfrDataStorage,
|
|
IN CVfrQuestionDB &lCVfrQuestionDB,
|
|
IN EFI_GUID *LocalFormSetGuid,
|
|
IN UINT32 LineNo,
|
|
OUT CHAR8 **InsertOpcodeAddr
|
|
);
|
|
EFI_VFR_RETURN_CODE AdjustDynamicInsertOpcode (
|
|
IN CHAR8 *LastFormEndAddr,
|
|
IN CHAR8 *InsertOpcodeAddr,
|
|
IN BOOLEAN CreateOpcodeAfterParsingVfr
|
|
);
|
|
CHAR8 * GetBufAddrBaseOnOffset (
|
|
IN UINT32 Offset
|
|
);
|
|
};
|
|
|
|
extern CFormPkg gCFormPkg;
|
|
extern CVfrStringDB gCVfrStringDB;
|
|
extern UINT32 gAdjustOpcodeOffset;
|
|
extern BOOLEAN gNeedAdjustOpcode;
|
|
|
|
struct SIfrRecord {
|
|
UINT32 mLineNo;
|
|
CHAR8 *mIfrBinBuf;
|
|
UINT8 mBinBufLen;
|
|
UINT32 mOffset;
|
|
SIfrRecord *mNext;
|
|
|
|
SIfrRecord (VOID);
|
|
~SIfrRecord (VOID);
|
|
};
|
|
|
|
|
|
#define EFI_IFR_RECORDINFO_IDX_INVALUD 0xFFFFFF
|
|
#define EFI_IFR_RECORDINFO_IDX_START 0x0
|
|
#define EFI_HII_MAX_SUPPORT_DEFAULT_TYPE 0x08
|
|
|
|
struct QuestionDefaultRecord {
|
|
BOOLEAN mIsDefaultIdExist[EFI_HII_MAX_SUPPORT_DEFAULT_TYPE]; // Record the default id in mAllDefaultIdArray[EFI_HII_MAX_SUPPORT_DEFAULT_TYPE]
|
|
// whether exists in current question.
|
|
|
|
SIfrRecord *mDefaultValueRecord; // Point to the default value record in RecordList which has smallest default Id.
|
|
// (for checkbox it may be NULL, because the dedault value is always true when the flag is set.)
|
|
|
|
BOOLEAN mIsDefaultOpcode; // whether the default value with smallest default id is given by default opcode.
|
|
// (for oneof and checkbox default info may be given by flag.)
|
|
|
|
UINT16 mDefaultNumber; // The default number of this question.
|
|
};
|
|
|
|
class CIfrRecordInfoDB {
|
|
private:
|
|
bool mSwitch;
|
|
UINT32 mRecordCount;
|
|
SIfrRecord *mIfrRecordListHead;
|
|
SIfrRecord *mIfrRecordListTail;
|
|
UINT8 mAllDefaultTypeCount;
|
|
UINT16 mAllDefaultIdArray[EFI_HII_MAX_SUPPORT_DEFAULT_TYPE];
|
|
|
|
SIfrRecord * GetRecordInfoFromIdx (IN UINT32);
|
|
BOOLEAN CheckQuestionOpCode (IN UINT8);
|
|
BOOLEAN CheckIdOpCode (IN UINT8);
|
|
EFI_QUESTION_ID GetOpcodeQuestionId (IN EFI_IFR_OP_HEADER *);
|
|
public:
|
|
CIfrRecordInfoDB (VOID);
|
|
~CIfrRecordInfoDB (VOID);
|
|
|
|
inline VOID TurnOn (VOID) {
|
|
mSwitch = TRUE;
|
|
}
|
|
|
|
inline VOID TurnOff (VOID) {
|
|
mSwitch = FALSE;
|
|
}
|
|
|
|
SIfrRecord * GetRecordInfoFromOffset (IN UINT32);
|
|
VOID IfrAdjustOffsetForRecord (VOID);
|
|
BOOLEAN IfrAdjustDynamicOpcodeInRecords (IN BOOLEAN);
|
|
|
|
UINT32 IfrRecordRegister (IN UINT32, IN CHAR8 *, IN UINT8, IN UINT32);
|
|
VOID IfrRecordInfoUpdate (IN UINT32, IN UINT32, IN CHAR8*, IN UINT8, IN UINT32);
|
|
VOID IfrRecordOutput (IN FILE *, IN UINT32 LineNo);
|
|
VOID IfrRecordOutput (OUT PACKAGE_DATA &);
|
|
EFI_VFR_RETURN_CODE IfrRecordAdjust (VOID);
|
|
VOID IfrUpdateRecordInfoForDynamicOpcode (IN BOOLEAN);
|
|
VOID IfrCheckAddDefaultRecord (IN BOOLEAN, IN BOOLEAN);
|
|
VOID IfrGetDefaultStoreInfo ();
|
|
VOID IfrCreateDefaultRecord (IN UINT8 Size,IN UINT16 DefaultId,IN UINT8 Type,IN UINT32 LineNo,IN EFI_IFR_TYPE_VALUE Value);
|
|
VOID IfrCreateDefaultForQuestion (IN SIfrRecord *, IN QuestionDefaultRecord *);
|
|
VOID IfrParseDefaulInfoInQuestion (IN SIfrRecord *, OUT QuestionDefaultRecord *);
|
|
VOID IfrAddDefaultToBufferConfig (IN UINT16, IN SIfrRecord *,IN EFI_IFR_TYPE_VALUE);
|
|
|
|
private:
|
|
CIfrRecordInfoDB (IN CONST CIfrRecordInfoDB&); // Prevent copy-construction
|
|
CIfrRecordInfoDB& operator= (IN CONST CIfrRecordInfoDB&); // Prevent assignment
|
|
};
|
|
|
|
extern CIfrRecordInfoDB gCIfrRecordInfoDB;
|
|
|
|
/*
|
|
* The definition of CIfrObj
|
|
*/
|
|
extern BOOLEAN gCreateOp;
|
|
|
|
class CIfrObj {
|
|
private:
|
|
BOOLEAN mDelayEmit;
|
|
|
|
CHAR8 *mObjBinBuf;
|
|
UINT8 mObjBinLen;
|
|
UINT32 mLineNo;
|
|
UINT32 mRecordIdx;
|
|
UINT32 mPkgOffset;
|
|
|
|
public:
|
|
CIfrObj (IN UINT8 OpCode, OUT CHAR8 **IfrObj = NULL, IN UINT8 ObjBinLen = 0, IN BOOLEAN DelayEmit = FALSE);
|
|
virtual ~CIfrObj(VOID);
|
|
|
|
VOID _EMIT_PENDING_OBJ (VOID);
|
|
|
|
inline VOID SetLineNo (IN UINT32 LineNo) {
|
|
mLineNo = LineNo;
|
|
}
|
|
|
|
inline CHAR8 * GetObjBinAddr (VOID) {
|
|
return mObjBinBuf;
|
|
}
|
|
|
|
inline UINT32 GetObjBinOffset (VOID) {
|
|
return mPkgOffset;
|
|
}
|
|
|
|
inline UINT8 GetObjBinLen (VOID) {
|
|
return mObjBinLen;
|
|
}
|
|
|
|
inline bool ExpendObjBin (IN UINT8 Size) {
|
|
if ((mDelayEmit == TRUE) && ((mObjBinLen + Size) > mObjBinLen)) {
|
|
mObjBinLen = mObjBinLen + Size;
|
|
return TRUE;
|
|
} else {
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
inline bool ShrinkObjBin (IN UINT8 Size) {
|
|
if ((mDelayEmit == TRUE) && (mObjBinLen > Size)) {
|
|
mObjBinLen -= Size;
|
|
return TRUE;
|
|
} else {
|
|
return FALSE;
|
|
}
|
|
}
|
|
};
|
|
|
|
/*
|
|
* The definition of CIfrOpHeader
|
|
*/
|
|
class CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_OP_HEADER *mHeader;
|
|
|
|
public:
|
|
CIfrOpHeader (IN UINT8 OpCode, IN VOID *StartAddr, IN UINT8 Length = 0);
|
|
CIfrOpHeader (IN CIfrOpHeader &);
|
|
CIfrOpHeader& operator=(IN CONST CIfrOpHeader &);
|
|
|
|
VOID IncLength (UINT8 Size) {
|
|
if ((mHeader->Length + Size) > mHeader->Length) {
|
|
mHeader->Length = mHeader->Length + Size;
|
|
}
|
|
}
|
|
|
|
VOID DecLength (UINT8 Size) {
|
|
if (mHeader->Length >= Size) {
|
|
mHeader->Length -= Size;
|
|
}
|
|
}
|
|
|
|
UINT8 GetLength () {
|
|
return mHeader->Length;
|
|
}
|
|
|
|
UINT8 GetScope () {
|
|
return mHeader->Scope;
|
|
}
|
|
|
|
VOID SetScope (IN UINT8 Scope) {
|
|
mHeader->Scope = Scope;
|
|
}
|
|
|
|
VOID UpdateHeader (IN EFI_IFR_OP_HEADER *Header) {
|
|
mHeader = Header;
|
|
}
|
|
|
|
UINT8 GetOpCode () {
|
|
return mHeader->OpCode;
|
|
}
|
|
};
|
|
|
|
extern UINT8 gScopeCount;
|
|
|
|
/*
|
|
* The definition of CIfrStatementHeader
|
|
*/
|
|
class CIfrStatementHeader {
|
|
private:
|
|
EFI_IFR_STATEMENT_HEADER *mHeader;
|
|
|
|
public:
|
|
CIfrStatementHeader (
|
|
IN EFI_IFR_STATEMENT_HEADER *StartAddr
|
|
) : mHeader ((EFI_IFR_STATEMENT_HEADER *)StartAddr) {
|
|
mHeader = StartAddr;
|
|
mHeader->Help = EFI_STRING_ID_INVALID;
|
|
mHeader->Prompt = EFI_STRING_ID_INVALID;
|
|
}
|
|
|
|
EFI_IFR_STATEMENT_HEADER *GetStatementHeader () {
|
|
return mHeader;
|
|
}
|
|
|
|
VOID SetPrompt (IN EFI_STRING_ID Prompt) {
|
|
mHeader->Prompt = Prompt;
|
|
}
|
|
|
|
VOID SetHelp (IN EFI_STRING_ID Help) {
|
|
mHeader->Help = Help;
|
|
}
|
|
};
|
|
|
|
/*
|
|
* The definition of CIfrQuestionHeader
|
|
*/
|
|
#define EFI_IFR_QUESTION_FLAG_DEFAULT 0
|
|
|
|
class CIfrQuestionHeader : public CIfrStatementHeader {
|
|
private:
|
|
EFI_IFR_QUESTION_HEADER *mHeader;
|
|
|
|
EFI_IFR_STATEMENT_HEADER * QH2SH (EFI_IFR_QUESTION_HEADER *Qheader) {
|
|
return &(Qheader)->Header;
|
|
}
|
|
|
|
public:
|
|
EFI_QUESTION_ID QUESTION_ID (VOID) {
|
|
return mHeader->QuestionId;
|
|
}
|
|
|
|
EFI_VARSTORE_ID VARSTORE_ID (VOID) {
|
|
return mHeader->VarStoreId;
|
|
}
|
|
|
|
VOID VARSTORE_INFO (OUT EFI_VARSTORE_INFO *Info) {
|
|
if (Info != NULL) {
|
|
Info->mVarStoreId = mHeader->VarStoreId;
|
|
memmove (&Info->mVarStoreId, &mHeader->VarStoreInfo, sizeof (Info->mVarStoreId));
|
|
}
|
|
}
|
|
|
|
UINT8 FLAGS (VOID) {
|
|
return mHeader->Flags;
|
|
}
|
|
|
|
public:
|
|
CIfrQuestionHeader (
|
|
IN EFI_IFR_QUESTION_HEADER *StartAddr,
|
|
IN UINT8 Flags = EFI_IFR_QUESTION_FLAG_DEFAULT
|
|
) : CIfrStatementHeader (QH2SH(StartAddr)) {
|
|
mHeader = StartAddr;
|
|
mHeader->QuestionId = EFI_QUESTION_ID_INVALID;
|
|
mHeader->VarStoreId = EFI_VARSTORE_ID_INVALID;
|
|
mHeader->VarStoreInfo.VarName = EFI_STRING_ID_INVALID;
|
|
mHeader->VarStoreInfo.VarOffset = EFI_VAROFFSET_INVALID;
|
|
mHeader->Flags = Flags;
|
|
}
|
|
|
|
VOID SetQuestionId (IN EFI_QUESTION_ID QuestionId) {
|
|
mHeader->QuestionId = QuestionId;
|
|
}
|
|
|
|
VOID SetVarStoreInfo (IN EFI_VARSTORE_INFO *Info) {
|
|
mHeader->VarStoreId = Info->mVarStoreId;
|
|
mHeader->VarStoreInfo.VarName = Info->mInfo.mVarName;
|
|
mHeader->VarStoreInfo.VarOffset = Info->mInfo.mVarOffset;
|
|
}
|
|
|
|
EFI_VFR_RETURN_CODE SetFlags (IN UINT8 Flags) {
|
|
if (_FLAG_TEST_AND_CLEAR (Flags, EFI_IFR_FLAG_READ_ONLY)) {
|
|
mHeader->Flags |= EFI_IFR_FLAG_READ_ONLY;
|
|
}
|
|
|
|
_FLAG_CLEAR (Flags, 0x02);
|
|
|
|
if (_FLAG_TEST_AND_CLEAR (Flags, EFI_IFR_FLAG_CALLBACK)) {
|
|
mHeader->Flags |= EFI_IFR_FLAG_CALLBACK;
|
|
}
|
|
|
|
//
|
|
// ignore NVAccessFlag
|
|
//
|
|
_FLAG_CLEAR (Flags, 0x08);
|
|
|
|
if (_FLAG_TEST_AND_CLEAR (Flags, EFI_IFR_FLAG_RESET_REQUIRED)) {
|
|
mHeader->Flags |= EFI_IFR_FLAG_RESET_REQUIRED;
|
|
}
|
|
|
|
if (_FLAG_TEST_AND_CLEAR (Flags, EFI_IFR_FLAG_RECONNECT_REQUIRED)) {
|
|
mHeader->Flags |= EFI_IFR_FLAG_RECONNECT_REQUIRED;
|
|
}
|
|
|
|
//
|
|
// Set LateCheck Flag to compatible for framework flag
|
|
// but it uses 0x20 as its flag, if in the future UEFI may take this flag
|
|
//
|
|
if (_FLAG_TEST_AND_CLEAR (Flags, 0x20)) {
|
|
mHeader->Flags |= 0x20;
|
|
}
|
|
|
|
if (_FLAG_TEST_AND_CLEAR (Flags, EFI_IFR_FLAG_OPTIONS_ONLY)) {
|
|
mHeader->Flags |= EFI_IFR_FLAG_OPTIONS_ONLY;
|
|
}
|
|
|
|
return _FLAGS_ZERO (Flags) ? VFR_RETURN_SUCCESS : VFR_RETURN_FLAGS_UNSUPPORTED;
|
|
}
|
|
|
|
VOID UpdateCIfrQuestionHeader (IN EFI_IFR_QUESTION_HEADER *Header) {
|
|
mHeader = Header;
|
|
}
|
|
};
|
|
|
|
/*
|
|
* The definition of CIfrMinMaxStepData
|
|
*/
|
|
class CIfrMinMaxStepData {
|
|
private:
|
|
MINMAXSTEP_DATA *mMinMaxStepData;
|
|
BOOLEAN ValueIsSet;
|
|
BOOLEAN IsNumeric;
|
|
|
|
public:
|
|
CIfrMinMaxStepData (MINMAXSTEP_DATA *DataAddr, BOOLEAN NumericOpcode=FALSE) : mMinMaxStepData (DataAddr) {
|
|
mMinMaxStepData->u64.MinValue = 0;
|
|
mMinMaxStepData->u64.MaxValue = 0;
|
|
mMinMaxStepData->u64.Step = 0;
|
|
ValueIsSet = FALSE;
|
|
IsNumeric = NumericOpcode;
|
|
}
|
|
|
|
VOID SetMinMaxStepData (IN UINT64 MinValue, IN UINT64 MaxValue, IN UINT64 Step) {
|
|
if (!ValueIsSet) {
|
|
mMinMaxStepData->u64.MinValue = MinValue;
|
|
mMinMaxStepData->u64.MaxValue = MaxValue;
|
|
ValueIsSet = TRUE;
|
|
} else {
|
|
if (MinValue < mMinMaxStepData->u64.MinValue) {
|
|
mMinMaxStepData->u64.MinValue = MinValue;
|
|
}
|
|
if (MaxValue > mMinMaxStepData->u64.MaxValue) {
|
|
mMinMaxStepData->u64.MaxValue = MaxValue;
|
|
}
|
|
}
|
|
mMinMaxStepData->u64.Step = Step;
|
|
}
|
|
|
|
VOID SetMinMaxStepData (IN UINT32 MinValue, IN UINT32 MaxValue, IN UINT32 Step) {
|
|
if (!ValueIsSet) {
|
|
mMinMaxStepData->u32.MinValue = MinValue;
|
|
mMinMaxStepData->u32.MaxValue = MaxValue;
|
|
ValueIsSet = TRUE;
|
|
} else {
|
|
if (MinValue < mMinMaxStepData->u32.MinValue) {
|
|
mMinMaxStepData->u32.MinValue = MinValue;
|
|
}
|
|
if (MaxValue > mMinMaxStepData->u32.MaxValue) {
|
|
mMinMaxStepData->u32.MaxValue = MaxValue;
|
|
}
|
|
}
|
|
mMinMaxStepData->u32.Step = Step;
|
|
}
|
|
|
|
VOID SetMinMaxStepData (IN UINT16 MinValue, IN UINT16 MaxValue, IN UINT16 Step) {
|
|
if (!ValueIsSet) {
|
|
mMinMaxStepData->u16.MinValue = MinValue;
|
|
mMinMaxStepData->u16.MaxValue = MaxValue;
|
|
ValueIsSet = TRUE;
|
|
} else {
|
|
if (MinValue < mMinMaxStepData->u16.MinValue) {
|
|
mMinMaxStepData->u16.MinValue = MinValue;
|
|
}
|
|
if (MaxValue > mMinMaxStepData->u16.MaxValue) {
|
|
mMinMaxStepData->u16.MaxValue = MaxValue;
|
|
}
|
|
}
|
|
mMinMaxStepData->u16.Step = Step;
|
|
}
|
|
|
|
VOID SetMinMaxStepData (IN UINT8 MinValue, IN UINT8 MaxValue, IN UINT8 Step) {
|
|
if (!ValueIsSet) {
|
|
mMinMaxStepData->u8.MinValue = MinValue;
|
|
mMinMaxStepData->u8.MaxValue = MaxValue;
|
|
ValueIsSet = TRUE;
|
|
} else {
|
|
if (MinValue < mMinMaxStepData->u8.MinValue) {
|
|
mMinMaxStepData->u8.MinValue = MinValue;
|
|
}
|
|
if (MaxValue > mMinMaxStepData->u8.MaxValue) {
|
|
mMinMaxStepData->u8.MaxValue = MaxValue;
|
|
}
|
|
}
|
|
mMinMaxStepData->u8.Step = Step;
|
|
}
|
|
|
|
UINT64 GetMinData (UINT8 VarType, BOOLEAN IsBitVar) {
|
|
UINT64 MinValue = 0;
|
|
if (IsBitVar) {
|
|
MinValue = mMinMaxStepData->u32.MinValue;
|
|
return MinValue;
|
|
}
|
|
switch (VarType) {
|
|
case EFI_IFR_TYPE_NUM_SIZE_64:
|
|
MinValue = mMinMaxStepData->u64.MinValue;
|
|
break;
|
|
case EFI_IFR_TYPE_NUM_SIZE_32:
|
|
MinValue = (UINT64) mMinMaxStepData->u32.MinValue;
|
|
break;
|
|
case EFI_IFR_TYPE_NUM_SIZE_16:
|
|
MinValue = (UINT64) mMinMaxStepData->u16.MinValue;
|
|
break;
|
|
case EFI_IFR_TYPE_NUM_SIZE_8:
|
|
MinValue = (UINT64) mMinMaxStepData->u8.MinValue;
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
return MinValue;
|
|
}
|
|
|
|
UINT64 GetMaxData (UINT8 VarType, BOOLEAN IsBitVar) {
|
|
UINT64 MaxValue = 0;
|
|
if (IsBitVar) {
|
|
MaxValue = mMinMaxStepData->u32.MaxValue;
|
|
return MaxValue;
|
|
}
|
|
switch (VarType) {
|
|
case EFI_IFR_TYPE_NUM_SIZE_64:
|
|
MaxValue = mMinMaxStepData->u64.MaxValue;
|
|
break;
|
|
case EFI_IFR_TYPE_NUM_SIZE_32:
|
|
MaxValue = (UINT64) mMinMaxStepData->u32.MaxValue;
|
|
break;
|
|
case EFI_IFR_TYPE_NUM_SIZE_16:
|
|
MaxValue = (UINT64) mMinMaxStepData->u16.MaxValue;
|
|
break;
|
|
case EFI_IFR_TYPE_NUM_SIZE_8:
|
|
MaxValue = (UINT64) mMinMaxStepData->u8.MaxValue;
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
return MaxValue;
|
|
}
|
|
|
|
UINT64 GetStepData (UINT8 VarType, BOOLEAN IsBitVar) {
|
|
UINT64 MaxValue = 0;
|
|
if (IsBitVar) {
|
|
MaxValue = mMinMaxStepData->u32.Step;
|
|
return MaxValue;
|
|
}
|
|
switch (VarType) {
|
|
case EFI_IFR_TYPE_NUM_SIZE_64:
|
|
MaxValue = mMinMaxStepData->u64.Step;
|
|
break;
|
|
case EFI_IFR_TYPE_NUM_SIZE_32:
|
|
MaxValue = (UINT64) mMinMaxStepData->u32.Step;
|
|
break;
|
|
case EFI_IFR_TYPE_NUM_SIZE_16:
|
|
MaxValue = (UINT64) mMinMaxStepData->u16.Step;
|
|
break;
|
|
case EFI_IFR_TYPE_NUM_SIZE_8:
|
|
MaxValue = (UINT64) mMinMaxStepData->u8.Step;
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
return MaxValue;
|
|
}
|
|
|
|
BOOLEAN IsNumericOpcode () {
|
|
return IsNumeric;
|
|
}
|
|
|
|
VOID UpdateCIfrMinMaxStepData (IN MINMAXSTEP_DATA *MinMaxStepData) {
|
|
mMinMaxStepData = MinMaxStepData;
|
|
}
|
|
};
|
|
|
|
static CIfrQuestionHeader *gCurrentQuestion = NULL;
|
|
static CIfrMinMaxStepData *gCurrentMinMaxData = NULL;
|
|
static BOOLEAN gIsOrderedList = FALSE;
|
|
static BOOLEAN gIsStringOp = FALSE;
|
|
|
|
/*
|
|
* The definition of all of the UEFI IFR Objects
|
|
*/
|
|
class CIfrFormSet : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_FORM_SET *mFormSet;
|
|
EFI_GUID *mClassGuid;
|
|
|
|
public:
|
|
CIfrFormSet (UINT8 Size) : CIfrObj (EFI_IFR_FORM_SET_OP, (CHAR8 **)&mFormSet, Size),
|
|
CIfrOpHeader (EFI_IFR_FORM_SET_OP, &mFormSet->Header, Size) {
|
|
mFormSet->Help = EFI_STRING_ID_INVALID;
|
|
mFormSet->FormSetTitle = EFI_STRING_ID_INVALID;
|
|
mFormSet->Flags = 0;
|
|
memset (&mFormSet->Guid, 0, sizeof (EFI_GUID));
|
|
mClassGuid = (EFI_GUID *) (mFormSet + 1);
|
|
}
|
|
|
|
VOID SetGuid (IN EFI_GUID *Guid) {
|
|
memmove (&mFormSet->Guid, Guid, sizeof (EFI_GUID));
|
|
}
|
|
|
|
VOID SetFormSetTitle (IN EFI_STRING_ID FormSetTitle) {
|
|
mFormSet->FormSetTitle = FormSetTitle;
|
|
}
|
|
|
|
VOID SetHelp (IN EFI_STRING_ID Help) {
|
|
mFormSet->Help = Help;
|
|
}
|
|
|
|
VOID SetClassGuid (IN EFI_GUID *Guid) {
|
|
memmove (&(mClassGuid[mFormSet->Flags++]), Guid, sizeof (EFI_GUID));
|
|
}
|
|
|
|
UINT8 GetFlags() {
|
|
return mFormSet->Flags;
|
|
}
|
|
};
|
|
|
|
class CIfrEnd : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_END *mEnd;
|
|
|
|
public:
|
|
CIfrEnd () : CIfrObj (EFI_IFR_END_OP, (CHAR8 **)&mEnd),
|
|
CIfrOpHeader (EFI_IFR_END_OP, &mEnd->Header) {}
|
|
};
|
|
|
|
class CIfrDefaultStore : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_DEFAULTSTORE *mDefaultStore;
|
|
|
|
public:
|
|
CIfrDefaultStore () : CIfrObj (EFI_IFR_DEFAULTSTORE_OP, (CHAR8 **)&mDefaultStore),
|
|
CIfrOpHeader (EFI_IFR_DEFAULTSTORE_OP, &mDefaultStore->Header) {
|
|
mDefaultStore->DefaultId = EFI_VARSTORE_ID_INVALID;
|
|
mDefaultStore->DefaultName = EFI_STRING_ID_INVALID;
|
|
}
|
|
|
|
VOID SetDefaultName (IN EFI_STRING_ID DefaultName) {
|
|
mDefaultStore->DefaultName = DefaultName;
|
|
}
|
|
|
|
VOID SetDefaultId (IN UINT16 DefaultId) {
|
|
mDefaultStore->DefaultId = DefaultId;
|
|
}
|
|
};
|
|
|
|
#define EFI_FORM_ID_MAX 0xFFFF
|
|
#define EFI_FREE_FORM_ID_BITMAP_SIZE ((EFI_FORM_ID_MAX + 1) / EFI_BITS_PER_UINT32)
|
|
|
|
class CIfrFormId {
|
|
public:
|
|
STATIC UINT32 FormIdBitMap[EFI_FREE_FORM_ID_BITMAP_SIZE];
|
|
|
|
STATIC BOOLEAN ChekFormIdFree (IN EFI_FORM_ID FormId) {
|
|
UINT32 Index = (FormId / EFI_BITS_PER_UINT32);
|
|
UINT32 Offset = (FormId % EFI_BITS_PER_UINT32);
|
|
|
|
return (FormIdBitMap[Index] & (0x80000000 >> Offset)) == 0;
|
|
}
|
|
|
|
STATIC VOID MarkFormIdUsed (IN EFI_FORM_ID FormId) {
|
|
UINT32 Index = (FormId / EFI_BITS_PER_UINT32);
|
|
UINT32 Offset = (FormId % EFI_BITS_PER_UINT32);
|
|
|
|
FormIdBitMap[Index] |= (0x80000000 >> Offset);
|
|
}
|
|
};
|
|
|
|
class CIfrForm : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_FORM *mForm;
|
|
|
|
public:
|
|
CIfrForm () : CIfrObj (EFI_IFR_FORM_OP, (CHAR8 **)&mForm),
|
|
CIfrOpHeader (EFI_IFR_FORM_OP, &mForm->Header) {
|
|
mForm->FormId = 0;
|
|
mForm->FormTitle = EFI_STRING_ID_INVALID;
|
|
}
|
|
|
|
EFI_VFR_RETURN_CODE SetFormId (IN EFI_FORM_ID FormId) {
|
|
if (FormId == 0) {
|
|
//
|
|
// FormId can't be 0.
|
|
//
|
|
return VFR_RETURN_INVALID_PARAMETER;
|
|
}
|
|
if (CIfrFormId::ChekFormIdFree (FormId) == FALSE) {
|
|
return VFR_RETURN_FORMID_REDEFINED;
|
|
}
|
|
mForm->FormId = FormId;
|
|
CIfrFormId::MarkFormIdUsed (FormId);
|
|
return VFR_RETURN_SUCCESS;
|
|
}
|
|
|
|
VOID SetFormTitle (IN EFI_STRING_ID FormTitle) {
|
|
mForm->FormTitle = FormTitle;
|
|
}
|
|
};
|
|
|
|
class CIfrFormMap : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_FORM_MAP *mFormMap;
|
|
EFI_IFR_FORM_MAP_METHOD *mMethodMap;
|
|
|
|
public:
|
|
CIfrFormMap () : CIfrObj (EFI_IFR_FORM_MAP_OP, (CHAR8 **)&mFormMap, sizeof (EFI_IFR_FORM_MAP), TRUE),
|
|
CIfrOpHeader (EFI_IFR_FORM_MAP_OP, &mFormMap->Header) {
|
|
mFormMap->FormId = 0;
|
|
mMethodMap = (EFI_IFR_FORM_MAP_METHOD *) (mFormMap + 1);
|
|
}
|
|
|
|
EFI_VFR_RETURN_CODE SetFormId (IN EFI_FORM_ID FormId) {
|
|
if (FormId == 0) {
|
|
//
|
|
// FormId can't be 0.
|
|
//
|
|
return VFR_RETURN_INVALID_PARAMETER;
|
|
}
|
|
if (CIfrFormId::ChekFormIdFree (FormId) == FALSE) {
|
|
return VFR_RETURN_FORMID_REDEFINED;
|
|
}
|
|
mFormMap->FormId = FormId;
|
|
CIfrFormId::MarkFormIdUsed (FormId);
|
|
return VFR_RETURN_SUCCESS;
|
|
}
|
|
|
|
VOID SetFormMapMethod (IN EFI_STRING_ID MethodTitle, IN EFI_GUID *MethodGuid) {
|
|
if (ExpendObjBin (sizeof (EFI_IFR_FORM_MAP_METHOD))) {
|
|
IncLength (sizeof (EFI_IFR_FORM_MAP_METHOD));
|
|
|
|
mMethodMap->MethodTitle = MethodTitle;
|
|
memmove (&(mMethodMap->MethodIdentifier), MethodGuid, sizeof (EFI_GUID));
|
|
mMethodMap ++;
|
|
}
|
|
}
|
|
};
|
|
|
|
class CIfrVarStore : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_VARSTORE *mVarStore;
|
|
|
|
public:
|
|
CIfrVarStore () : CIfrObj (EFI_IFR_VARSTORE_OP, (CHAR8 **)&mVarStore, sizeof (EFI_IFR_VARSTORE), TRUE),
|
|
CIfrOpHeader (EFI_IFR_VARSTORE_OP, &mVarStore->Header) {
|
|
mVarStore->VarStoreId = EFI_VARSTORE_ID_INVALID;
|
|
mVarStore->Size = 0;
|
|
memset (&mVarStore->Guid, 0, sizeof (EFI_GUID));
|
|
mVarStore->Name[0] = '\0';
|
|
}
|
|
|
|
VOID SetGuid (IN EFI_GUID *Guid) {
|
|
memmove (&mVarStore->Guid, Guid, sizeof (EFI_GUID));
|
|
}
|
|
|
|
VOID SetVarStoreId (IN EFI_VARSTORE_ID VarStoreId) {
|
|
mVarStore->VarStoreId = VarStoreId;
|
|
}
|
|
|
|
VOID SetSize (IN UINT16 Size) {
|
|
mVarStore->Size = Size;
|
|
}
|
|
|
|
VOID SetName (IN CHAR8 *Name) {
|
|
UINT8 Len;
|
|
|
|
if (Name != NULL) {
|
|
Len = (UINT8) strlen (Name);
|
|
if (Len != 0) {
|
|
if (ExpendObjBin (Len) == TRUE) {
|
|
IncLength (Len);
|
|
strcpy ((CHAR8 *)(mVarStore->Name), Name);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
};
|
|
|
|
class CIfrVarStoreEfi : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_VARSTORE_EFI *mVarStoreEfi;
|
|
|
|
public:
|
|
CIfrVarStoreEfi () : CIfrObj (EFI_IFR_VARSTORE_EFI_OP, (CHAR8 **)&mVarStoreEfi, sizeof (EFI_IFR_VARSTORE_EFI), TRUE),
|
|
CIfrOpHeader (EFI_IFR_VARSTORE_EFI_OP, &mVarStoreEfi->Header) {
|
|
mVarStoreEfi->VarStoreId = EFI_VAROFFSET_INVALID;
|
|
mVarStoreEfi->Size = 0;
|
|
memset (&mVarStoreEfi->Guid, 0, sizeof (EFI_GUID));
|
|
mVarStoreEfi->Name[0] = '\0';
|
|
}
|
|
|
|
VOID SetGuid (IN EFI_GUID *Guid) {
|
|
memmove (&mVarStoreEfi->Guid, Guid, sizeof (EFI_GUID));
|
|
}
|
|
|
|
VOID SetVarStoreId (IN UINT16 VarStoreId) {
|
|
mVarStoreEfi->VarStoreId = VarStoreId;
|
|
}
|
|
|
|
VOID SetAttributes (IN UINT32 Attributes) {
|
|
mVarStoreEfi->Attributes = Attributes;
|
|
}
|
|
VOID SetSize (IN UINT16 Size) {
|
|
mVarStoreEfi->Size = Size;
|
|
}
|
|
|
|
VOID SetName (IN CHAR8 *Name) {
|
|
UINT8 Len;
|
|
|
|
if (Name != NULL) {
|
|
Len = (UINT8) strlen (Name);
|
|
if (Len != 0) {
|
|
if (ExpendObjBin (Len) == TRUE) {
|
|
IncLength (Len);
|
|
strcpy ((CHAR8 *)(mVarStoreEfi->Name), Name);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
VOID SetBinaryLength (IN UINT16 Size) {
|
|
UINT16 Len;
|
|
|
|
Len = sizeof (EFI_IFR_VARSTORE_EFI);
|
|
if (Size > Len) {
|
|
ExpendObjBin(Size - Len);
|
|
IncLength(Size - Len);
|
|
} else {
|
|
ShrinkObjBin(Len - Size);
|
|
DecLength(Len - Size);
|
|
}
|
|
}
|
|
};
|
|
|
|
class CIfrVarStoreNameValue : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_VARSTORE_NAME_VALUE *mVarStoreNameValue;
|
|
|
|
public:
|
|
CIfrVarStoreNameValue () : CIfrObj (EFI_IFR_VARSTORE_NAME_VALUE_OP, (CHAR8 **)&mVarStoreNameValue),
|
|
CIfrOpHeader (EFI_IFR_VARSTORE_NAME_VALUE_OP, &mVarStoreNameValue->Header) {
|
|
mVarStoreNameValue->VarStoreId = EFI_VAROFFSET_INVALID;
|
|
memset (&mVarStoreNameValue->Guid, 0, sizeof (EFI_GUID));
|
|
}
|
|
|
|
VOID SetGuid (IN EFI_GUID *Guid) {
|
|
memmove (&mVarStoreNameValue->Guid, Guid, sizeof (EFI_GUID));
|
|
}
|
|
|
|
VOID SetVarStoreId (IN UINT16 VarStoreId) {
|
|
mVarStoreNameValue->VarStoreId = VarStoreId;
|
|
}
|
|
};
|
|
|
|
class CIfrImage : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_IMAGE *mImage;
|
|
|
|
public:
|
|
CIfrImage () : CIfrObj (EFI_IFR_IMAGE_OP, (CHAR8 **)&mImage),
|
|
CIfrOpHeader (EFI_IFR_IMAGE_OP, &mImage->Header) {
|
|
mImage->Id = EFI_IMAGE_ID_INVALID;
|
|
}
|
|
|
|
VOID SetImageId (IN EFI_IMAGE_ID ImageId) {
|
|
mImage->Id = ImageId;
|
|
}
|
|
};
|
|
|
|
class CIfrModal : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_MODAL_TAG *mModal;
|
|
|
|
public:
|
|
CIfrModal () : CIfrObj (EFI_IFR_MODAL_TAG_OP, (CHAR8 **)&mModal),
|
|
CIfrOpHeader (EFI_IFR_MODAL_TAG_OP, &mModal->Header) {
|
|
}
|
|
};
|
|
|
|
|
|
class CIfrLocked : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_LOCKED *mLocked;
|
|
|
|
public:
|
|
CIfrLocked () : CIfrObj (EFI_IFR_LOCKED_OP, (CHAR8 **)&mLocked),
|
|
CIfrOpHeader (EFI_IFR_LOCKED_OP, &mLocked->Header) {}
|
|
};
|
|
|
|
class CIfrRule : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_RULE *mRule;
|
|
|
|
public:
|
|
CIfrRule () : CIfrObj (EFI_IFR_RULE_OP, (CHAR8 **)&mRule),
|
|
mRule ((EFI_IFR_RULE *)GetObjBinAddr()),
|
|
CIfrOpHeader (EFI_IFR_RULE_OP, &mRule->Header) {
|
|
mRule->RuleId = EFI_RULE_ID_INVALID;
|
|
}
|
|
|
|
VOID SetRuleId (IN UINT8 RuleId) {
|
|
mRule->RuleId = RuleId;
|
|
}
|
|
};
|
|
|
|
static EFI_IFR_TYPE_VALUE gZeroEfiIfrTypeValue = {0, };
|
|
|
|
class CIfrDefault : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_DEFAULT *mDefault;
|
|
|
|
public:
|
|
CIfrDefault (
|
|
IN UINT8 Size,
|
|
IN UINT16 DefaultId = EFI_HII_DEFAULT_CLASS_STANDARD,
|
|
IN UINT8 Type = EFI_IFR_TYPE_OTHER,
|
|
IN EFI_IFR_TYPE_VALUE Value = gZeroEfiIfrTypeValue
|
|
) : CIfrObj (EFI_IFR_DEFAULT_OP, (CHAR8 **)&mDefault, Size),
|
|
CIfrOpHeader (EFI_IFR_DEFAULT_OP, &mDefault->Header, Size) {
|
|
mDefault->Type = Type;
|
|
mDefault->DefaultId = DefaultId;
|
|
memmove (&(mDefault->Value), &Value, Size - OFFSET_OF (EFI_IFR_DEFAULT, Value));
|
|
}
|
|
|
|
VOID SetDefaultId (IN UINT16 DefaultId) {
|
|
mDefault->DefaultId = DefaultId;
|
|
}
|
|
|
|
VOID SetType (IN UINT8 Type) {
|
|
mDefault->Type = Type;
|
|
}
|
|
|
|
VOID SetValue (IN EFI_IFR_TYPE_VALUE Value) {
|
|
memmove (&mDefault->Value, &Value, mDefault->Header.Length - OFFSET_OF (EFI_IFR_DEFAULT, Value));
|
|
}
|
|
};
|
|
|
|
class CIfrDefault2 : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_DEFAULT_2 *mDefault;
|
|
|
|
public:
|
|
CIfrDefault2 (
|
|
IN UINT16 DefaultId = EFI_HII_DEFAULT_CLASS_STANDARD,
|
|
IN UINT8 Type = EFI_IFR_TYPE_OTHER
|
|
) : CIfrObj (EFI_IFR_DEFAULT_OP, (CHAR8 **)&mDefault, sizeof (EFI_IFR_DEFAULT_2)),
|
|
CIfrOpHeader (EFI_IFR_DEFAULT_OP, &mDefault->Header, sizeof (EFI_IFR_DEFAULT_2)) {
|
|
mDefault->Type = Type;
|
|
mDefault->DefaultId = DefaultId;
|
|
}
|
|
|
|
VOID SetDefaultId (IN UINT16 DefaultId) {
|
|
mDefault->DefaultId = DefaultId;
|
|
}
|
|
|
|
VOID SetType (IN UINT8 Type) {
|
|
mDefault->Type = Type;
|
|
}
|
|
};
|
|
|
|
class CIfrValue : public CIfrObj, public CIfrOpHeader{
|
|
private:
|
|
EFI_IFR_VALUE *mValue;
|
|
|
|
public:
|
|
CIfrValue () : CIfrObj (EFI_IFR_VALUE_OP, (CHAR8 **)&mValue),
|
|
CIfrOpHeader (EFI_IFR_VALUE_OP, &mValue->Header) {}
|
|
|
|
};
|
|
|
|
class CIfrRead : public CIfrObj, public CIfrOpHeader{
|
|
private:
|
|
EFI_IFR_READ *mRead;
|
|
|
|
public:
|
|
CIfrRead () : CIfrObj (EFI_IFR_READ_OP, (CHAR8 **)&mRead),
|
|
CIfrOpHeader (EFI_IFR_READ_OP, &mRead->Header) {}
|
|
|
|
};
|
|
|
|
class CIfrWrite : public CIfrObj, public CIfrOpHeader{
|
|
private:
|
|
EFI_IFR_WRITE *mWrite;
|
|
|
|
public:
|
|
CIfrWrite () : CIfrObj (EFI_IFR_WRITE_OP, (CHAR8 **)&mWrite),
|
|
CIfrOpHeader (EFI_IFR_WRITE_OP, &mWrite->Header) {}
|
|
|
|
};
|
|
|
|
class CIfrGet : public CIfrObj, public CIfrOpHeader{
|
|
private:
|
|
EFI_IFR_GET *mGet;
|
|
|
|
public:
|
|
CIfrGet (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_GET_OP, (CHAR8 **)&mGet),
|
|
CIfrOpHeader (EFI_IFR_GET_OP, &mGet->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
|
|
VOID SetVarInfo (IN EFI_VARSTORE_INFO *Info) {
|
|
mGet->VarStoreId = Info->mVarStoreId;
|
|
mGet->VarStoreInfo.VarName = Info->mInfo.mVarName;
|
|
mGet->VarStoreInfo.VarOffset = Info->mInfo.mVarOffset;
|
|
mGet->VarStoreType = Info->mVarType;
|
|
}
|
|
};
|
|
|
|
class CIfrSet : public CIfrObj, public CIfrOpHeader{
|
|
private:
|
|
EFI_IFR_SET *mSet;
|
|
|
|
public:
|
|
CIfrSet (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_SET_OP, (CHAR8 **)&mSet),
|
|
CIfrOpHeader (EFI_IFR_SET_OP, &mSet->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
|
|
VOID SetVarInfo (IN EFI_VARSTORE_INFO *Info) {
|
|
mSet->VarStoreId = Info->mVarStoreId;
|
|
mSet->VarStoreInfo.VarName = Info->mInfo.mVarName;
|
|
mSet->VarStoreInfo.VarOffset = Info->mInfo.mVarOffset;
|
|
mSet->VarStoreType = Info->mVarType;
|
|
}
|
|
};
|
|
|
|
class CIfrSubtitle : public CIfrObj, public CIfrOpHeader, public CIfrStatementHeader {
|
|
private:
|
|
EFI_IFR_SUBTITLE *mSubtitle;
|
|
|
|
public:
|
|
CIfrSubtitle () : CIfrObj (EFI_IFR_SUBTITLE_OP, (CHAR8 **)&mSubtitle),
|
|
CIfrOpHeader (EFI_IFR_SUBTITLE_OP, &mSubtitle->Header),
|
|
CIfrStatementHeader (&mSubtitle->Statement) {
|
|
mSubtitle->Flags = 0;
|
|
}
|
|
|
|
EFI_VFR_RETURN_CODE SetFlags (IN UINT8 LFlags) {
|
|
if (_FLAG_TEST_AND_CLEAR (LFlags, EFI_IFR_FLAGS_HORIZONTAL)) {
|
|
mSubtitle->Flags |= EFI_IFR_FLAGS_HORIZONTAL;
|
|
}
|
|
|
|
return _FLAGS_ZERO (LFlags) ? VFR_RETURN_SUCCESS : VFR_RETURN_FLAGS_UNSUPPORTED;
|
|
}
|
|
};
|
|
|
|
class CIfrText : public CIfrObj, public CIfrOpHeader, public CIfrStatementHeader {
|
|
private:
|
|
EFI_IFR_TEXT *mText;
|
|
|
|
public:
|
|
CIfrText () : CIfrObj (EFI_IFR_TEXT_OP, (CHAR8 **)&mText),
|
|
CIfrOpHeader (EFI_IFR_TEXT_OP, &mText->Header),
|
|
CIfrStatementHeader (&mText->Statement) {
|
|
mText->TextTwo = EFI_STRING_ID_INVALID;
|
|
}
|
|
|
|
VOID SetTextTwo (IN EFI_STRING_ID StringId) {
|
|
mText->TextTwo = StringId;
|
|
}
|
|
};
|
|
|
|
class CIfrRef : public CIfrObj, public CIfrOpHeader, public CIfrQuestionHeader {
|
|
private:
|
|
EFI_IFR_REF *mRef;
|
|
|
|
public:
|
|
CIfrRef () : CIfrObj (EFI_IFR_REF_OP, (CHAR8 **)&mRef),
|
|
CIfrOpHeader (EFI_IFR_REF_OP, &mRef->Header),
|
|
CIfrQuestionHeader (&mRef->Question) {
|
|
mRef->FormId = 0;
|
|
}
|
|
|
|
VOID SetFormId (IN EFI_FORM_ID FormId) {
|
|
mRef->FormId = FormId;
|
|
}
|
|
};
|
|
|
|
class CIfrRef2 : public CIfrObj, public CIfrOpHeader, public CIfrQuestionHeader {
|
|
private:
|
|
EFI_IFR_REF2 *mRef2;
|
|
|
|
public:
|
|
CIfrRef2 () : CIfrObj (EFI_IFR_REF_OP, (CHAR8 **)&mRef2, sizeof (EFI_IFR_REF2)),
|
|
CIfrOpHeader (EFI_IFR_REF_OP, &mRef2->Header, sizeof (EFI_IFR_REF2)),
|
|
CIfrQuestionHeader (&mRef2->Question) {
|
|
mRef2->FormId = 0;
|
|
mRef2->QuestionId = EFI_QUESTION_ID_INVALID;
|
|
}
|
|
|
|
VOID SetFormId (IN EFI_FORM_ID FormId) {
|
|
mRef2->FormId = FormId;
|
|
}
|
|
|
|
VOID SetQuestionId (IN EFI_QUESTION_ID QuestionId) {
|
|
mRef2->QuestionId = QuestionId;
|
|
}
|
|
};
|
|
|
|
class CIfrRef3 : public CIfrObj, public CIfrOpHeader, public CIfrQuestionHeader {
|
|
private:
|
|
EFI_IFR_REF3 *mRef3;
|
|
|
|
public:
|
|
CIfrRef3 () : CIfrObj (EFI_IFR_REF_OP, (CHAR8 **)&mRef3, sizeof(EFI_IFR_REF3)),
|
|
CIfrOpHeader (EFI_IFR_REF_OP, &mRef3->Header, sizeof (EFI_IFR_REF3)),
|
|
CIfrQuestionHeader (&mRef3->Question) {
|
|
mRef3->FormId = 0;
|
|
mRef3->QuestionId = EFI_QUESTION_ID_INVALID;
|
|
memset (&mRef3->FormSetId, 0, sizeof (EFI_GUID));
|
|
}
|
|
|
|
VOID SetFormId (IN EFI_FORM_ID FormId) {
|
|
mRef3->FormId = FormId;
|
|
}
|
|
|
|
VOID SetQuestionId (IN EFI_QUESTION_ID QuestionId) {
|
|
mRef3->QuestionId = QuestionId;
|
|
}
|
|
|
|
VOID SetFormSetId (IN EFI_GUID FormSetId) {
|
|
mRef3->FormSetId = FormSetId;
|
|
}
|
|
};
|
|
|
|
class CIfrRef4 : public CIfrObj, public CIfrOpHeader, public CIfrQuestionHeader {
|
|
private:
|
|
EFI_IFR_REF4 *mRef4;
|
|
|
|
public:
|
|
CIfrRef4 () : CIfrObj (EFI_IFR_REF_OP, (CHAR8 **)&mRef4, sizeof(EFI_IFR_REF4)),
|
|
CIfrOpHeader (EFI_IFR_REF_OP, &mRef4->Header, sizeof(EFI_IFR_REF4)),
|
|
CIfrQuestionHeader (&mRef4->Question) {
|
|
mRef4->FormId = 0;
|
|
mRef4->QuestionId = EFI_QUESTION_ID_INVALID;
|
|
memset (&mRef4->FormSetId, 0, sizeof (EFI_GUID));
|
|
mRef4->DevicePath = EFI_STRING_ID_INVALID;
|
|
}
|
|
|
|
VOID SetFormId (IN EFI_FORM_ID FormId) {
|
|
mRef4->FormId = FormId;
|
|
}
|
|
|
|
VOID SetQuestionId (IN EFI_QUESTION_ID QuestionId) {
|
|
mRef4->QuestionId = QuestionId;
|
|
}
|
|
|
|
VOID SetFormSetId (IN EFI_GUID FormSetId) {
|
|
mRef4->FormSetId = FormSetId;
|
|
}
|
|
|
|
VOID SetDevicePath (IN EFI_STRING_ID DevicePath) {
|
|
mRef4->DevicePath = DevicePath;
|
|
}
|
|
};
|
|
|
|
class CIfrRef5 : public CIfrObj, public CIfrOpHeader, public CIfrQuestionHeader {
|
|
private:
|
|
EFI_IFR_REF5 *mRef5;
|
|
|
|
public:
|
|
CIfrRef5 () : CIfrObj (EFI_IFR_REF_OP, (CHAR8 **)&mRef5, sizeof (EFI_IFR_REF5)),
|
|
CIfrOpHeader (EFI_IFR_REF_OP, &mRef5->Header, sizeof (EFI_IFR_REF5)),
|
|
CIfrQuestionHeader (&mRef5->Question) {
|
|
}
|
|
};
|
|
|
|
class CIfrResetButton : public CIfrObj, public CIfrOpHeader, public CIfrStatementHeader {
|
|
private:
|
|
EFI_IFR_RESET_BUTTON *mResetButton;
|
|
|
|
public:
|
|
CIfrResetButton () : CIfrObj (EFI_IFR_RESET_BUTTON_OP, (CHAR8 **)&mResetButton),
|
|
CIfrOpHeader (EFI_IFR_RESET_BUTTON_OP, &mResetButton->Header),
|
|
CIfrStatementHeader (&mResetButton->Statement) {
|
|
mResetButton->DefaultId = EFI_HII_DEFAULT_CLASS_STANDARD;
|
|
}
|
|
|
|
VOID SetDefaultId (IN UINT16 DefaultId) {
|
|
mResetButton->DefaultId = DefaultId;
|
|
}
|
|
};
|
|
|
|
class CIfrCheckBox : public CIfrObj, public CIfrOpHeader, public CIfrQuestionHeader {
|
|
private:
|
|
EFI_IFR_CHECKBOX *mCheckBox;
|
|
|
|
public:
|
|
CIfrCheckBox () : CIfrObj (EFI_IFR_CHECKBOX_OP, (CHAR8 **)&mCheckBox),
|
|
CIfrOpHeader (EFI_IFR_CHECKBOX_OP, &mCheckBox->Header),
|
|
CIfrQuestionHeader (&mCheckBox->Question) {
|
|
mCheckBox->Flags = 0;
|
|
gCurrentQuestion = this;
|
|
}
|
|
|
|
~CIfrCheckBox () {
|
|
gCurrentQuestion = NULL;
|
|
}
|
|
|
|
EFI_VFR_RETURN_CODE SetFlags (IN UINT8 HFlags, UINT8 LFlags) {
|
|
EFI_VFR_RETURN_CODE Ret;
|
|
|
|
Ret = CIfrQuestionHeader::SetFlags (HFlags);
|
|
if (Ret != VFR_RETURN_SUCCESS) {
|
|
return Ret;
|
|
}
|
|
|
|
if (_FLAG_TEST_AND_CLEAR (LFlags, EFI_IFR_CHECKBOX_DEFAULT)) {
|
|
mCheckBox->Flags |= EFI_IFR_CHECKBOX_DEFAULT;
|
|
}
|
|
|
|
if (_FLAG_TEST_AND_CLEAR (LFlags, EFI_IFR_CHECKBOX_DEFAULT_MFG)) {
|
|
mCheckBox->Flags |= EFI_IFR_CHECKBOX_DEFAULT_MFG;
|
|
}
|
|
|
|
return _FLAGS_ZERO (LFlags) ? VFR_RETURN_SUCCESS : VFR_RETURN_FLAGS_UNSUPPORTED;
|
|
}
|
|
|
|
UINT8 GetFlags (VOID) {
|
|
return mCheckBox->Flags;
|
|
}
|
|
};
|
|
|
|
class CIfrAction : public CIfrObj, public CIfrOpHeader, public CIfrQuestionHeader {
|
|
private:
|
|
EFI_IFR_ACTION *mAction;
|
|
|
|
public:
|
|
CIfrAction () : CIfrObj (EFI_IFR_ACTION_OP, (CHAR8 **)&mAction),
|
|
CIfrOpHeader (EFI_IFR_ACTION_OP, &mAction->Header),
|
|
CIfrQuestionHeader (&mAction->Question) {
|
|
mAction->QuestionConfig = EFI_STRING_ID_INVALID;
|
|
}
|
|
|
|
VOID SetQuestionConfig (IN EFI_STRING_ID QuestionConfig) {
|
|
mAction->QuestionConfig = QuestionConfig;
|
|
}
|
|
};
|
|
|
|
class CIfrDate : public CIfrObj, public CIfrOpHeader, public CIfrQuestionHeader {
|
|
private:
|
|
EFI_IFR_DATE *mDate;
|
|
|
|
public:
|
|
CIfrDate () : CIfrObj (EFI_IFR_DATE_OP, (CHAR8 **)&mDate),
|
|
CIfrOpHeader (EFI_IFR_DATE_OP, &mDate->Header),
|
|
CIfrQuestionHeader (&mDate->Question) {
|
|
mDate->Flags = 0;
|
|
}
|
|
|
|
EFI_VFR_RETURN_CODE SetFlags (IN UINT8 HFlags, IN UINT8 LFlags) {
|
|
EFI_VFR_RETURN_CODE Ret;
|
|
|
|
Ret = CIfrQuestionHeader::SetFlags (HFlags);
|
|
if (Ret != VFR_RETURN_SUCCESS) {
|
|
return Ret;
|
|
}
|
|
|
|
if (_FLAG_TEST_AND_CLEAR (LFlags, EFI_QF_DATE_YEAR_SUPPRESS)) {
|
|
mDate->Flags |= EFI_QF_DATE_YEAR_SUPPRESS;
|
|
}
|
|
|
|
if (_FLAG_TEST_AND_CLEAR (LFlags, EFI_QF_DATE_MONTH_SUPPRESS)) {
|
|
mDate->Flags |= EFI_QF_DATE_MONTH_SUPPRESS;
|
|
}
|
|
|
|
if (_FLAG_TEST_AND_CLEAR (LFlags, EFI_QF_DATE_DAY_SUPPRESS)) {
|
|
mDate->Flags |= EFI_QF_DATE_DAY_SUPPRESS;
|
|
}
|
|
|
|
if (_FLAG_TEST_AND_CLEAR (LFlags, QF_DATE_STORAGE_NORMAL)) {
|
|
mDate->Flags |= QF_DATE_STORAGE_NORMAL;
|
|
} else if (_FLAG_TEST_AND_CLEAR (LFlags, QF_DATE_STORAGE_TIME)) {
|
|
mDate->Flags |= QF_DATE_STORAGE_TIME;
|
|
} else if (_FLAG_TEST_AND_CLEAR (LFlags, QF_DATE_STORAGE_WAKEUP)) {
|
|
mDate->Flags |= QF_DATE_STORAGE_WAKEUP;
|
|
}
|
|
|
|
return _FLAGS_ZERO (LFlags) ? VFR_RETURN_SUCCESS : VFR_RETURN_FLAGS_UNSUPPORTED;
|
|
}
|
|
};
|
|
|
|
class CIfrNumeric : public CIfrObj, public CIfrOpHeader, public CIfrQuestionHeader, public CIfrMinMaxStepData {
|
|
private:
|
|
EFI_IFR_NUMERIC *mNumeric;
|
|
|
|
public:
|
|
CIfrNumeric () : CIfrObj (EFI_IFR_NUMERIC_OP, (CHAR8 **)&mNumeric, sizeof (EFI_IFR_NUMERIC), TRUE),
|
|
CIfrOpHeader (EFI_IFR_NUMERIC_OP, &mNumeric->Header),
|
|
CIfrQuestionHeader (&mNumeric->Question),
|
|
CIfrMinMaxStepData (&mNumeric->data, TRUE) {
|
|
mNumeric->Flags = EFI_IFR_NUMERIC_SIZE_1 | EFI_IFR_DISPLAY_UINT_DEC;
|
|
gCurrentQuestion = this;
|
|
gCurrentMinMaxData = this;
|
|
}
|
|
|
|
~CIfrNumeric () {
|
|
gCurrentQuestion = NULL;
|
|
gCurrentMinMaxData = NULL;
|
|
}
|
|
|
|
VOID ShrinkBinSize (IN UINT16 Size) {
|
|
//
|
|
// Update the buffer size which is truly be used later.
|
|
//
|
|
ShrinkObjBin(Size);
|
|
DecLength(Size);
|
|
|
|
//
|
|
// Allocate buffer in gCFormPkg.
|
|
//
|
|
_EMIT_PENDING_OBJ();
|
|
|
|
//
|
|
// Update the buffer pointer used by other class.
|
|
//
|
|
mNumeric = (EFI_IFR_NUMERIC *) GetObjBinAddr();
|
|
UpdateHeader (&mNumeric->Header);
|
|
UpdateCIfrQuestionHeader(&mNumeric->Question);
|
|
UpdateCIfrMinMaxStepData(&mNumeric->data);
|
|
}
|
|
|
|
EFI_VFR_RETURN_CODE SetFlags (IN UINT8 HFlags, IN UINT8 LFlags, BOOLEAN DisplaySettingsSpecified = FALSE) {
|
|
EFI_VFR_RETURN_CODE Ret;
|
|
|
|
Ret = CIfrQuestionHeader::SetFlags (HFlags);
|
|
if (Ret != VFR_RETURN_SUCCESS) {
|
|
return Ret;
|
|
}
|
|
|
|
if (DisplaySettingsSpecified == FALSE) {
|
|
mNumeric->Flags = LFlags | EFI_IFR_DISPLAY_UINT_DEC;
|
|
} else {
|
|
mNumeric->Flags = LFlags;
|
|
}
|
|
return VFR_RETURN_SUCCESS;
|
|
}
|
|
|
|
EFI_VFR_RETURN_CODE SetFlagsForBitField (IN UINT8 HFlags, IN UINT8 LFlags, BOOLEAN DisplaySettingsSpecified = FALSE) {
|
|
EFI_VFR_RETURN_CODE Ret;
|
|
|
|
Ret = CIfrQuestionHeader::SetFlags (HFlags);
|
|
if (Ret != VFR_RETURN_SUCCESS) {
|
|
return Ret;
|
|
}
|
|
|
|
if (DisplaySettingsSpecified == FALSE) {
|
|
mNumeric->Flags = LFlags | EDKII_IFR_DISPLAY_UINT_DEC_BIT;
|
|
} else {
|
|
mNumeric->Flags = LFlags;
|
|
}
|
|
return VFR_RETURN_SUCCESS;
|
|
}
|
|
|
|
UINT8 GetNumericFlags () {
|
|
return mNumeric->Flags;
|
|
}
|
|
};
|
|
|
|
class CIfrOneOf : public CIfrObj, public CIfrOpHeader, public CIfrQuestionHeader, public CIfrMinMaxStepData {
|
|
private:
|
|
EFI_IFR_ONE_OF *mOneOf;
|
|
|
|
public:
|
|
CIfrOneOf () : CIfrObj (EFI_IFR_ONE_OF_OP, (CHAR8 **)&mOneOf, sizeof (EFI_IFR_ONE_OF), TRUE),
|
|
CIfrOpHeader (EFI_IFR_ONE_OF_OP, &mOneOf->Header),
|
|
CIfrQuestionHeader (&mOneOf->Question),
|
|
CIfrMinMaxStepData (&mOneOf->data) {
|
|
mOneOf->Flags = 0;
|
|
gCurrentQuestion = this;
|
|
gCurrentMinMaxData = this;
|
|
}
|
|
|
|
~CIfrOneOf () {
|
|
gCurrentQuestion = NULL;
|
|
gCurrentMinMaxData = NULL;
|
|
}
|
|
|
|
EFI_VFR_RETURN_CODE SetFlags (IN UINT8 HFlags, IN UINT8 LFlags) {
|
|
EFI_VFR_RETURN_CODE Ret;
|
|
|
|
Ret = CIfrQuestionHeader::SetFlags (HFlags);
|
|
if (Ret != VFR_RETURN_SUCCESS) {
|
|
return Ret;
|
|
}
|
|
|
|
if (LFlags & EFI_IFR_DISPLAY) {
|
|
mOneOf->Flags = LFlags;
|
|
} else {
|
|
mOneOf->Flags = LFlags | EFI_IFR_DISPLAY_UINT_DEC;
|
|
}
|
|
return VFR_RETURN_SUCCESS;
|
|
}
|
|
|
|
EFI_VFR_RETURN_CODE SetFlagsForBitField (IN UINT8 HFlags, IN UINT8 LFlags) {
|
|
EFI_VFR_RETURN_CODE Ret;
|
|
|
|
Ret = CIfrQuestionHeader::SetFlags (HFlags);
|
|
if (Ret != VFR_RETURN_SUCCESS) {
|
|
return Ret;
|
|
}
|
|
|
|
if (LFlags & EFI_IFR_DISPLAY) {
|
|
mOneOf->Flags = LFlags;
|
|
} else {
|
|
mOneOf->Flags = LFlags | EDKII_IFR_DISPLAY_UINT_DEC_BIT;
|
|
}
|
|
return VFR_RETURN_SUCCESS;
|
|
}
|
|
|
|
VOID ShrinkBinSize (IN UINT16 Size) {
|
|
//
|
|
// Update the buffer size which is truly be used later.
|
|
//
|
|
ShrinkObjBin(Size);
|
|
DecLength(Size);
|
|
|
|
//
|
|
// Allocate buffer in gCFormPkg.
|
|
//
|
|
_EMIT_PENDING_OBJ();
|
|
|
|
//
|
|
// Update the buffer pointer used by other class.
|
|
//
|
|
mOneOf = (EFI_IFR_ONE_OF *) GetObjBinAddr();
|
|
UpdateHeader (&mOneOf->Header);
|
|
UpdateCIfrQuestionHeader(&mOneOf->Question);
|
|
UpdateCIfrMinMaxStepData(&mOneOf->data);
|
|
}
|
|
};
|
|
|
|
class CIfrString : public CIfrObj, public CIfrOpHeader, public CIfrQuestionHeader {
|
|
private:
|
|
EFI_IFR_STRING *mString;
|
|
|
|
public:
|
|
CIfrString () : CIfrObj (EFI_IFR_STRING_OP, (CHAR8 **)&mString),
|
|
CIfrOpHeader (EFI_IFR_STRING_OP, &mString->Header),
|
|
CIfrQuestionHeader (&mString->Question) {
|
|
mString->Flags = 0;
|
|
mString->MinSize = 0;
|
|
mString->MaxSize = 0;
|
|
gCurrentQuestion = this;
|
|
}
|
|
|
|
~CIfrString () {
|
|
gCurrentQuestion = NULL;
|
|
}
|
|
|
|
EFI_VFR_RETURN_CODE SetFlags (IN UINT8 HFlags, IN UINT8 LFlags) {
|
|
EFI_VFR_RETURN_CODE Ret;
|
|
|
|
Ret = CIfrQuestionHeader::SetFlags (HFlags);
|
|
if (Ret != VFR_RETURN_SUCCESS) {
|
|
return Ret;
|
|
}
|
|
|
|
if (_FLAG_TEST_AND_CLEAR (LFlags, EFI_IFR_STRING_MULTI_LINE)) {
|
|
mString->Flags |= EFI_IFR_STRING_MULTI_LINE;
|
|
}
|
|
|
|
return _FLAGS_ZERO (LFlags) ? VFR_RETURN_SUCCESS : VFR_RETURN_FLAGS_UNSUPPORTED;
|
|
}
|
|
|
|
VOID SetMinSize (IN UINT8 Flags) {
|
|
mString->MinSize = Flags;
|
|
}
|
|
|
|
VOID SetMaxSize (IN UINT8 MaxSize) {
|
|
mString->MaxSize = MaxSize;
|
|
}
|
|
};
|
|
|
|
class CIfrPassword : public CIfrObj, public CIfrOpHeader, public CIfrQuestionHeader {
|
|
private:
|
|
EFI_IFR_PASSWORD *mPassword;
|
|
|
|
public:
|
|
CIfrPassword () : CIfrObj (EFI_IFR_PASSWORD_OP, (CHAR8 **)&mPassword),
|
|
CIfrOpHeader (EFI_IFR_PASSWORD_OP, &mPassword->Header),
|
|
CIfrQuestionHeader (&mPassword->Question) {
|
|
mPassword->MinSize = 0;
|
|
mPassword->MaxSize = 0;
|
|
gCurrentQuestion = this;
|
|
}
|
|
|
|
~CIfrPassword () {
|
|
gCurrentQuestion = NULL;
|
|
}
|
|
|
|
VOID SetMinSize (IN UINT16 MinSize) {
|
|
mPassword->MinSize = MinSize;
|
|
}
|
|
|
|
VOID SetMaxSize (IN UINT16 MaxSize) {
|
|
mPassword->MaxSize = MaxSize;
|
|
}
|
|
};
|
|
|
|
class CIfrOrderedList : public CIfrObj, public CIfrOpHeader, public CIfrQuestionHeader {
|
|
private:
|
|
EFI_IFR_ORDERED_LIST *mOrderedList;
|
|
|
|
public:
|
|
CIfrOrderedList () : CIfrObj (EFI_IFR_ORDERED_LIST_OP, (CHAR8 **)&mOrderedList),
|
|
CIfrOpHeader (EFI_IFR_ORDERED_LIST_OP, &mOrderedList->Header),
|
|
CIfrQuestionHeader (&mOrderedList->Question) {
|
|
mOrderedList->MaxContainers = 0;
|
|
mOrderedList->Flags = 0;
|
|
gCurrentQuestion = this;
|
|
}
|
|
|
|
~CIfrOrderedList () {
|
|
gCurrentQuestion = NULL;
|
|
}
|
|
|
|
VOID SetMaxContainers (IN UINT8 MaxContainers) {
|
|
mOrderedList->MaxContainers = MaxContainers;
|
|
}
|
|
|
|
EFI_VFR_RETURN_CODE SetFlags (IN UINT8 HFlags, IN UINT8 LFlags) {
|
|
EFI_VFR_RETURN_CODE Ret;
|
|
|
|
Ret = CIfrQuestionHeader::SetFlags (HFlags);
|
|
if (Ret != VFR_RETURN_SUCCESS) {
|
|
return Ret;
|
|
}
|
|
|
|
if (_FLAG_TEST_AND_CLEAR (LFlags, EFI_IFR_UNIQUE_SET)) {
|
|
mOrderedList->Flags |= EFI_IFR_UNIQUE_SET;
|
|
}
|
|
|
|
if (_FLAG_TEST_AND_CLEAR (LFlags, EFI_IFR_NO_EMPTY_SET)) {
|
|
mOrderedList->Flags |= EFI_IFR_NO_EMPTY_SET;
|
|
}
|
|
|
|
return _FLAGS_ZERO (LFlags) ? VFR_RETURN_SUCCESS : VFR_RETURN_FLAGS_UNSUPPORTED;
|
|
}
|
|
};
|
|
|
|
class CIfrTime : public CIfrObj, public CIfrOpHeader, public CIfrQuestionHeader {
|
|
private:
|
|
EFI_IFR_TIME *mTime;
|
|
|
|
public:
|
|
CIfrTime () : CIfrObj (EFI_IFR_TIME_OP, (CHAR8 **)&mTime),
|
|
CIfrOpHeader (EFI_IFR_TIME_OP, &mTime->Header),
|
|
CIfrQuestionHeader (&mTime->Question) {
|
|
mTime->Flags = 0;
|
|
}
|
|
|
|
EFI_VFR_RETURN_CODE SetFlags (IN UINT8 HFlags, IN UINT8 LFlags) {
|
|
EFI_VFR_RETURN_CODE Ret;
|
|
|
|
Ret = CIfrQuestionHeader::SetFlags (HFlags);
|
|
if (Ret != VFR_RETURN_SUCCESS) {
|
|
return Ret;
|
|
}
|
|
|
|
if (_FLAG_TEST_AND_CLEAR (LFlags, QF_TIME_HOUR_SUPPRESS)) {
|
|
mTime->Flags |= QF_TIME_HOUR_SUPPRESS;
|
|
}
|
|
|
|
if (_FLAG_TEST_AND_CLEAR (LFlags, QF_TIME_MINUTE_SUPPRESS)) {
|
|
mTime->Flags |= QF_TIME_MINUTE_SUPPRESS;
|
|
}
|
|
|
|
if (_FLAG_TEST_AND_CLEAR (LFlags, QF_TIME_SECOND_SUPPRESS)) {
|
|
mTime->Flags |= QF_TIME_SECOND_SUPPRESS;
|
|
}
|
|
|
|
if (_FLAG_TEST_AND_CLEAR (LFlags, QF_TIME_STORAGE_NORMAL)) {
|
|
mTime->Flags |= QF_TIME_STORAGE_NORMAL;
|
|
} else if (_FLAG_TEST_AND_CLEAR (LFlags, QF_TIME_STORAGE_TIME)) {
|
|
mTime->Flags |= QF_TIME_STORAGE_TIME;
|
|
} else if (_FLAG_TEST_AND_CLEAR (LFlags, QF_TIME_STORAGE_WAKEUP)) {
|
|
mTime->Flags |= QF_TIME_STORAGE_WAKEUP;
|
|
}
|
|
|
|
return _FLAGS_ZERO (LFlags) ? VFR_RETURN_SUCCESS : VFR_RETURN_FLAGS_UNSUPPORTED;
|
|
}
|
|
};
|
|
|
|
class CIfrDisableIf : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_DISABLE_IF *mDisableIf;
|
|
|
|
public:
|
|
CIfrDisableIf () : CIfrObj (EFI_IFR_DISABLE_IF_OP, (CHAR8 **)&mDisableIf),
|
|
mDisableIf ((EFI_IFR_DISABLE_IF *) GetObjBinAddr()),
|
|
CIfrOpHeader (EFI_IFR_DISABLE_IF_OP, &mDisableIf->Header) {}
|
|
};
|
|
|
|
class CIfrSuppressIf : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_SUPPRESS_IF *mSuppressIf;
|
|
|
|
public:
|
|
CIfrSuppressIf () : CIfrObj (EFI_IFR_SUPPRESS_IF_OP, (CHAR8 **)&mSuppressIf),
|
|
CIfrOpHeader (EFI_IFR_SUPPRESS_IF_OP, &mSuppressIf->Header) {}
|
|
};
|
|
|
|
class CIfrGrayOutIf : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_GRAY_OUT_IF *mGrayOutIf;
|
|
|
|
public:
|
|
CIfrGrayOutIf () : CIfrObj (EFI_IFR_GRAY_OUT_IF_OP, (CHAR8 **)&mGrayOutIf),
|
|
CIfrOpHeader (EFI_IFR_GRAY_OUT_IF_OP, &mGrayOutIf->Header) {}
|
|
};
|
|
|
|
class CIfrInconsistentIf : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_INCONSISTENT_IF *mInconsistentIf;
|
|
|
|
public:
|
|
CIfrInconsistentIf () : CIfrObj (EFI_IFR_INCONSISTENT_IF_OP, (CHAR8 **)&mInconsistentIf),
|
|
CIfrOpHeader (EFI_IFR_INCONSISTENT_IF_OP, &mInconsistentIf->Header) {
|
|
mInconsistentIf->Error = EFI_STRING_ID_INVALID;
|
|
}
|
|
|
|
VOID SetError (IN EFI_STRING_ID Error) {
|
|
mInconsistentIf->Error = Error;
|
|
}
|
|
};
|
|
|
|
class CIfrWarningIf : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_WARNING_IF *mWarningIf;
|
|
|
|
public:
|
|
CIfrWarningIf () : CIfrObj (EFI_IFR_WARNING_IF_OP, (CHAR8 **)&mWarningIf),
|
|
CIfrOpHeader (EFI_IFR_WARNING_IF_OP, &mWarningIf->Header) {
|
|
mWarningIf->Warning = EFI_STRING_ID_INVALID;
|
|
mWarningIf->TimeOut = 0;
|
|
}
|
|
|
|
VOID SetWarning (IN EFI_STRING_ID Warning) {
|
|
mWarningIf->Warning = Warning;
|
|
}
|
|
|
|
VOID SetTimeOut (IN UINT8 TimeOut) {
|
|
mWarningIf->TimeOut = TimeOut;
|
|
}
|
|
};
|
|
|
|
class CIfrNoSubmitIf : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_NO_SUBMIT_IF *mNoSubmitIf;
|
|
|
|
public:
|
|
CIfrNoSubmitIf () : CIfrObj (EFI_IFR_NO_SUBMIT_IF_OP, (CHAR8 **)&mNoSubmitIf),
|
|
CIfrOpHeader (EFI_IFR_NO_SUBMIT_IF_OP, &mNoSubmitIf->Header) {
|
|
mNoSubmitIf->Error = EFI_STRING_ID_INVALID;
|
|
}
|
|
|
|
VOID SetError (IN EFI_STRING_ID Error) {
|
|
mNoSubmitIf->Error = Error;
|
|
}
|
|
};
|
|
|
|
class CIfrRefresh : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_REFRESH *mRefresh;
|
|
|
|
public:
|
|
CIfrRefresh () : CIfrObj (EFI_IFR_REFRESH_OP, (CHAR8 **)&mRefresh),
|
|
CIfrOpHeader (EFI_IFR_REFRESH_OP, &mRefresh->Header) {
|
|
mRefresh->RefreshInterval = 0;
|
|
}
|
|
|
|
VOID SetRefreshInterval (IN UINT8 RefreshInterval) {
|
|
mRefresh->RefreshInterval = RefreshInterval;
|
|
}
|
|
};
|
|
|
|
class CIfrRefreshId : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_REFRESH_ID *mRefreshId;
|
|
|
|
public:
|
|
CIfrRefreshId () : CIfrObj (EFI_IFR_REFRESH_ID_OP, (CHAR8 **)&mRefreshId),
|
|
CIfrOpHeader (EFI_IFR_REFRESH_ID_OP, &mRefreshId->Header) {
|
|
memset (&mRefreshId->RefreshEventGroupId, 0, sizeof (EFI_GUID));
|
|
}
|
|
|
|
VOID SetRefreshEventGroutId (IN EFI_GUID *RefreshEventGroupId) {
|
|
memmove (&mRefreshId->RefreshEventGroupId, RefreshEventGroupId, sizeof (EFI_GUID));
|
|
}
|
|
};
|
|
|
|
class CIfrVarStoreDevice : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_VARSTORE_DEVICE *mVarStoreDevice;
|
|
|
|
public:
|
|
CIfrVarStoreDevice () : CIfrObj (EFI_IFR_VARSTORE_DEVICE_OP, (CHAR8 **)&mVarStoreDevice),
|
|
CIfrOpHeader (EFI_IFR_VARSTORE_DEVICE_OP, &mVarStoreDevice->Header) {
|
|
mVarStoreDevice->DevicePath = EFI_STRING_ID_INVALID;
|
|
}
|
|
|
|
VOID SetDevicePath (IN EFI_STRING_ID DevicePath) {
|
|
mVarStoreDevice->DevicePath = DevicePath;
|
|
}
|
|
};
|
|
|
|
class CIfrOneOfOption : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_ONE_OF_OPTION *mOneOfOption;
|
|
|
|
public:
|
|
CIfrOneOfOption (UINT8 Size) : CIfrObj (EFI_IFR_ONE_OF_OPTION_OP, (CHAR8 **)&mOneOfOption, Size),
|
|
CIfrOpHeader (EFI_IFR_ONE_OF_OPTION_OP, &mOneOfOption->Header, Size) {
|
|
mOneOfOption->Flags = 0;
|
|
mOneOfOption->Option = EFI_STRING_ID_INVALID;
|
|
mOneOfOption->Type = EFI_IFR_TYPE_OTHER;
|
|
memset (&mOneOfOption->Value, 0, Size - OFFSET_OF (EFI_IFR_ONE_OF_OPTION, Value));
|
|
}
|
|
|
|
VOID SetOption (IN EFI_STRING_ID Option) {
|
|
mOneOfOption->Option = Option;
|
|
}
|
|
|
|
EFI_VFR_RETURN_CODE SetFlags (IN UINT8 LFlags) {
|
|
mOneOfOption->Flags = 0;
|
|
if (_FLAG_TEST_AND_CLEAR (LFlags, EFI_IFR_OPTION_DEFAULT)) {
|
|
mOneOfOption->Flags |= EFI_IFR_OPTION_DEFAULT;
|
|
}
|
|
|
|
if (_FLAG_TEST_AND_CLEAR (LFlags, EFI_IFR_OPTION_DEFAULT_MFG)) {
|
|
mOneOfOption->Flags |= EFI_IFR_OPTION_DEFAULT_MFG;
|
|
}
|
|
|
|
if (_IS_EQUAL (LFlags, EFI_IFR_TYPE_NUM_SIZE_8)) {
|
|
_FLAG_CLEAR (LFlags, EFI_IFR_TYPE_NUM_SIZE_8);
|
|
mOneOfOption->Flags |= EFI_IFR_TYPE_NUM_SIZE_8;
|
|
} else if (_IS_EQUAL (LFlags, EFI_IFR_TYPE_NUM_SIZE_16)) {
|
|
_FLAG_CLEAR (LFlags, EFI_IFR_TYPE_NUM_SIZE_16);
|
|
mOneOfOption->Flags |= EFI_IFR_TYPE_NUM_SIZE_16;
|
|
} else if (_IS_EQUAL (LFlags, EFI_IFR_TYPE_NUM_SIZE_32)) {
|
|
_FLAG_CLEAR (LFlags, EFI_IFR_TYPE_NUM_SIZE_32);
|
|
mOneOfOption->Flags |= EFI_IFR_TYPE_NUM_SIZE_32;
|
|
} else if (_IS_EQUAL (LFlags, EFI_IFR_TYPE_NUM_SIZE_64)) {
|
|
_FLAG_CLEAR (LFlags, EFI_IFR_TYPE_NUM_SIZE_64);
|
|
mOneOfOption->Flags |= EFI_IFR_TYPE_NUM_SIZE_64;
|
|
} else if (_IS_EQUAL (LFlags, EFI_IFR_TYPE_BOOLEAN)) {
|
|
_FLAG_CLEAR (LFlags, EFI_IFR_TYPE_BOOLEAN);
|
|
mOneOfOption->Flags |= EFI_IFR_TYPE_BOOLEAN;
|
|
} else if (_IS_EQUAL (LFlags, EFI_IFR_TYPE_TIME)) {
|
|
_FLAG_CLEAR (LFlags, EFI_IFR_TYPE_TIME);
|
|
mOneOfOption->Flags |= EFI_IFR_TYPE_TIME;
|
|
} else if (_IS_EQUAL (LFlags, EFI_IFR_TYPE_DATE)) {
|
|
_FLAG_CLEAR (LFlags, EFI_IFR_TYPE_DATE);
|
|
mOneOfOption->Flags |= EFI_IFR_TYPE_DATE;
|
|
} else if (_IS_EQUAL (LFlags, EFI_IFR_TYPE_STRING)) {
|
|
_FLAG_CLEAR (LFlags, EFI_IFR_TYPE_STRING);
|
|
mOneOfOption->Flags |= EFI_IFR_TYPE_STRING;
|
|
} else if (_IS_EQUAL (LFlags, EFI_IFR_TYPE_OTHER)) {
|
|
_FLAG_CLEAR (LFlags, EFI_IFR_TYPE_OTHER);
|
|
mOneOfOption->Flags |= EFI_IFR_TYPE_OTHER;
|
|
}
|
|
|
|
return _FLAGS_ZERO (LFlags) ? VFR_RETURN_SUCCESS : VFR_RETURN_FLAGS_UNSUPPORTED;
|
|
}
|
|
|
|
VOID SetType (IN UINT8 Type) {
|
|
mOneOfOption->Type = Type;
|
|
}
|
|
|
|
VOID SetValue (IN EFI_IFR_TYPE_VALUE Value) {
|
|
memmove (&mOneOfOption->Value, &Value, mOneOfOption->Header.Length - OFFSET_OF (EFI_IFR_ONE_OF_OPTION, Value));
|
|
}
|
|
|
|
UINT8 GetFlags (VOID) {
|
|
return mOneOfOption->Flags;
|
|
}
|
|
};
|
|
|
|
static EFI_GUID IfrTianoGuid = EFI_IFR_TIANO_GUID;
|
|
static EFI_GUID IfrFrameworkGuid = EFI_IFR_FRAMEWORK_GUID;
|
|
|
|
class CIfrClass : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_GUID_CLASS *mClass;
|
|
|
|
public:
|
|
CIfrClass () : CIfrObj (EFI_IFR_GUID_OP, (CHAR8 **)&mClass, sizeof (EFI_IFR_GUID_CLASS)),
|
|
CIfrOpHeader (EFI_IFR_GUID_OP, &mClass->Header, sizeof (EFI_IFR_GUID_CLASS)) {
|
|
mClass->ExtendOpCode = EFI_IFR_EXTEND_OP_CLASS;
|
|
mClass->Guid = IfrTianoGuid;
|
|
mClass->Class = EFI_NON_DEVICE_CLASS;
|
|
}
|
|
|
|
VOID SetClass (IN UINT16 Class) {
|
|
mClass->Class = Class;
|
|
}
|
|
};
|
|
|
|
class CIfrSubClass : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_GUID_SUBCLASS *mSubClass;
|
|
|
|
public:
|
|
CIfrSubClass () : CIfrObj (EFI_IFR_GUID_OP, (CHAR8 **)&mSubClass, sizeof (EFI_IFR_GUID_SUBCLASS)),
|
|
CIfrOpHeader (EFI_IFR_GUID_OP, &mSubClass->Header, sizeof (EFI_IFR_GUID_SUBCLASS)) {
|
|
mSubClass->ExtendOpCode = EFI_IFR_EXTEND_OP_SUBCLASS;
|
|
mSubClass->Guid = IfrTianoGuid;
|
|
mSubClass->SubClass = EFI_SETUP_APPLICATION_SUBCLASS;
|
|
}
|
|
|
|
VOID SetSubClass (IN UINT16 SubClass) {
|
|
mSubClass->SubClass = SubClass;
|
|
}
|
|
};
|
|
|
|
class CIfrLabel : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_GUID_LABEL *mLabel;
|
|
|
|
public:
|
|
CIfrLabel () : CIfrObj (EFI_IFR_GUID_OP, (CHAR8 **)&mLabel, sizeof (EFI_IFR_GUID_LABEL)),
|
|
CIfrOpHeader (EFI_IFR_GUID_OP, &mLabel->Header, sizeof (EFI_IFR_GUID_LABEL)) {
|
|
mLabel->ExtendOpCode = EFI_IFR_EXTEND_OP_LABEL;
|
|
mLabel->Guid = IfrTianoGuid;
|
|
}
|
|
|
|
VOID SetNumber (IN UINT16 Number) {
|
|
mLabel->Number = Number;
|
|
}
|
|
};
|
|
|
|
class CIfrBanner : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_GUID_BANNER *mBanner;
|
|
|
|
public:
|
|
CIfrBanner () : CIfrObj (EFI_IFR_GUID_OP, (CHAR8 **)&mBanner, sizeof (EFI_IFR_GUID_BANNER)),
|
|
CIfrOpHeader (EFI_IFR_GUID_OP, &mBanner->Header, sizeof (EFI_IFR_GUID_BANNER)) {
|
|
mBanner->ExtendOpCode = EFI_IFR_EXTEND_OP_BANNER;
|
|
mBanner->Guid = IfrTianoGuid;
|
|
}
|
|
|
|
VOID SetTitle (IN EFI_STRING_ID StringId) {
|
|
mBanner->Title = StringId;
|
|
}
|
|
|
|
VOID SetLine (IN UINT16 Line) {
|
|
mBanner->LineNumber = Line;
|
|
}
|
|
|
|
VOID SetAlign (IN UINT8 Align) {
|
|
mBanner->Alignment = Align;
|
|
}
|
|
};
|
|
|
|
class CIfrOptionKey : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_GUID_OPTIONKEY *mOptionKey;
|
|
|
|
public:
|
|
CIfrOptionKey (
|
|
IN EFI_QUESTION_ID QuestionId,
|
|
IN EFI_IFR_TYPE_VALUE &OptionValue,
|
|
IN EFI_QUESTION_ID KeyValue
|
|
) : CIfrObj (EFI_IFR_GUID_OP, (CHAR8 **)&mOptionKey, sizeof (EFI_IFR_GUID_OPTIONKEY)),
|
|
CIfrOpHeader (EFI_IFR_GUID_OP, &mOptionKey->Header, sizeof (EFI_IFR_GUID_OPTIONKEY)) {
|
|
mOptionKey->ExtendOpCode = EFI_IFR_EXTEND_OP_OPTIONKEY;
|
|
mOptionKey->Guid = IfrFrameworkGuid;
|
|
mOptionKey->QuestionId = QuestionId;
|
|
mOptionKey->OptionValue = OptionValue;
|
|
mOptionKey->KeyValue = KeyValue;
|
|
}
|
|
};
|
|
|
|
class CIfrVarEqName : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_GUID_VAREQNAME *mVarEqName;
|
|
|
|
public:
|
|
CIfrVarEqName (
|
|
IN EFI_QUESTION_ID QuestionId,
|
|
IN EFI_STRING_ID NameId
|
|
) : CIfrObj (EFI_IFR_GUID_OP, (CHAR8 **)&mVarEqName, sizeof (EFI_IFR_GUID_VAREQNAME)),
|
|
CIfrOpHeader (EFI_IFR_GUID_OP, &mVarEqName->Header, sizeof (EFI_IFR_GUID_VAREQNAME)) {
|
|
mVarEqName->ExtendOpCode = EFI_IFR_EXTEND_OP_VAREQNAME;
|
|
mVarEqName->Guid = IfrFrameworkGuid;
|
|
mVarEqName->QuestionId = QuestionId;
|
|
mVarEqName->NameId = NameId;
|
|
}
|
|
};
|
|
|
|
class CIfrTimeout : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_GUID_TIMEOUT *mTimeout;
|
|
|
|
public:
|
|
CIfrTimeout (IN UINT16 Timeout = 0) : CIfrObj (EFI_IFR_GUID_OP, (CHAR8 **)&mTimeout, sizeof (EFI_IFR_GUID_TIMEOUT)),
|
|
CIfrOpHeader (EFI_IFR_GUID_OP, &mTimeout->Header, sizeof (EFI_IFR_GUID_TIMEOUT)) {
|
|
mTimeout->ExtendOpCode = EFI_IFR_EXTEND_OP_TIMEOUT;
|
|
mTimeout->Guid = IfrTianoGuid;
|
|
mTimeout->TimeOut = Timeout;
|
|
}
|
|
|
|
VOID SetTimeout (IN UINT16 Timeout) {
|
|
mTimeout->TimeOut = Timeout;
|
|
}
|
|
};
|
|
|
|
class CIfrGuid : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_GUID *mGuid;
|
|
|
|
public:
|
|
CIfrGuid (UINT8 Size) : CIfrObj (EFI_IFR_GUID_OP, (CHAR8 **)&mGuid, sizeof (EFI_IFR_GUID)+Size),
|
|
CIfrOpHeader (EFI_IFR_GUID_OP, &mGuid->Header, sizeof (EFI_IFR_GUID)+Size) {
|
|
memset (&mGuid->Guid, 0, sizeof (EFI_GUID));
|
|
}
|
|
|
|
VOID SetGuid (IN EFI_GUID *Guid) {
|
|
memmove (&mGuid->Guid, Guid, sizeof (EFI_GUID));
|
|
}
|
|
|
|
VOID SetData (IN UINT8* DataBuff, IN UINT8 Size) {
|
|
memmove ((UINT8 *)mGuid + sizeof (EFI_IFR_GUID), DataBuff, Size);
|
|
}
|
|
};
|
|
|
|
class CIfrDup : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_DUP *mDup;
|
|
|
|
public:
|
|
CIfrDup (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_DUP_OP, (CHAR8 **)&mDup),
|
|
CIfrOpHeader (EFI_IFR_DUP_OP, &mDup->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrEqIdId : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_EQ_ID_ID *mEqIdId;
|
|
|
|
public:
|
|
CIfrEqIdId (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_EQ_ID_ID_OP, (CHAR8 **)&mEqIdId),
|
|
CIfrOpHeader (EFI_IFR_EQ_ID_ID_OP, &mEqIdId->Header) {
|
|
SetLineNo (LineNo);
|
|
mEqIdId->QuestionId1 = EFI_QUESTION_ID_INVALID;
|
|
mEqIdId->QuestionId2 = EFI_QUESTION_ID_INVALID;
|
|
}
|
|
|
|
VOID SetQuestionId1 (
|
|
IN EFI_QUESTION_ID QuestionId,
|
|
IN CHAR8 *VarIdStr,
|
|
IN UINT32 LineNo
|
|
) {
|
|
if (QuestionId != EFI_QUESTION_ID_INVALID) {
|
|
mEqIdId->QuestionId1 = QuestionId;
|
|
} else {
|
|
gCFormPkg.AssignPending (VarIdStr, (VOID *)(&mEqIdId->QuestionId1), sizeof (EFI_QUESTION_ID), LineNo, NO_QST_REFED);
|
|
}
|
|
}
|
|
|
|
VOID SetQuestionId2 (
|
|
IN EFI_QUESTION_ID QuestionId,
|
|
IN CHAR8 *VarIdStr,
|
|
IN UINT32 LineNo
|
|
) {
|
|
if (QuestionId != EFI_QUESTION_ID_INVALID) {
|
|
mEqIdId->QuestionId2 = QuestionId;
|
|
} else {
|
|
gCFormPkg.AssignPending (VarIdStr, (VOID *)(&mEqIdId->QuestionId2), sizeof (EFI_QUESTION_ID), LineNo, NO_QST_REFED);
|
|
}
|
|
}
|
|
};
|
|
|
|
class CIfrEqIdVal : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_EQ_ID_VAL *mEqIdVal;
|
|
|
|
public:
|
|
CIfrEqIdVal (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_EQ_ID_VAL_OP, (CHAR8 **)&mEqIdVal),
|
|
CIfrOpHeader (EFI_IFR_EQ_ID_VAL_OP, &mEqIdVal->Header) {
|
|
SetLineNo (LineNo);
|
|
mEqIdVal->QuestionId = EFI_QUESTION_ID_INVALID;
|
|
}
|
|
|
|
VOID SetQuestionId (
|
|
IN EFI_QUESTION_ID QuestionId,
|
|
IN CHAR8 *VarIdStr,
|
|
IN UINT32 LineNo
|
|
) {
|
|
if (QuestionId != EFI_QUESTION_ID_INVALID) {
|
|
mEqIdVal->QuestionId = QuestionId;
|
|
} else {
|
|
gCFormPkg.AssignPending (VarIdStr, (VOID *)(&mEqIdVal->QuestionId), sizeof (EFI_QUESTION_ID), LineNo, NO_QST_REFED);
|
|
}
|
|
}
|
|
|
|
VOID SetValue (IN UINT16 Value) {
|
|
mEqIdVal->Value = Value;
|
|
}
|
|
};
|
|
|
|
class CIfrEqIdList : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_EQ_ID_VAL_LIST *mEqIdVList;
|
|
|
|
public:
|
|
CIfrEqIdList (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_EQ_ID_VAL_LIST_OP, (CHAR8 **)&mEqIdVList, sizeof (EFI_IFR_EQ_ID_VAL_LIST), TRUE),
|
|
CIfrOpHeader (EFI_IFR_EQ_ID_VAL_LIST_OP, &mEqIdVList->Header) {
|
|
SetLineNo (LineNo);
|
|
mEqIdVList->QuestionId = EFI_QUESTION_ID_INVALID;
|
|
mEqIdVList->ListLength = 0;
|
|
mEqIdVList->ValueList[0] = 0;
|
|
}
|
|
|
|
VOID UpdateIfrBuffer (
|
|
) {
|
|
_EMIT_PENDING_OBJ();
|
|
mEqIdVList = (EFI_IFR_EQ_ID_VAL_LIST *) GetObjBinAddr();
|
|
UpdateHeader (&mEqIdVList->Header);
|
|
}
|
|
|
|
VOID SetQuestionId (
|
|
IN EFI_QUESTION_ID QuestionId,
|
|
IN CHAR8 *VarIdStr,
|
|
IN UINT32 LineNo
|
|
) {
|
|
if (QuestionId != EFI_QUESTION_ID_INVALID) {
|
|
mEqIdVList->QuestionId = QuestionId;
|
|
} else {
|
|
gCFormPkg.AssignPending (VarIdStr, (VOID *)(&mEqIdVList->QuestionId), sizeof (EFI_QUESTION_ID), LineNo, NO_QST_REFED);
|
|
}
|
|
}
|
|
|
|
VOID SetListLength (IN UINT16 ListLength) {
|
|
mEqIdVList->ListLength = ListLength;
|
|
}
|
|
|
|
VOID SetValueList (IN UINT16 Index, IN UINT16 Value) {
|
|
if (Index == 0) {
|
|
mEqIdVList->ValueList[0] = Value;
|
|
return;
|
|
}
|
|
|
|
if (ExpendObjBin (sizeof (UINT16)) ==TRUE) {
|
|
IncLength (sizeof (UINT16));
|
|
mEqIdVList->ValueList[Index] = Value;
|
|
}
|
|
}
|
|
};
|
|
|
|
class CIfrQuestionRef1 : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_QUESTION_REF1 *mQuestionRef1;
|
|
|
|
public:
|
|
CIfrQuestionRef1 (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_QUESTION_REF1_OP, (CHAR8 **)&mQuestionRef1),
|
|
CIfrOpHeader (EFI_IFR_QUESTION_REF1_OP, &mQuestionRef1->Header) {
|
|
SetLineNo (LineNo);
|
|
mQuestionRef1->QuestionId = EFI_QUESTION_ID_INVALID;
|
|
}
|
|
|
|
VOID SetQuestionId (
|
|
IN EFI_QUESTION_ID QuestionId,
|
|
IN CHAR8 *VarIdStr,
|
|
IN UINT32 LineNo
|
|
) {
|
|
if (QuestionId != EFI_QUESTION_ID_INVALID) {
|
|
mQuestionRef1->QuestionId = QuestionId;
|
|
} else {
|
|
gCFormPkg.AssignPending (VarIdStr, (VOID *)(&mQuestionRef1->QuestionId), sizeof (EFI_QUESTION_ID), LineNo, NO_QST_REFED);
|
|
}
|
|
}
|
|
};
|
|
|
|
class CIfrQuestionRef2 : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_QUESTION_REF2 *mQuestionRef2;
|
|
|
|
public:
|
|
CIfrQuestionRef2 (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_QUESTION_REF2_OP, (CHAR8 **)&mQuestionRef2),
|
|
CIfrOpHeader (EFI_IFR_QUESTION_REF2_OP, &mQuestionRef2->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrQuestionRef3 : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_QUESTION_REF3 *mQuestionRef3;
|
|
|
|
public:
|
|
CIfrQuestionRef3 (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_QUESTION_REF3_OP, (CHAR8 **)&mQuestionRef3),
|
|
CIfrOpHeader (EFI_IFR_QUESTION_REF3_OP, &mQuestionRef3->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrQuestionRef3_2 : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_QUESTION_REF3_2 *mQuestionRef3_2;
|
|
|
|
public:
|
|
CIfrQuestionRef3_2 (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_QUESTION_REF3_OP, (CHAR8 **)&mQuestionRef3_2, sizeof (EFI_IFR_QUESTION_REF3_2)),
|
|
CIfrOpHeader (EFI_IFR_QUESTION_REF3_OP, &mQuestionRef3_2->Header, sizeof (EFI_IFR_QUESTION_REF3_2)) {
|
|
SetLineNo (LineNo);
|
|
mQuestionRef3_2->DevicePath = EFI_STRING_ID_INVALID;
|
|
}
|
|
|
|
VOID SetDevicePath (IN EFI_STRING_ID DevicePath) {
|
|
mQuestionRef3_2->DevicePath = DevicePath;
|
|
}
|
|
};
|
|
|
|
class CIfrQuestionRef3_3 : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_QUESTION_REF3_3 *mQuestionRef3_3;
|
|
|
|
public:
|
|
CIfrQuestionRef3_3 (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_QUESTION_REF3_OP, (CHAR8 **)&mQuestionRef3_3, sizeof (EFI_IFR_QUESTION_REF3_3)),
|
|
CIfrOpHeader (EFI_IFR_QUESTION_REF3_OP, &mQuestionRef3_3->Header, sizeof (EFI_IFR_QUESTION_REF3_3)) {
|
|
SetLineNo (LineNo);
|
|
mQuestionRef3_3->DevicePath = EFI_STRING_ID_INVALID;
|
|
memset (&mQuestionRef3_3->Guid, 0, sizeof (EFI_GUID));
|
|
}
|
|
|
|
VOID SetDevicePath (IN EFI_STRING_ID DevicePath) {
|
|
mQuestionRef3_3->DevicePath = DevicePath;
|
|
}
|
|
|
|
VOID SetGuid (IN EFI_GUID *Guid) {
|
|
mQuestionRef3_3->Guid = *Guid;
|
|
}
|
|
};
|
|
|
|
class CIfrRuleRef : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_RULE_REF *mRuleRef;
|
|
|
|
public:
|
|
CIfrRuleRef (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_RULE_REF_OP, (CHAR8 **)&mRuleRef),
|
|
CIfrOpHeader (EFI_IFR_RULE_REF_OP, &mRuleRef->Header) {
|
|
SetLineNo (LineNo);
|
|
mRuleRef->RuleId = EFI_RULE_ID_INVALID;
|
|
}
|
|
|
|
VOID SetRuleId (IN UINT8 RuleId) {
|
|
mRuleRef->RuleId = RuleId;
|
|
}
|
|
};
|
|
|
|
class CIfrStringRef1 : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_STRING_REF1 *mStringRef1;
|
|
|
|
public:
|
|
CIfrStringRef1 (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_STRING_REF1_OP, (CHAR8 **)&mStringRef1),
|
|
CIfrOpHeader (EFI_IFR_STRING_REF1_OP, &mStringRef1->Header) {
|
|
SetLineNo (LineNo);
|
|
mStringRef1->StringId = EFI_STRING_ID_INVALID;
|
|
}
|
|
|
|
VOID SetStringId (IN EFI_STRING_ID StringId) {
|
|
mStringRef1->StringId = StringId;
|
|
}
|
|
};
|
|
|
|
class CIfrStringRef2 : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_STRING_REF2 *mStringRef2;
|
|
|
|
public:
|
|
CIfrStringRef2 (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_STRING_REF2_OP, (CHAR8 **)&mStringRef2),
|
|
CIfrOpHeader (EFI_IFR_STRING_REF2_OP, &mStringRef2->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrThis : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_THIS *mThis;
|
|
|
|
public:
|
|
CIfrThis (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_THIS_OP, (CHAR8 **)&mThis),
|
|
CIfrOpHeader (EFI_IFR_THIS_OP, &mThis->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrSecurity : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_SECURITY *mSecurity;
|
|
|
|
public:
|
|
CIfrSecurity (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_SECURITY_OP, (CHAR8 **)&mSecurity),
|
|
CIfrOpHeader (EFI_IFR_SECURITY_OP, &mSecurity->Header) {
|
|
SetLineNo (LineNo);
|
|
memset (&mSecurity->Permissions, 0, sizeof (EFI_GUID));
|
|
}
|
|
|
|
VOID SetPermissions (IN EFI_GUID *Permissions) {
|
|
memmove (&mSecurity->Permissions, Permissions, sizeof (EFI_GUID));
|
|
}
|
|
};
|
|
|
|
class CIfrUint8 : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_UINT8 *mUint8;
|
|
|
|
public:
|
|
CIfrUint8 (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_UINT8_OP, (CHAR8 **)&mUint8),
|
|
CIfrOpHeader (EFI_IFR_UINT8_OP, &mUint8->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
|
|
VOID SetValue (IN UINT8 Value) {
|
|
mUint8->Value = Value;
|
|
}
|
|
};
|
|
|
|
class CIfrUint16 : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_UINT16 *mUint16;
|
|
|
|
public:
|
|
CIfrUint16 (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_UINT16_OP, (CHAR8 **)&mUint16),
|
|
CIfrOpHeader (EFI_IFR_UINT16_OP, &mUint16->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
|
|
VOID SetValue (IN UINT16 Value) {
|
|
mUint16->Value = Value;
|
|
}
|
|
};
|
|
|
|
class CIfrUint32 : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_UINT32 *mUint32;
|
|
|
|
public:
|
|
CIfrUint32 (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_UINT32_OP, (CHAR8 **)&mUint32),
|
|
CIfrOpHeader (EFI_IFR_UINT32_OP, &mUint32->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
|
|
VOID SetValue (IN UINT32 Value) {
|
|
mUint32->Value = Value;
|
|
}
|
|
};
|
|
|
|
class CIfrUint64 : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_UINT64 *mUint64;
|
|
|
|
public:
|
|
CIfrUint64 (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_UINT64_OP, (CHAR8 **)&mUint64),
|
|
CIfrOpHeader (EFI_IFR_UINT64_OP, &mUint64->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
|
|
VOID SetValue (IN UINT64 Value) {
|
|
mUint64->Value = Value;
|
|
}
|
|
};
|
|
|
|
class CIfrTrue : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_TRUE *mTrue;
|
|
|
|
public:
|
|
CIfrTrue (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_TRUE_OP, (CHAR8 **)&mTrue),
|
|
CIfrOpHeader (EFI_IFR_TRUE_OP, &mTrue->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrFalse : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_FALSE *mFalse;
|
|
|
|
public:
|
|
CIfrFalse (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_FALSE_OP, (CHAR8 **)&mFalse),
|
|
CIfrOpHeader (EFI_IFR_FALSE_OP, &mFalse->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrOne : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_ONE *mOne;
|
|
|
|
public:
|
|
CIfrOne (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_ONE_OP, (CHAR8 **)&mOne),
|
|
CIfrOpHeader (EFI_IFR_ONE_OP, &mOne->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrOnes : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_ONES *mOnes;
|
|
|
|
public:
|
|
CIfrOnes (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_ONES_OP, (CHAR8 **)&mOnes),
|
|
CIfrOpHeader (EFI_IFR_ONES_OP, &mOnes->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrZero : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_ZERO *mZero;
|
|
|
|
public:
|
|
CIfrZero (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_ZERO_OP, (CHAR8 **)&mZero),
|
|
CIfrOpHeader (EFI_IFR_ZERO_OP, &mZero->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrUndefined : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_UNDEFINED *mUndefined;
|
|
|
|
public:
|
|
CIfrUndefined (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_UNDEFINED_OP, (CHAR8 **)&mUndefined),
|
|
CIfrOpHeader (EFI_IFR_UNDEFINED_OP, &mUndefined->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrVersion : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_VERSION *mVersion;
|
|
|
|
public:
|
|
CIfrVersion (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_VERSION_OP, (CHAR8 **)&mVersion),
|
|
CIfrOpHeader (EFI_IFR_VERSION_OP, &mVersion->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrLength : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_LENGTH *mLength;
|
|
|
|
public:
|
|
CIfrLength (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_LENGTH_OP, (CHAR8 **)&mLength),
|
|
CIfrOpHeader (EFI_IFR_LENGTH_OP, &mLength->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrNot : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_NOT *mNot;
|
|
|
|
public:
|
|
CIfrNot (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_NOT_OP, (CHAR8 **)&mNot),
|
|
CIfrOpHeader (EFI_IFR_NOT_OP, &mNot->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrBitWiseNot : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_BITWISE_NOT *mBitWise;
|
|
|
|
public:
|
|
CIfrBitWiseNot (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_BITWISE_NOT_OP, (CHAR8 **)&mBitWise),
|
|
CIfrOpHeader (EFI_IFR_BITWISE_NOT_OP, &mBitWise->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrToBoolean : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_TO_BOOLEAN *mToBoolean;
|
|
|
|
public:
|
|
CIfrToBoolean (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_TO_BOOLEAN_OP, (CHAR8 **)&mToBoolean),
|
|
CIfrOpHeader (EFI_IFR_TO_BOOLEAN_OP, &mToBoolean->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrToString : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_TO_STRING *mToString;
|
|
|
|
public:
|
|
CIfrToString (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_TO_STRING_OP, (CHAR8 **)&mToString),
|
|
CIfrOpHeader (EFI_IFR_TO_STRING_OP, &mToString->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
|
|
VOID SetFormat (IN UINT8 Format) {
|
|
mToString->Format = Format;
|
|
}
|
|
};
|
|
|
|
class CIfrToUint : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_TO_UINT *mToUint;
|
|
|
|
public:
|
|
CIfrToUint (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_TO_UINT_OP, (CHAR8 **)&mToUint),
|
|
CIfrOpHeader (EFI_IFR_TO_UINT_OP, &mToUint->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrToUpper : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_TO_UPPER *mToUpper;
|
|
|
|
public:
|
|
CIfrToUpper (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_TO_UPPER_OP, (CHAR8 **)&mToUpper),
|
|
CIfrOpHeader (EFI_IFR_TO_UPPER_OP, &mToUpper->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrToLower : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_TO_LOWER *mToLower;
|
|
|
|
public:
|
|
CIfrToLower (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_TO_LOWER_OP, (CHAR8 **)&mToLower),
|
|
CIfrOpHeader (EFI_IFR_TO_LOWER_OP, &mToLower->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrAdd : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_ADD *mAdd;
|
|
|
|
public:
|
|
CIfrAdd (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_ADD_OP, (CHAR8 **)&mAdd),
|
|
CIfrOpHeader (EFI_IFR_ADD_OP, &mAdd->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrBitWiseAnd : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_BITWISE_AND *mBitWiseAnd;
|
|
|
|
public:
|
|
CIfrBitWiseAnd (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_BITWISE_AND_OP, (CHAR8 **)&mBitWiseAnd),
|
|
CIfrOpHeader (EFI_IFR_BITWISE_AND_OP, &mBitWiseAnd->Header) {
|
|
SetLineNo(LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrBitWiseOr : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_BITWISE_OR *mBitWiseOr;
|
|
|
|
public:
|
|
CIfrBitWiseOr (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_BITWISE_OR_OP, (CHAR8 **)&mBitWiseOr),
|
|
CIfrOpHeader (EFI_IFR_BITWISE_OR_OP, &mBitWiseOr->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrAnd : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_AND *mAnd;
|
|
|
|
public:
|
|
CIfrAnd (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_AND_OP, (CHAR8 **)&mAnd),
|
|
CIfrOpHeader (EFI_IFR_AND_OP, &mAnd->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrCatenate : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_CATENATE *mCatenate;
|
|
|
|
public:
|
|
CIfrCatenate (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_CATENATE_OP, (CHAR8 **)&mCatenate),
|
|
CIfrOpHeader (EFI_IFR_CATENATE_OP, &mCatenate->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrDivide : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_DIVIDE *mDivide;
|
|
|
|
public:
|
|
CIfrDivide (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_DIVIDE_OP, (CHAR8 **)&mDivide),
|
|
CIfrOpHeader (EFI_IFR_DIVIDE_OP, &mDivide->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrEqual : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_EQUAL *mEqual;
|
|
|
|
public:
|
|
CIfrEqual (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_EQUAL_OP, (CHAR8 **)&mEqual),
|
|
CIfrOpHeader (EFI_IFR_EQUAL_OP, &mEqual->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrGreaterEqual : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_GREATER_EQUAL *mGreaterEqual;
|
|
|
|
public:
|
|
CIfrGreaterEqual (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_GREATER_EQUAL_OP, (CHAR8 **)&mGreaterEqual),
|
|
CIfrOpHeader (EFI_IFR_GREATER_EQUAL_OP, &mGreaterEqual->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrGreaterThan : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_GREATER_THAN *mGreaterThan;
|
|
|
|
public:
|
|
CIfrGreaterThan (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_GREATER_THAN_OP, (CHAR8 **)&mGreaterThan),
|
|
CIfrOpHeader (EFI_IFR_GREATER_THAN_OP, &mGreaterThan->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrLessEqual : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_LESS_EQUAL *mLessEqual;
|
|
|
|
public:
|
|
CIfrLessEqual (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_LESS_EQUAL_OP, (CHAR8 **)&mLessEqual),
|
|
CIfrOpHeader (EFI_IFR_LESS_EQUAL_OP, &mLessEqual->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrLessThan : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_LESS_THAN *mLessThan;
|
|
|
|
public:
|
|
CIfrLessThan (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_LESS_THAN_OP, (CHAR8 **)&mLessThan),
|
|
CIfrOpHeader (EFI_IFR_LESS_THAN_OP, &mLessThan->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrMap : public CIfrObj, public CIfrOpHeader{
|
|
private:
|
|
EFI_IFR_MAP *mMap;
|
|
|
|
public:
|
|
CIfrMap (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_MAP_OP, (CHAR8 **)&mMap),
|
|
CIfrOpHeader (EFI_IFR_MAP_OP, &mMap->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrMatch : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_MATCH *mMatch;
|
|
|
|
public:
|
|
CIfrMatch (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_MATCH_OP, (CHAR8 **)&mMatch),
|
|
CIfrOpHeader (EFI_IFR_MATCH_OP, &mMatch->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrMatch2 : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_MATCH2 *mMatch2;
|
|
|
|
public:
|
|
CIfrMatch2 (
|
|
IN UINT32 LineNo,
|
|
IN EFI_GUID *Guid
|
|
) : CIfrObj (EFI_IFR_MATCH2_OP, (CHAR8 **)&mMatch2),
|
|
CIfrOpHeader (EFI_IFR_MATCH2_OP, &mMatch2->Header) {
|
|
SetLineNo (LineNo);
|
|
memmove (&mMatch2->SyntaxType, Guid, sizeof (EFI_GUID));
|
|
}
|
|
};
|
|
|
|
class CIfrMultiply : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_MULTIPLY *mMultiply;
|
|
|
|
public:
|
|
CIfrMultiply (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_MULTIPLY_OP, (CHAR8 **)&mMultiply),
|
|
CIfrOpHeader (EFI_IFR_MULTIPLY_OP, &mMultiply->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrModulo : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_MODULO *mModulo;
|
|
|
|
public:
|
|
CIfrModulo (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_MODULO_OP, (CHAR8 **)&mModulo),
|
|
CIfrOpHeader (EFI_IFR_MODULO_OP, &mModulo->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrNotEqual : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_NOT_EQUAL *mNotEqual;
|
|
|
|
public:
|
|
CIfrNotEqual (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_NOT_EQUAL_OP, (CHAR8 **)&mNotEqual),
|
|
CIfrOpHeader (EFI_IFR_NOT_EQUAL_OP, &mNotEqual->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrOr : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_OR *mOr;
|
|
|
|
public:
|
|
CIfrOr (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_OR_OP, (CHAR8 **)&mOr),
|
|
CIfrOpHeader (EFI_IFR_OR_OP, &mOr->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrShiftLeft : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_SHIFT_LEFT *mShiftLeft;
|
|
|
|
public:
|
|
CIfrShiftLeft (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_SHIFT_LEFT_OP, (CHAR8 **)&mShiftLeft),
|
|
CIfrOpHeader (EFI_IFR_SHIFT_LEFT_OP, &mShiftLeft->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrShiftRight : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_SHIFT_RIGHT *mShiftRight;
|
|
|
|
public:
|
|
CIfrShiftRight (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_SHIFT_RIGHT_OP, (CHAR8 **)&mShiftRight),
|
|
CIfrOpHeader (EFI_IFR_SHIFT_RIGHT_OP, &mShiftRight->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrSubtract : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_SUBTRACT *mSubtract;
|
|
|
|
public:
|
|
CIfrSubtract (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_SUBTRACT_OP, (CHAR8 **)&mSubtract),
|
|
CIfrOpHeader (EFI_IFR_SUBTRACT_OP, &mSubtract->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrConditional : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_CONDITIONAL *mConditional;
|
|
|
|
public:
|
|
CIfrConditional (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_CONDITIONAL_OP, (CHAR8 **)&mConditional),
|
|
CIfrOpHeader (EFI_IFR_CONDITIONAL_OP, &mConditional->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrFind : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_FIND *mFind;
|
|
|
|
public:
|
|
CIfrFind (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_FIND_OP, (CHAR8 **)&mFind),
|
|
CIfrOpHeader (EFI_IFR_FIND_OP, &mFind->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
|
|
VOID SetFormat (IN UINT8 Format) {
|
|
mFind->Format = Format;
|
|
}
|
|
};
|
|
|
|
class CIfrMid : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_MID *mMid;
|
|
|
|
public:
|
|
CIfrMid (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_MID_OP, (CHAR8 **)&mMid),
|
|
CIfrOpHeader (EFI_IFR_MID_OP, &mMid->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrToken : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_TOKEN *mToken;
|
|
|
|
public:
|
|
CIfrToken (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_TOKEN_OP, (CHAR8 **)&mToken),
|
|
CIfrOpHeader (EFI_IFR_TOKEN_OP, &mToken->Header) {
|
|
SetLineNo (LineNo);
|
|
}
|
|
};
|
|
|
|
class CIfrSpan : public CIfrObj, public CIfrOpHeader {
|
|
private:
|
|
EFI_IFR_SPAN *mSpan;
|
|
|
|
public:
|
|
CIfrSpan (
|
|
IN UINT32 LineNo
|
|
) : CIfrObj (EFI_IFR_SPAN_OP, (CHAR8 **)&mSpan),
|
|
CIfrOpHeader (EFI_IFR_SPAN_OP, &mSpan->Header) {
|
|
SetLineNo (LineNo);
|
|
mSpan->Flags = EFI_IFR_FLAGS_FIRST_MATCHING;
|
|
}
|
|
|
|
EFI_VFR_RETURN_CODE SetFlags (IN UINT8 LFlags) {
|
|
if (_IS_EQUAL (LFlags, EFI_IFR_FLAGS_FIRST_MATCHING)) {
|
|
mSpan->Flags |= EFI_IFR_FLAGS_FIRST_MATCHING;
|
|
} else if (_FLAG_TEST_AND_CLEAR (LFlags, EFI_IFR_FLAGS_FIRST_NON_MATCHING)) {
|
|
mSpan->Flags |= EFI_IFR_FLAGS_FIRST_NON_MATCHING;
|
|
}
|
|
|
|
return _FLAGS_ZERO (LFlags) ? VFR_RETURN_SUCCESS : VFR_RETURN_FLAGS_UNSUPPORTED;
|
|
}
|
|
};
|
|
|
|
#endif
|