]> git.proxmox.com Git - mirror_edk2.git/commitdiff
MdeModulePkg UiApp: change code for easy customization.
authorEric Dong <eric.dong@intel.com>
Thu, 12 May 2016 05:25:26 +0000 (13:25 +0800)
committerLiming Gao <liming.gao@intel.com>
Fri, 13 May 2016 03:18:13 +0000 (11:18 +0800)
Change file arrangement to let user easy customize the front page UI.
After this change:
1. UiCustomizeFrontPage function in FrontPageCustomizedUi.c use to
let user customize front page menus. UiFrontPageCallbackHandler
function use to handle the callback for the added menus.
2. FrontPageCustomizedUiSupport.c file used to add support functions
used by FrontPageCustomizedUi.c file.
3. After this change, only above two files need to be updated if front page
menus needed to be changed.

Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Eric Dong <eric.dong@intel.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>
13 files changed:
MdeModulePkg/Application/UiApp/FrontPage.c
MdeModulePkg/Application/UiApp/FrontPage.h
MdeModulePkg/Application/UiApp/FrontPageCustomizedUi.c [new file with mode: 0644]
MdeModulePkg/Application/UiApp/FrontPageCustomizedUi.h [new file with mode: 0644]
MdeModulePkg/Application/UiApp/FrontPageCustomizedUiSupport.c [new file with mode: 0644]
MdeModulePkg/Application/UiApp/FrontPageCustomizedUiSupport.h [new file with mode: 0644]
MdeModulePkg/Application/UiApp/FrontPageStrings.uni
MdeModulePkg/Application/UiApp/FrontPageVfr.Vfr
MdeModulePkg/Application/UiApp/Language.c [deleted file]
MdeModulePkg/Application/UiApp/Language.h [deleted file]
MdeModulePkg/Application/UiApp/String.c
MdeModulePkg/Application/UiApp/String.h
MdeModulePkg/Application/UiApp/UiApp.inf

index d6207b6fa3b2ef1e105ab599e4601ef9fc9d55b7..8efe4d137b070af5e66162a98d8c1a3ad3cd5e86 100644 (file)
@@ -13,8 +13,9 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
 **/\r
 \r
 #include "FrontPage.h"\r
-#include "Language.h"\r
-#define MAX_STRING_LEN        200\r
+#include "FrontPageCustomizedUi.h"\r
+\r
+#define MAX_STRING_LEN            200\r
 \r
 EFI_GUID   mFrontPageGuid      = FRONT_PAGE_FORMSET_GUID;\r
 \r
