]> git.proxmox.com Git - mirror_edk2.git/blame - MdeModulePkg/Universal/DriverSampleDxe/DriverSample.c
Fix incorrect return status usage of HiiGetBrowserData().
[mirror_edk2.git] / MdeModulePkg / Universal / DriverSampleDxe / DriverSample.c
CommitLineData
93e3992d 1/** @file\r
53cf48e0 2This is an example of how a driver might export data to the HII protocol to be\r
3later utilized by the Setup Protocol\r
4\r
a6973cff 5Copyright (c) 2004 - 2009, Intel Corporation\r
93e3992d 6All rights reserved. This program and the accompanying materials\r
7are licensed and made available under the terms and conditions of the BSD License\r
8which accompanies this distribution. The full text of the license may be found at\r
9http://opensource.org/licenses/bsd-license.php\r
10\r
11THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
12WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
13\r
93e3992d 14**/\r
15\r
16\r
17#include "DriverSample.h"\r
18\r
7e3bcccb 19#define DISPLAY_ONLY_MY_ITEM 0x0002\r
93e3992d 20\r
21EFI_GUID mFormSetGuid = FORMSET_GUID;\r
22EFI_GUID mInventoryGuid = INVENTORY_GUID;\r
23\r
24CHAR16 VariableName[] = L"MyIfrNVData";\r
2f3065c0
LG
25EFI_HANDLE DriverHandle[2] = {NULL, NULL};\r
26DRIVER_SAMPLE_PRIVATE_DATA *PrivateData = NULL;\r
27\r
28HII_VENDOR_DEVICE_PATH mHiiVendorDevicePath0 = {\r
f6f910dd 29 {\r
30 {\r
31 HARDWARE_DEVICE_PATH,\r
32 HW_VENDOR_DP,\r
33 {\r
34 (UINT8) (sizeof (VENDOR_DEVICE_PATH)),\r
35 (UINT8) ((sizeof (VENDOR_DEVICE_PATH)) >> 8)\r
36 }\r
37 },\r
38 //\r
39 // {C153B68D-EBFC-488e-B110-662867745B87}\r
40 //\r
41 { 0xc153b68d, 0xebfc, 0x488e, { 0xb1, 0x10, 0x66, 0x28, 0x67, 0x74, 0x5b, 0x87 } }\r
42 },\r
43 {\r
44 END_DEVICE_PATH_TYPE,\r
45 END_ENTIRE_DEVICE_PATH_SUBTYPE,\r
a6973cff 46 {\r
f6f910dd 47 (UINT8) (END_DEVICE_PATH_LENGTH),\r
48 (UINT8) ((END_DEVICE_PATH_LENGTH) >> 8)\r
49 }\r
50 }\r
51};\r
52\r
2f3065c0 53HII_VENDOR_DEVICE_PATH mHiiVendorDevicePath1 = {\r
f6f910dd 54 {\r
55 {\r
56 HARDWARE_DEVICE_PATH,\r
57 HW_VENDOR_DP,\r
58 {\r
59 (UINT8) (sizeof (VENDOR_DEVICE_PATH)),\r
60 (UINT8) ((sizeof (VENDOR_DEVICE_PATH)) >> 8)\r
61 }\r
62 },\r
63 //\r
64 // {06F37F07-0C48-40e9-8436-0A08A0BB76B0}\r
65 //\r
66 { 0x6f37f07, 0xc48, 0x40e9, { 0x84, 0x36, 0xa, 0x8, 0xa0, 0xbb, 0x76, 0xb0 } }\r
67 },\r
68 {\r
69 END_DEVICE_PATH_TYPE,\r
70 END_ENTIRE_DEVICE_PATH_SUBTYPE,\r
a6973cff 71 {\r
f6f910dd 72 (UINT8) (END_DEVICE_PATH_LENGTH),\r
73 (UINT8) ((END_DEVICE_PATH_LENGTH) >> 8)\r
74 }\r
75 }\r
76};\r
77\r
7064c0a5 78/**\r
79 Encode the password using a simple algorithm.\r
a6973cff 80\r
7064c0a5 81 @param Password The string to be encoded.\r
82 @param MaxSize The size of the string.\r
a6973cff 83\r
7064c0a5 84**/\r
93e3992d 85VOID\r
86EncodePassword (\r
87 IN CHAR16 *Password,\r
5a829f56 88 IN UINTN MaxSize\r
93e3992d 89 )\r
90{\r
91 UINTN Index;\r
92 UINTN Loop;\r
93 CHAR16 *Buffer;\r
94 CHAR16 *Key;\r
95\r
96 Key = L"MAR10648567";\r
97 Buffer = AllocateZeroPool (MaxSize);\r
98 ASSERT (Buffer != NULL);\r
99\r
100 for (Index = 0; Key[Index] != 0; Index++) {\r
101 for (Loop = 0; Loop < (UINT8) (MaxSize / 2); Loop++) {\r
102 Buffer[Loop] = (CHAR16) (Password[Loop] ^ Key[Index]);\r
103 }\r
104 }\r
105\r
106 CopyMem (Password, Buffer, MaxSize);\r
107\r
53cf48e0 108 FreePool (Buffer);\r
93e3992d 109 return ;\r
110}\r
111\r
7064c0a5 112/**\r
113 Validate the user's password.\r
a6973cff 114\r
7064c0a5 115 @param PrivateData This driver's private context data.\r
116 @param StringId The user's input.\r
a6973cff 117\r
7064c0a5 118 @retval EFI_SUCCESS The user's input matches the password.\r
119 @retval EFI_NOT_READY The user's input does not match the password.\r
120**/\r
93e3992d 121EFI_STATUS\r
122ValidatePassword (\r
7064c0a5 123 IN DRIVER_SAMPLE_PRIVATE_DATA *PrivateData,\r
124 IN EFI_STRING_ID StringId\r
93e3992d 125 )\r
126{\r
127 EFI_STATUS Status;\r
128 UINTN Index;\r
129 UINTN BufferSize;\r
84f9a9ec 130 UINTN PasswordMaxSize;\r
93e3992d 131 CHAR16 *Password;\r
132 CHAR16 *EncodedPassword;\r
133 BOOLEAN OldPassword;\r
134\r
135 //\r
136 // Get encoded password first\r
137 //\r
138 BufferSize = sizeof (DRIVER_SAMPLE_CONFIGURATION);\r
139 Status = gRT->GetVariable (\r
140 VariableName,\r
141 &mFormSetGuid,\r
142 NULL,\r
143 &BufferSize,\r
144 &PrivateData->Configuration\r
145 );\r
146 if (EFI_ERROR (Status)) {\r
147 //\r
148 // Old password not exist, prompt for new password\r
149 //\r
150 return EFI_SUCCESS;\r
151 }\r
152\r
153 OldPassword = FALSE;\r
84f9a9ec 154 PasswordMaxSize = sizeof (PrivateData->Configuration.WhatIsThePassword2);\r
93e3992d 155 //\r
156 // Check whether we have any old password set\r
157 //\r
84f9a9ec 158 for (Index = 0; Index < PasswordMaxSize / sizeof (UINT16); Index++) {\r
93e3992d 159 if (PrivateData->Configuration.WhatIsThePassword2[Index] != 0) {\r
160 OldPassword = TRUE;\r
161 break;\r
162 }\r
163 }\r
164 if (!OldPassword) {\r
165 //\r
166 // Old password not exist, return EFI_SUCCESS to prompt for new password\r
167 //\r
168 return EFI_SUCCESS;\r
169 }\r
170\r
171 //\r
172 // Get user input password\r
173 //\r
cb7d01c0 174 Password = HiiGetString (PrivateData->HiiHandle[0], StringId, NULL);\r
175 if (Password == NULL) {\r
176 return EFI_NOT_READY;\r
177 }\r
84f9a9ec 178 if (StrSize (Password) > PasswordMaxSize) {\r
53cf48e0 179 FreePool (Password);\r
cb7d01c0 180 return EFI_NOT_READY;\r
93e3992d 181 }\r
182\r
183 //\r
184 // Validate old password\r
185 //\r
84f9a9ec 186 EncodedPassword = AllocateZeroPool (PasswordMaxSize);\r
93e3992d 187 ASSERT (EncodedPassword != NULL);\r
84f9a9ec
LG
188 StrnCpy (EncodedPassword, Password, StrLen (Password));\r
189 EncodePassword (EncodedPassword, StrLen (EncodedPassword) * sizeof (CHAR16));\r
190 if (CompareMem (EncodedPassword, PrivateData->Configuration.WhatIsThePassword2, StrLen (EncodedPassword) * sizeof (CHAR16)) != 0) {\r
93e3992d 191 //\r
192 // Old password mismatch, return EFI_NOT_READY to prompt for error message\r
193 //\r
194 Status = EFI_NOT_READY;\r
195 } else {\r
196 Status = EFI_SUCCESS;\r
197 }\r
198\r
53cf48e0 199 FreePool (Password);\r
200 FreePool (EncodedPassword);\r
93e3992d 201\r
202 return Status;\r
203}\r
204\r
7064c0a5 205/**\r
206 Encode the password using a simple algorithm.\r
a6973cff 207\r
7064c0a5 208 @param PrivateData This driver's private context data.\r
209 @param StringId The password from User.\r
a6973cff 210\r
7064c0a5 211 @retval EFI_SUCESS The operation is successful.\r
212 @return Other value if gRT->SetVariable () fails.\r
a6973cff 213\r
7064c0a5 214**/\r
93e3992d 215EFI_STATUS\r
216SetPassword (\r
7064c0a5 217 IN DRIVER_SAMPLE_PRIVATE_DATA *PrivateData,\r
218 IN EFI_STRING_ID StringId\r
93e3992d 219 )\r
220{\r
221 EFI_STATUS Status;\r
93e3992d 222 CHAR16 *Password;\r
cb7d01c0 223 CHAR16 *TempPassword;\r
5a829f56 224 UINTN PasswordSize;\r
93e3992d 225 DRIVER_SAMPLE_CONFIGURATION *Configuration;\r
7e3bcccb 226 UINTN BufferSize;\r
93e3992d 227\r
228 //\r
229 // Get Buffer Storage data from EFI variable\r
230 //\r
231 BufferSize = sizeof (DRIVER_SAMPLE_CONFIGURATION);\r
232 Status = gRT->GetVariable (\r
233 VariableName,\r
234 &mFormSetGuid,\r
235 NULL,\r
236 &BufferSize,\r
237 &PrivateData->Configuration\r
238 );\r
239 if (EFI_ERROR (Status)) {\r
240 return Status;\r
241 }\r
242\r
243 //\r
244 // Get user input password\r
245 //\r
246 Password = &PrivateData->Configuration.WhatIsThePassword2[0];\r
a6973cff 247 PasswordSize = sizeof (PrivateData->Configuration.WhatIsThePassword2);\r
5a829f56 248 ZeroMem (Password, PasswordSize);\r
a6973cff 249\r
cb7d01c0 250 TempPassword = HiiGetString (PrivateData->HiiHandle[0], StringId, NULL);\r
251 if (TempPassword == NULL) {\r
252 return EFI_NOT_READY;\r
253 }\r
84f9a9ec 254 if (StrSize (TempPassword) > PasswordSize) {\r
cb7d01c0 255 FreePool (TempPassword);\r
256 return EFI_NOT_READY;\r
93e3992d 257 }\r
84f9a9ec 258 StrnCpy (Password, TempPassword, StrLen (TempPassword));\r
cb7d01c0 259 FreePool (TempPassword);\r
93e3992d 260\r
261 //\r
262 // Retrive uncommitted data from Browser\r
263 //\r
1d451ff9
LG
264 Configuration = AllocateZeroPool (sizeof (DRIVER_SAMPLE_CONFIGURATION));\r
265 ASSERT (Configuration != NULL);\r
266 if (HiiGetBrowserData (&mFormSetGuid, VariableName, sizeof (DRIVER_SAMPLE_CONFIGURATION), (UINT8 *) Configuration)) {\r
93e3992d 267 //\r
268 // Update password's clear text in the screen\r
269 //\r
84f9a9ec 270 CopyMem (Configuration->PasswordClearText, Password, StrSize (Password));\r
93e3992d 271\r
272 //\r
273 // Update uncommitted data of Browser\r
274 //\r
7e3bcccb
LG
275 HiiSetBrowserData (\r
276 &mFormSetGuid,\r
277 VariableName,\r
278 sizeof (DRIVER_SAMPLE_CONFIGURATION),\r
279 (UINT8 *) Configuration,\r
280 NULL\r
281 );\r
93e3992d 282 }\r
7e3bcccb 283\r
1d451ff9
LG
284 //\r
285 // Free Configuration Buffer\r
286 //\r
287 FreePool (Configuration);\r
288\r
93e3992d 289\r
290 //\r
291 // Set password\r
292 //\r
84f9a9ec 293 EncodePassword (Password, StrLen (Password) * 2);\r
93e3992d 294 Status = gRT->SetVariable(\r
295 VariableName,\r
296 &mFormSetGuid,\r
297 EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_BOOTSERVICE_ACCESS,\r
298 sizeof (DRIVER_SAMPLE_CONFIGURATION),\r
299 &PrivateData->Configuration\r
300 );\r
301 return Status;\r
302}\r
303\r
304\r
305/**\r
306 This function allows a caller to extract the current configuration for one\r
307 or more named elements from the target driver.\r
308\r
309 @param This Points to the EFI_HII_CONFIG_ACCESS_PROTOCOL.\r
310 @param Request A null-terminated Unicode string in\r
311 <ConfigRequest> format.\r
312 @param Progress On return, points to a character in the Request\r
313 string. Points to the string's null terminator if\r
314 request was successful. Points to the most recent\r
315 '&' before the first failing name/value pair (or\r
316 the beginning of the string if the failure is in\r
317 the first name/value pair) if the request was not\r
318 successful.\r
319 @param Results A null-terminated Unicode string in\r
320 <ConfigAltResp> format which has all values filled\r
321 in for the names in the Request string. String to\r
322 be allocated by the called function.\r
323\r
324 @retval EFI_SUCCESS The Results is filled with the requested values.\r
325 @retval EFI_OUT_OF_RESOURCES Not enough memory to store the results.\r
326 @retval EFI_INVALID_PARAMETER Request is NULL, illegal syntax, or unknown name.\r
327 @retval EFI_NOT_FOUND Routing data doesn't match any storage in this\r
328 driver.\r
329\r
330**/\r
331EFI_STATUS\r
332EFIAPI\r
333ExtractConfig (\r
334 IN CONST EFI_HII_CONFIG_ACCESS_PROTOCOL *This,\r
335 IN CONST EFI_STRING Request,\r
336 OUT EFI_STRING *Progress,\r
337 OUT EFI_STRING *Results\r
338 )\r
339{\r
340 EFI_STATUS Status;\r
341 UINTN BufferSize;\r
342 DRIVER_SAMPLE_PRIVATE_DATA *PrivateData;\r
343 EFI_HII_CONFIG_ROUTING_PROTOCOL *HiiConfigRouting;\r
84f9a9ec 344 EFI_STRING ConfigRequest;\r
086cd2c8 345 EFI_STRING ConfigRequestHdr;\r
84f9a9ec 346 UINTN Size;\r
a6973cff 347\r
086cd2c8 348 if (Progress == NULL || Results == NULL || Request == NULL) {\r
ae79d2f9
LG
349 return EFI_INVALID_PARAMETER;\r
350 }\r
84f9a9ec
LG
351 //\r
352 // Initialize the local variables.\r
353 //\r
086cd2c8
LG
354 ConfigRequestHdr = NULL;\r
355 ConfigRequest = NULL;\r
356 Size = 0;\r
357 *Progress = Request;\r
93e3992d 358\r
359 PrivateData = DRIVER_SAMPLE_PRIVATE_FROM_THIS (This);\r
360 HiiConfigRouting = PrivateData->HiiConfigRouting;\r
361\r
8d00a0f1 362 //\r
84f9a9ec
LG
363 // Get Buffer Storage data from EFI variable.\r
364 // Try to get the current setting from variable.\r
93e3992d 365 //\r
366 BufferSize = sizeof (DRIVER_SAMPLE_CONFIGURATION);\r
04da0b4a
LG
367 Status = gRT->GetVariable (\r
368 VariableName,\r
369 &mFormSetGuid,\r
370 NULL,\r
371 &BufferSize,\r
372 &PrivateData->Configuration\r
373 );\r
374 if (EFI_ERROR (Status)) {\r
de482998 375 return EFI_NOT_FOUND;\r
04da0b4a 376 }\r
a6973cff 377\r
8d00a0f1 378 if (Request == NULL) {\r
379 //\r
84f9a9ec 380 // Request is set to NULL, construct full request string.\r
7e3bcccb 381 //\r
84f9a9ec 382\r
84f9a9ec 383 //\r
a6973cff 384 // Allocate and fill a buffer large enough to hold the <ConfigHdr> template\r
84f9a9ec
LG
385 // followed by "&OFFSET=0&WIDTH=WWWWWWWWWWWWWWWW" followed by a Null-terminator\r
386 //\r
086cd2c8
LG
387 ConfigRequestHdr = HiiConstructConfigHdr (&mFormSetGuid, VariableName, PrivateData->DriverHandle[0]);\r
388 Size = (StrLen (ConfigRequest) + 32 + 1) * sizeof (CHAR16);\r
84f9a9ec 389 ConfigRequest = AllocateZeroPool (Size);\r
086cd2c8
LG
390 UnicodeSPrint (ConfigRequest, Size, L"%s&OFFSET=0&WIDTH=%016LX", ConfigRequestHdr, (UINT64)BufferSize);\r
391 FreePool (ConfigRequestHdr);\r
84f9a9ec 392 } else {\r
de482998
LG
393 //\r
394 // Check routing data in <ConfigHdr>.\r
395 // Note: if only one Storage is used, then this checking could be skipped.\r
396 //\r
397 if (!HiiIsConfigHdrMatch (Request, &mFormSetGuid, VariableName)) {\r
398 return EFI_NOT_FOUND;\r
84f9a9ec 399 }\r
de482998 400 ConfigRequest = Request;\r
8d00a0f1 401 }\r
402\r
93e3992d 403 //\r
404 // Convert buffer data to <ConfigResp> by helper function BlockToConfig()\r
405 //\r
406 Status = HiiConfigRouting->BlockToConfig (\r
407 HiiConfigRouting,\r
84f9a9ec 408 ConfigRequest,\r
93e3992d 409 (UINT8 *) &PrivateData->Configuration,\r
410 BufferSize,\r
411 Results,\r
412 Progress\r
413 );\r
a6973cff 414\r
84f9a9ec
LG
415 if (Request == NULL) {\r
416 FreePool (ConfigRequest);\r
1f1cb2f2 417 *Progress = NULL;\r
84f9a9ec
LG
418 }\r
419\r
93e3992d 420 return Status;\r
421}\r
422\r
423\r
424/**\r
425 This function processes the results of changes in configuration.\r
426\r
427 @param This Points to the EFI_HII_CONFIG_ACCESS_PROTOCOL.\r
428 @param Configuration A null-terminated Unicode string in <ConfigResp>\r
429 format.\r
430 @param Progress A pointer to a string filled in with the offset of\r
431 the most recent '&' before the first failing\r
432 name/value pair (or the beginning of the string if\r
433 the failure is in the first name/value pair) or\r
434 the terminating NULL if all was successful.\r
435\r
436 @retval EFI_SUCCESS The Results is processed successfully.\r
437 @retval EFI_INVALID_PARAMETER Configuration is NULL.\r
438 @retval EFI_NOT_FOUND Routing data doesn't match any storage in this\r
439 driver.\r
440\r
441**/\r
442EFI_STATUS\r
443EFIAPI\r
444RouteConfig (\r
445 IN CONST EFI_HII_CONFIG_ACCESS_PROTOCOL *This,\r
446 IN CONST EFI_STRING Configuration,\r
447 OUT EFI_STRING *Progress\r
448 )\r
449{\r
450 EFI_STATUS Status;\r
451 UINTN BufferSize;\r
452 DRIVER_SAMPLE_PRIVATE_DATA *PrivateData;\r
453 EFI_HII_CONFIG_ROUTING_PROTOCOL *HiiConfigRouting;\r
454\r
f5e9ff82 455 if (Configuration == NULL || Progress == NULL) {\r
8d00a0f1 456 return EFI_INVALID_PARAMETER;\r
457 }\r
458\r
93e3992d 459 PrivateData = DRIVER_SAMPLE_PRIVATE_FROM_THIS (This);\r
460 HiiConfigRouting = PrivateData->HiiConfigRouting;\r
f5e9ff82 461 *Progress = Configuration;\r
93e3992d 462\r
84f9a9ec 463 //\r
8d00a0f1 464 // Check routing data in <ConfigHdr>.\r
465 // Note: if only one Storage is used, then this checking could be skipped.\r
466 //\r
7e3bcccb 467 if (!HiiIsConfigHdrMatch (Configuration, &mFormSetGuid, VariableName)) {\r
8d00a0f1 468 return EFI_NOT_FOUND;\r
469 }\r
470\r
93e3992d 471 //\r
472 // Get Buffer Storage data from EFI variable\r
473 //\r
474 BufferSize = sizeof (DRIVER_SAMPLE_CONFIGURATION);\r
04da0b4a
LG
475 Status = gRT->GetVariable (\r
476 VariableName,\r
477 &mFormSetGuid,\r
478 NULL,\r
479 &BufferSize,\r
480 &PrivateData->Configuration\r
481 );\r
482 if (EFI_ERROR (Status)) {\r
483 return Status;\r
484 }\r
93e3992d 485\r
486 //\r
487 // Convert <ConfigResp> to buffer data by helper function ConfigToBlock()\r
488 //\r
489 BufferSize = sizeof (DRIVER_SAMPLE_CONFIGURATION);\r
490 Status = HiiConfigRouting->ConfigToBlock (\r
491 HiiConfigRouting,\r
492 Configuration,\r
493 (UINT8 *) &PrivateData->Configuration,\r
494 &BufferSize,\r
495 Progress\r
496 );\r
497 if (EFI_ERROR (Status)) {\r
498 return Status;\r
499 }\r
500\r
501 //\r
502 // Store Buffer Storage back to EFI variable\r
503 //\r
504 Status = gRT->SetVariable(\r
505 VariableName,\r
506 &mFormSetGuid,\r
507 EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_BOOTSERVICE_ACCESS,\r
508 sizeof (DRIVER_SAMPLE_CONFIGURATION),\r
509 &PrivateData->Configuration\r
510 );\r
511\r
512 return Status;\r
513}\r
514\r
515\r
516/**\r
517 This function processes the results of changes in configuration.\r
518\r
519 @param This Points to the EFI_HII_CONFIG_ACCESS_PROTOCOL.\r
520 @param Action Specifies the type of action taken by the browser.\r
521 @param QuestionId A unique value which is sent to the original\r
522 exporting driver so that it can identify the type\r
523 of data to expect.\r
524 @param Type The type of value for the question.\r
525 @param Value A pointer to the data being sent to the original\r
526 exporting driver.\r
527 @param ActionRequest On return, points to the action requested by the\r
528 callback function.\r
529\r
530 @retval EFI_SUCCESS The callback successfully handled the action.\r
531 @retval EFI_OUT_OF_RESOURCES Not enough storage is available to hold the\r
532 variable and its data.\r
533 @retval EFI_DEVICE_ERROR The variable could not be saved.\r
534 @retval EFI_UNSUPPORTED The specified Action is not supported by the\r
535 callback.\r
536\r
537**/\r
538EFI_STATUS\r
539EFIAPI\r
540DriverCallback (\r
541 IN CONST EFI_HII_CONFIG_ACCESS_PROTOCOL *This,\r
542 IN EFI_BROWSER_ACTION Action,\r
543 IN EFI_QUESTION_ID QuestionId,\r
544 IN UINT8 Type,\r
545 IN EFI_IFR_TYPE_VALUE *Value,\r
546 OUT EFI_BROWSER_ACTION_REQUEST *ActionRequest\r
547 )\r
548{\r
549 DRIVER_SAMPLE_PRIVATE_DATA *PrivateData;\r
550 EFI_STATUS Status;\r
8d00a0f1 551 UINT8 MyVar;\r
7e3bcccb
LG
552 VOID *StartOpCodeHandle;\r
553 VOID *OptionsOpCodeHandle;\r
554 EFI_IFR_GUID_LABEL *StartLabel;\r
555 VOID *EndOpCodeHandle;\r
556 EFI_IFR_GUID_LABEL *EndLabel;\r
a6973cff 557 EFI_INPUT_KEY Key;\r
558 DRIVER_SAMPLE_CONFIGURATION *Configuration;\r
16019c85 559 UINTN MyVarSize;\r
a6973cff 560\r
561 if (Action == EFI_BROWSER_ACTION_FORM_OPEN) {\r
562 //\r
563 // On FORM_OPEN event, update the form on-the-fly\r
564 //\r
565 PrivateData = DRIVER_SAMPLE_PRIVATE_FROM_THIS (This);\r
566\r
567 //\r
568 // Initialize the container for dynamic opcodes\r
569 //\r
570 StartOpCodeHandle = HiiAllocateOpCodeHandle ();\r
571 ASSERT (StartOpCodeHandle != NULL);\r
572\r
573 //\r
574 // Create Hii Extend Label OpCode as the start opcode\r
575 //\r
576 StartLabel = (EFI_IFR_GUID_LABEL *) HiiCreateGuidOpCode (StartOpCodeHandle, &gEfiIfrTianoGuid, NULL, sizeof (EFI_IFR_GUID_LABEL));\r
577 StartLabel->ExtendOpCode = EFI_IFR_EXTEND_OP_LABEL;\r
578 StartLabel->Number = LABEL_UPDATE2;\r
579\r
580 HiiCreateActionOpCode (\r
581 StartOpCodeHandle, // Container for dynamic created opcodes\r
582 0x1238, // Question ID\r
583 STRING_TOKEN(STR_SAVE_TEXT), // Prompt text\r
584 STRING_TOKEN(STR_SAVE_TEXT), // Help text\r
585 EFI_IFR_FLAG_CALLBACK, // Question flag\r
586 0 // Action String ID\r
587 );\r
588\r
589 HiiUpdateForm (\r
590 PrivateData->HiiHandle[0], // HII handle\r
591 &mFormSetGuid, // Formset GUID\r
592 0x3, // Form ID\r
593 StartOpCodeHandle, // Label for where to insert opcodes\r
594 NULL // Insert data\r
595 );\r
596\r
597 HiiFreeOpCodeHandle (StartOpCodeHandle);\r
598 return EFI_SUCCESS;\r
599 }\r
600\r
601 if (Action == EFI_BROWSER_ACTION_FORM_CLOSE) {\r
602 //\r
603 // On FORM_CLOSE event, show up a pop-up\r
604 //\r
605 do {\r
606 CreatePopUp (\r
607 EFI_LIGHTGRAY | EFI_BACKGROUND_BLUE,\r
608 &Key,\r
609 L"",\r
610 L"You are going to leave the Form!",\r
611 L"Press ESC or ENTER to continue ...",\r
612 L"",\r
613 NULL\r
614 );\r
615 } while ((Key.ScanCode != SCAN_ESC) && (Key.UnicodeChar != CHAR_CARRIAGE_RETURN));\r
616\r
617 return EFI_SUCCESS;\r
618 }\r
93e3992d 619\r
620 if ((Value == NULL) || (ActionRequest == NULL)) {\r
621 return EFI_INVALID_PARAMETER;\r
622 }\r
a6973cff 623\r
84f9a9ec
LG
624 if ((Type == EFI_IFR_TYPE_STRING) && (Value->string == 0)) {\r
625 return EFI_INVALID_PARAMETER;\r
626 }\r
a6973cff 627\r
93e3992d 628 Status = EFI_SUCCESS;\r
629 PrivateData = DRIVER_SAMPLE_PRIVATE_FROM_THIS (This);\r
630\r
631 switch (QuestionId) {\r
632 case 0x1234:\r
633 //\r
8d00a0f1 634 // Initialize the container for dynamic opcodes\r
93e3992d 635 //\r
7e3bcccb
LG
636 StartOpCodeHandle = HiiAllocateOpCodeHandle ();\r
637 ASSERT (StartOpCodeHandle != NULL);\r
638\r
639 EndOpCodeHandle = HiiAllocateOpCodeHandle ();\r
640 ASSERT (EndOpCodeHandle != NULL);\r
641\r
642 //\r
643 // Create Hii Extend Label OpCode as the start opcode\r
644 //\r
645 StartLabel = (EFI_IFR_GUID_LABEL *) HiiCreateGuidOpCode (StartOpCodeHandle, &gEfiIfrTianoGuid, NULL, sizeof (EFI_IFR_GUID_LABEL));\r
646 StartLabel->ExtendOpCode = EFI_IFR_EXTEND_OP_LABEL;\r
647 StartLabel->Number = LABEL_UPDATE1;\r
648\r
649 //\r
650 // Create Hii Extend Label OpCode as the end opcode\r
651 //\r
652 EndLabel = (EFI_IFR_GUID_LABEL *) HiiCreateGuidOpCode (EndOpCodeHandle, &gEfiIfrTianoGuid, NULL, sizeof (EFI_IFR_GUID_LABEL));\r
653 EndLabel->ExtendOpCode = EFI_IFR_EXTEND_OP_LABEL;\r
654 EndLabel->Number = LABEL_END;\r
655\r
656 HiiCreateActionOpCode (\r
657 StartOpCodeHandle, // Container for dynamic created opcodes\r
658 0x1237, // Question ID\r
659 STRING_TOKEN(STR_EXIT_TEXT), // Prompt text\r
660 STRING_TOKEN(STR_EXIT_TEXT), // Help text\r
661 EFI_IFR_FLAG_CALLBACK, // Question flag\r
662 0 // Action String ID\r
663 );\r
664\r
665 //\r
666 // Create Option OpCode\r
667 //\r
668 OptionsOpCodeHandle = HiiAllocateOpCodeHandle ();\r
669 ASSERT (OptionsOpCodeHandle != NULL);\r
670\r
671 HiiCreateOneOfOptionOpCode (\r
672 OptionsOpCodeHandle,\r
673 STRING_TOKEN (STR_BOOT_OPTION1),\r
674 0,\r
675 EFI_IFR_NUMERIC_SIZE_1,\r
676 1\r
677 );\r
678\r
679 HiiCreateOneOfOptionOpCode (\r
680 OptionsOpCodeHandle,\r
681 STRING_TOKEN (STR_BOOT_OPTION2),\r
682 0,\r
683 EFI_IFR_NUMERIC_SIZE_1,\r
684 2\r
685 );\r
686\r
687 //\r
688 // Prepare initial value for the dynamic created oneof Question\r
689 //\r
690 PrivateData->Configuration.DynamicOneof = 2;\r
691 Status = gRT->SetVariable(\r
692 VariableName,\r
693 &mFormSetGuid,\r
694 EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_BOOTSERVICE_ACCESS,\r
695 sizeof (DRIVER_SAMPLE_CONFIGURATION),\r
696 &PrivateData->Configuration\r
697 );\r
698\r
a6973cff 699 //\r
700 // Set initial vlaue of dynamic created oneof Question in Form Browser\r
701 //\r
702 Configuration = AllocateZeroPool (sizeof (DRIVER_SAMPLE_CONFIGURATION));\r
703 ASSERT (Configuration != NULL);\r
824e8a52 704 if (HiiGetBrowserData (&mFormSetGuid, VariableName, sizeof (DRIVER_SAMPLE_CONFIGURATION), (UINT8 *) Configuration)) {\r
a6973cff 705 Configuration->DynamicOneof = 2;\r
706\r
707 //\r
708 // Update uncommitted data of Browser\r
709 //\r
710 HiiSetBrowserData (\r
711 &mFormSetGuid,\r
712 VariableName,\r
713 sizeof (DRIVER_SAMPLE_CONFIGURATION),\r
714 (UINT8 *) Configuration,\r
715 NULL\r
716 );\r
717 }\r
718 FreePool (Configuration);\r
719\r
7e3bcccb
LG
720 HiiCreateOneOfOpCode (\r
721 StartOpCodeHandle, // Container for dynamic created opcodes\r
722 0x8001, // Question ID (or call it "key")\r
723 CONFIGURATION_VARSTORE_ID, // VarStore ID\r
724 (UINT16) DYNAMIC_ONE_OF_VAR_OFFSET, // Offset in Buffer Storage\r
725 STRING_TOKEN (STR_ONE_OF_PROMPT), // Question prompt text\r
726 STRING_TOKEN (STR_ONE_OF_HELP), // Question help text\r
727 EFI_IFR_FLAG_CALLBACK, // Question flag\r
728 EFI_IFR_NUMERIC_SIZE_1, // Data type of Question Value\r
729 OptionsOpCodeHandle, // Option Opcode list\r
730 NULL // Default Opcode is NULl\r
731 );\r
732\r
733 HiiCreateOrderedListOpCode (\r
734 StartOpCodeHandle, // Container for dynamic created opcodes\r
735 0x8002, // Question ID\r
736 CONFIGURATION_VARSTORE_ID, // VarStore ID\r
737 (UINT16) DYNAMIC_ORDERED_LIST_VAR_OFFSET, // Offset in Buffer Storage\r
738 STRING_TOKEN (STR_BOOT_OPTIONS), // Question prompt text\r
739 STRING_TOKEN (STR_BOOT_OPTIONS), // Question help text\r
740 EFI_IFR_FLAG_RESET_REQUIRED, // Question flag\r
741 0, // Ordered list flag, e.g. EFI_IFR_UNIQUE_SET\r
742 EFI_IFR_NUMERIC_SIZE_1, // Data type of Question value\r
743 5, // Maximum container\r
744 OptionsOpCodeHandle, // Option Opcode list\r
745 NULL // Default Opcode is NULl\r
746 );\r
747\r
748 HiiCreateGotoOpCode (\r
749 StartOpCodeHandle, // Container for dynamic created opcodes\r
750 1, // Target Form ID\r
751 STRING_TOKEN (STR_GOTO_FORM1), // Prompt text\r
752 STRING_TOKEN (STR_GOTO_HELP), // Help text\r
753 0, // Question flag\r
754 0x8003 // Question ID\r
755 );\r
756\r
757 HiiUpdateForm (\r
758 PrivateData->HiiHandle[0], // HII handle\r
759 &mFormSetGuid, // Formset GUID\r
760 0x1234, // Form ID\r
761 StartOpCodeHandle, // Label for where to insert opcodes\r
762 EndOpCodeHandle // Replace data\r
763 );\r
764\r
765 HiiFreeOpCodeHandle (StartOpCodeHandle);\r
766 HiiFreeOpCodeHandle (OptionsOpCodeHandle);\r
a6973cff 767 HiiFreeOpCodeHandle (EndOpCodeHandle);\r
7e3bcccb 768 break;\r
a6973cff 769\r
7e3bcccb
LG
770 case 0x5678:\r
771 //\r
772 // We will reach here once the Question is refreshed\r
773 //\r
774\r
775 //\r
776 // Initialize the container for dynamic opcodes\r
777 //\r
778 StartOpCodeHandle = HiiAllocateOpCodeHandle ();\r
779 ASSERT (StartOpCodeHandle != NULL);\r
780\r
781 //\r
782 // Create Hii Extend Label OpCode as the start opcode\r
783 //\r
784 StartLabel = (EFI_IFR_GUID_LABEL *) HiiCreateGuidOpCode (StartOpCodeHandle, &gEfiIfrTianoGuid, NULL, sizeof (EFI_IFR_GUID_LABEL));\r
785 StartLabel->ExtendOpCode = EFI_IFR_EXTEND_OP_LABEL;\r
786 StartLabel->Number = LABEL_UPDATE2;\r
787\r
788 HiiCreateActionOpCode (\r
789 StartOpCodeHandle, // Container for dynamic created opcodes\r
790 0x1237, // Question ID\r
791 STRING_TOKEN(STR_EXIT_TEXT), // Prompt text\r
792 STRING_TOKEN(STR_EXIT_TEXT), // Help text\r
793 EFI_IFR_FLAG_CALLBACK, // Question flag\r
794 0 // Action String ID\r
795 );\r
a6973cff 796\r
7e3bcccb
LG
797 HiiUpdateForm (\r
798 PrivateData->HiiHandle[0], // HII handle\r
799 &mFormSetGuid, // Formset GUID\r
800 0x3, // Form ID\r
801 StartOpCodeHandle, // Label for where to insert opcodes\r
802 NULL // Insert data\r
803 );\r
804\r
a6973cff 805 HiiFreeOpCodeHandle (StartOpCodeHandle);\r
806\r
7e3bcccb
LG
807 //\r
808 // Refresh the Question value\r
809 //\r
810 PrivateData->Configuration.DynamicRefresh++;\r
811 Status = gRT->SetVariable(\r
812 VariableName,\r
813 &mFormSetGuid,\r
814 EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_BOOTSERVICE_ACCESS,\r
815 sizeof (DRIVER_SAMPLE_CONFIGURATION),\r
816 &PrivateData->Configuration\r
817 );\r
a6973cff 818\r
7e3bcccb
LG
819 //\r
820 // Change an EFI Variable storage (MyEfiVar) asynchronous, this will cause\r
821 // the first statement in Form 3 be suppressed\r
822 //\r
16019c85 823 MyVarSize = 1;\r
7e3bcccb
LG
824 MyVar = 111;\r
825 Status = gRT->SetVariable(\r
826 L"MyVar",\r
827 &mFormSetGuid,\r
828 EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_BOOTSERVICE_ACCESS,\r
16019c85 829 MyVarSize,\r
7e3bcccb
LG
830 &MyVar\r
831 );\r
93e3992d 832 break;\r
833\r
834 case 0x1237:\r
835 //\r
836 // User press "Exit now", request Browser to exit\r
837 //\r
838 *ActionRequest = EFI_BROWSER_ACTION_REQUEST_EXIT;\r
839 break;\r
840\r
841 case 0x1238:\r
842 //\r
843 // User press "Save now", request Browser to save the uncommitted data.\r
844 //\r
845 *ActionRequest = EFI_BROWSER_ACTION_REQUEST_SUBMIT;\r
846 break;\r
847\r
848 case 0x2000:\r
849 //\r
850 // When try to set a new password, user will be chanlleged with old password.\r
851 // The Callback is responsible for validating old password input by user,\r
852 // If Callback return EFI_SUCCESS, it indicates validation pass.\r
853 //\r
854 switch (PrivateData->PasswordState) {\r
855 case BROWSER_STATE_VALIDATE_PASSWORD:\r
856 Status = ValidatePassword (PrivateData, Value->string);\r
857 if (Status == EFI_SUCCESS) {\r
858 PrivateData->PasswordState = BROWSER_STATE_SET_PASSWORD;\r
859 }\r
860 break;\r
861\r
862 case BROWSER_STATE_SET_PASSWORD:\r
863 Status = SetPassword (PrivateData, Value->string);\r
864 PrivateData->PasswordState = BROWSER_STATE_VALIDATE_PASSWORD;\r
865 break;\r
866\r
867 default:\r
868 break;\r
869 }\r
870\r
871 break;\r
872\r
16019c85
LG
873 case 0x1111:\r
874 //\r
875 // EfiVarstore question takes sample action (print value as debug information) \r
876 // after read/write question.\r
877 //\r
878 MyVarSize = 1;\r
879 Status = gRT->GetVariable(\r
880 L"MyVar",\r
881 &mFormSetGuid,\r
882 NULL,\r
883 &MyVarSize,\r
884 &MyVar\r
885 );\r
886 ASSERT_EFI_ERROR (Status);\r
887 DEBUG ((DEBUG_INFO, "EfiVarstore question: Tall value is %d with value width %d\n", MyVar, MyVarSize));\r
93e3992d 888 default:\r
889 break;\r
890 }\r
891\r
892 return Status;\r
893}\r
894\r
7064c0a5 895/**\r
896 Main entry for this driver.\r
a6973cff 897\r
7064c0a5 898 @param ImageHandle Image handle this driver.\r
899 @param SystemTable Pointer to SystemTable.\r
900\r
901 @retval EFI_SUCESS This function always complete successfully.\r
902\r
903**/\r
93e3992d 904EFI_STATUS\r
905EFIAPI\r
906DriverSampleInit (\r
907 IN EFI_HANDLE ImageHandle,\r
908 IN EFI_SYSTEM_TABLE *SystemTable\r
909 )\r
910{\r
911 EFI_STATUS Status;\r
93e3992d 912 EFI_HII_HANDLE HiiHandle[2];\r
93e3992d 913 EFI_SCREEN_DESCRIPTOR Screen;\r
914 EFI_HII_DATABASE_PROTOCOL *HiiDatabase;\r
915 EFI_HII_STRING_PROTOCOL *HiiString;\r
916 EFI_FORM_BROWSER2_PROTOCOL *FormBrowser2;\r
917 EFI_HII_CONFIG_ROUTING_PROTOCOL *HiiConfigRouting;\r
918 CHAR16 *NewString;\r
919 UINTN BufferSize;\r
920 DRIVER_SAMPLE_CONFIGURATION *Configuration;\r
84f9a9ec 921 BOOLEAN ActionFlag;\r
a6973cff 922 EFI_STRING ConfigRequestHdr;\r
923\r
93e3992d 924 //\r
84f9a9ec 925 // Initialize the local variables.\r
93e3992d 926 //\r
84f9a9ec 927 ConfigRequestHdr = NULL;\r
93e3992d 928 //\r
929 // Initialize screen dimensions for SendForm().\r
930 // Remove 3 characters from top and bottom\r
931 //\r
932 ZeroMem (&Screen, sizeof (EFI_SCREEN_DESCRIPTOR));\r
933 gST->ConOut->QueryMode (gST->ConOut, gST->ConOut->Mode->Mode, &Screen.RightColumn, &Screen.BottomRow);\r
934\r
935 Screen.TopRow = 3;\r
936 Screen.BottomRow = Screen.BottomRow - 3;\r
937\r
938 //\r
939 // Initialize driver private data\r
940 //\r
ccee6099 941 PrivateData = AllocateZeroPool (sizeof (DRIVER_SAMPLE_PRIVATE_DATA));\r
93e3992d 942 if (PrivateData == NULL) {\r
943 return EFI_OUT_OF_RESOURCES;\r
944 }\r
945\r
946 PrivateData->Signature = DRIVER_SAMPLE_PRIVATE_SIGNATURE;\r
947\r
948 PrivateData->ConfigAccess.ExtractConfig = ExtractConfig;\r
949 PrivateData->ConfigAccess.RouteConfig = RouteConfig;\r
950 PrivateData->ConfigAccess.Callback = DriverCallback;\r
951 PrivateData->PasswordState = BROWSER_STATE_VALIDATE_PASSWORD;\r
952\r
953 //\r
954 // Locate Hii Database protocol\r
955 //\r
956 Status = gBS->LocateProtocol (&gEfiHiiDatabaseProtocolGuid, NULL, (VOID **) &HiiDatabase);\r
957 if (EFI_ERROR (Status)) {\r
958 return Status;\r
959 }\r
960 PrivateData->HiiDatabase = HiiDatabase;\r
961\r
962 //\r
963 // Locate HiiString protocol\r
964 //\r
965 Status = gBS->LocateProtocol (&gEfiHiiStringProtocolGuid, NULL, (VOID **) &HiiString);\r
966 if (EFI_ERROR (Status)) {\r
967 return Status;\r
968 }\r
969 PrivateData->HiiString = HiiString;\r
970\r
971 //\r
972 // Locate Formbrowser2 protocol\r
973 //\r
974 Status = gBS->LocateProtocol (&gEfiFormBrowser2ProtocolGuid, NULL, (VOID **) &FormBrowser2);\r
975 if (EFI_ERROR (Status)) {\r
976 return Status;\r
977 }\r
978 PrivateData->FormBrowser2 = FormBrowser2;\r
979\r
980 //\r
981 // Locate ConfigRouting protocol\r
982 //\r
983 Status = gBS->LocateProtocol (&gEfiHiiConfigRoutingProtocolGuid, NULL, (VOID **) &HiiConfigRouting);\r
984 if (EFI_ERROR (Status)) {\r
985 return Status;\r
986 }\r
987 PrivateData->HiiConfigRouting = HiiConfigRouting;\r
988\r
f6f910dd 989 Status = gBS->InstallMultipleProtocolInterfaces (\r
93e3992d 990 &DriverHandle[0],\r
f6f910dd 991 &gEfiDevicePathProtocolGuid,\r
2f3065c0 992 &mHiiVendorDevicePath0,\r
93e3992d 993 &gEfiHiiConfigAccessProtocolGuid,\r
f6f910dd 994 &PrivateData->ConfigAccess,\r
995 NULL\r
93e3992d 996 );\r
997 ASSERT_EFI_ERROR (Status);\r
998\r
f6f910dd 999 PrivateData->DriverHandle[0] = DriverHandle[0];\r
1000\r
93e3992d 1001 //\r
1002 // Publish our HII data\r
1003 //\r
cb7d01c0 1004 HiiHandle[0] = HiiAddPackages (\r
1005 &mFormSetGuid,\r
1006 DriverHandle[0],\r
1007 DriverSampleStrings,\r
1008 VfrBin,\r
1009 NULL\r
1010 );\r
1011 if (HiiHandle[0] == NULL) {\r
93e3992d 1012 return EFI_OUT_OF_RESOURCES;\r
1013 }\r
1014\r
93e3992d 1015 PrivateData->HiiHandle[0] = HiiHandle[0];\r
1016\r
1017 //\r
1018 // Publish another Fromset\r
1019 //\r
f6f910dd 1020 Status = gBS->InstallMultipleProtocolInterfaces (\r
1021 &DriverHandle[1],\r
1022 &gEfiDevicePathProtocolGuid,\r
2f3065c0 1023 &mHiiVendorDevicePath1,\r
f6f910dd 1024 NULL\r
1025 );\r
1026 ASSERT_EFI_ERROR (Status);\r
1027\r
93e3992d 1028 PrivateData->DriverHandle[1] = DriverHandle[1];\r
1029\r
cb7d01c0 1030 HiiHandle[1] = HiiAddPackages (\r
1031 &mInventoryGuid,\r
1032 DriverHandle[1],\r
1033 DriverSampleStrings,\r
1034 InventoryBin,\r
1035 NULL\r
1036 );\r
1037 if (HiiHandle[1] == NULL) {\r
93e3992d 1038 return EFI_OUT_OF_RESOURCES;\r
1039 }\r
1040\r
93e3992d 1041 PrivateData->HiiHandle[1] = HiiHandle[1];\r
1042\r
1043 //\r
1044 // Very simple example of how one would update a string that is already\r
1045 // in the HII database\r
1046 //\r
1047 NewString = L"700 Mhz";\r
1048\r
cb7d01c0 1049 if (HiiSetString (HiiHandle[0], STRING_TOKEN (STR_CPU_STRING2), NewString, NULL) == 0) {\r
1050 return EFI_OUT_OF_RESOURCES;\r
93e3992d 1051 }\r
1052\r
1053 //\r
1054 // Initialize configuration data\r
1055 //\r
1056 Configuration = &PrivateData->Configuration;\r
1057 ZeroMem (Configuration, sizeof (DRIVER_SAMPLE_CONFIGURATION));\r
1058\r
1059 //\r
1060 // Try to read NV config EFI variable first\r
1061 //\r
84f9a9ec
LG
1062 ConfigRequestHdr = HiiConstructConfigHdr (&mFormSetGuid, VariableName, DriverHandle[0]);\r
1063 ASSERT (ConfigRequestHdr != NULL);\r
1064\r
93e3992d 1065 BufferSize = sizeof (DRIVER_SAMPLE_CONFIGURATION);\r
1066 Status = gRT->GetVariable (VariableName, &mFormSetGuid, NULL, &BufferSize, Configuration);\r
84f9a9ec 1067 if (EFI_ERROR (Status)) {\r
04da0b4a
LG
1068 //\r
1069 // Store zero data Buffer Storage to EFI variable\r
1070 //\r
1071 Status = gRT->SetVariable(\r
1072 VariableName,\r
1073 &mFormSetGuid,\r
1074 EFI_VARIABLE_NON_VOLATILE | EFI_VARIABLE_BOOTSERVICE_ACCESS,\r
1075 sizeof (DRIVER_SAMPLE_CONFIGURATION),\r
1076 Configuration\r
1077 );\r
1078 ASSERT (Status == EFI_SUCCESS);\r
93e3992d 1079 //\r
1080 // EFI variable for NV config doesn't exit, we should build this variable\r
1081 // based on default values stored in IFR\r
1082 //\r
84f9a9ec
LG
1083 ActionFlag = HiiSetToDefaults (ConfigRequestHdr, EFI_HII_DEFAULT_CLASS_STANDARD);\r
1084 ASSERT (ActionFlag);\r
1085 } else {\r
1086 //\r
1087 // EFI variable does exist and Validate Current Setting\r
1088 //\r
1089 ActionFlag = HiiValidateSettings (ConfigRequestHdr);\r
1090 ASSERT (ActionFlag);\r
93e3992d 1091 }\r
a6973cff 1092\r
84f9a9ec
LG
1093 FreePool (ConfigRequestHdr);\r
1094\r
93e3992d 1095\r
1096 //\r
a6973cff 1097 // In default, this driver is built into Flash device image,\r
7e3bcccb 1098 // the following code doesn't run.\r
93e3992d 1099 //\r
7e3bcccb 1100\r
2f3065c0 1101 //\r
7e3bcccb 1102 // Example of how to display only the item we sent to HII\r
a6973cff 1103 // When this driver is not built into Flash device image,\r
7e3bcccb 1104 // it need to call SendForm to show front page by itself.\r
2f3065c0 1105 //\r
7e3bcccb
LG
1106 if (DISPLAY_ONLY_MY_ITEM <= 1) {\r
1107 //\r
1108 // Have the browser pull out our copy of the data, and only display our data\r
1109 //\r
1110 Status = FormBrowser2->SendForm (\r
1111 FormBrowser2,\r
1112 &(HiiHandle[DISPLAY_ONLY_MY_ITEM]),\r
1113 1,\r
1114 NULL,\r
1115 0,\r
1116 NULL,\r
1117 NULL\r
1118 );\r
a6973cff 1119\r
14d59fa1 1120 HiiRemovePackages (HiiHandle[0]);\r
a6973cff 1121\r
14d59fa1 1122 HiiRemovePackages (HiiHandle[1]);\r
2f3065c0
LG
1123 }\r
1124\r
84f9a9ec 1125 return EFI_SUCCESS;\r
2f3065c0
LG
1126}\r
1127\r
1128/**\r
1129 Unloads the application and its installed protocol.\r
1130\r
1131 @param[in] ImageHandle Handle that identifies the image to be unloaded.\r
1132\r
1133 @retval EFI_SUCCESS The image has been unloaded.\r
1134**/\r
1135EFI_STATUS\r
1136EFIAPI\r
1137DriverSampleUnload (\r
1138 IN EFI_HANDLE ImageHandle\r
1139 )\r
1140{\r
1141 if (DriverHandle[0] != NULL) {\r
1142 gBS->UninstallMultipleProtocolInterfaces (\r
1143 DriverHandle[0],\r
1144 &gEfiDevicePathProtocolGuid,\r
1145 &mHiiVendorDevicePath0,\r
1146 &gEfiHiiConfigAccessProtocolGuid,\r
1147 &PrivateData->ConfigAccess,\r
1148 NULL\r
1149 );\r
ccee6099 1150 DriverHandle[0] = NULL;\r
2f3065c0
LG
1151 }\r
1152\r
1153 if (DriverHandle[1] != NULL) {\r
1154 gBS->UninstallMultipleProtocolInterfaces (\r
1155 DriverHandle[1],\r
1156 &gEfiDevicePathProtocolGuid,\r
1157 &mHiiVendorDevicePath1,\r
1158 NULL\r
1159 );\r
ccee6099 1160 DriverHandle[1] = NULL;\r
2f3065c0
LG
1161 }\r
1162\r
14d59fa1
LG
1163 if (PrivateData->HiiHandle[0] != NULL) {\r
1164 HiiRemovePackages (PrivateData->HiiHandle[0]);\r
1165 }\r
1166\r
1167 if (PrivateData->HiiHandle[1] != NULL) {\r
1168 HiiRemovePackages (PrivateData->HiiHandle[1]);\r
1169 }\r
1170\r
2f3065c0
LG
1171 if (PrivateData != NULL) {\r
1172 FreePool (PrivateData);\r
ccee6099 1173 PrivateData = NULL;\r
93e3992d 1174 }\r
1175\r
1176 return EFI_SUCCESS;\r
1177}\r