mirror of
https://github.com/acidanthera/audk.git
synced 2025-04-08 17:05:09 +02:00
MdeModulePkg/HiiDatabase: Return default value for BIT VarStore as UNIT32
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=4874 Question CheckBox, OneOf and Numeric can refer to Bit EFI VarStore. CheckBox: data type is Boolean (1 byte), Numeric/Oneof: data type is always UNIT32 for BIT VarStore, When get default value for BIT VarStore, should return default value with sizeof (UINT32) rather than the byte the bit width occupied. Or incorrect default value will be used due to the size mismatch. Signed-off-by: Dandan Bi <dandan.bi@intel.com>
This commit is contained in:
parent
9a9bcacbe0
commit
9112fb0ecc
@ -825,7 +825,7 @@ FindQuestionDefaultSetting (
|
||||
if (BitFieldQuestion) {
|
||||
CopyMem (&BufferValue, (UINT8 *)AuthVariableHeader + sizeof (AUTHENTICATED_VARIABLE_HEADER) + AuthVariableHeader->NameSize + ByteOffset, Width);
|
||||
BitFieldVal = BitFieldRead32 (BufferValue, StartBit, EndBit);
|
||||
CopyMem (ValueBuffer, &BitFieldVal, Width);
|
||||
CopyMem (ValueBuffer, &BitFieldVal, sizeof (UINT32));
|
||||
} else {
|
||||
CopyMem (ValueBuffer, (UINT8 *)AuthVariableHeader + sizeof (AUTHENTICATED_VARIABLE_HEADER) + AuthVariableHeader->NameSize + IfrQuestionHdr->VarStoreInfo.VarOffset, Width);
|
||||
}
|
||||
@ -862,7 +862,7 @@ FindQuestionDefaultSetting (
|
||||
if (BitFieldQuestion) {
|
||||
CopyMem (&BufferValue, (UINT8 *)VariableHeader + sizeof (VARIABLE_HEADER) + VariableHeader->NameSize + ByteOffset, Width);
|
||||
BitFieldVal = BitFieldRead32 (BufferValue, StartBit, EndBit);
|
||||
CopyMem (ValueBuffer, &BitFieldVal, Width);
|
||||
CopyMem (ValueBuffer, &BitFieldVal, sizeof (UINT32));
|
||||
} else {
|
||||
CopyMem (ValueBuffer, (UINT8 *)VariableHeader + sizeof (VARIABLE_HEADER) + VariableHeader->NameSize + IfrQuestionHdr->VarStoreInfo.VarOffset, Width);
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user