@@ -82,7 +83,7 @@ HII_VENDOR_DEVICE_PATH  mFrontPageHiiVendorDevicePath = {
 \r
 **/\r
 VOID\r
-UpdateFrontPageStrings (\r
+UpdateFrontPageBannerStrings (\r
   VOID\r
   );\r
 \r
@@ -155,190 +156,6 @@ FakeRouteConfig (
   return EFI_NOT_FOUND;\r
 }\r
 \r
-/**\r
-  Create oneof options for language.\r
-\r
-**/\r
-VOID\r
-InitializeLanguage (\r
-  VOID\r
-  )\r
-{\r
-  EFI_STATUS                  Status;\r
-  CHAR8                       *LangCode;\r
-  CHAR8                       *Lang;\r
-  CHAR8                       *CurrentLang;\r
-  UINTN                       OptionCount;\r
-  CHAR16                      *StringBuffer;\r
-  EFI_HII_HANDLE              HiiHandle;\r
-  VOID                        *OptionsOpCodeHandle;\r
-  VOID                        *StartOpCodeHandle;\r
-  VOID                        *EndOpCodeHandle;\r
-  EFI_IFR_GUID_LABEL          *StartLabel;\r
-  EFI_IFR_GUID_LABEL          *EndLabel;    \r
-  EFI_HII_STRING_PROTOCOL     *HiiString;\r
-  UINTN                       StringSize;\r
-\r
-  Lang         = NULL;\r
-  StringBuffer = NULL;\r
-\r
-  //\r
-  // Init OpCode Handle and Allocate space for creation of UpdateData Buffer\r
-  //\r
-  StartOpCodeHandle = HiiAllocateOpCodeHandle ();\r
-  ASSERT (StartOpCodeHandle != NULL);\r
-\r
-  EndOpCodeHandle = HiiAllocateOpCodeHandle ();\r
-  ASSERT (EndOpCodeHandle != NULL);\r
-\r
-  OptionsOpCodeHandle = HiiAllocateOpCodeHandle ();\r
-  ASSERT (OptionsOpCodeHandle != NULL);\r
-  //\r
-  // Create Hii Extend Label OpCode as the start opcode\r
-  //\r
-  StartLabel = (EFI_IFR_GUID_LABEL *) HiiCreateGuidOpCode (StartOpCodeHandle, &gEfiIfrTianoGuid, NULL, sizeof (EFI_IFR_GUID_LABEL));\r
-  StartLabel->ExtendOpCode = EFI_IFR_EXTEND_OP_LABEL;\r
-  StartLabel->Number       = LABEL_SELECT_LANGUAGE;\r
-\r
-  //\r
-  // Create Hii Extend Label OpCode as the end opcode\r
-  //\r
-  EndLabel = (EFI_IFR_GUID_LABEL *) HiiCreateGuidOpCode (EndOpCodeHandle, &gEfiIfrTianoGuid, NULL, sizeof (EFI_IFR_GUID_LABEL));\r
-  EndLabel->ExtendOpCode = EFI_IFR_EXTEND_OP_LABEL;\r
-  EndLabel->Number       = LABEL_END;\r
-  //\r
-  // Collect the languages from what our current Language support is based on our VFR\r
-  //\r
-  HiiHandle = gFrontPagePrivate.HiiHandle;\r
-\r
-  GetEfiGlobalVariable2 (L"PlatformLang", (VOID**)&CurrentLang, NULL);\r
-\r
-  if (mLanguageString == NULL) {\r
-    //\r
-    // Get Support language list from variable.\r
-    //\r
-    GetEfiGlobalVariable2 (L"PlatformLangCodes", (VOID**)&mLanguageString, NULL);\r
-    if (mLanguageString == NULL) {\r
-      mLanguageString = AllocateCopyPool (\r
-                                 AsciiStrSize ((CHAR8 *) PcdGetPtr (PcdUefiVariableDefaultPlatformLangCodes)),\r
-                                 (CHAR8 *) PcdGetPtr (PcdUefiVariableDefaultPlatformLangCodes)\r
-                                 );\r
-      ASSERT (mLanguageString != NULL);\r
-    }\r
-  }\r
-\r
-  if (gFrontPagePrivate.LanguageToken == NULL) {\r
-    //\r
-    // Count the language list number.\r
-    //  \r
-    LangCode      = mLanguageString;\r
-    Lang          = AllocatePool (AsciiStrSize (mLanguageString));\r
-    ASSERT (Lang != NULL);\r
-    OptionCount = 0;\r
-    while (*LangCode != 0) {\r
-      GetNextLanguage (&LangCode, Lang);\r
-      OptionCount ++;\r
-    }\r
-\r
-    //\r
-    // Allocate extra 1 as the end tag.\r
-    //\r
-    gFrontPagePrivate.LanguageToken = AllocateZeroPool ((OptionCount + 1) * sizeof (EFI_STRING_ID));\r
-    ASSERT (gFrontPagePrivate.LanguageToken != NULL);\r
-\r
-    Status = gBS->LocateProtocol (&gEfiHiiStringProtocolGuid, NULL, (VOID **) &HiiString);\r
-    ASSERT_EFI_ERROR (Status);\r
-\r
-    LangCode     = mLanguageString;\r
-    OptionCount  = 0;\r
-    while (*LangCode != 0) {\r
-      GetNextLanguage (&LangCode, Lang);\r
-\r
-      StringSize = 0;\r
-      Status = HiiString->GetString (HiiString, Lang, HiiHandle, PRINTABLE_LANGUAGE_NAME_STRING_ID, StringBuffer, &StringSize, NULL);\r
-      if (Status == EFI_BUFFER_TOO_SMALL) {\r
-        StringBuffer = AllocateZeroPool (StringSize);\r
-        ASSERT (StringBuffer != NULL);\r
-        Status = HiiString->GetString (HiiString, Lang, HiiHandle, PRINTABLE_LANGUAGE_NAME_STRING_ID, StringBuffer, &StringSize, NULL);\r
-        ASSERT_EFI_ERROR (Status);\r
-      }\r
-\r
-      if (EFI_ERROR (Status)) {\r
-        StringBuffer = AllocatePool (AsciiStrSize (Lang) * sizeof (CHAR16));\r
-        ASSERT (StringBuffer != NULL);\r
-        AsciiStrToUnicodeStr (Lang, StringBuffer);\r
-      }\r
-\r
-      ASSERT (StringBuffer != NULL);\r
-      gFrontPagePrivate.LanguageToken[OptionCount] = HiiSetString (HiiHandle, 0, StringBuffer, NULL);\r
-      FreePool (StringBuffer);\r
-\r
-      OptionCount++;\r
-    }\r
-  }\r
-\r
-  ASSERT (gFrontPagePrivate.LanguageToken != NULL);\r
-  LangCode     = mLanguageString;\r
-  OptionCount  = 0;\r
-  if (Lang == NULL) {\r
-    Lang = AllocatePool (AsciiStrSize (mLanguageString));\r
-    ASSERT (Lang != NULL);\r
-  }\r
-  while (*LangCode != 0) {\r
-    GetNextLanguage (&LangCode, Lang);\r
-\r
-    if (CurrentLang != NULL && AsciiStrCmp (Lang, CurrentLang) == 0) {\r
-      HiiCreateOneOfOptionOpCode (\r
-        OptionsOpCodeHandle,\r
-        gFrontPagePrivate.LanguageToken[OptionCount],\r
-        EFI_IFR_OPTION_DEFAULT,\r
-        EFI_IFR_NUMERIC_SIZE_1,\r
-        (UINT8) OptionCount\r
-        );\r
-    } else {\r
-      HiiCreateOneOfOptionOpCode (\r
-        OptionsOpCodeHandle,\r
-        gFrontPagePrivate.LanguageToken[OptionCount],\r
-        0,\r
-        EFI_IFR_NUMERIC_SIZE_1,\r
-        (UINT8) OptionCount\r
-        );\r
-    }\r
-\r
-    OptionCount++;\r
-  }\r
-\r
-  if (CurrentLang != NULL) {\r
-    FreePool (CurrentLang);\r
-  }\r
-  FreePool (Lang);\r
-\r
-  HiiCreateOneOfOpCode (\r
-    StartOpCodeHandle,\r
-    FRONT_PAGE_KEY_LANGUAGE,\r
-    0,\r
-    0,\r
-    STRING_TOKEN (STR_LANGUAGE_SELECT),\r
-    STRING_TOKEN (STR_LANGUAGE_SELECT_HELP),\r
-    EFI_IFR_FLAG_CALLBACK,\r
-    EFI_IFR_NUMERIC_SIZE_1,\r
-    OptionsOpCodeHandle,\r
-    NULL\r
-    );\r
-\r
-  Status = HiiUpdateForm (\r
-             HiiHandle,\r
-             &mFrontPageGuid,\r
-             FRONT_PAGE_FORM_ID,\r
-             StartOpCodeHandle, // LABEL_SELECT_LANGUAGE\r
-             EndOpCodeHandle    // LABEL_END\r
-             );\r
-\r
-  HiiFreeOpCodeHandle (StartOpCodeHandle);\r
-  HiiFreeOpCodeHandle (EndOpCodeHandle);\r
-  HiiFreeOpCodeHandle (OptionsOpCodeHandle);\r
-}\r
-\r
 /**\r
   This function processes the results of changes in configuration.\r
 \r
@@ -368,82 +185,12 @@ FrontPageCallback (
   OUT EFI_BROWSER_ACTION_REQUEST             *ActionRequest\r
   )\r
 {\r
-  CHAR8                         *LangCode;\r
-  CHAR8                         *Lang;\r
-  UINTN                         Index;\r
-  EFI_STATUS                    Status;\r
-\r
-  if (Action != EFI_BROWSER_ACTION_CHANGED) {\r
-    //\r
-    // Do nothing for other UEFI Action. Only do call back when data is changed.\r
-    //\r
-    return EFI_UNSUPPORTED;\r
-  }\r
-\r
-  if (Action == EFI_BROWSER_ACTION_CHANGED) {\r
-    if ((Value == NULL) || (ActionRequest == NULL)) {\r
-      return EFI_INVALID_PARAMETER;\r
-    }\r
-\r
-    switch (QuestionId) {\r
-    case FRONT_PAGE_KEY_CONTINUE:\r
-      //\r
-      // This is the continue - clear the screen and return an error to get out of FrontPage loop\r
-      //\r
-      *ActionRequest = EFI_BROWSER_ACTION_REQUEST_EXIT;\r
-      break;\r
-\r
-    case FRONT_PAGE_KEY_LANGUAGE:\r
-      //\r
-      // Allocate working buffer for RFC 4646 language in supported LanguageString.\r
-      //\r
-      Lang = AllocatePool (AsciiStrSize (mLanguageString));\r
-      ASSERT (Lang != NULL);  \r
-\r
-      Index = 0;\r
-      LangCode = mLanguageString;\r
-      while (*LangCode != 0) {\r
-        GetNextLanguage (&LangCode, Lang);\r
-\r
-        if (Index == Value->u8) {\r
-          break;\r
-        }\r
-\r
-        Index++;\r
-      }\r
-\r
-      if (Index == Value->u8) {\r
-        Status = gRT->SetVariable (\r
-                        L"PlatformLang",\r
-                        &gEfiGlobalVariableGuid,\r
-                        EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_RUNTIME_ACCESS,\r
-                        AsciiStrSize (Lang),\r
-                        Lang\r
-                        );\r
-        if (EFI_ERROR (Status)) {\r
-          FreePool (Lang);\r
-          return EFI_DEVICE_ERROR;\r
-        }\r
-      } else {\r
-        ASSERT (FALSE);\r
-      }\r
-      FreePool (Lang);\r
-      //\r
-      //Current language of platform is changed,recreate oneof options for language.\r
-      //\r
-      InitializeLanguage();\r
-      break;\r
-\r
-    default:\r
-      break;\r
-    }\r
-  }\r
-\r
-  return EFI_SUCCESS;\r
+  return UiFrontPageCallbackHandler (gFrontPagePrivate.HiiHandle, Action, QuestionId, Type, Value, ActionRequest);\r
 }\r
 \r
 /**\r
-Update front page form base on the ClassGuid in the formset in other modules.\r
+\r
+  Update the menus in the front page.\r
 \r
 **/\r
 VOID\r
@@ -451,32 +198,10 @@ UpdateFrontPageForm (
   VOID\r
   )\r
 {\r
-  EFI_STATUS                  Status;\r
-  EFI_HII_HANDLE              HiiHandle;\r
   VOID                        *StartOpCodeHandle;\r
   VOID                        *EndOpCodeHandle;\r
-  EFI_IFR_GUID_LABEL          *StartLabel;\r
-  EFI_IFR_GUID_LABEL          *EndLabel;\r
-  UINTN                       Index;\r
-  EFI_STRING                  String;\r
-  EFI_STRING_ID               Token;\r
-  EFI_STRING_ID               TokenHelp;\r
-  EFI_HII_HANDLE              *HiiHandles;\r
-  EFI_GUID                    FormSetGuid;\r
-  CHAR16                      *DevicePathStr;\r
-  EFI_STRING_ID               DevicePathId;\r
-  EFI_IFR_FORM_SET            *Buffer;\r
-  UINTN                       BufferSize;\r
-  UINT8                       ClassGuidNum;\r
-  EFI_GUID                    *ClassGuid;\r
-  UINTN                       TempSize;\r
-  UINT8                       *Ptr;\r
-\r
-  TempSize =0;\r
-  BufferSize = 0;\r
-  Buffer = NULL;\r
-\r
-  HiiHandle = gFrontPagePrivate.HiiHandle;\r
+  EFI_IFR_GUID_LABEL          *StartGuidLabel;\r
+  EFI_IFR_GUID_LABEL          *EndGuidLabel;\r
 \r
   //\r
   // Allocate space for creation of UpdateData Buffer\r
@@ -489,99 +214,26 @@ UpdateFrontPageForm (
   //\r
   // Create Hii Extend Label OpCode as the start opcode\r
   //\r
-  StartLabel = (EFI_IFR_GUID_LABEL *) HiiCreateGuidOpCode (StartOpCodeHandle, &gEfiIfrTianoGuid, NULL, sizeof (EFI_IFR_GUID_LABEL));\r
-  StartLabel->ExtendOpCode = EFI_IFR_EXTEND_OP_LABEL;\r
-  StartLabel->Number       = LABEL_PLATFORM_INFORMATION;\r
+  StartGuidLabel = (EFI_IFR_GUID_LABEL *) HiiCreateGuidOpCode (StartOpCodeHandle, &gEfiIfrTianoGuid, NULL, sizeof (EFI_IFR_GUID_LABEL));\r
+  StartGuidLabel->ExtendOpCode = EFI_IFR_EXTEND_OP_LABEL;\r
+  StartGuidLabel->Number       = LABEL_FRANTPAGE_INFORMATION;\r
   //\r
   // Create Hii Extend Label OpCode as the end opcode\r
   //\r
-  EndLabel = (EFI_IFR_GUID_LABEL *) HiiCreateGuidOpCode (EndOpCodeHandle, &gEfiIfrTianoGuid, NULL, sizeof (EFI_IFR_GUID_LABEL));\r
-  EndLabel->ExtendOpCode = EFI_IFR_EXTEND_OP_LABEL;\r
-  EndLabel->Number       = LABEL_END;\r
+  EndGuidLabel = (EFI_IFR_GUID_LABEL *) HiiCreateGuidOpCode (EndOpCodeHandle, &gEfiIfrTianoGuid, NULL, sizeof (EFI_IFR_GUID_LABEL));\r
+  EndGuidLabel->ExtendOpCode = EFI_IFR_EXTEND_OP_LABEL;\r
+  EndGuidLabel->Number       = LABEL_END;\r
 \r
   //\r
-  // Get all the Hii handles\r
-  //\r
-  HiiHandles = HiiGetHiiHandles (NULL);\r
-  ASSERT (HiiHandles != NULL);\r
-  //\r
-  // Search for formset of each class type\r
+  //Updata Front Page form\r
   //\r
-  for (Index = 0; HiiHandles[Index] != NULL; Index++) {\r
-    Status = HiiGetFormSetFromHiiHandle(HiiHandles[Index], &Buffer,&BufferSize);\r
-    if (EFI_ERROR (Status)) {\r
-      continue;\r
-    }\r
-\r
-    Ptr = (UINT8 *)Buffer;\r
-    while(TempSize < BufferSize)  {\r
-      TempSize += ((EFI_IFR_OP_HEADER *) Ptr)->Length;\r
-\r
-      if (((EFI_IFR_OP_HEADER *) Ptr)->Length <= OFFSET_OF (EFI_IFR_FORM_SET, Flags)){\r
-        Ptr += ((EFI_IFR_OP_HEADER *) Ptr)->Length;\r
-        continue;\r
-      }\r
-\r
-      //\r
-      // Find Class Guid\r
-      //\r
-      ClassGuidNum = (UINT8) (((EFI_IFR_FORM_SET *)Ptr)->Flags & 0x3);\r
-      ClassGuid = (EFI_GUID *) (VOID *)(Ptr + sizeof (EFI_IFR_FORM_SET));\r
-      while (ClassGuidNum-- > 0) {\r
-        if (CompareGuid (&gEfiIfrFrontPageGuid, ClassGuid) == 0){\r
-          ClassGuid ++;\r
-          continue;\r
-        }\r
-\r
-        String = HiiGetString (HiiHandles[Index], ((EFI_IFR_FORM_SET *)Ptr)->FormSetTitle, NULL);\r
-        if (String == NULL) {\r
-          String = HiiGetString (HiiHandle, STRING_TOKEN (STR_MISSING_STRING), NULL);\r
-          ASSERT (String != NULL);\r
-        }\r
-        Token = HiiSetString (HiiHandle, 0, String, NULL);\r
-        FreePool (String);\r
-\r
-        String = HiiGetString (HiiHandles[Index], ((EFI_IFR_FORM_SET *)Ptr)->Help, NULL);\r
-\r
-        if (String == NULL) {\r
-          String = HiiGetString (HiiHandle, STRING_TOKEN (STR_MISSING_STRING), NULL);\r
-          ASSERT (String != NULL);\r
-        }\r
-        TokenHelp = HiiSetString (HiiHandle, 0, String, NULL);\r
-        FreePool (String);\r
-\r
-        FormSetGuid = ((EFI_IFR_FORM_SET *)Ptr)->Guid;\r
-\r
-        DevicePathStr = ExtractDevicePathFromHiiHandle(HiiHandles[Index]);\r
-        DevicePathId  = 0;\r
-        if (DevicePathStr != NULL){\r
-          DevicePathId = HiiSetString (HiiHandle, 0, DevicePathStr, NULL);\r
-          FreePool (DevicePathStr);\r
-        }\r
-        HiiCreateGotoExOpCode (\r
-          StartOpCodeHandle,\r
-          0,\r
-          Token,\r
-          TokenHelp,\r
-          0,\r
-          (EFI_QUESTION_ID) (Index + FRONT_PAGE_KEY_OFFSET),\r
-          0,\r
-          &FormSetGuid,\r
-          DevicePathId\r
-        );\r
-        break;\r
-      }\r
-      Ptr += ((EFI_IFR_OP_HEADER *) Ptr)->Length;\r
-    }\r
-\r
-    FreePool(Buffer);\r
-    Buffer = NULL;\r
-    TempSize = 0;\r
-    BufferSize = 0;\r
-  }\r
+  UiCustomizeFrontPage (\r
+    gFrontPagePrivate.HiiHandle,\r
+    StartOpCodeHandle\r
+    );\r
 \r
   HiiUpdateForm (\r
-    HiiHandle,\r
+    gFrontPagePrivate.HiiHandle,\r
     &mFrontPageGuid,\r
     FRONT_PAGE_FORM_ID,\r
     StartOpCodeHandle,\r
@@ -590,7 +242,6 @@ UpdateFrontPageForm (
 \r
   HiiFreeOpCodeHandle (StartOpCodeHandle);\r
   HiiFreeOpCodeHandle (EndOpCodeHandle);\r
-  FreePool (HiiHandles);\r
 }\r
 \r
 /**\r
@@ -642,17 +293,12 @@ InitializeFrontPage (
   ASSERT (gFrontPagePrivate.HiiHandle != NULL);\r
 \r
   //\r
-  //Updata Front Page strings\r
-  //\r
-  UpdateFrontPageStrings ();\r
-\r
-  //\r
-  // Initialize laguage options\r
+  //Updata Front Page banner strings\r
   //\r
-  InitializeLanguage ();\r
+  UpdateFrontPageBannerStrings ();\r
 \r
   //\r
-  //Updata Front Page form\r
+  // Update front page menus.\r
   //\r
   UpdateFrontPageForm();\r
 \r
@@ -846,10 +492,12 @@ GetOptionalStringByIndex (
 \r
 \r
 /**\r
+\r
   Update the banner information for the Front Page based on Smbios information.\r
+\r
 **/\r
 VOID\r
-UpdateFrontPageStrings (\r
+UpdateFrontPageBannerStrings (\r
   VOID\r
   )\r
 {\r
@@ -857,7 +505,6 @@ UpdateFrontPageStrings (
   CHAR16                            *NewString;\r
   CHAR16                            *FirmwareVersionString;\r
   EFI_STATUS                        Status;\r
-  EFI_STRING_ID                     TokenToUpdate;\r
   EFI_SMBIOS_HANDLE                 SmbiosHandle;\r
   EFI_SMBIOS_PROTOCOL               *Smbios;\r
   SMBIOS_TABLE_TYPE0                *Type0Record;\r
@@ -872,92 +519,143 @@ UpdateFrontPageStrings (
   FoundCpu = 0;\r
 \r
   //\r
-  // Update Front Page strings\r
+  // Update default banner string.\r
   //\r
-  Status = gBS->LocateProtocol (\r
-                  &gEfiSmbiosProtocolGuid,\r
-                  NULL,\r
-                  (VOID **) &Smbios\r
-                  );\r
-  if (!EFI_ERROR (Status)) {\r
-    SmbiosHandle = SMBIOS_HANDLE_PI_RESERVED;\r
-    Status = Smbios->GetNext (Smbios, &SmbiosHandle, NULL, &Record, NULL);\r
-    while (!EFI_ERROR(Status)) {\r
-      if (Record->Type == EFI_SMBIOS_TYPE_BIOS_INFORMATION) {\r
-        Type0Record = (SMBIOS_TABLE_TYPE0 *) Record;\r
-        StrIndex = Type0Record->BiosVersion;\r
-        GetOptionalStringByIndex ((CHAR8*)((UINT8*)Type0Record + Type0Record->Hdr.Length), StrIndex, &NewString);\r
-        TokenToUpdate = STRING_TOKEN (STR_FRONT_PAGE_BIOS_VERSION);\r
-        FirmwareVersionString = (CHAR16 *) PcdGetPtr (PcdFirmwareVersionString);\r
-        if (*FirmwareVersionString != 0x0000 ) {\r
-          FreePool (NewString);\r
-          NewString = (CHAR16 *) PcdGetPtr (PcdFirmwareVersionString);\r
-          HiiSetString (gFrontPagePrivate.HiiHandle, TokenToUpdate, NewString, NULL);\r
-        } else {\r
-          HiiSetString (gFrontPagePrivate.HiiHandle, TokenToUpdate, NewString, NULL);\r
-          FreePool (NewString);\r
-        }\r
-      }\r
+  NewString = HiiGetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_CUSTOMIZE_BANNER_LINE4_LEFT), NULL);\r
+  UiCustomizeFrontPageBanner (4, TRUE, &NewString);\r
+  HiiSetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_CUSTOMIZE_BANNER_LINE4_LEFT), NewString, NULL);\r
+  FreePool (NewString);\r
+\r
+  NewString = HiiGetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_CUSTOMIZE_BANNER_LINE4_RIGHT), NULL);\r
+  UiCustomizeFrontPageBanner (4, FALSE, &NewString);\r
+  HiiSetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_CUSTOMIZE_BANNER_LINE4_RIGHT), NewString, NULL);\r
+  FreePool (NewString);\r
+\r
+  NewString = HiiGetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_CUSTOMIZE_BANNER_LINE5_LEFT), NULL);\r
+  UiCustomizeFrontPageBanner (5, TRUE, &NewString);\r
+  HiiSetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_CUSTOMIZE_BANNER_LINE5_LEFT), NewString, NULL);\r
+  FreePool (NewString);\r
+\r
+  NewString = HiiGetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_CUSTOMIZE_BANNER_LINE5_RIGHT), NULL);\r
+  UiCustomizeFrontPageBanner (5, FALSE, &NewString);\r
+  HiiSetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_CUSTOMIZE_BANNER_LINE5_RIGHT), NewString, NULL);\r
+  FreePool (NewString);\r
 \r
