Fix an issue that an assert occurrs if user inputs a password whose length is less than the minimum required length. The root cause is that under such case the Form Browser will pass a null string (string ID = 0) to the Config Access callback. The callback handler does not handle such case correctly.

git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@8103 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
rsun3 2009-04-16 07:02:42 +00:00
parent b2f5a3718b
commit 887c077d91
1 changed files with 12 additions and 6 deletions

View File

@ -690,10 +690,14 @@ CreateIfrDataArray (
break;
case EFI_IFR_TYPE_STRING:
String = HiiGetString (ConfigAccess->ThunkContext->UefiHiiHandle, Value->string, NULL);
ASSERT (String != NULL);
if (Value->string == 0) {
Size = 0;
} else {
String = HiiGetString (ConfigAccess->ThunkContext->UefiHiiHandle, Value->string, NULL);
ASSERT (String != NULL);
Size = StrSize (String);
Size = StrSize (String);
}
break;
default:
@ -741,9 +745,11 @@ CreateIfrDataArray (
break;
case EFI_IFR_TYPE_STRING:
ASSERT (String != NULL);
StrCpy ((CHAR16 *) &IfrDataEntry->Data, String);
FreePool (String);
if (Size != 0) {
ASSERT (String != NULL);
StrCpy ((CHAR16 *) &IfrDataEntry->Data, String);
FreePool (String);
}
break;
default:
ASSERT (FALSE);