]> git.proxmox.com Git - mirror_edk2.git/blobdiff - IntelFrameworkModulePkg/Universal/BdsDxe/BootMaint/FileExplorer.c
Introduce video resolution and text mode PCDs for BIOS setup in BDS module. User...
[mirror_edk2.git] / IntelFrameworkModulePkg / Universal / BdsDxe / BootMaint / FileExplorer.c
index 8253ded9882ba3ef489d7ae5696c7c9f19708442..b77e909ad538d7a4d92356ef5ee3d419d84fce82 100644 (file)
@@ -1,8 +1,8 @@
 /** @file\r
   File explorer related functions.\r
 \r
-Copyright (c) 2004 - 2008, Intel Corporation. <BR>\r
-All rights reserved. This program and the accompanying materials\r
+Copyright (c) 2004 - 2011, 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
@@ -37,6 +37,7 @@ UpdateFileExplorePage (
   FormId          = 0;\r
 \r
   RefreshUpdateData ();\r
+  mStartLabel->Number = FORM_FILE_EXPLORER_ID;\r
 \r
   for (Index = 0; Index < MenuOption->MenuNumber; Index++) {\r
     NewMenuEntry    = BOpt_GetMenuEntry (MenuOption, Index);\r
@@ -46,46 +47,45 @@ UpdateFileExplorePage (
       continue;\r
     }\r
 \r
-    if ((NewFileContext->IsDir) || (BOOT_FROM_FILE_STATE == CallbackData->FeCurrentState)) {\r
+    if ((NewFileContext->IsDir) || (FileExplorerStateBootFromFile == CallbackData->FeCurrentState)) {\r
       //\r
-      // Create Text opcode for directory, also create Text opcode for file in BOOT_FROM_FILE_STATE.\r
+      // Create Text opcode for directory, also create Text opcode for file in FileExplorerStateBootFromFile.\r
       //\r
-      CreateActionOpCode (\r
+      HiiCreateActionOpCode (\r
+        mStartOpCodeHandle,\r
         (UINT16) (FILE_OPTION_OFFSET + Index),\r
         NewMenuEntry->DisplayStringToken,\r
         STRING_TOKEN (STR_NULL_STRING),\r
         EFI_IFR_FLAG_CALLBACK,\r
-        0,\r
-        &gUpdateData\r
+        0\r
         );\r
     } else {\r
       //\r
-      // Create Goto opcode for file in ADD_BOOT_OPTION_STATE or ADD_DRIVER_OPTION_STATE.\r
+      // Create Goto opcode for file in FileExplorerStateAddBootOption or FileExplorerStateAddDriverOptionState.\r
       //\r
-      if (ADD_BOOT_OPTION_STATE == CallbackData->FeCurrentState) {\r
+      if (FileExplorerStateAddBootOption == CallbackData->FeCurrentState) {\r
         FormId = FORM_BOOT_ADD_DESCRIPTION_ID;\r
-      } else if (ADD_DRIVER_OPTION_STATE == CallbackData->FeCurrentState) {\r
+      } else if (FileExplorerStateAddDriverOptionState == CallbackData->FeCurrentState) {\r
         FormId = FORM_DRIVER_ADD_FILE_DESCRIPTION_ID;\r
       }\r
 \r
-      CreateGotoOpCode (\r
+      HiiCreateGotoOpCode (\r
+        mStartOpCodeHandle,\r
         FormId,\r
         NewMenuEntry->DisplayStringToken,\r
         STRING_TOKEN (STR_NULL_STRING),\r
         EFI_IFR_FLAG_CALLBACK,\r
-        (UINT16) (FILE_OPTION_OFFSET + Index),\r
-        &gUpdateData\r
+        (UINT16) (FILE_OPTION_OFFSET + Index)\r
         );\r
     }\r
   }\r
 \r
-  IfrLibUpdateForm (\r
+  HiiUpdateForm (\r
     CallbackData->FeHiiHandle,\r
-    &mFileExplorerGuid,\r
-    FORM_FILE_EXPLORER_ID,\r
+    &gFileExploreFormSetGuid,\r
     FORM_FILE_EXPLORER_ID,\r
-    FALSE,\r
-    &gUpdateData\r
+    mStartOpCodeHandle, // Label FORM_FILE_EXPLORER_ID\r
+    mEndOpCodeHandle    // LABEL_END\r
     );\r
 }\r
 \r
@@ -119,7 +119,7 @@ UpdateFileExplorer (
 \r
   FileOptionMask    = (UINT16) (FILE_OPTION_MASK & KeyValue);\r
 \r
-  if (UNKNOWN_CONTEXT == CallbackData->FeDisplayContext) {\r
+  if (FileExplorerDisplayUnknown == CallbackData->FeDisplayContext) {\r
     //\r
     // First in, display file system.\r
     //\r
@@ -129,19 +129,19 @@ UpdateFileExplorer (
 \r
     UpdateFileExplorePage (CallbackData, &FsOptionMenu);\r
 \r
-    CallbackData->FeDisplayContext = FILE_SYSTEM;\r
+    CallbackData->FeDisplayContext = FileExplorerDisplayFileSystem;\r
   } else {\r
-    if (FILE_SYSTEM == CallbackData->FeDisplayContext) {\r
+    if (FileExplorerDisplayFileSystem == CallbackData->FeDisplayContext) {\r
       NewMenuEntry = BOpt_GetMenuEntry (&FsOptionMenu, FileOptionMask);\r
-    } else if (DIRECTORY == CallbackData->FeDisplayContext) {\r
+    } else if (FileExplorerDisplayDirectory == CallbackData->FeDisplayContext) {\r
       NewMenuEntry = BOpt_GetMenuEntry (&DirectoryMenu, FileOptionMask);\r
     }\r
 \r
-    CallbackData->FeDisplayContext  = DIRECTORY;\r
-\r
     NewFileContext                  = (BM_FILE_CONTEXT *) NewMenuEntry->VariableContext;\r
 \r
     if (NewFileContext->IsDir ) {\r
+      CallbackData->FeDisplayContext = FileExplorerDisplayDirectory;\r
+\r
       RemoveEntryList (&NewMenuEntry->Link);\r
       BOpt_FreeMenu (&DirectoryMenu);\r
       Status = BOpt_FindFiles (CallbackData, NewMenuEntry);\r
@@ -156,17 +156,21 @@ UpdateFileExplorer (
 \r
     } else {\r
       switch (CallbackData->FeCurrentState) {\r
-      case BOOT_FROM_FILE_STATE:\r
+      case FileExplorerStateBootFromFile:\r
         //\r
         // Here boot from file\r
         //\r
         BootThisFile (NewFileContext);\r
+        //\r
+        // Set proper video resolution and text mode for setup.\r
+        //\r
+        ChangeModeForSetup ();\r
         ExitFileExplorer = TRUE;\r
         break;\r
 \r
-      case ADD_BOOT_OPTION_STATE:\r
-      case ADD_DRIVER_OPTION_STATE:\r
-        if (ADD_BOOT_OPTION_STATE == CallbackData->FeCurrentState) {\r
+      case FileExplorerStateAddBootOption:\r
+      case FileExplorerStateAddDriverOptionState:\r
+        if (FileExplorerStateAddBootOption == CallbackData->FeCurrentState) {\r
           FormId = FORM_BOOT_ADD_DESCRIPTION_ID;\r
         } else {\r
           FormId = FORM_DRIVER_ADD_FILE_DESCRIPTION_ID;\r
@@ -179,22 +183,22 @@ UpdateFileExplorer (
         // Create Subtitle op-code for the display string of the option.\r
         //\r
         RefreshUpdateData ();\r
+        mStartLabel->Number = FormId;\r
 \r
-        CreateSubTitleOpCode (\r
+        HiiCreateSubTitleOpCode (\r
+          mStartOpCodeHandle,\r
           NewMenuEntry->DisplayStringToken,\r
           0,\r
           0,\r
-          0,\r
-          &gUpdateData\r
+          0\r
           );\r
 \r
-        IfrLibUpdateForm (\r
+        HiiUpdateForm (\r
           CallbackData->FeHiiHandle,\r
-          &mFileExplorerGuid,\r
-          FormId,\r
+          &gFileExploreFormSetGuid,\r
           FormId,\r
-          FALSE,\r
-          &gUpdateData\r
+          mStartOpCodeHandle, // Label FormId\r
+          mEndOpCodeHandle    // LABEL_END\r
           );\r
         break;\r
 \r
@@ -248,72 +252,73 @@ FileExplorerCallback (
   BMM_CALLBACK_DATA     *Private;\r
   FILE_EXPLORER_NV_DATA *NvRamMap;\r
   EFI_STATUS            Status;\r
-  UINTN                 BufferSize;\r
 \r
-  if ((Value == NULL) || (ActionRequest == NULL)) {\r
-    return EFI_INVALID_PARAMETER;\r
-  }\r
+  if (Action == EFI_BROWSER_ACTION_CHANGING) {\r
+    if ((Value == NULL) || (ActionRequest == NULL)) {\r
+      return EFI_INVALID_PARAMETER;\r
+    }\r
 \r
-  Status         = EFI_SUCCESS;\r
-  Private        = FE_CALLBACK_DATA_FROM_THIS (This);\r
-  *ActionRequest = EFI_BROWSER_ACTION_REQUEST_NONE;\r
+    Status         = EFI_SUCCESS;\r
+    Private        = FE_CALLBACK_DATA_FROM_THIS (This);\r
+    *ActionRequest = EFI_BROWSER_ACTION_REQUEST_NONE;\r
 \r
-  //\r
-  // Retrieve uncommitted data from Form Browser\r
-  //\r
-  NvRamMap = &Private->FeFakeNvData;\r
-  BufferSize = sizeof (FILE_EXPLORER_NV_DATA);\r
-  Status = GetBrowserData (NULL, NULL, &BufferSize, (UINT8 *) NvRamMap);\r
-  if (EFI_ERROR (Status)) {\r
-    return Status;\r
-  }\r
-\r
-  if (QuestionId == KEY_VALUE_SAVE_AND_EXIT_BOOT || QuestionId == KEY_VALUE_SAVE_AND_EXIT_DRIVER) {\r
     //\r
-    // Apply changes and exit formset\r
+    // Retrieve uncommitted data from Form Browser\r
     //\r
-    if (ADD_BOOT_OPTION_STATE == Private->FeCurrentState) {\r
-      Status = Var_UpdateBootOption (Private, NvRamMap);\r
-      if (EFI_ERROR (Status)) {\r
-        return Status;\r
-      }\r
+    NvRamMap = &Private->FeFakeNvData;\r
+    HiiGetBrowserData (&gFileExploreFormSetGuid, mFileExplorerStorageName, sizeof (FILE_EXPLORER_NV_DATA), (UINT8 *) NvRamMap);\r
 \r
-      BOpt_GetBootOptions (Private);\r
-      CreateMenuStringToken (Private, Private->FeHiiHandle, &BootOptionMenu);\r
-    } else if (ADD_DRIVER_OPTION_STATE == Private->FeCurrentState) {\r
-      Status = Var_UpdateDriverOption (\r
-                Private,\r
-                Private->FeHiiHandle,\r
-                NvRamMap->DescriptionData,\r
-                NvRamMap->OptionalData,\r
-                NvRamMap->ForceReconnect\r
-                );\r
-      if (EFI_ERROR (Status)) {\r
-        return Status;\r
-      }\r
+    if (QuestionId == KEY_VALUE_SAVE_AND_EXIT_BOOT || QuestionId == KEY_VALUE_SAVE_AND_EXIT_DRIVER) {\r
+      //\r
+      // Apply changes and exit formset\r
+      //\r
+      if (FileExplorerStateAddBootOption == Private->FeCurrentState) {\r
+        Status = Var_UpdateBootOption (Private, NvRamMap);\r
+        if (EFI_ERROR (Status)) {\r
+          return Status;\r
+        }\r
 \r
-      BOpt_GetDriverOptions (Private);\r
-      CreateMenuStringToken (Private, Private->FeHiiHandle, &DriverOptionMenu);\r
-    }\r
+        BOpt_GetBootOptions (Private);\r
+        CreateMenuStringToken (Private, Private->FeHiiHandle, &BootOptionMenu);\r
+      } else if (FileExplorerStateAddDriverOptionState == Private->FeCurrentState) {\r
+        Status = Var_UpdateDriverOption (\r
+                  Private,\r
+                  Private->FeHiiHandle,\r
+                  NvRamMap->DescriptionData,\r
+                  NvRamMap->OptionalData,\r
+                  NvRamMap->ForceReconnect\r
+                  );\r
+        if (EFI_ERROR (Status)) {\r
+          return Status;\r
+        }\r
 \r
-    *ActionRequest = EFI_BROWSER_ACTION_REQUEST_EXIT;\r
-  } else if (QuestionId == KEY_VALUE_NO_SAVE_AND_EXIT_BOOT || QuestionId == KEY_VALUE_NO_SAVE_AND_EXIT_DRIVER) {\r
-    //\r
-    // Discard changes and exit formset\r
-    //\r
-    NvRamMap->OptionalData[0]     = 0x0000;\r
-    NvRamMap->DescriptionData[0]  = 0x0000;\r
-    *ActionRequest = EFI_BROWSER_ACTION_REQUEST_EXIT;\r
-  } else if (QuestionId < FILE_OPTION_OFFSET) {\r
-    //\r
-    // Exit File Explorer formset\r
-    //\r
-    *ActionRequest = EFI_BROWSER_ACTION_REQUEST_EXIT;\r
-  } else {\r
-    if (UpdateFileExplorer (Private, QuestionId)) {\r
+        BOpt_GetDriverOptions (Private);\r
+        CreateMenuStringToken (Private, Private->FeHiiHandle, &DriverOptionMenu);\r
+      }\r
+\r
+      *ActionRequest = EFI_BROWSER_ACTION_REQUEST_EXIT;\r
+    } else if (QuestionId == KEY_VALUE_NO_SAVE_AND_EXIT_BOOT || QuestionId == KEY_VALUE_NO_SAVE_AND_EXIT_DRIVER) {\r
+      //\r
+      // Discard changes and exit formset\r
+      //\r
+      NvRamMap->OptionalData[0]     = 0x0000;\r
+      NvRamMap->DescriptionData[0]  = 0x0000;\r
       *ActionRequest = EFI_BROWSER_ACTION_REQUEST_EXIT;\r
+    } else if (QuestionId < FILE_OPTION_OFFSET) {\r
+      //\r
+      // Exit File Explorer formset\r
+      //\r
+      *ActionRequest = EFI_BROWSER_ACTION_REQUEST_EXIT;\r
+    } else {\r
+      if (UpdateFileExplorer (Private, QuestionId)) {\r
+        *ActionRequest = EFI_BROWSER_ACTION_REQUEST_EXIT;\r
+      }\r
     }\r
-  }\r
 \r
-  return Status;\r
+    return Status;\r
+  }\r
+  //\r
+  // All other action return unsupported.\r
+  //\r
+  return EFI_UNSUPPORTED;\r
 }\r