-      if (Record->Type == EFI_SMBIOS_TYPE_SYSTEM_INFORMATION) {\r
-        Type1Record = (SMBIOS_TABLE_TYPE1 *) Record;\r
-        StrIndex = Type1Record->ProductName;\r
-        GetOptionalStringByIndex ((CHAR8*)((UINT8*)Type1Record + Type1Record->Hdr.Length), StrIndex, &NewString);\r
-        TokenToUpdate = STRING_TOKEN (STR_FRONT_PAGE_COMPUTER_MODEL);\r
-        HiiSetString (gFrontPagePrivate.HiiHandle, TokenToUpdate, NewString, NULL);\r
+  //\r
+  // Update Front Page banner strings base on SmBios Table.\r
+  //\r
+  Status = gBS->LocateProtocol (&gEfiSmbiosProtocolGuid, NULL, (VOID **) &Smbios);\r
+  if (EFI_ERROR (Status)) {\r
+    //\r
+    // Smbios protocol not found, get the default value.\r
+    //\r
+    NewString = HiiGetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_FRONT_PAGE_COMPUTER_MODEL), NULL);\r
+    UiCustomizeFrontPageBanner (1, TRUE, &NewString);\r
+    HiiSetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_FRONT_PAGE_COMPUTER_MODEL), NewString, NULL);\r
+    FreePool (NewString);\r
+\r
+    NewString = HiiGetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_FRONT_PAGE_CPU_MODEL), NULL);\r
+    UiCustomizeFrontPageBanner (2, TRUE, &NewString);\r
+    HiiSetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_FRONT_PAGE_CPU_MODEL), NewString, NULL);\r
+    FreePool (NewString);\r
+\r
+    NewString = HiiGetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_FRONT_PAGE_CPU_SPEED), NULL);\r
+    UiCustomizeFrontPageBanner (2, FALSE, &NewString);\r
+    HiiSetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_FRONT_PAGE_CPU_SPEED), NewString, NULL);\r
+    FreePool (NewString);\r
+\r
+    NewString = HiiGetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_FRONT_PAGE_BIOS_VERSION), NULL);\r
+    UiCustomizeFrontPageBanner (3, TRUE, &NewString);\r
+    HiiSetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_FRONT_PAGE_BIOS_VERSION), NewString, NULL);\r
+    FreePool (NewString);\r
+\r
+    NewString = HiiGetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_FRONT_PAGE_MEMORY_SIZE), NULL);\r
+    UiCustomizeFrontPageBanner (3, FALSE, &NewString);\r
+    HiiSetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_FRONT_PAGE_MEMORY_SIZE), NewString, NULL);\r
+    FreePool (NewString);\r
+\r
+    return;\r
+  }\r
+\r
+  SmbiosHandle = SMBIOS_HANDLE_PI_RESERVED;\r
+  Status = Smbios->GetNext (Smbios, &SmbiosHandle, NULL, &Record, NULL);\r
+  while (!EFI_ERROR(Status)) {\r
+    if (Record->Type == EFI_SMBIOS_TYPE_BIOS_INFORMATION) {\r
+      Type0Record = (SMBIOS_TABLE_TYPE0 *) Record;\r
+      StrIndex = Type0Record->BiosVersion;\r
+      GetOptionalStringByIndex ((CHAR8*)((UINT8*)Type0Record + Type0Record->Hdr.Length), StrIndex, &NewString);\r
+\r
+      FirmwareVersionString = (CHAR16 *) PcdGetPtr (PcdFirmwareVersionString);\r
+      if (*FirmwareVersionString != 0x0000 ) {\r
+        FreePool (NewString);\r
+        NewString = (CHAR16 *) PcdGetPtr (PcdFirmwareVersionString);\r
+        UiCustomizeFrontPageBanner (3, TRUE, &NewString);\r
+        HiiSetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_FRONT_PAGE_BIOS_VERSION), NewString, NULL);\r
+      } else {\r
+        UiCustomizeFrontPageBanner (3, TRUE, &NewString);\r
+        HiiSetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_FRONT_PAGE_BIOS_VERSION), NewString, NULL);\r
         FreePool (NewString);\r
       }\r
+    }\r
 \r
-      if ((Record->Type == EFI_SMBIOS_TYPE_PROCESSOR_INFORMATION) && !FoundCpu) {\r
-        Type4Record = (SMBIOS_TABLE_TYPE4 *) Record;\r
-        //\r
-        // The information in the record should be only valid when the CPU Socket is populated.\r
-        //\r
-        if ((Type4Record->Status & SMBIOS_TYPE4_CPU_SOCKET_POPULATED) == SMBIOS_TYPE4_CPU_SOCKET_POPULATED) {\r
-          StrIndex = Type4Record->ProcessorVersion;\r
-          GetOptionalStringByIndex ((CHAR8*)((UINT8*)Type4Record + Type4Record->Hdr.Length), StrIndex, &NewString);\r
-          TokenToUpdate = STRING_TOKEN (STR_FRONT_PAGE_CPU_MODEL);\r
-          HiiSetString (gFrontPagePrivate.HiiHandle, TokenToUpdate, NewString, NULL);\r
-          FreePool (NewString);\r
-\r
-          ConvertProcessorToString(Type4Record->CurrentSpeed, 6, &NewString);\r
-          TokenToUpdate = STRING_TOKEN (STR_FRONT_PAGE_CPU_SPEED);\r
-          HiiSetString (gFrontPagePrivate.HiiHandle, TokenToUpdate, NewString, NULL);\r
-          FreePool (NewString);\r
-\r
-          FoundCpu = TRUE;\r
-        }\r
-      }\r
+    if (Record->Type == EFI_SMBIOS_TYPE_SYSTEM_INFORMATION) {\r
+      Type1Record = (SMBIOS_TABLE_TYPE1 *) Record;\r
+      StrIndex = Type1Record->ProductName;\r
+      GetOptionalStringByIndex ((CHAR8*)((UINT8*)Type1Record + Type1Record->Hdr.Length), StrIndex, &NewString);\r
+      UiCustomizeFrontPageBanner (1, TRUE, &NewString);\r
+      HiiSetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_FRONT_PAGE_COMPUTER_MODEL), NewString, NULL);\r
+      FreePool (NewString);\r
+    }\r
 \r
-      if ( Record->Type == EFI_SMBIOS_TYPE_MEMORY_ARRAY_MAPPED_ADDRESS ) {\r
-        Type19Record = (SMBIOS_TABLE_TYPE19 *) Record;\r
-        if (Type19Record->StartingAddress != 0xFFFFFFFF ) {\r
-          InstalledMemory += RShiftU64(Type19Record->EndingAddress -\r
-                                       Type19Record->StartingAddress + 1, 10);\r
-        } else {\r
-          InstalledMemory += RShiftU64(Type19Record->ExtendedEndingAddress -\r
-                                       Type19Record->ExtendedStartingAddress + 1, 20);\r
-        }\r
+    if ((Record->Type == EFI_SMBIOS_TYPE_PROCESSOR_INFORMATION) && !FoundCpu) {\r
+      Type4Record = (SMBIOS_TABLE_TYPE4 *) Record;\r
+      //\r
+      // The information in the record should be only valid when the CPU Socket is populated.\r
+      //\r
+      if ((Type4Record->Status & SMBIOS_TYPE4_CPU_SOCKET_POPULATED) == SMBIOS_TYPE4_CPU_SOCKET_POPULATED) {\r
+        StrIndex = Type4Record->ProcessorVersion;\r
+        GetOptionalStringByIndex ((CHAR8*)((UINT8*)Type4Record + Type4Record->Hdr.Length), StrIndex, &NewString);\r
+        UiCustomizeFrontPageBanner (2, TRUE, &NewString);\r
+        HiiSetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_FRONT_PAGE_CPU_MODEL), NewString, NULL);\r
+        FreePool (NewString);\r
+\r
+        ConvertProcessorToString(Type4Record->CurrentSpeed, 6, &NewString);\r
+        UiCustomizeFrontPageBanner (2, FALSE, &NewString);\r
+        HiiSetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_FRONT_PAGE_CPU_SPEED), NewString, NULL);\r
+        FreePool (NewString);\r
+\r
+        FoundCpu = TRUE;\r
       }\r
+    }\r
 \r
-      Status = Smbios->GetNext (Smbios, &SmbiosHandle, NULL, &Record, NULL);\r
+    if ( Record->Type == EFI_SMBIOS_TYPE_MEMORY_ARRAY_MAPPED_ADDRESS ) {\r
+      Type19Record = (SMBIOS_TABLE_TYPE19 *) Record;\r
+      if (Type19Record->StartingAddress != 0xFFFFFFFF ) {\r
+        InstalledMemory += RShiftU64(Type19Record->EndingAddress -\r
+                                     Type19Record->StartingAddress + 1, 10);\r
+      } else {\r
+        InstalledMemory += RShiftU64(Type19Record->ExtendedEndingAddress -\r
+                                     Type19Record->ExtendedStartingAddress + 1, 20);\r
+      }\r
     }\r
 \r
-    // now update the total installed RAM size\r
-    ConvertMemorySizeToString ((UINT32)InstalledMemory, &NewString );\r
-    TokenToUpdate = STRING_TOKEN (STR_FRONT_PAGE_MEMORY_SIZE);\r
-    HiiSetString (gFrontPagePrivate.HiiHandle, TokenToUpdate, NewString, NULL);\r
-    FreePool (NewString);\r
+    Status = Smbios->GetNext (Smbios, &SmbiosHandle, NULL, &Record, NULL);\r
   }\r
 \r
