mirror of https://github.com/acidanthera/audk.git
Refine question value update logic.
Signed-off-by: Eric Dong <eric.dong@intel.com> Reviewed-by: Liming Gao <liming.gao@intel.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@14673 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
parent
e84f07b5fc
commit
e6cc2ab38e
|
@ -1618,9 +1618,6 @@ ProcessUserInput (
|
||||||
CopyMem (&Statement->HiiValue, &UserInput->InputValue, sizeof (EFI_HII_VALUE));
|
CopyMem (&Statement->HiiValue, &UserInput->InputValue, sizeof (EFI_HII_VALUE));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (Statement->Operand != EFI_IFR_PASSWORD_OP) {
|
|
||||||
SetQuestionValue (gCurrentSelection->FormSet, gCurrentSelection->Form, Statement, GetSetValueWithEditBuffer);
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2012,6 +2009,8 @@ ProcessCallBackFunction (
|
||||||
BOOLEAN NeedExit;
|
BOOLEAN NeedExit;
|
||||||
LIST_ENTRY *Link;
|
LIST_ENTRY *Link;
|
||||||
BROWSER_SETTING_SCOPE SettingLevel;
|
BROWSER_SETTING_SCOPE SettingLevel;
|
||||||
|
EFI_IFR_TYPE_VALUE BackUpValue;
|
||||||
|
UINT8 *BackUpBuffer;
|
||||||
|
|
||||||
ConfigAccess = Selection->FormSet->ConfigAccess;
|
ConfigAccess = Selection->FormSet->ConfigAccess;
|
||||||
SubmitFormIsRequired = FALSE;
|
SubmitFormIsRequired = FALSE;
|
||||||
|
@ -2020,6 +2019,7 @@ ProcessCallBackFunction (
|
||||||
NeedExit = FALSE;
|
NeedExit = FALSE;
|
||||||
Status = EFI_SUCCESS;
|
Status = EFI_SUCCESS;
|
||||||
ActionRequest = EFI_BROWSER_ACTION_REQUEST_NONE;
|
ActionRequest = EFI_BROWSER_ACTION_REQUEST_NONE;
|
||||||
|
BackUpBuffer = NULL;
|
||||||
|
|
||||||
if (ConfigAccess == NULL) {
|
if (ConfigAccess == NULL) {
|
||||||
return EFI_SUCCESS;
|
return EFI_SUCCESS;
|
||||||
|
@ -2059,6 +2059,17 @@ ProcessCallBackFunction (
|
||||||
TypeValue = (EFI_IFR_TYPE_VALUE *) Statement->BufferValue;
|
TypeValue = (EFI_IFR_TYPE_VALUE *) Statement->BufferValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
// If EFI_BROWSER_ACTION_CHANGING type, back up the new question value.
|
||||||
|
//
|
||||||
|
if (Action == EFI_BROWSER_ACTION_CHANGING) {
|
||||||
|
if (HiiValue->Type == EFI_IFR_TYPE_BUFFER) {
|
||||||
|
BackUpBuffer = AllocateCopyPool(Statement->StorageWidth + sizeof(CHAR16), Statement->BufferValue);
|
||||||
|
} else {
|
||||||
|
CopyMem (&BackUpValue, &HiiValue->Value, sizeof (EFI_IFR_TYPE_VALUE));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
ActionRequest = EFI_BROWSER_ACTION_REQUEST_NONE;
|
ActionRequest = EFI_BROWSER_ACTION_REQUEST_NONE;
|
||||||
Status = ConfigAccess->Callback (
|
Status = ConfigAccess->Callback (
|
||||||
ConfigAccess,
|
ConfigAccess,
|
||||||
|
@ -2125,11 +2136,27 @@ ProcessCallBackFunction (
|
||||||
SetQuestionValue(Selection->FormSet, Selection->Form, Statement, GetSetValueWithEditBuffer);
|
SetQuestionValue(Selection->FormSet, Selection->Form, Statement, GetSetValueWithEditBuffer);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
//
|
||||||
|
// If the callback returns EFI_UNSUPPORTED for EFI_BROWSER_ACTION_CHANGING,
|
||||||
|
// then the browser will use the value passed to Callback() and ignore the
|
||||||
|
// value returned by Callback().
|
||||||
|
//
|
||||||
|
if (Action == EFI_BROWSER_ACTION_CHANGING && Status == EFI_UNSUPPORTED) {
|
||||||
|
if (HiiValue->Type == EFI_IFR_TYPE_BUFFER) {
|
||||||
|
CopyMem (Statement->BufferValue, BackUpBuffer, Statement->StorageWidth + sizeof(CHAR16));
|
||||||
|
} else {
|
||||||
|
CopyMem (&HiiValue->Value, &BackUpValue, sizeof (EFI_IFR_TYPE_VALUE));
|
||||||
|
}
|
||||||
|
|
||||||
|
SetQuestionValue(Selection->FormSet, Selection->Form, Statement, GetSetValueWithEditBuffer);
|
||||||
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// According the spec, return fail from call back of "changing" and
|
// According the spec, return fail from call back of "changing" and
|
||||||
// "retrieve", should restore the question's value.
|
// "retrieve", should restore the question's value.
|
||||||
//
|
//
|
||||||
if (Action == EFI_BROWSER_ACTION_CHANGING || Action == EFI_BROWSER_ACTION_RETRIEVE) {
|
if ((Action == EFI_BROWSER_ACTION_CHANGING && Status != EFI_UNSUPPORTED) ||
|
||||||
|
Action == EFI_BROWSER_ACTION_RETRIEVE) {
|
||||||
GetQuestionValue(Selection->FormSet, Selection->Form, Statement, GetSetValueWithEditBuffer);
|
GetQuestionValue(Selection->FormSet, Selection->Form, Statement, GetSetValueWithEditBuffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2140,6 +2167,10 @@ ProcessCallBackFunction (
|
||||||
Status = EFI_SUCCESS;
|
Status = EFI_SUCCESS;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (BackUpBuffer != NULL) {
|
||||||
|
FreePool (BackUpBuffer);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (SubmitFormIsRequired && !SkipSaveOrDiscard) {
|
if (SubmitFormIsRequired && !SkipSaveOrDiscard) {
|
||||||
|
@ -2399,6 +2430,8 @@ SetupBrowser (
|
||||||
if (!EFI_ERROR (Status) && Statement->Operand != EFI_IFR_REF_OP) {
|
if (!EFI_ERROR (Status) && Statement->Operand != EFI_IFR_REF_OP) {
|
||||||
ProcessCallBackFunction(Selection, Statement, EFI_BROWSER_ACTION_CHANGED, FALSE);
|
ProcessCallBackFunction(Selection, Statement, EFI_BROWSER_ACTION_CHANGED, FALSE);
|
||||||
}
|
}
|
||||||
|
} else if (Statement->Operand != EFI_IFR_PASSWORD_OP) {
|
||||||
|
SetQuestionValue (gCurrentSelection->FormSet, gCurrentSelection->Form, Statement, GetSetValueWithEditBuffer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue