]> git.proxmox.com Git - mirror_edk2.git/blame - IntelFrameworkModulePkg/Universal/BdsDxe/BootMaint/FileExplorer.c
Add BootlogoOnly feature in BDS for BGRT
[mirror_edk2.git] / IntelFrameworkModulePkg / Universal / BdsDxe / BootMaint / FileExplorer.c
CommitLineData
5c08e117 1/** @file\r
2 File explorer related functions.\r
3\r
2df686c6 4Copyright (c) 2004 - 2012, Intel Corporation. All rights reserved.<BR>\r
180a5a35 5This program and the accompanying materials\r
5c08e117 6are licensed and made available under the terms and conditions of the BSD License\r
7which accompanies this distribution. The full text of the license may be found at\r
8http://opensource.org/licenses/bsd-license.php\r
9\r
10THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
11WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
12\r
13**/\r
14\r
15#include "BootMaint.h"\r
16\r
17/**\r
18 Update the File Explore page.\r
19\r
20 @param CallbackData The BMM context data.\r
21 @param MenuOption Pointer to menu options to display.\r
22\r
23**/\r
24VOID\r
25UpdateFileExplorePage (\r
26 IN BMM_CALLBACK_DATA *CallbackData,\r
27 BM_MENU_OPTION *MenuOption\r
28 )\r
29{\r
30 UINTN Index;\r
31 BM_MENU_ENTRY *NewMenuEntry;\r
32 BM_FILE_CONTEXT *NewFileContext;\r
33 EFI_FORM_ID FormId;\r
34\r
35 NewMenuEntry = NULL;\r
36 NewFileContext = NULL;\r
37 FormId = 0;\r
38\r
39 RefreshUpdateData ();\r
75bf9d0e 40 mStartLabel->Number = FORM_FILE_EXPLORER_ID;\r
5c08e117 41\r
42 for (Index = 0; Index < MenuOption->MenuNumber; Index++) {\r
43 NewMenuEntry = BOpt_GetMenuEntry (MenuOption, Index);\r
44 NewFileContext = (BM_FILE_CONTEXT *) NewMenuEntry->VariableContext;\r
45\r
46 if (NewFileContext->IsBootLegacy) {\r
47 continue;\r
48 }\r
49\r
13078b3f 50 if ((NewFileContext->IsDir) || (FileExplorerStateBootFromFile == CallbackData->FeCurrentState)) {\r
5c08e117 51 //\r
13078b3f 52 // Create Text opcode for directory, also create Text opcode for file in FileExplorerStateBootFromFile.\r
5c08e117 53 //\r
75bf9d0e
LG
54 HiiCreateActionOpCode (\r
55 mStartOpCodeHandle,\r
5c08e117 56 (UINT16) (FILE_OPTION_OFFSET + Index),\r
57 NewMenuEntry->DisplayStringToken,\r
58 STRING_TOKEN (STR_NULL_STRING),\r
59 EFI_IFR_FLAG_CALLBACK,\r
75bf9d0e 60 0\r
5c08e117 61 );\r
62 } else {\r
63 //\r
13078b3f 64 // Create Goto opcode for file in FileExplorerStateAddBootOption or FileExplorerStateAddDriverOptionState.\r
5c08e117 65 //\r
13078b3f 66 if (FileExplorerStateAddBootOption == CallbackData->FeCurrentState) {\r
5c08e117 67 FormId = FORM_BOOT_ADD_DESCRIPTION_ID;\r
13078b3f 68 } else if (FileExplorerStateAddDriverOptionState == CallbackData->FeCurrentState) {\r
5c08e117 69 FormId = FORM_DRIVER_ADD_FILE_DESCRIPTION_ID;\r
70 }\r
71\r
75bf9d0e
LG
72 HiiCreateGotoOpCode (\r
73 mStartOpCodeHandle,\r
5c08e117 74 FormId,\r
75 NewMenuEntry->DisplayStringToken,\r
76 STRING_TOKEN (STR_NULL_STRING),\r
77 EFI_IFR_FLAG_CALLBACK,\r
75bf9d0e 78 (UINT16) (FILE_OPTION_OFFSET + Index)\r
5c08e117 79 );\r
80 }\r
81 }\r
82\r
75bf9d0e 83 HiiUpdateForm (\r
5c08e117 84 CallbackData->FeHiiHandle,\r
e24fc103 85 &gFileExploreFormSetGuid,\r
5c08e117 86 FORM_FILE_EXPLORER_ID,\r
75bf9d0e
LG
87 mStartOpCodeHandle, // Label FORM_FILE_EXPLORER_ID\r
88 mEndOpCodeHandle // LABEL_END\r
5c08e117 89 );\r
90}\r
91\r
92/**\r
93 Update the file explower page with the refershed file system.\r
94\r
95\r
96 @param CallbackData BMM context data\r
97 @param KeyValue Key value to identify the type of data to expect.\r
98\r
99 @retval TRUE Inform the caller to create a callback packet to exit file explorer.\r
100 @retval FALSE Indicate that there is no need to exit file explorer.\r
101\r
102**/\r
103BOOLEAN\r
104UpdateFileExplorer (\r
105 IN BMM_CALLBACK_DATA *CallbackData,\r
106 IN UINT16 KeyValue\r
107 )\r
108{\r
109 UINT16 FileOptionMask;\r
110 BM_MENU_ENTRY *NewMenuEntry;\r
111 BM_FILE_CONTEXT *NewFileContext;\r
112 EFI_FORM_ID FormId;\r
113 BOOLEAN ExitFileExplorer;\r
114 EFI_STATUS Status;\r
115\r
116 NewMenuEntry = NULL;\r
117 NewFileContext = NULL;\r
118 ExitFileExplorer = FALSE;\r
119\r
120 FileOptionMask = (UINT16) (FILE_OPTION_MASK & KeyValue);\r
121\r
13078b3f 122 if (FileExplorerDisplayUnknown == CallbackData->FeDisplayContext) {\r
5c08e117 123 //\r
124 // First in, display file system.\r
125 //\r
126 BOpt_FreeMenu (&FsOptionMenu);\r
127 BOpt_FindFileSystem (CallbackData);\r
128 CreateMenuStringToken (CallbackData, CallbackData->FeHiiHandle, &FsOptionMenu);\r
129\r
130 UpdateFileExplorePage (CallbackData, &FsOptionMenu);\r
131\r
13078b3f 132 CallbackData->FeDisplayContext = FileExplorerDisplayFileSystem;\r
5c08e117 133 } else {\r
13078b3f 134 if (FileExplorerDisplayFileSystem == CallbackData->FeDisplayContext) {\r
5c08e117 135 NewMenuEntry = BOpt_GetMenuEntry (&FsOptionMenu, FileOptionMask);\r
13078b3f 136 } else if (FileExplorerDisplayDirectory == CallbackData->FeDisplayContext) {\r
5c08e117 137 NewMenuEntry = BOpt_GetMenuEntry (&DirectoryMenu, FileOptionMask);\r
138 }\r
139\r
a19ad64b 140 NewFileContext = (BM_FILE_CONTEXT *) NewMenuEntry->VariableContext;\r
5c08e117 141\r
5c08e117 142 if (NewFileContext->IsDir ) {\r
a19ad64b 143 CallbackData->FeDisplayContext = FileExplorerDisplayDirectory;\r
9ecbc654 144\r
5c08e117 145 RemoveEntryList (&NewMenuEntry->Link);\r
146 BOpt_FreeMenu (&DirectoryMenu);\r
147 Status = BOpt_FindFiles (CallbackData, NewMenuEntry);\r
148 if (EFI_ERROR (Status)) {\r
149 ExitFileExplorer = TRUE;\r
150 goto exit;\r
151 }\r
152 CreateMenuStringToken (CallbackData, CallbackData->FeHiiHandle, &DirectoryMenu);\r
153 BOpt_DestroyMenuEntry (NewMenuEntry);\r
154\r
155 UpdateFileExplorePage (CallbackData, &DirectoryMenu);\r
156\r
157 } else {\r
158 switch (CallbackData->FeCurrentState) {\r
13078b3f 159 case FileExplorerStateBootFromFile:\r
2df686c6 160 //\r
161 // Restore to original mode before launching boot option.\r
162 //\r
163 BdsSetConsoleMode (FALSE);\r
164\r
5c08e117 165 //\r
166 // Here boot from file\r
167 //\r
168 BootThisFile (NewFileContext);\r
72861c22 169 //\r
170 // Set proper video resolution and text mode for setup.\r
171 //\r
2df686c6 172 BdsSetConsoleMode (TRUE);\r
5c08e117 173 ExitFileExplorer = TRUE;\r
174 break;\r
175\r
13078b3f 176 case FileExplorerStateAddBootOption:\r
177 case FileExplorerStateAddDriverOptionState:\r
178 if (FileExplorerStateAddBootOption == CallbackData->FeCurrentState) {\r
5c08e117 179 FormId = FORM_BOOT_ADD_DESCRIPTION_ID;\r
180 } else {\r
181 FormId = FORM_DRIVER_ADD_FILE_DESCRIPTION_ID;\r
182 }\r
183\r
184 CallbackData->MenuEntry = NewMenuEntry;\r
185 CallbackData->LoadContext->FilePathList = ((BM_FILE_CONTEXT *) (CallbackData->MenuEntry->VariableContext))->DevicePath;\r
186\r
187 //\r
188 // Create Subtitle op-code for the display string of the option.\r
189 //\r
190 RefreshUpdateData ();\r
75bf9d0e 191 mStartLabel->Number = FormId;\r
5c08e117 192\r
75bf9d0e
LG
193 HiiCreateSubTitleOpCode (\r
194 mStartOpCodeHandle,\r
5c08e117 195 NewMenuEntry->DisplayStringToken,\r
196 0,\r
197 0,\r
75bf9d0e 198 0\r
5c08e117 199 );\r
200\r
75bf9d0e 201 HiiUpdateForm (\r
5c08e117 202 CallbackData->FeHiiHandle,\r
e24fc103 203 &gFileExploreFormSetGuid,\r
5c08e117 204 FormId,\r
75bf9d0e
LG
205 mStartOpCodeHandle, // Label FormId\r
206 mEndOpCodeHandle // LABEL_END\r
5c08e117 207 );\r
208 break;\r
209\r
210 default:\r
211 break;\r
212 }\r
213 }\r
214 }\r
215 exit:\r
216 return ExitFileExplorer;\r
217}\r
218\r
219/**\r
220 This function processes the results of changes in configuration.\r
221 When user select a interactive opcode, this callback will be triggered.\r
222 Based on the Question(QuestionId) that triggers the callback, the corresponding\r
223 actions is performed. It handles:\r
224\r
225 1) the addition of boot option.\r
226 2) the addition of driver option.\r
227 3) exit from file browser\r
228 4) update of file content if a dir is selected.\r
229 5) boot the file if a file is selected in "boot from file"\r
230\r
231\r
232 @param This Points to the EFI_HII_CONFIG_ACCESS_PROTOCOL.\r
233 @param Action Specifies the type of action taken by the browser.\r
234 @param QuestionId A unique value which is sent to the original exporting driver\r
235 so that it can identify the type of data to expect.\r
236 @param Type The type of value for the question.\r
237 @param Value A pointer to the data being sent to the original exporting driver.\r
238 @param ActionRequest On return, points to the action requested by the callback function.\r
239\r
240 @retval EFI_SUCCESS The callback successfully handled the action.\r
241 @retval EFI_OUT_OF_RESOURCES Not enough storage is available to hold the variable and its data.\r
242 @retval EFI_DEVICE_ERROR The variable could not be saved.\r
243 @retval EFI_UNSUPPORTED The specified Action is not supported by the callback.\r
244 @retval EFI_INVALID_PARAMETER If paramter Value or ActionRequest is NULL.\r
245**/\r
246EFI_STATUS\r
247EFIAPI\r
248FileExplorerCallback (\r
249 IN CONST EFI_HII_CONFIG_ACCESS_PROTOCOL *This,\r
250 IN EFI_BROWSER_ACTION Action,\r
251 IN EFI_QUESTION_ID QuestionId,\r
252 IN UINT8 Type,\r
253 IN EFI_IFR_TYPE_VALUE *Value,\r
254 OUT EFI_BROWSER_ACTION_REQUEST *ActionRequest\r
255 )\r
256{\r
257 BMM_CALLBACK_DATA *Private;\r
258 FILE_EXPLORER_NV_DATA *NvRamMap;\r
259 EFI_STATUS Status;\r
5c08e117 260\r
84724077 261 if (Action != EFI_BROWSER_ACTION_CHANGING && Action != EFI_BROWSER_ACTION_CHANGED) {\r
4548fc2a 262 //\r
84724077 263 // All other action return unsupported.\r
4548fc2a 264 //\r
84724077
ED
265 return EFI_UNSUPPORTED;\r
266 }\r
267 \r
268 Status = EFI_SUCCESS;\r
269 Private = FE_CALLBACK_DATA_FROM_THIS (This);\r
4548fc2a 270\r
84724077
ED
271 //\r
272 // Retrieve uncommitted data from Form Browser\r
273 //\r
274 NvRamMap = &Private->FeFakeNvData;\r
275 HiiGetBrowserData (&gFileExploreFormSetGuid, mFileExplorerStorageName, sizeof (FILE_EXPLORER_NV_DATA), (UINT8 *) NvRamMap);\r
276\r
277 if (Action == EFI_BROWSER_ACTION_CHANGED) {\r
278 if ((Value == NULL) || (ActionRequest == NULL)) {\r
279 return EFI_INVALID_PARAMETER;\r
280 }\r
281 \r
d88f86f1
ED
282 if (QuestionId == KEY_VALUE_SAVE_AND_EXIT_BOOT || QuestionId == KEY_VALUE_SAVE_AND_EXIT_DRIVER) {\r
283 //\r
284 // Apply changes and exit formset\r
285 //\r
286 if (FileExplorerStateAddBootOption == Private->FeCurrentState) {\r
287 Status = Var_UpdateBootOption (Private, NvRamMap);\r
288 if (EFI_ERROR (Status)) {\r
289 return Status;\r
290 }\r
5c08e117 291\r
d88f86f1
ED
292 BOpt_GetBootOptions (Private);\r
293 CreateMenuStringToken (Private, Private->FeHiiHandle, &BootOptionMenu);\r
294 } else if (FileExplorerStateAddDriverOptionState == Private->FeCurrentState) {\r
295 Status = Var_UpdateDriverOption (\r
296 Private,\r
297 Private->FeHiiHandle,\r
298 NvRamMap->DescriptionData,\r
299 NvRamMap->OptionalData,\r
300 NvRamMap->ForceReconnect\r
301 );\r
302 if (EFI_ERROR (Status)) {\r
303 return Status;\r
304 }\r
5c08e117 305\r
d88f86f1
ED
306 BOpt_GetDriverOptions (Private);\r
307 CreateMenuStringToken (Private, Private->FeHiiHandle, &DriverOptionMenu);\r
5c08e117 308 }\r
309\r
d88f86f1
ED
310 *ActionRequest = EFI_BROWSER_ACTION_REQUEST_EXIT;\r
311 } else if (QuestionId == KEY_VALUE_NO_SAVE_AND_EXIT_BOOT || QuestionId == KEY_VALUE_NO_SAVE_AND_EXIT_DRIVER) {\r
312 //\r
313 // Discard changes and exit formset\r
314 //\r
315 NvRamMap->OptionalData[0] = 0x0000;\r
316 NvRamMap->DescriptionData[0] = 0x0000;\r
317 *ActionRequest = EFI_BROWSER_ACTION_REQUEST_EXIT;\r
318 } else if (QuestionId < FILE_OPTION_OFFSET) {\r
319 //\r
320 // Exit File Explorer formset\r
321 //\r
322 *ActionRequest = EFI_BROWSER_ACTION_REQUEST_EXIT;\r
5c08e117 323 }\r
84724077
ED
324 } else if (Action == EFI_BROWSER_ACTION_CHANGING) {\r
325 if (Value == NULL) {\r
326 return EFI_INVALID_PARAMETER;\r
327 }\r
328 \r
329 if (QuestionId >= FILE_OPTION_OFFSET) {\r
330 UpdateFileExplorer (Private, QuestionId);\r
331 }\r
5c08e117 332 }\r
84724077
ED
333\r
334 return Status;\r
5c08e117 335}\r