-  return ;\r
+  //\r
+  // Now update the total installed RAM size\r
+  //\r
+  ConvertMemorySizeToString ((UINT32)InstalledMemory, &NewString );\r
+  UiCustomizeFrontPageBanner (3, FALSE, &NewString);\r
+  HiiSetString (gFrontPagePrivate.HiiHandle, STRING_TOKEN (STR_FRONT_PAGE_MEMORY_SIZE), NewString, NULL);\r
+  FreePool (NewString);\r
 }\r
 \r
 /**\r
   This function will change video resolution and text mode\r
-  according to defined setup mode or defined boot mode  \r
+  according to defined setup mode or defined boot mode\r
 \r
-  @param  IsSetupMode   Indicate mode is changed to setup mode or boot mode. \r
+  @param  IsSetupMode   Indicate mode is changed to setup mode or boot mode.\r
 \r
   @retval  EFI_SUCCESS  Mode is changed successfully.\r
   @retval  Others             Mode failed to be changed.\r
@@ -985,13 +683,13 @@ BdsSetConsoleMode (
   EFI_STATUS                            Status;\r
   UINTN                                 Index;\r
   UINTN                                 CurrentColumn;\r
-  UINTN                                 CurrentRow;  \r
+  UINTN                                 CurrentRow;\r
 \r
   MaxGopMode  = 0;\r
   MaxTextMode = 0;\r
 \r
   //\r
-  // Get current video resolution and text mode \r
+  // Get current video resolution and text mode\r
   //\r
   Status = gBS->HandleProtocol (\r
                   gST->ConsoleOutHandle,\r
@@ -1009,7 +707,7 @@ BdsSetConsoleMode (
                   );\r
   if (EFI_ERROR (Status)) {\r
     SimpleTextOut = NULL;\r
-  }  \r
+  }\r
 \r
   if ((GraphicsOutput == NULL) || (SimpleTextOut == NULL)) {\r
     return EFI_UNSUPPORTED;\r
@@ -1030,12 +728,12 @@ BdsSetConsoleMode (
     NewHorizontalResolution = mBootHorizontalResolution;\r
     NewVerticalResolution   = mBootVerticalResolution;\r
     NewColumns              = mBootTextModeColumn;\r
-    NewRows                 = mBootTextModeRow;   \r
+    NewRows                 = mBootTextModeRow;\r
   }\r
-  \r
+\r
   if (GraphicsOutput != NULL) {\r
     MaxGopMode  = GraphicsOutput->Mode->MaxMode;\r
-  } \r
+  }\r
 \r
   if (SimpleTextOut != NULL) {\r
     MaxTextMode = SimpleTextOut->Mode->MaxMode;\r
@@ -1139,8 +837,7 @@ BdsSetConsoleMode (
   ASSERT_EFI_ERROR (Status);\r
   Status = PcdSet32S (PcdConOutRow, NewRows);\r
   ASSERT_EFI_ERROR (Status);\r
-  \r
-  \r
+\r
   //\r
   // Video mode is changed, so restart graphics console driver and higher level driver.\r
   // Reconnect graphics console driver and higher level driver.\r
@@ -1170,12 +867,12 @@ BdsSetConsoleMode (
 \r
 /**\r
   The user Entry Point for Application. The user code starts with this function\r
-  as the real entry point for the image goes into a library that calls this \r
+  as the real entry point for the image goes into a library that calls this\r
   function.\r
 \r
-  @param[in] ImageHandle    The firmware allocated handle for the EFI image.  \r
+  @param[in] ImageHandle    The firmware allocated handle for the EFI image.\r
   @param[in] SystemTable    A pointer to the EFI System Table.\r
-  \r
+\r
   @retval EFI_SUCCESS       The entry point is executed successfully.\r
   @retval other             Some error occurs when executing this entry point.\r
 \r
@@ -1196,7 +893,7 @@ InitializeUserInterface (
 \r
   if (!mModeInitialized) {\r
     //\r
-    // After the console is ready, get current video resolution \r
+    // After the console is ready, get current video resolution\r
     // and text mode before launching setup at first time.\r
     //\r
     Status = gBS->HandleProtocol (\r
@@ -1207,7 +904,7 @@ InitializeUserInterface (
     if (EFI_ERROR (Status)) {\r
       GraphicsOutput = NULL;\r
     }\r
-    \r
+\r
     Status = gBS->HandleProtocol (\r
                     gST->ConsoleOutHandle,\r
                     &gEfiSimpleTextOutProtocolGuid,\r
@@ -1215,7 +912,7 @@ InitializeUserInterface (
                     );\r
     if (EFI_ERROR (Status)) {\r
       SimpleTextOut = NULL;\r
-    }  \r
+    }\r
 \r
     if (GraphicsOutput != NULL) {\r
       //\r
@@ -1238,9 +935,9 @@ InitializeUserInterface (
 \r
     //\r
     // Get user defined text mode for setup.\r
-    //  \r
+    //\r
     mSetupHorizontalResolution = PcdGet32 (PcdSetupVideoHorizontalResolution);\r
-    mSetupVerticalResolution   = PcdGet32 (PcdSetupVideoVerticalResolution);      \r
+    mSetupVerticalResolution   = PcdGet32 (PcdSetupVideoVerticalResolution);\r
     mSetupTextModeColumn       = PcdGet32 (PcdSetupConOutColumn);\r
     mSetupTextModeRow          = PcdGet32 (PcdSetupConOutRow);\r
 \r
@@ -1249,11 +946,10 @@ InitializeUserInterface (
 \r
   gBS->SetWatchdogTimer (0x0000, 0x0000, 0x0000, NULL);\r
   gST->ConOut->ClearScreen (gST->ConOut);\r
-  \r
+\r
   //\r
   // Install customized fonts needed by Front Page\r
   //\r
-  \r
   HiiHandle = ExportFonts ();\r
   ASSERT (HiiHandle != NULL);\r
 \r
@@ -1322,38 +1018,6 @@ UiEntry (
   SetupResetReminder ();\r
 }\r
 \r
-/**\r
-  Extract device path for given HII handle and class guid.\r
-\r
-  @param Handle          The HII handle.\r
-\r
-  @retval  NULL          Fail to get the device path string.\r
-  @return  PathString    Get the device path string.\r
-\r
-**/\r
-CHAR16 *\r
-ExtractDevicePathFromHiiHandle (\r
-  IN      EFI_HII_HANDLE      Handle\r
-  )\r
-{\r
-  EFI_STATUS                       Status;\r
-  EFI_HANDLE                       DriverHandle;\r
-  \r
-  ASSERT (Handle != NULL);\r
-\r
-  if (Handle == NULL) {\r
-    return NULL;\r
-  }\r
-\r
-  Status = gHiiDatabase->GetPackageListHandle (gHiiDatabase, Handle, &DriverHandle);\r
-  if (EFI_ERROR (Status)) {\r
-    return NULL;\r
-  }\r
-\r
- return ConvertDevicePathToText(DevicePathFromHandle (DriverHandle), FALSE, FALSE);\r
-\r
-}\r
-\r
 //\r
 //  Following are BDS Lib functions which contain all the code about setup browser reset reminder feature.\r
 //  Setup Browser reset reminder feature is that an reset reminder will be given before user leaves the setup browser  if\r
index a42253f401a596b2f1e9a32c73f8605f8d3b2ccc..1da56aced21d60a9a271c624dccd3930c291fd60 100644 (file)
@@ -41,12 +41,7 @@ extern BOOLEAN  gConnectAllHappened;
 //\r
 #define FRONT_PAGE_FORM_ID             0x1000\r
 \r
-#define FRONT_PAGE_KEY_OFFSET          0x4000\r
-#define FRONT_PAGE_KEY_CONTINUE        0x1000\r
-#define FRONT_PAGE_KEY_LANGUAGE        0x1234\r
-\r
-#define LABEL_SELECT_LANGUAGE          0x1000\r
-#define LABEL_PLATFORM_INFORMATION     0x1001\r
+#define LABEL_FRANTPAGE_INFORMATION    0x1000\r
 #define LABEL_END                      0xffff\r
 \r
 #define FRONT_PAGE_FORMSET_GUID \\r
