mirror of https://github.com/acidanthera/audk.git
MdeModulePkg:Set default string value
Previously construct Default Value in AltResp for string opcode is String Id, Now change it to string value if the string opcode has default value. This change is compatible for SetupBrowser to handle.And add default value for string in DriverSample to test this case. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Dandan Bi <dandan.bi@intel.com> Reviewed-by: Liming Gao <liming.gao@intel.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@18337 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
parent
2bf63b20d2
commit
e68c776bf8
|
@ -461,6 +461,7 @@ formset
|
||||||
help = STRING_TOKEN(STR_MY_STRING_HELP),
|
help = STRING_TOKEN(STR_MY_STRING_HELP),
|
||||||
minsize = 6,
|
minsize = 6,
|
||||||
maxsize = 0x14,
|
maxsize = 0x14,
|
||||||
|
default = STRING_TOKEN(STR_MY_STRING_DEFAULT),
|
||||||
endstring;
|
endstring;
|
||||||
|
|
||||||
//
|
//
|
||||||
|
|
Binary file not shown.
|
@ -2056,11 +2056,6 @@ ParseIfrData (
|
||||||
if (EFI_ERROR (Status)) {
|
if (EFI_ERROR (Status)) {
|
||||||
goto Done;
|
goto Done;
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
|
||||||
// No default value for string.
|
|
||||||
//
|
|
||||||
BlockData = NULL;
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case EFI_IFR_PASSWORD_OP:
|
case EFI_IFR_PASSWORD_OP:
|
||||||
|
@ -2850,6 +2845,7 @@ GetStorageWidth (
|
||||||
/**
|
/**
|
||||||
Generate ConfigAltResp string base on the varstore info.
|
Generate ConfigAltResp string base on the varstore info.
|
||||||
|
|
||||||
|
@param HiiHandle Hii Handle for this hii package.
|
||||||
@param ConfigHdr The config header for this varstore.
|
@param ConfigHdr The config header for this varstore.
|
||||||
@param VarStorageData The varstore info.
|
@param VarStorageData The varstore info.
|
||||||
@param DefaultIdArray The Default id array.
|
@param DefaultIdArray The Default id array.
|
||||||
|
@ -2860,6 +2856,7 @@ GetStorageWidth (
|
||||||
**/
|
**/
|
||||||
EFI_STATUS
|
EFI_STATUS
|
||||||
GenerateAltConfigResp (
|
GenerateAltConfigResp (
|
||||||
|
IN EFI_HII_HANDLE HiiHandle,
|
||||||
IN CHAR16 *ConfigHdr,
|
IN CHAR16 *ConfigHdr,
|
||||||
IN IFR_VARSTORAGE_DATA *VarStorageData,
|
IN IFR_VARSTORAGE_DATA *VarStorageData,
|
||||||
IN IFR_DEFAULT_DATA *DefaultIdArray,
|
IN IFR_DEFAULT_DATA *DefaultIdArray,
|
||||||
|
@ -2878,10 +2875,11 @@ GenerateAltConfigResp (
|
||||||
IFR_DEFAULT_DATA *DefaultValueData;
|
IFR_DEFAULT_DATA *DefaultValueData;
|
||||||
UINTN Width;
|
UINTN Width;
|
||||||
UINT8 *TmpBuffer;
|
UINT8 *TmpBuffer;
|
||||||
|
CHAR16 *DefaultString;
|
||||||
|
|
||||||
BlockData = NULL;
|
BlockData = NULL;
|
||||||
DataExist = FALSE;
|
DataExist = FALSE;
|
||||||
|
DefaultString = NULL;
|
||||||
//
|
//
|
||||||
// Add length for <ConfigHdr> + '\0'
|
// Add length for <ConfigHdr> + '\0'
|
||||||
//
|
//
|
||||||
|
@ -2993,10 +2991,19 @@ GenerateAltConfigResp (
|
||||||
// Convert Value to a hex string in "%x" format
|
// Convert Value to a hex string in "%x" format
|
||||||
// NOTE: This is in the opposite byte that GUID and PATH use
|
// NOTE: This is in the opposite byte that GUID and PATH use
|
||||||
//
|
//
|
||||||
|
if (BlockData->OpCode == EFI_IFR_STRING_OP){
|
||||||
|
DefaultString = InternalGetString(HiiHandle, DefaultValueData->Value.string);
|
||||||
|
TmpBuffer = (UINT8 *) DefaultString;
|
||||||
|
} else {
|
||||||
TmpBuffer = (UINT8 *) &(DefaultValueData->Value);
|
TmpBuffer = (UINT8 *) &(DefaultValueData->Value);
|
||||||
for (; Width > 0; Width--) {
|
}
|
||||||
|
for (; Width > 0 && (TmpBuffer != NULL); Width--) {
|
||||||
StringPtr += UnicodeValueToString (StringPtr, PREFIX_ZERO | RADIX_HEX, TmpBuffer[Width - 1], 2);
|
StringPtr += UnicodeValueToString (StringPtr, PREFIX_ZERO | RADIX_HEX, TmpBuffer[Width - 1], 2);
|
||||||
}
|
}
|
||||||
|
if (DefaultString != NULL){
|
||||||
|
FreePool(DefaultString);
|
||||||
|
DefaultString = NULL;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3218,7 +3225,7 @@ GetFullStringFromHiiFormPackages (
|
||||||
// Go through all VarStorageData Entry and get the DefaultId array for each one
|
// Go through all VarStorageData Entry and get the DefaultId array for each one
|
||||||
// Then construct them all to : ConfigHdr AltConfigHdr ConfigBody AltConfigHdr ConfigBody
|
// Then construct them all to : ConfigHdr AltConfigHdr ConfigBody AltConfigHdr ConfigBody
|
||||||
//
|
//
|
||||||
Status = GenerateAltConfigResp (ConfigHdr, VarStorageData, DefaultIdArray, &DefaultAltCfgResp);
|
Status = GenerateAltConfigResp (DataBaseRecord->Handle,ConfigHdr, VarStorageData, DefaultIdArray, &DefaultAltCfgResp);
|
||||||
if (EFI_ERROR (Status)) {
|
if (EFI_ERROR (Status)) {
|
||||||
goto Done;
|
goto Done;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue