Sync value for string opcode after call the Callback function.

Contributed-under: TianoCore Contribution Agreement 1.0
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@15448 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
Eric Dong 2014-04-11 06:15:57 +00:00 committed by ydong10
parent 66a5771e7a
commit 061d546224
3 changed files with 52 additions and 3 deletions

View File

@ -2092,6 +2092,7 @@ ProcessCallBackFunction (
BROWSER_SETTING_SCOPE SettingLevel; BROWSER_SETTING_SCOPE SettingLevel;
EFI_IFR_TYPE_VALUE BackUpValue; EFI_IFR_TYPE_VALUE BackUpValue;
UINT8 *BackUpBuffer; UINT8 *BackUpBuffer;
CHAR16 *NewString;
ConfigAccess = FormSet->ConfigAccess; ConfigAccess = FormSet->ConfigAccess;
SubmitFormIsRequired = FALSE; SubmitFormIsRequired = FALSE;
@ -2209,6 +2210,22 @@ ProcessCallBackFunction (
} }
} }
//
// Need to sync the value between Statement->HiiValue->Value and Statement->BufferValue
//
if (HiiValue->Type == EFI_IFR_TYPE_STRING) {
NewString = GetToken (Statement->HiiValue.Value.string, FormSet->HiiHandle);
ASSERT (NewString != NULL);
ASSERT (StrLen (NewString) * sizeof (CHAR16) <= Statement->StorageWidth);
if (StrLen (NewString) * sizeof (CHAR16) <= Statement->StorageWidth) {
CopyMem (Statement->BufferValue, NewString, StrSize (NewString));
} else {
CopyMem (Statement->BufferValue, NewString, Statement->StorageWidth);
}
FreePool (NewString);
}
// //
// According the spec, return value from call back of "changing" and // According the spec, return value from call back of "changing" and
// "retrieve" should update to the question's temp buffer. // "retrieve" should update to the question's temp buffer.
@ -2277,6 +2294,7 @@ ProcessCallBackFunction (
@param ConfigAccess The config access protocol produced by the hii driver. @param ConfigAccess The config access protocol produced by the hii driver.
@param Statement The Question which need to call. @param Statement The Question which need to call.
@param FormSet The formset this question belong to.
@retval EFI_SUCCESS The call back function excutes successfully. @retval EFI_SUCCESS The call back function excutes successfully.
@return Other value if the call back function failed to excute. @return Other value if the call back function failed to excute.
@ -2284,13 +2302,15 @@ ProcessCallBackFunction (
EFI_STATUS EFI_STATUS
ProcessRetrieveForQuestion ( ProcessRetrieveForQuestion (
IN EFI_HII_CONFIG_ACCESS_PROTOCOL *ConfigAccess, IN EFI_HII_CONFIG_ACCESS_PROTOCOL *ConfigAccess,
IN FORM_BROWSER_STATEMENT *Statement IN FORM_BROWSER_STATEMENT *Statement,
IN FORM_BROWSER_FORMSET *FormSet
) )
{ {
EFI_STATUS Status; EFI_STATUS Status;
EFI_BROWSER_ACTION_REQUEST ActionRequest; EFI_BROWSER_ACTION_REQUEST ActionRequest;
EFI_HII_VALUE *HiiValue; EFI_HII_VALUE *HiiValue;
EFI_IFR_TYPE_VALUE *TypeValue; EFI_IFR_TYPE_VALUE *TypeValue;
CHAR16 *NewString;
Status = EFI_SUCCESS; Status = EFI_SUCCESS;
ActionRequest = EFI_BROWSER_ACTION_REQUEST_NONE; ActionRequest = EFI_BROWSER_ACTION_REQUEST_NONE;
@ -2317,6 +2337,19 @@ ProcessRetrieveForQuestion (
TypeValue, TypeValue,
&ActionRequest &ActionRequest
); );
if (!EFI_ERROR (Status) && HiiValue->Type == EFI_IFR_TYPE_STRING) {
NewString = GetToken (Statement->HiiValue.Value.string, FormSet->HiiHandle);
ASSERT (NewString != NULL);
ASSERT (StrLen (NewString) * sizeof (CHAR16) <= Statement->StorageWidth);
if (StrLen (NewString) * sizeof (CHAR16) <= Statement->StorageWidth) {
CopyMem (Statement->BufferValue, NewString, StrSize (NewString));
} else {
CopyMem (Statement->BufferValue, NewString, Statement->StorageWidth);
}
FreePool (NewString);
}
return Status; return Status;
} }

View File

@ -2993,6 +2993,7 @@ GetQuestionDefault (
EFI_HII_CONFIG_ACCESS_PROTOCOL *ConfigAccess; EFI_HII_CONFIG_ACCESS_PROTOCOL *ConfigAccess;
EFI_BROWSER_ACTION_REQUEST ActionRequest; EFI_BROWSER_ACTION_REQUEST ActionRequest;
INTN Action; INTN Action;
CHAR16 *NewString;
Status = EFI_NOT_FOUND; Status = EFI_NOT_FOUND;
StrValue = NULL; StrValue = NULL;
@ -3030,6 +3031,19 @@ GetQuestionDefault (
&ActionRequest &ActionRequest
); );
if (!EFI_ERROR (Status)) { if (!EFI_ERROR (Status)) {
if (HiiValue->Type == EFI_IFR_TYPE_STRING) {
NewString = GetToken (Question->HiiValue.Value.string, FormSet->HiiHandle);
ASSERT (NewString != NULL);
ASSERT (StrLen (NewString) * sizeof (CHAR16) <= Question->StorageWidth);
if (StrLen (NewString) * sizeof (CHAR16) <= Question->StorageWidth) {
CopyMem (Question->BufferValue, NewString, StrSize (NewString));
} else {
CopyMem (Question->BufferValue, NewString, Question->StorageWidth);
}
FreePool (NewString);
}
return Status; return Status;
} }
} }
@ -3307,7 +3321,7 @@ ExtractDefault (
// //
// Call the Retrieve call back to get the initial question value. // Call the Retrieve call back to get the initial question value.
// //
Status = ProcessRetrieveForQuestion(FormSet->ConfigAccess, Question); Status = ProcessRetrieveForQuestion(FormSet->ConfigAccess, Question, FormSet);
} }
// //

View File

@ -1205,6 +1205,7 @@ ProcessCallBackFunction (
@param ConfigAccess The config access protocol produced by the hii driver. @param ConfigAccess The config access protocol produced by the hii driver.
@param Statement The Question which need to call. @param Statement The Question which need to call.
@param FormSet The formset this question belong to.
@retval EFI_SUCCESS The call back function excutes successfully. @retval EFI_SUCCESS The call back function excutes successfully.
@return Other value if the call back function failed to excute. @return Other value if the call back function failed to excute.
@ -1212,7 +1213,8 @@ ProcessCallBackFunction (
EFI_STATUS EFI_STATUS
ProcessRetrieveForQuestion ( ProcessRetrieveForQuestion (
IN EFI_HII_CONFIG_ACCESS_PROTOCOL *ConfigAccess, IN EFI_HII_CONFIG_ACCESS_PROTOCOL *ConfigAccess,
IN FORM_BROWSER_STATEMENT *Statement IN FORM_BROWSER_STATEMENT *Statement,
IN FORM_BROWSER_FORMSET *FormSet
); );
/** /**