diff --git a/MdeModulePkg/Application/UiApp/FrontPageCustomizedUi.c b/MdeModulePkg/Application/UiApp/FrontPageCustomizedUi.c
new file mode 100644 (file)
index 0000000..6e4f7b5
--- /dev/null
@@ -0,0 +1,132 @@
+/** @file\r
+\r
+  This library class defines a set of interfaces to customize Ui module\r
+\r
+Copyright (c) 2016, Intel Corporation. All rights reserved.<BR>\r
+This program and the accompanying materials are licensed and made available under\r
+the terms and conditions of the BSD License that accompanies this distribution.\r
+The full text of the license may be found at\r
+http://opensource.org/licenses/bsd-license.php.\r
+\r
+THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
+WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
+\r
+**/\r
+#include <Uefi.h>\r
+#include <Protocol/HiiConfigAccess.h>\r
+#include <Library/BaseLib.h>\r
+#include <Library/MemoryAllocationLib.h>\r
+#include "FrontPageCustomizedUiSupport.h"\r
+\r
+/**\r
+  Customize menus in the page.\r
+\r
+  @param[in]  HiiHandle             The HII Handle of the form to update.\r
+  @param[in]  StartOpCodeHandle     The context used to insert opcode.\r
+  @param[in]  CustomizePageType     The page type need to be customized.\r
+\r
+**/\r
+VOID\r
+UiCustomizeFrontPage (\r
+  IN EFI_HII_HANDLE  HiiHandle,\r
+  IN VOID            *StartOpCodeHandle\r
+  )\r
+{\r
+  //\r
+  // Create "Select Language" menu with Oneof opcode.\r
+  //\r
+  UiCreateLanguageMenu (HiiHandle, StartOpCodeHandle);\r
+\r
+  //\r
+  // Create empty line.\r
+  //\r
+  UiCreateEmptyLine(HiiHandle, StartOpCodeHandle);\r
+\r
+  //\r
+  // Find third party drivers which need to be shown in the front page.\r
+  //\r
+  UiListThirdPartyDrivers (HiiHandle, &gEfiIfrFrontPageGuid, NULL, StartOpCodeHandle);\r
+\r
+  //\r
+  // Create empty line.\r
+  //\r
+  UiCreateEmptyLine(HiiHandle, StartOpCodeHandle);\r
+\r
+  //\r
+  // Create "Continue" menu.\r
+  //\r
+  UiCreateContinueMenu(HiiHandle, StartOpCodeHandle);\r
+\r
+  //\r
+  // Create reset menu.\r
+  //\r
+  UiCreateResetMenu(HiiHandle, StartOpCodeHandle);\r
+}\r
+\r
+/**\r
+  This function processes the results of changes in configuration.\r
+\r
+\r
+  @param HiiHandle       Points to the hii handle for this formset.\r
+  @param Action          Specifies the type of action taken by the browser.\r
+  @param QuestionId      A unique value which is sent to the original exporting driver\r
+                         so that it can identify the type of data to expect.\r
+  @param Type            The type of value for the question.\r
+  @param Value           A pointer to the data being sent to the original exporting driver.\r
+  @param ActionRequest   On return, points to the action requested by the callback function.\r
+\r
+  @retval  EFI_SUCCESS           The callback successfully handled the action.\r
+  @retval  EFI_OUT_OF_RESOURCES  Not enough storage is available to hold the variable and its data.\r
+  @retval  EFI_DEVICE_ERROR      The variable could not be saved.\r
+  @retval  EFI_UNSUPPORTED       The specified Action is not supported by the callback.\r
+\r
+**/\r
+EFI_STATUS\r
+UiFrontPageCallbackHandler (\r
+  IN  EFI_HII_HANDLE                         HiiHandle,\r
+  IN  EFI_BROWSER_ACTION                     Action,\r
+  IN  EFI_QUESTION_ID                        QuestionId,\r
+  IN  UINT8                                  Type,\r
+  IN  EFI_IFR_TYPE_VALUE                     *Value,\r
+  OUT EFI_BROWSER_ACTION_REQUEST             *ActionRequest\r
+  )\r
+{\r
+  EFI_STATUS    Status;\r
+\r
+  if (UiSupportLibCallbackHandler (HiiHandle, Action, QuestionId, Type, Value, ActionRequest, &Status)) {\r
+    return Status;\r
+  }\r
+\r
+  return EFI_UNSUPPORTED;\r
+}\r
+\r
+/**\r
+  Update the banner string in the front page.\r
+\r
+  Current layout for the banner string like below:\r
+  PS: Totally only 5 lines of banner supported.\r
+\r
+  Line 1: Left BannerStr                           RightBannerStr\r
+  Line 2: Left BannerStr                           RightBannerStr\r
+  Line 3: Left BannerStr                           RightBannerStr\r
+  Line 4: Left BannerStr                           RightBannerStr\r
+  Line 5: Left BannerStr                           RightBannerStr\r
+  <EmptyLine>\r
+  First menu in front page.\r
+  ...\r
+\r
+  @param  LineIndex         The line index of the banner need to check.\r
+  @param  LeftOrRight       The left or right banner need to check.\r
+  @param  BannerStr         Banner string need to update.\r
+                            Input the current string and user can update\r
+                            it and return the new string.\r
+\r
+**/\r
+VOID\r
+UiCustomizeFrontPageBanner (\r
+  IN     UINTN          LineIndex,\r
+  IN     BOOLEAN        LeftOrRight,\r
+  IN OUT EFI_STRING     *BannerStr\r
+  )\r
+{\r
+}\r
diff --git a/MdeModulePkg/Application/UiApp/FrontPageCustomizedUi.h b/MdeModulePkg/Application/UiApp/FrontPageCustomizedUi.h
new file mode 100644 (file)
index 0000000..6df0d13
--- /dev/null
@@ -0,0 +1,88 @@
+/** @file\r
+  This library class defines a set of interfaces to customize Ui module\r
+\r
+Copyright (c) 2016, Intel Corporation. All rights reserved.<BR>\r
+This program and the accompanying materials are licensed and made available under\r
+the terms and conditions of the BSD License that accompanies this distribution.\r
+The full text of the license may be found at\r
+http://opensource.org/licenses/bsd-license.php.\r
+\r
+THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
+WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
+\r
+**/\r
+\r
+#ifndef __FRONTPAGE_CUSTOMIZED_UI_H__\r
+#define __FRONTPAGE_CUSTOMIZED_UI_H__\r
+\r
+/**\r
+  Update the banner string in the front page.\r
+\r
+  Current layout for the banner string like below:\r
+  PS: Totally only 5 lines of banner supported.\r
+\r
+  Line 1: Left BannerStr                           RightBannerStr\r
+  Line 2: Left BannerStr                           RightBannerStr\r
+  Line 3: Left BannerStr                           RightBannerStr\r
+  Line 4: Left BannerStr                           RightBannerStr\r
+  Line 5: Left BannerStr                           RightBannerStr\r
+  <EmptyLine>\r
+  First menu in front page.\r
+  ...\r
+\r
+  @param  LineIndex         The line index of the banner need to check.\r
+  @param  LeftOrRight       The left or right banner need to check.\r
+  @param  BannerStr         Banner string need to update.\r
+                            Input the current string and user can update\r
+                            it and return the new string.\r
+\r
+**/\r
+VOID\r
+UiCustomizeFrontPageBanner (\r
+  IN     UINTN          LineIndex,\r
+  IN     BOOLEAN        LeftOrRight,\r
+  IN OUT EFI_STRING     *BannerStr\r
+  );\r
+\r
+/**\r
+  Customize menus in the page.\r
+\r
+  @param[in]  HiiHandle             The HII Handle of the form to update.\r
+  @param[in]  StartOpCodeHandle     The context used to insert opcode.\r
+\r
+**/\r
+VOID\r
+UiCustomizeFrontPage (\r
+  IN EFI_HII_HANDLE  HiiHandle,\r
+  IN VOID            *StartOpCodeHandle\r
+  );\r
+\r
+/**\r
+  This function processes the results of changes in configuration.\r
+\r
+\r
+  @param HiiHandle       Points to the hii handle for this formset.\r
+  @param Action          Specifies the type of action taken by the browser.\r
+  @param QuestionId      A unique value which is sent to the original exporting driver\r
+                         so that it can identify the type of data to expect.\r
+  @param Type            The type of value for the question.\r
+  @param Value           A pointer to the data being sent to the original exporting driver.\r
+  @param ActionRequest   On return, points to the action requested by the callback function.\r
+\r
+  @retval  EFI_SUCCESS           The callback successfully handled the action.\r
+  @retval  EFI_OUT_OF_RESOURCES  Not enough storage is available to hold the variable and its data.\r
+  @retval  EFI_DEVICE_ERROR      The variable could not be saved.\r
+  @retval  EFI_UNSUPPORTED       The specified Action is not supported by the callback.\r
+\r
+**/\r
+EFI_STATUS\r
+UiFrontPageCallbackHandler (\r
+  IN  EFI_HII_HANDLE                         HiiHandle,\r
+  IN  EFI_BROWSER_ACTION                     Action,\r
+  IN  EFI_QUESTION_ID                        QuestionId,\r
+  IN  UINT8                                  Type,\r
+  IN  EFI_IFR_TYPE_VALUE                     *Value,\r
+  OUT EFI_BROWSER_ACTION_REQUEST             *ActionRequest\r
+  );\r
+\r
+#endif\r
diff --git a/MdeModulePkg/Application/UiApp/FrontPageCustomizedUiSupport.c b/MdeModulePkg/Application/UiApp/FrontPageCustomizedUiSupport.c
new file mode 100644 (file)
index 0000000..80450a5
--- /dev/null
@@ -0,0 +1,659 @@
+/** @file\r
+\r
+  This library class defines a set of interfaces to customize Ui module\r
+\r
+Copyright (c) 2016, Intel Corporation. All rights reserved.<BR>\r
+This program and the accompanying materials are licensed and made available under\r
+the terms and conditions of the BSD License that accompanies this distribution.\r
+The full text of the license may be found at\r
+http://opensource.org/licenses/bsd-license.php.\r
+\r
+THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
+WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
+\r
+**/\r
+#include <Uefi.h>\r
+\r
+#include <Guid/MdeModuleHii.h>\r
+#include <Guid/GlobalVariable.h>\r
+\r
+#include <Protocol/HiiConfigAccess.h>\r
+#include <Protocol/HiiString.h>\r
+\r
+#include <Library/HiiLib.h>\r
+#include <Library/DebugLib.h>\r
+#include <Library/UefiLib.h>\r
+#include <Library/BaseMemoryLib.h>\r
+#include <Library/PcdLib.h>\r
+#include <Library/MemoryAllocationLib.h>\r
+#include <Library/UefiRuntimeServicesTableLib.h>\r
+#include <Library/UefiHiiServicesLib.h>\r
+#include <Library/DevicePathLib.h>\r
+#include <Library/UefiBootServicesTableLib.h>\r
+#include "FrontPageCustomizedUiSupport.h"\r
+\r
+//\r
+// This is the VFR compiler generated header file which defines the\r
+// string identifiers.\r
+//\r
+#define PRINTABLE_LANGUAGE_NAME_STRING_ID     0x0001\r
+\r
+#define UI_HII_DRIVER_LIST_SIZE               0x8\r
+\r
+#define FRONT_PAGE_KEY_CONTINUE               0x1000\r
+#define FRONT_PAGE_KEY_RESET                  0x1001\r
+#define FRONT_PAGE_KEY_LANGUAGE               0x1002\r
+\r
+typedef struct {\r
+  EFI_STRING_ID   PromptId;\r
+  EFI_STRING_ID   HelpId;\r
+  EFI_STRING_ID   DevicePathId;\r
+  EFI_GUID        FormSetGuid;\r
+  BOOLEAN         EmptyLineAfter;\r
+} UI_HII_DRIVER_INSTANCE;\r
+\r
+CHAR8                        *gLanguageString;\r
+EFI_STRING_ID                *gLanguageToken;\r
+UI_HII_DRIVER_INSTANCE       *gHiiDriverList;\r
+EFI_HII_HANDLE               gHiiHandle;\r
+\r
+\r
+/**\r
+  Get next language from language code list (with separator ';').\r
+\r
+  If LangCode is NULL, then ASSERT.\r
+  If Lang is NULL, then ASSERT.\r
+\r
+  @param  LangCode    On input: point to first language in the list. On\r
+                                 output: point to next language in the list, or\r
+                                 NULL if no more language in the list.\r
+  @param  Lang           The first language in the list.\r
+\r
+**/\r
+VOID\r
+GetNextLanguage (\r
+  IN OUT CHAR8      **LangCode,\r
+  OUT CHAR8         *Lang\r
+  )\r
+{\r
+  UINTN  Index;\r
+  CHAR8  *StringPtr;\r
+\r
+  ASSERT (LangCode != NULL);\r
+  ASSERT (*LangCode != NULL);\r
+  ASSERT (Lang != NULL);\r
+\r
+  Index = 0;\r
+  StringPtr = *LangCode;\r
+  while (StringPtr[Index] != 0 && StringPtr[Index] != ';') {\r
+    Index++;\r
+  }\r
+\r
+  CopyMem (Lang, StringPtr, Index);\r
+  Lang[Index] = 0;\r
+\r
+  if (StringPtr[Index] == ';') {\r
+    Index++;\r
+  }\r
+  *LangCode = StringPtr + Index;\r
+}\r
+\r
+/**\r
+  This function processes the language changes in configuration.\r
+\r
+  @param Value           A pointer to the data being sent to the original exporting driver.\r
+\r
+\r
+  @retval  TRUE          The callback successfully handled the action.\r
+  @retval  FALSE         The callback not supported in this handler.\r
+\r
+**/\r
+EFI_STATUS\r
+LanguageChangeHandler (\r
+  IN  EFI_IFR_TYPE_VALUE                     *Value\r
+  )\r
+{\r
+  CHAR8                         *LangCode;\r
+  CHAR8                         *Lang;\r
+  UINTN                         Index;\r
+  EFI_STATUS                    Status;\r
+\r
+  //\r
+  // Allocate working buffer for RFC 4646 language in supported LanguageString.\r
+  //\r
+  Lang = AllocatePool (AsciiStrSize (gLanguageString));\r
+  ASSERT (Lang != NULL);\r
+\r
+  Index = 0;\r
+  LangCode = gLanguageString;\r
+  while (*LangCode != 0) {\r
+    GetNextLanguage (&LangCode, Lang);\r
+\r
+    if (Index == Value->u8) {\r
+      break;\r
+    }\r
+\r
+    Index++;\r
+  }\r
+\r
+  if (Index == Value->u8) {\r
+    Status = gRT->SetVariable (\r
+                    L"PlatformLang",\r
+                    &gEfiGlobalVariableGuid,\r
+                    EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_BOOTSERVICE_ACCESS | EFI_VARIABLE_RUNTIME_ACCESS,\r
+                    AsciiStrSize (Lang),\r
+                    Lang\r
+                    );\r
+    if (EFI_ERROR (Status)) {\r
+      FreePool (Lang);\r
+      return EFI_DEVICE_ERROR;\r
+    }\r
+  } else {\r
+    ASSERT (FALSE);\r
+  }\r
+  FreePool (Lang);\r
+\r
+  return EFI_SUCCESS;\r
+}\r
+\r
+/**\r
+  This function processes the results of changes in configuration.\r
+\r
+\r
+  @param HiiHandle       Points to the hii handle for this formset.\r
+  @param Action          Specifies the type of action taken by the browser.\r
+  @param QuestionId      A unique value which is sent to the original exporting driver\r
+                         so that it can identify the type of data to expect.\r
+  @param Type            The type of value for the question.\r
+  @param Value           A pointer to the data being sent to the original exporting driver.\r
+  @param ActionRequest   On return, points to the action requested by the callback function.\r
+  @param Status          Return the handle status.\r
+\r
+  @retval  TRUE          The callback successfully handled the action.\r
+  @retval  FALSE         The callback not supported in this handler.\r
+\r
+**/\r
+BOOLEAN\r
+UiSupportLibCallbackHandler (\r
+  IN  EFI_HII_HANDLE                         HiiHandle,\r
+  IN  EFI_BROWSER_ACTION                     Action,\r
+  IN  EFI_QUESTION_ID                        QuestionId,\r
+  IN  UINT8                                  Type,\r
+  IN  EFI_IFR_TYPE_VALUE                     *Value,\r
+  OUT EFI_BROWSER_ACTION_REQUEST             *ActionRequest,\r
+  OUT EFI_STATUS                             *Status\r
+  )\r
+{\r
+  if (QuestionId != FRONT_PAGE_KEY_CONTINUE &&\r
+      QuestionId != FRONT_PAGE_KEY_RESET &&\r
+      QuestionId != FRONT_PAGE_KEY_LANGUAGE) {\r
+    return FALSE;\r
+  }\r
+\r
+  if (Action != EFI_BROWSER_ACTION_CHANGED) {\r
+    //\r
+    // Do nothing for other UEFI Action. Only do call back when data is changed.\r
+    //\r
+    *Status = EFI_UNSUPPORTED;\r
+  }\r
+\r
+  if (Action == EFI_BROWSER_ACTION_CHANGED) {\r
+    if ((Value == NULL) || (ActionRequest == NULL)) {\r
+      *Status = EFI_INVALID_PARAMETER;\r
+    }\r
+\r
+    *Status = EFI_SUCCESS;\r
+    switch (QuestionId) {\r
+    case FRONT_PAGE_KEY_CONTINUE:\r
+      //\r
+      // This is the continue - clear the screen and return an error to get out of FrontPage loop\r
+      //\r
+      *ActionRequest = EFI_BROWSER_ACTION_REQUEST_EXIT;\r
+      break;\r
+\r
+    case FRONT_PAGE_KEY_LANGUAGE:\r
+      *Status = LanguageChangeHandler(Value);\r
+      break;\r
+\r
+    case FRONT_PAGE_KEY_RESET:\r
+      //\r
+      // Reset\r
+      //\r
+      gRT->ResetSystem (EfiResetCold, EFI_SUCCESS, 0, NULL);\r
+      *Status = EFI_UNSUPPORTED;\r
+\r
+    default:\r
+      break;\r
+    }\r
+  }\r
+\r
+  return TRUE;\r
+}\r
+\r
+/**\r
+  Create Select language menu in the front page with oneof opcode.\r
+\r
+  @param[in]    HiiHandle           The hii handle for the Uiapp driver.\r
+  @param[in]    QuestionId          Question ID\r
+  @param[in]    StartOpCodeHandle   The opcode handle to save the new opcode.\r
+\r
+  @retval   EFI_SUCCESS         Search the driver success\r
+\r
+**/\r
+VOID\r
+UiCreateLanguageMenu (\r
+  IN EFI_HII_HANDLE              HiiHandle,\r
+  IN VOID                        *StartOpCodeHandle\r
+  )\r
+{\r
+  CHAR8                       *LangCode;\r
+  CHAR8                       *Lang;\r
+  CHAR8                       *CurrentLang;\r
+  UINTN                       OptionCount;\r
+  CHAR16                      *StringBuffer;\r
+  VOID                        *OptionsOpCodeHandle;\r
+  UINTN                       StringSize;\r
+  EFI_STATUS                  Status;\r
+  EFI_HII_STRING_PROTOCOL     *HiiString;\r
+\r
+  Lang         = NULL;\r
+  StringBuffer = NULL;\r
+\r
+  //\r
+  // Init OpCode Handle and Allocate space for creation of UpdateData Buffer\r
+  //\r
+  OptionsOpCodeHandle = HiiAllocateOpCodeHandle ();\r
+  ASSERT (OptionsOpCodeHandle != NULL);\r
+\r
+  GetEfiGlobalVariable2 (L"PlatformLang", (VOID**)&CurrentLang, NULL);\r
+\r
+  //\r
+  // Get Support language list from variable.\r
+  //\r
+  GetEfiGlobalVariable2 (L"PlatformLangCodes", (VOID**)&gLanguageString, NULL);\r
+  if (gLanguageString == NULL) {\r
+    gLanguageString = AllocateCopyPool (\r
+                               AsciiStrSize ((CHAR8 *) PcdGetPtr (PcdUefiVariableDefaultPlatformLangCodes)),\r
+                               (CHAR8 *) PcdGetPtr (PcdUefiVariableDefaultPlatformLangCodes)\r
+                               );\r
+    ASSERT (gLanguageString != NULL);\r
+  }\r
+\r
+  if (gLanguageToken == NULL) {\r
+    //\r
+    // Count the language list number.\r
+    //\r
+    LangCode = gLanguageString;\r
+    Lang = AllocatePool (AsciiStrSize (gLanguageString));\r
+    ASSERT (Lang != NULL);\r
+\r
+    OptionCount = 0;\r
+    while (*LangCode != 0) {\r
+      GetNextLanguage (&LangCode, Lang);\r
+      OptionCount ++;\r
+    }\r
+\r
+    //\r
+    // Allocate extra 1 as the end tag.\r
+    //\r
+    gLanguageToken = AllocateZeroPool ((OptionCount + 1) * sizeof (EFI_STRING_ID));\r
+    ASSERT (gLanguageToken != NULL);\r
+\r
+    Status = gBS->LocateProtocol (&gEfiHiiStringProtocolGuid, NULL, (VOID **) &HiiString);\r
+    ASSERT_EFI_ERROR (Status);\r
+\r
+    LangCode     = gLanguageString;\r
+    OptionCount  = 0;\r
+    while (*LangCode != 0) {\r
+      GetNextLanguage (&LangCode, Lang);\r
+\r
+      StringSize = 0;\r
+      Status = HiiString->GetString (HiiString, Lang, HiiHandle, PRINTABLE_LANGUAGE_NAME_STRING_ID, StringBuffer, &StringSize, NULL);\r
+      if (Status == EFI_BUFFER_TOO_SMALL) {\r
+        StringBuffer = AllocateZeroPool (StringSize);\r
+        ASSERT (StringBuffer != NULL);\r
+        Status = HiiString->GetString (HiiString, Lang, HiiHandle, PRINTABLE_LANGUAGE_NAME_STRING_ID, StringBuffer, &StringSize, NULL);\r
+        ASSERT_EFI_ERROR (Status);\r
+      }\r
+\r
+      if (EFI_ERROR (Status)) {\r
+        StringBuffer = AllocatePool (AsciiStrSize (Lang) * sizeof (CHAR16));\r
+        ASSERT (StringBuffer != NULL);\r
+        AsciiStrToUnicodeStr (Lang, StringBuffer);\r
+      }\r
+\r
+      ASSERT (StringBuffer != NULL);\r
+      gLanguageToken[OptionCount] = HiiSetString (HiiHandle, 0, StringBuffer, NULL);\r
+      FreePool (StringBuffer);\r
+\r
+      OptionCount++;\r
+    }\r
+  }\r
+\r
+  ASSERT (gLanguageToken != NULL);\r
+  LangCode = gLanguageString;\r
+  OptionCount = 0;\r
+  if (Lang == NULL) {\r
+    Lang = AllocatePool (AsciiStrSize (gLanguageString));\r
+    ASSERT (Lang != NULL);\r
+  }\r
+  while (*LangCode != 0) {\r
+    GetNextLanguage (&LangCode, Lang);\r
+\r
+    if (CurrentLang != NULL && AsciiStrCmp (Lang, CurrentLang) == 0) {\r
+      HiiCreateOneOfOptionOpCode (\r
+        OptionsOpCodeHandle,\r
+        gLanguageToken[OptionCount],\r
+        EFI_IFR_OPTION_DEFAULT,\r
+        EFI_IFR_NUMERIC_SIZE_1,\r
+        (UINT8) OptionCount\r
+        );\r
+    } else {\r
+      HiiCreateOneOfOptionOpCode (\r
+        OptionsOpCodeHandle,\r
+        gLanguageToken[OptionCount],\r
+        0,\r
+        EFI_IFR_NUMERIC_SIZE_1,\r
+        (UINT8) OptionCount\r
+        );\r
+    }\r
+\r
+    OptionCount++;\r
+  }\r
+\r
+  if (CurrentLang != NULL) {\r
+    FreePool (CurrentLang);\r
+  }\r
+  FreePool (Lang);\r
+\r
+  HiiCreateOneOfOpCode (\r
+    StartOpCodeHandle,\r
+    FRONT_PAGE_KEY_LANGUAGE,\r
+    0,\r
+    0,\r
+    STRING_TOKEN (STR_LANGUAGE_SELECT),\r
+    STRING_TOKEN (STR_LANGUAGE_SELECT_HELP),\r
+    EFI_IFR_FLAG_CALLBACK,\r
+    EFI_IFR_NUMERIC_SIZE_1,\r
+    OptionsOpCodeHandle,\r
+    NULL\r
+    );\r
+}\r
+\r
+/**\r
+  Create continue menu in the front page.\r
+\r
+  @param[in]    HiiHandle           The hii handle for the Uiapp driver.\r
+  @param[in]    StartOpCodeHandle   The opcode handle to save the new opcode.\r
+\r
+**/\r
+VOID\r
+UiCreateContinueMenu (\r
+  IN EFI_HII_HANDLE              HiiHandle,\r
+  IN VOID                        *StartOpCodeHandle\r
+  )\r
+{\r
+  HiiCreateActionOpCode (\r
+    StartOpCodeHandle,\r
+    FRONT_PAGE_KEY_CONTINUE,\r
+    STRING_TOKEN (STR_CONTINUE_PROMPT),\r
+    STRING_TOKEN (STR_CONTINUE_PROMPT),\r
+    EFI_IFR_FLAG_CALLBACK,\r
+    0\r
+    );\r
+}\r
+\r
+/**\r
+  Create empty line menu in the front page.\r
+\r
+  @param    HiiHandle           The hii handle for the Uiapp driver.\r
+  @param    StartOpCodeHandle   The opcode handle to save the new opcode.\r
+\r
+**/\r
+VOID\r
+UiCreateEmptyLine (\r
+  IN EFI_HII_HANDLE              HiiHandle,\r
+  IN VOID                        *StartOpCodeHandle\r
+  )\r
+{\r
+  HiiCreateSubTitleOpCode (StartOpCodeHandle, STRING_TOKEN (STR_NULL_STRING), 0, 0, 0);\r
+}\r
+\r
+/**\r
+  Create Reset menu in the front page.\r
+\r
+  @param[in]    HiiHandle           The hii handle for the Uiapp driver.\r
+  @param[in]    StartOpCodeHandle   The opcode handle to save the new opcode.\r
+\r
+**/\r
+VOID\r
+UiCreateResetMenu (\r
+  IN EFI_HII_HANDLE              HiiHandle,\r
+  IN VOID                        *StartOpCodeHandle\r
+  )\r
+{\r
+  HiiCreateActionOpCode (\r
+    StartOpCodeHandle,\r
+    FRONT_PAGE_KEY_RESET,\r
+    STRING_TOKEN (STR_RESET_STRING),\r
+    STRING_TOKEN (STR_RESET_STRING),\r
+    EFI_IFR_FLAG_CALLBACK,\r
+    0\r
+    );\r
+}\r
+\r
+/**\r
+  Extract device path for given HII handle and class guid.\r
+\r
+  @param Handle          The HII handle.\r
+\r
+  @retval  NULL          Fail to get the device path string.\r
+  @return  PathString    Get the device path string.\r
+\r
+**/\r
+CHAR16 *\r
+ExtractDevicePathFromHiiHandle (\r
+  IN      EFI_HII_HANDLE      Handle\r
+  )\r
+{\r
+  EFI_STATUS                       Status;\r
+  EFI_HANDLE                       DriverHandle;\r
+\r
+  ASSERT (Handle != NULL);\r
+\r
+  if (Handle == NULL) {\r
+    return NULL;\r
+  }\r
+\r
+  Status = gHiiDatabase->GetPackageListHandle (gHiiDatabase, Handle, &DriverHandle);\r
+  if (EFI_ERROR (Status)) {\r
+    return NULL;\r
+  }\r
+\r
+  return ConvertDevicePathToText(DevicePathFromHandle (DriverHandle), FALSE, FALSE);\r
+}\r
+\r
+/**\r
+  Check whether this driver need to be shown in the front page.\r
+\r
+  @param    HiiHandle           The hii handle for the driver.\r
+  @param    Guid                The special guid for the driver which is the target.\r
+  @param    PromptId            Return the prompt string id.\r
+  @param    HelpId              Return the help string id.\r
+  @param    FormsetGuid         Return the formset guid info.\r
+\r
+  @retval   EFI_SUCCESS         Search the driver success\r
+\r
+**/\r
+BOOLEAN\r
+RequiredDriver (\r
+  IN  EFI_HII_HANDLE              HiiHandle,\r
+  IN  EFI_GUID                    *Guid,\r
+  OUT EFI_STRING_ID               *PromptId,\r
+  OUT EFI_STRING_ID               *HelpId,\r
+  OUT VOID                        *FormsetGuid\r
+  )\r
+{\r
+  EFI_STATUS                  Status;\r
+  UINT8                       ClassGuidNum;\r
+  EFI_GUID                    *ClassGuid;\r
+  EFI_IFR_FORM_SET            *Buffer;\r
+  UINTN                       BufferSize;\r
+  UINT8                       *Ptr;\r
+  UINTN                       TempSize;\r
+  BOOLEAN                     RetVal;\r
+\r
+  Status = HiiGetFormSetFromHiiHandle(HiiHandle, &Buffer,&BufferSize);\r
+  if (EFI_ERROR (Status)) {\r
+    return FALSE;\r
+  }\r
+\r
+  RetVal = FALSE;\r
+  TempSize = 0;\r
+  Ptr = (UINT8 *) Buffer;\r
+  while(TempSize < BufferSize)  {\r
+    TempSize += ((EFI_IFR_OP_HEADER *) Ptr)->Length;\r
+\r
+    if (((EFI_IFR_OP_HEADER *) Ptr)->Length <= OFFSET_OF (EFI_IFR_FORM_SET, Flags)){\r
+      Ptr += ((EFI_IFR_OP_HEADER *) Ptr)->Length;\r
+      continue;\r
+    }\r
+\r
+    ClassGuidNum = (UINT8) (((EFI_IFR_FORM_SET *)Ptr)->Flags & 0x3);\r
+    ClassGuid = (EFI_GUID *) (VOID *)(Ptr + sizeof (EFI_IFR_FORM_SET));\r
+    while (ClassGuidNum-- > 0) {\r
+      if (!CompareGuid (Guid, ClassGuid)){\r
+        ClassGuid ++;\r
+        continue;\r
+      }\r
+\r
+      *PromptId = ((EFI_IFR_FORM_SET *)Ptr)->FormSetTitle;\r
+      *HelpId = ((EFI_IFR_FORM_SET *)Ptr)->Help;\r
+      CopyMem (FormsetGuid, &((EFI_IFR_FORM_SET *) Ptr)->Guid, sizeof (EFI_GUID));\r
+      RetVal = TRUE;\r
+    }\r
+  }\r
+\r
+  FreePool (Buffer);\r
+\r
+  return RetVal;\r
+}\r
+\r
+/**\r
+  Search the drivers in the system which need to show in the front page\r
+  and insert the menu to the front page.\r
+\r
+  @param    HiiHandle           The hii handle for the Uiapp driver.\r
+  @param    ClassGuid           The class guid for the driver which is the target.\r
+  @param    StartOpCodeHandle   The opcode handle to save the new opcode.\r
+  @param    SpecialHandler      The pointer to the specail handler function, if any.\r
+\r
+  @retval   EFI_SUCCESS         Search the driver success\r
+\r
+**/\r
+EFI_STATUS\r
+UiListThirdPartyDrivers (\r
+  IN EFI_HII_HANDLE              HiiHandle,\r
+  IN EFI_GUID                    *ClassGuid,\r
+  IN DRIVER_SPECIAL_HANDLER      SpecialHandlerFn,\r
+  IN VOID                        *StartOpCodeHandle\r
+  )\r
+{\r
+  UINTN                       Index;\r
+  EFI_STRING                  String;\r
+  EFI_STRING_ID               Token;\r
+  EFI_STRING_ID               TokenHelp;\r
+  EFI_HII_HANDLE              *HiiHandles;\r
+  CHAR16                      *DevicePathStr;\r
+  UINTN                       Count;\r
+  UINTN                       CurrentSize;\r
+  UI_HII_DRIVER_INSTANCE      *DriverListPtr;\r
+  EFI_STRING                  NewName;\r
+  BOOLEAN                     EmptyLineAfter;\r
+\r
+  if (gHiiDriverList != NULL) {\r
+    FreePool (gHiiDriverList);\r
+  }\r
+\r
+  HiiHandles = HiiGetHiiHandles (NULL);\r
+  ASSERT (HiiHandles != NULL);\r
+\r
+  gHiiDriverList = AllocateZeroPool (UI_HII_DRIVER_LIST_SIZE * sizeof (UI_HII_DRIVER_INSTANCE));\r
+  ASSERT (gHiiDriverList != NULL);\r
+  DriverListPtr = gHiiDriverList;\r
+  CurrentSize = UI_HII_DRIVER_LIST_SIZE;\r
+\r
+  for (Index = 0, Count = 0; HiiHandles[Index] != NULL; Index++) {\r
+    if (!RequiredDriver (HiiHandles[Index], ClassGuid, &Token, &TokenHelp, &gHiiDriverList[Count].FormSetGuid)) {\r
+      continue;\r
+    }\r
+\r
+    String = HiiGetString (HiiHandles[Index], Token, NULL);\r
+    if (String == NULL) {\r
+      String = HiiGetString (gHiiHandle, STRING_TOKEN (STR_MISSING_STRING), NULL);\r
+      ASSERT (String != NULL);\r
+    } else if (SpecialHandlerFn != NULL) {\r
+      //\r
+      // Check whether need to rename the driver name.\r
+      //\r
+      EmptyLineAfter = FALSE;\r
+      if (SpecialHandlerFn (String, &NewName, &EmptyLineAfter)) {\r
+        FreePool (String);\r
+        String = NewName;\r
+        DriverListPtr[Count].EmptyLineAfter = EmptyLineAfter;\r
+      }\r
+    }\r
+    DriverListPtr[Count].PromptId = HiiSetString (HiiHandle, 0, String, NULL);\r
+    FreePool (String);\r
+\r
+    String = HiiGetString (HiiHandles[Index], TokenHelp, NULL);\r
+    if (String == NULL) {\r
+      String = HiiGetString (gHiiHandle, STRING_TOKEN (STR_MISSING_STRING), NULL);\r
+      ASSERT (String != NULL);\r
+    }\r
+    DriverListPtr[Count].HelpId = HiiSetString (HiiHandle, 0, String, NULL);\r
+    FreePool (String);\r
+\r
+    DevicePathStr = ExtractDevicePathFromHiiHandle(HiiHandles[Index]);\r
+    if (DevicePathStr != NULL){\r
+      DriverListPtr[Count].DevicePathId = HiiSetString (HiiHandle, 0, DevicePathStr, NULL);\r
+      FreePool (DevicePathStr);\r
+    } else {\r
+      DriverListPtr[Count].DevicePathId = 0;\r
+    }\r
+\r
+    Count++;\r
+    if (Count >= CurrentSize) {\r
+      DriverListPtr = AllocateCopyPool ((Count + UI_HII_DRIVER_LIST_SIZE) * sizeof (UI_HII_DRIVER_INSTANCE), gHiiDriverList);\r
+      ASSERT (DriverListPtr != NULL);\r
+      FreePool (gHiiDriverList);\r
+      gHiiDriverList = DriverListPtr;\r
+      CurrentSize += UI_HII_DRIVER_LIST_SIZE;\r
+    }\r
+  }\r
+\r
+  FreePool (HiiHandles);\r
+\r
+  Index = 0;\r
+  while (gHiiDriverList[Index].PromptId != 0) {\r
+    HiiCreateGotoExOpCode (\r
+      StartOpCodeHandle,\r
+      0,\r
+      gHiiDriverList[Index].PromptId,\r
+      gHiiDriverList[Index].HelpId,\r
+      0,\r
+      0,\r
+      0,\r
+      &gHiiDriverList[Index].FormSetGuid,\r
+      gHiiDriverList[Index].DevicePathId\r
+    );\r
+\r
+    if (gHiiDriverList[Index].EmptyLineAfter) {\r
+      UiCreateEmptyLine (HiiHandle, StartOpCodeHandle);\r
+    }\r
+\r
+    Index ++;\r
+  }\r
+\r
+  return EFI_SUCCESS;\r
+}\r
diff --git a/MdeModulePkg/Application/UiApp/FrontPageCustomizedUiSupport.h b/MdeModulePkg/Application/UiApp/FrontPageCustomizedUiSupport.h
new file mode 100644 (file)
index 0000000..ce3ecd5
--- /dev/null
@@ -0,0 +1,144 @@
+/** @file\r
+  This library class defines a set of interfaces to be used by customize Ui module\r
+\r
+Copyright (c) 2016, Intel Corporation. All rights reserved.<BR>\r
+This program and the accompanying materials are licensed and made available under\r
+the terms and conditions of the BSD License that accompanies this distribution.\r
+The full text of the license may be found at\r
+http://opensource.org/licenses/bsd-license.php.\r
+\r
+THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
+WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
+\r
+**/\r
+\r
+#ifndef __FRONTPAGE_CUSTOMIZE_UI_SUPPORT_UI_H__\r
+#define __FRONTPAGE_CUSTOMIZE_UI_SUPPORT_UI_H__\r
+\r
+/**\r
+  Create continue menu in the front page.\r
+\r
+  @param[in]    HiiHandle           The hii handle for the Uiapp driver.\r
+  @param[in]    StartOpCodeHandle   The opcode handle to save the new opcode.\r
+\r
+  @retval   EFI_SUCCESS         Search the driver success\r
+\r
+**/\r
+VOID\r
+UiCreateContinueMenu (\r
+  IN EFI_HII_HANDLE              HiiHandle,\r
+  IN VOID                        *StartOpCodeHandle\r
+  );\r
+\r
+/**\r
+  Create empty line menu.\r
+\r
+  @param    HiiHandle           The hii handle for the Uiapp driver.\r
+  @param    StartOpCodeHandle   The opcode handle to save the new opcode.\r
+\r
+  @retval   EFI_SUCCESS         Search the driver success\r
+\r
+**/\r
+VOID\r
+UiCreateEmptyLine (\r
+  IN EFI_HII_HANDLE              HiiHandle,\r
+  IN VOID                        *StartOpCodeHandle\r
+  );\r
+\r
+/**\r
+  Create Select language menu in the front page with oneof opcode.\r
+\r
+  @param[in]    HiiHandle           The hii handle for the Uiapp driver.\r
+  @param[in]    StartOpCodeHandle   The opcode handle to save the new opcode.\r
+\r
+  @retval   EFI_SUCCESS         Search the driver success\r
+\r
+**/\r
+VOID\r
+UiCreateLanguageMenu (\r
+  IN EFI_HII_HANDLE              HiiHandle,\r
+  IN VOID                        *StartOpCodeHandle\r
+  );\r
+\r
+/**\r
+  Create Reset menu.\r
+\r
+  @param[in]    HiiHandle           The hii handle for the Uiapp driver.\r
+  @param[in]    StartOpCodeHandle   The opcode handle to save the new opcode.\r
+\r
+  @retval   EFI_SUCCESS         Search the driver success\r
+\r
+**/\r
+VOID\r
+UiCreateResetMenu (\r
+  IN EFI_HII_HANDLE              HiiHandle,\r
+  IN VOID                        *StartOpCodeHandle\r
+  );\r
+\r
+/**\r
+  Rename the driver name if necessary.\r
+\r
+  @param    DriverName          Input the driver name.\r
+  @param    NewDriverName       Return the new driver name.\r
+  @param    EmptyLineAfter      Whether need to insert empty line.\r
+\r
+  @retval   New driver name if compared, else NULL.\r
+\r
+**/\r
+typedef\r
+BOOLEAN\r
+(EFIAPI *DRIVER_SPECIAL_HANDLER)(\r
+  IN  CHAR16                   *DriverName,\r
+  OUT CHAR16                   **NewName,\r
+  OUT BOOLEAN                  *EmptyLineAfter\r
+);\r
+\r
+/**\r
+  Search the drivers in the system which need to show in the front page\r
+  and insert the menu to the front page.\r
+\r
+  @param    HiiHandle           The hii handle for the Uiapp driver.\r
+  @param    ClassGuid           The class guid for the driver which is the target.\r
+  @param    StartOpCodeHandle   The opcode handle to save the new opcode.\r
+  @param    SpecialHandler      The pointer to the specail handler function, if any.\r
+\r
+  @retval   EFI_SUCCESS         Search the driver success\r
+\r
+**/\r
+EFI_STATUS\r
+UiListThirdPartyDrivers (\r
+  IN EFI_HII_HANDLE              HiiHandle,\r
+  IN EFI_GUID                    *ClassGuid,\r
+  IN DRIVER_SPECIAL_HANDLER      SpecialHandlerFn,\r
+  IN VOID                        *StartOpCodeHandle\r
+  );\r
+\r
+/**\r
+  This function processes the results of changes in configuration.\r
+\r
+\r
+  @param HiiHandle       Points to the hii handle for this formset.\r
+  @param Action          Specifies the type of action taken by the browser.\r
+  @param QuestionId      A unique value which is sent to the original exporting driver\r
+                         so that it can identify the type of data to expect.\r
+  @param Type            The type of value for the question.\r
+  @param Value           A pointer to the data being sent to the original exporting driver.\r
+  @param ActionRequest   On return, points to the action requested by the callback function.\r
+  @param Status          Return the handle status.\r
+\r
+  @retval  TRUE          The callback successfully handled the action.\r
+  @retval  FALSE         The callback not supported in this handler.\r
+\r
+**/\r
+BOOLEAN\r
+UiSupportLibCallbackHandler (\r
+  IN  EFI_HII_HANDLE                         HiiHandle,\r
+  IN  EFI_BROWSER_ACTION                     Action,\r
+  IN  EFI_QUESTION_ID                        QuestionId,\r
+  IN  UINT8                                  Type,\r
+  IN  EFI_IFR_TYPE_VALUE                     *Value,\r
+  OUT EFI_BROWSER_ACTION_REQUEST             *ActionRequest,\r
+  OUT EFI_STATUS                             *Status\r
+  );\r
+\r
+#endif\r
index 43f379067abf1b364c345710d31f3336fdbddeee..71cb7887d199ba3b8e375865b43db43401943d54 100644 (file)
@@ -1,16 +1,16 @@
 ///** @file\r
-//  \r
+//\r
 //  String definitions for BdsPlatform formset.\r
-//  \r
+//\r
 //  Copyright (c) 2004 - 2015, Intel Corporation. All rights reserved.<BR>\r
 //  This program and the accompanying materials\r
 //  are licensed and made available under the terms and conditions of the BSD License\r
 //  which accompanies this distribution.  The full text of the license may be found at\r
 //  http://opensource.org/licenses/bsd-license.php\r
-//  \r
+//\r
 //  THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
 //  WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
-//  \r
+//\r
 //**/\r
 \r
 /=#\r
@@ -52,8 +52,6 @@
                                        #language fr-FR  "Choisir la Langue"\r
 #string STR_LANGUAGE_SELECT_HELP       #language en-US  "This is the option one adjusts to change the language for the current system"\r
                                        #language fr-FR  "Ceci est l'option que celui ajuste changer la langue pour le système actuel"\r
-#string STR_TIME_OUT_PROMPT            #language en-US  "Boot process will continue in %d seconds"\r
-                                       #language fr-FR  "Le procédé de botte continuera dans %d secondes"\r
 #string STR_MISSING_STRING             #language en-US  "Missing String"\r
                                        #language fr-FR  "Missing String"\r
 #string STR_EMPTY_STRING               #language en-US  ""\r
                                        #language fr-FR  "Reset"\r
 #string STR_RESET_STRING_HELP          #language en-US  "Reset the current setting."\r
                                        #language fr-FR  "Reset the current setting."\r
-#string STR_INTEL_COPYRIGHT            #language en-US  "Copyright (c) 2006-2015, Intel Corporation"\r
-                                       #language fr-FR  "Copyright (c) 2006-2015, Intel Corporation"
\ No newline at end of file
+#string STR_CUSTOMIZE_BANNER_LINE4_LEFT  #language en-US  ""\r
+                                         #language fr-FR  ""\r
+#string STR_CUSTOMIZE_BANNER_LINE4_RIGHT #language en-US  ""\r
+                                         #language fr-FR  ""\r
+#string STR_CUSTOMIZE_BANNER_LINE5_LEFT  #language en-US  ""\r
+                                         #language fr-FR  ""\r
+#string STR_CUSTOMIZE_BANNER_LINE5_RIGHT #language en-US  ""\r
+                                         #language fr-FR  ""\r
+#string STR_NULL_STRING                #language en-US  " "\r
+                                       #language fr-FR  " "\r
index aa622c169706fe34bfc1520252fbcba47f1cef88..6c59f82b97680e8f10fbfa238b71863c1e8e6ddb 100644 (file)
 \r
 #define FRONT_PAGE_FORM_ID             0x1000\r
 \r
-#define FRONT_PAGE_KEY_CONTINUE        0x1000\r
-#define FRONT_PAGE_KEY_LANGUAGE        0x1234\r
-\r
-#define LABEL_SELECT_LANGUAGE          0x1000\r
-#define LABEL_PLATFORM_INFORMATION     0x1001\r
+#define LABEL_FRANTPAGE_INFORMATION    0x1000\r
 #define LABEL_END                      0xffff\r
 \r
 formset\r
@@ -58,51 +54,27 @@ formset
       line  3,\r
       align right;\r
 \r
-//    banner\r
-//      title = STRING_TOKEN(STR_FRONT_PAGE_BANNER_0_LEFT),\r
-//      line  0,\r
-//      align left;\r
-\r
-//    banner\r
-//      title = STRING_TOKEN(STR_FRONT_PAGE_BANNER_0_RIGHT),\r
-//      line  0,\r
-//      align right;\r
-\r
-//    banner\r
-//      title = STRING_TOKEN(STR_FRONT_PAGE_BANNER_1_LEFT),\r
-//      line  1,\r
-//      align left;\r
-\r
-//    banner\r
-//      title = STRING_TOKEN(STR_FRONT_PAGE_BANNER_1_RIGHT),\r
-//      line  1,\r
-//      align right;\r
-\r
-//    banner\r
-//      title = STRING_TOKEN(STR_FRONT_PAGE_BANNER_2_LEFT),\r
-//      line  2,\r
-//      align left;\r
-\r
-//    banner\r
-//      title = STRING_TOKEN(STR_FRONT_PAGE_BANNER_3_LEFT),\r
-//      line  3,\r
-//      align left;\r
+    banner\r
+      title = STRING_TOKEN(STR_CUSTOMIZE_BANNER_LINE4_LEFT),\r
+      line  4,\r
+      align left;\r
 \r
+    banner\r
+      title = STRING_TOKEN(STR_CUSTOMIZE_BANNER_LINE4_RIGHT),\r
+      line  4,\r
+      align right;\r
 \r
-    text\r
-      help    = STRING_TOKEN(STR_CONTINUE_HELP),\r
-      text    = STRING_TOKEN(STR_CONTINUE_PROMPT),\r
-      flags   = INTERACTIVE,\r
-      key     = FRONT_PAGE_KEY_CONTINUE;\r
+    banner\r
+      title = STRING_TOKEN(STR_CUSTOMIZE_BANNER_LINE5_LEFT),\r
+      line  5,\r
+      align left;\r
 \r
-    label LABEL_SELECT_LANGUAGE;\r
-    //\r
-    // This is where we will dynamically add a OneOf type op-code to select\r
-    // Languages from the currently available choices\r
-    //\r
-    label LABEL_END;\r
+    banner\r
+      title = STRING_TOKEN(STR_CUSTOMIZE_BANNER_LINE5_RIGHT),\r
+      line  5,\r
+      align right;\r
 \r
-    label LABEL_PLATFORM_INFORMATION;\r
+    label LABEL_FRANTPAGE_INFORMATION;\r
     //\r
     // This is where we will dynamically add a Action type op-code to show \r
     // the platform information.\r
diff --git a/MdeModulePkg/Application/UiApp/Language.c b/MdeModulePkg/Application/UiApp/Language.c
deleted file mode 100644 (file)
index df7a0b3..0000000
+++ /dev/null
@@ -1,309 +0,0 @@
-/** @file\r
-  Language settings\r
-\r
-Copyright (c) 2004 - 2015, Intel Corporation. All rights reserved.<BR>\r
-This program and the accompanying materials\r
-are licensed and made available under the terms and conditions of the BSD License\r
-which accompanies this distribution.  The full text of the license may be found at\r
-http://opensource.org/licenses/bsd-license.php\r
-\r
-THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
-WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
-\r
-**/\r
-\r
-#include "Language.h"\r
-#include "FrontPage.h"\r
-\r
-EFI_GUID  mFontPackageGuid = {\r
-  0x78941450, 0x90ab, 0x4fb1, {0xb7, 0x5f, 0x58, 0x92, 0x14, 0xe2, 0x4a, 0xc}\r
-};\r
-\r
-#define NARROW_GLYPH_NUMBER 8\r
-#define WIDE_GLYPH_NUMBER   75\r
-\r
-typedef struct {\r
-  ///\r
-  /// This 4-bytes total array length is required by HiiAddPackages()\r
-  ///\r
-  UINT32                 Length;\r
-\r
-  //\r
-  // This is the Font package definition\r
-  //\r
-  EFI_HII_PACKAGE_HEADER Header;\r
-  UINT16                 NumberOfNarrowGlyphs;\r
-  UINT16                 NumberOfWideGlyphs;\r
-  EFI_NARROW_GLYPH       NarrowArray[NARROW_GLYPH_NUMBER];\r
-  EFI_WIDE_GLYPH         WideArray[WIDE_GLYPH_NUMBER];\r
-} FONT_PACK_BIN;\r
-\r
-FONT_PACK_BIN mFontBin = {\r
-  sizeof (FONT_PACK_BIN),\r
-  {\r
-    sizeof (FONT_PACK_BIN) - sizeof (UINT32),\r
-    EFI_HII_PACKAGE_SIMPLE_FONTS,\r
-  },\r
-  NARROW_GLYPH_NUMBER,\r
-  0,\r
-  {     // Narrow Glyphs\r
-    {\r
-      0x05d0,\r
-      0x00,\r
-      {\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x4E,\r
-        0x6E,\r
-        0x62,\r
-        0x32,\r
-        0x32,\r
-        0x3C,\r
-        0x68,\r
-        0x4C,\r
-        0x4C,\r
-        0x46,\r
-        0x76,\r
-        0x72,\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x00\r
-      }\r
-    },\r
-    {\r
-      0x05d1,\r
-      0x00,\r
-      {\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x78,\r
-        0x7C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x7E,\r
-        0x7E,\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x00\r
-      }\r
-    },\r
-    {\r
-      0x05d2,\r
-      0x00,\r
-      {\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x78,\r
-        0x7C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x1C,\r
-        0x3E,\r
-        0x66,\r
-        0x66,\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x00\r
-      }\r
-    },\r
-    {\r
-      0x05d3,\r
-      0x00,\r
-      {\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x7E,\r
-        0x7E,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x00\r
-      }\r
-    },\r
-    {\r
-      0x05d4,\r
-      0x00,\r
-      {\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x7C,\r
-        0x7E,\r
-        0x06,\r
-        0x06,\r
-        0x06,\r
-        0x06,\r
-        0x66,\r
-        0x66,\r
-        0x66,\r
-        0x66,\r
-        0x66,\r
-        0x66,\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x00\r
-      }\r
-    },\r
-    {\r
-      0x05d5,\r
-      0x00,\r
-      {\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x3C,\r
-        0x3C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x0C,\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x00\r
-      }\r
-    },\r
-    {\r
-      0x05d6,\r
-      0x00,\r
-      {\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x38,\r
-        0x38,\r
-        0x1E,\r
-        0x1E,\r
-        0x18,\r
-        0x18,\r
-        0x18,\r
-        0x18,\r
-        0x18,\r
-        0x18,\r
-        0x18,\r
-        0x18,\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x00\r
-      }\r
-    },\r
-    {\r
-      0x0000,\r
-      0x00,\r
-      {\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x00,\r
-        0x00\r
-      }\r
-    }\r
-  }\r
-};\r
-\r
-/**\r
-  Routine to export glyphs to the HII database.  This is in addition to whatever is defined in the Graphics Console driver.\r
-\r
-**/\r
-EFI_HII_HANDLE\r
-ExportFonts (\r
-  VOID\r
-  )\r
-{\r
-  return HiiAddPackages (\r
-           &mFontPackageGuid,\r
-           gImageHandle,\r
-           &mFontBin,\r
-           NULL\r
-           );\r
-}\r
-\r
-/**\r
-  Get next language from language code list (with separator ';').\r
-\r
-  If LangCode is NULL, then ASSERT.\r
-  If Lang is NULL, then ASSERT.\r
-\r
-  @param  LangCode    On input: point to first language in the list. On\r
-                                 output: point to next language in the list, or\r
-                                 NULL if no more language in the list.\r
-  @param  Lang           The first language in the list.\r
-\r
-**/\r
-VOID\r
-EFIAPI\r
-GetNextLanguage (\r
-  IN OUT CHAR8      **LangCode,\r
-  OUT CHAR8         *Lang\r
-  )\r
-{\r
-  UINTN  Index;\r
-  CHAR8  *StringPtr;\r
-\r
-  ASSERT (LangCode != NULL);\r
-  ASSERT (*LangCode != NULL);\r
-  ASSERT (Lang != NULL);\r
-\r
-  Index = 0;\r
-  StringPtr = *LangCode;\r
-  while (StringPtr[Index] != 0 && StringPtr[Index] != ';') {\r
-    Index++;\r
-  }\r
-\r
-  CopyMem (Lang, StringPtr, Index);\r
-  Lang[Index] = 0;\r
-\r
-  if (StringPtr[Index] == ';') {\r
-    Index++;\r
-  }\r
-  *LangCode = StringPtr + Index;\r
-}
\ No newline at end of file
diff --git a/MdeModulePkg/Application/UiApp/Language.h b/MdeModulePkg/Application/UiApp/Language.h
deleted file mode 100644 (file)
index 274de5c..0000000
+++ /dev/null
@@ -1,48 +0,0 @@
-/** @file\r
-  Language setting\r
-\r
-Copyright (c) 2004 - 2015, Intel Corporation. All rights reserved.<BR>\r
-This program and the accompanying materials\r
-are licensed and made available under the terms and conditions of the BSD License\r
-which accompanies this distribution.  The full text of the license may be found at\r
-http://opensource.org/licenses/bsd-license.php\r
-\r
-THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
-WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
-\r
-**/\r
-\r
-#ifndef _LANGUAGE_H_\r
-#define _LANGUAGE_H_\r
-\r
-#include "String.h"\r
-\r
-/**\r
-  Get next language from language code list (with separator ';').\r
-\r
-  If LangCode is NULL, then ASSERT.\r
-  If Lang is NULL, then ASSERT.\r
-\r
-  @param  LangCode    On input: point to first language in the list. On\r
-                                 output: point to next language in the list, or\r
-                                 NULL if no more language in the list.\r
-  @param  Lang           The first language in the list.\r
-\r
-**/\r
-VOID\r
-EFIAPI\r
-GetNextLanguage (\r
-  IN OUT CHAR8      **LangCode,\r
-  OUT CHAR8         *Lang\r
-  );\r
-\r
-/**\r
-  Routine to export glyphs to the HII database.  This is in addition to whatever is defined in the Graphics Console driver.\r
-\r
-**/\r
-EFI_HII_HANDLE\r
-ExportFonts (\r
-  VOID\r
-  );\r
-\r
-#endif // _LANGUAGE_H_\r
index 7884ae3fceba07195b08a9757662c072721b84c0..b6f22889ce287bac098d2d16da6977661868da86 100644 (file)
@@ -13,7 +13,6 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
 **/\r
 \r
 #include "Ui.h"\r
-#include "Language.h"\r
 #include "FrontPage.h"\r
 \r
 EFI_HII_HANDLE gStringPackHandle;\r
@@ -22,6 +21,241 @@ EFI_GUID mUiStringPackGuid = {
   0x136a3048, 0x752a, 0x4bf6, { 0xa7, 0x57, 0x9, 0x36, 0x11, 0x95, 0x38, 0xed }\r
 };\r
 \r
+EFI_GUID  mFontPackageGuid = {\r
+  0x78941450, 0x90ab, 0x4fb1, {0xb7, 0x5f, 0x58, 0x92, 0x14, 0xe2, 0x4a, 0xc}\r
+};\r
+\r
+#define NARROW_GLYPH_NUMBER 8\r
+#define WIDE_GLYPH_NUMBER   75\r
+\r
+typedef struct {\r
+  ///\r
+  /// This 4-bytes total array length is required by HiiAddPackages()\r
+  ///\r
+  UINT32                 Length;\r
+\r
+  //\r
+  // This is the Font package definition\r
+  //\r
+  EFI_HII_PACKAGE_HEADER Header;\r
+  UINT16                 NumberOfNarrowGlyphs;\r
+  UINT16                 NumberOfWideGlyphs;\r
+  EFI_NARROW_GLYPH       NarrowArray[NARROW_GLYPH_NUMBER];\r
+  EFI_WIDE_GLYPH         WideArray[WIDE_GLYPH_NUMBER];\r
+} FONT_PACK_BIN;\r
+\r
+FONT_PACK_BIN mFontBin = {\r
+  sizeof (FONT_PACK_BIN),\r
+  {\r
+    sizeof (FONT_PACK_BIN) - sizeof (UINT32),\r
+    EFI_HII_PACKAGE_SIMPLE_FONTS,\r
+  },\r
+  NARROW_GLYPH_NUMBER,\r
+  0,\r
+  {     // Narrow Glyphs\r
+    {\r
+      0x05d0,\r
+      0x00,\r
+      {\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x4E,\r
+        0x6E,\r
+        0x62,\r
+        0x32,\r
+        0x32,\r
+        0x3C,\r
+        0x68,\r
+        0x4C,\r
+        0x4C,\r
+        0x46,\r
+        0x76,\r
+        0x72,\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x00\r
+      }\r
+    },\r
+    {\r
+      0x05d1,\r
+      0x00,\r
+      {\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x78,\r
+        0x7C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x7E,\r
+        0x7E,\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x00\r
+      }\r
+    },\r
+    {\r
+      0x05d2,\r
+      0x00,\r
+      {\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x78,\r
+        0x7C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x1C,\r
+        0x3E,\r
+        0x66,\r
+        0x66,\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x00\r
+      }\r
+    },\r
+    {\r
+      0x05d3,\r
+      0x00,\r
+      {\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x7E,\r
+        0x7E,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x00\r
+      }\r
+    },\r
+    {\r
+      0x05d4,\r
+      0x00,\r
+      {\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x7C,\r
+        0x7E,\r
+        0x06,\r
+        0x06,\r
+        0x06,\r
+        0x06,\r
+        0x66,\r
+        0x66,\r
+        0x66,\r
+        0x66,\r
+        0x66,\r
+        0x66,\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x00\r
+      }\r
+    },\r
+    {\r
+      0x05d5,\r
+      0x00,\r
+      {\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x3C,\r
+        0x3C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x0C,\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x00\r
+      }\r
+    },\r
+    {\r
+      0x05d6,\r
+      0x00,\r
+      {\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x38,\r
+        0x38,\r
+        0x1E,\r
+        0x1E,\r
+        0x18,\r
+        0x18,\r
+        0x18,\r
+        0x18,\r
+        0x18,\r
+        0x18,\r
+        0x18,\r
+        0x18,\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x00\r
+      }\r
+    },\r
+    {\r
+      0x0000,\r
+      0x00,\r
+      {\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x00,\r
+        0x00\r
+      }\r
+    }\r
+  }\r
+};\r
+\r
 /**\r
   Initialize HII global accessor for string support.\r
 \r
@@ -69,3 +303,20 @@ GetStringById (
 {\r
   return HiiGetString (gStringPackHandle, Id, NULL);\r
 }\r
+\r
+/**\r
+  Routine to export glyphs to the HII database.  This is in addition to whatever is defined in the Graphics Console driver.\r
+\r
+**/\r
+EFI_HII_HANDLE\r
+ExportFonts (\r
+  VOID\r
+  )\r
+{\r
+  return HiiAddPackages (\r
+           &mFontPackageGuid,\r
+           gImageHandle,\r
+           &mFontBin,\r
+           NULL\r
+           );\r
+}\r
index 386b92d15a187778ccd20be0dcf7f852814fdbd2..31c443875ff48abc330630acba19f65604855c97 100644 (file)
@@ -65,4 +65,13 @@ UninitializeStringSupport (
   VOID\r
   );\r
 \r
+/**\r
+  Routine to export glyphs to the HII database.  This is in addition to whatever is defined in the Graphics Console driver.\r
+\r
+**/\r
+EFI_HII_HANDLE\r
+ExportFonts (\r
+  VOID\r
+  );\r
+\r
 #endif // _STRING_H_\r
index 95c2d087f9d7c21a4d61433decfa674cb9cad03f..6df6e4739e4fe2bc698f42a3b3d9042513d29695 100644 (file)
 \r
 [Sources]\r
   FrontPage.h\r
-  Language.h\r
   String.h\r
   Ui.h\r
   FrontPageVfr.Vfr\r
   FrontPageStrings.uni\r
   FrontPage.c\r
   String.c\r
-  Language.c\r
+  FrontPageCustomizedUi.c\r
+  FrontPageCustomizedUiSupport.c\r
+  FrontPageCustomizedUi.h\r
+  FrontPageCustomizedUiSupport.h\r
 \r
 [Packages]\r
   MdePkg/MdePkg.dec\r