2 Dynamically update the pages.
4 Copyright (c) 2004 - 2016, Intel Corporation. All rights reserved.<BR>
5 This program and the accompanying materials
6 are licensed and made available under the terms and conditions of the BSD License
7 which accompanies this distribution. The full text of the license may be found at
8 http://opensource.org/licenses/bsd-license.php
10 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
11 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
15 #include "BootMaintenanceManager.h"
18 Create the global UpdateData structure.
27 // Init OpCode Handle and Allocate space for creation of Buffer
29 mStartOpCodeHandle
= HiiAllocateOpCodeHandle ();
30 ASSERT (mStartOpCodeHandle
!= NULL
);
32 mEndOpCodeHandle
= HiiAllocateOpCodeHandle ();
33 ASSERT (mEndOpCodeHandle
!= NULL
);
36 // Create Hii Extend Label OpCode as the start opcode
38 mStartLabel
= (EFI_IFR_GUID_LABEL
*) HiiCreateGuidOpCode (mStartOpCodeHandle
, &gEfiIfrTianoGuid
, NULL
, sizeof (EFI_IFR_GUID_LABEL
));
39 mStartLabel
->ExtendOpCode
= EFI_IFR_EXTEND_OP_LABEL
;
42 // Create Hii Extend Label OpCode as the end opcode
44 mEndLabel
= (EFI_IFR_GUID_LABEL
*) HiiCreateGuidOpCode (mEndOpCodeHandle
, &gEfiIfrTianoGuid
, NULL
, sizeof (EFI_IFR_GUID_LABEL
));
45 mEndLabel
->ExtendOpCode
= EFI_IFR_EXTEND_OP_LABEL
;
46 mEndLabel
->Number
= LABEL_END
;
50 Refresh the global UpdateData structure.
59 // Free current updated date
61 if (mStartOpCodeHandle
!= NULL
) {
62 HiiFreeOpCodeHandle (mStartOpCodeHandle
);
66 // Create new OpCode Handle
68 mStartOpCodeHandle
= HiiAllocateOpCodeHandle ();
71 // Create Hii Extend Label OpCode as the start opcode
73 mStartLabel
= (EFI_IFR_GUID_LABEL
*) HiiCreateGuidOpCode (mStartOpCodeHandle
, &gEfiIfrTianoGuid
, NULL
, sizeof (EFI_IFR_GUID_LABEL
));
74 mStartLabel
->ExtendOpCode
= EFI_IFR_EXTEND_OP_LABEL
;
79 Add a "Go back to main page" tag in front of the form when there are no
80 "Apply changes" and "Discard changes" tags in the end of the form.
82 @param CallbackData The BMM context data.
87 IN BMM_CALLBACK_DATA
*CallbackData
91 mStartLabel
->Number
= CallbackData
->BmmCurrentPageId
;
93 if (!(CallbackData
->BmmAskSaveOrNot
)) {
95 // Add a "Go back to main page" tag in front of the form when there are no
96 // "Apply changes" and "Discard changes" tags in the end of the form.
101 STRING_TOKEN (STR_FORM_GOTO_MAIN
),
102 STRING_TOKEN (STR_FORM_GOTO_MAIN
),
110 Create the "Apply changes" and "Discard changes" tags. And
111 ensure user can return to the main page.
113 @param CallbackData The BMM context data.
118 IN BMM_CALLBACK_DATA
*CallbackData
122 // Create the "Apply changes" and "Discard changes" tags.
124 if (CallbackData
->BmmAskSaveOrNot
) {
125 HiiCreateSubTitleOpCode (
127 STRING_TOKEN (STR_NULL_STRING
),
133 HiiCreateActionOpCode (
135 KEY_VALUE_SAVE_AND_EXIT
,
136 STRING_TOKEN (STR_SAVE_AND_EXIT
),
137 STRING_TOKEN (STR_NULL_STRING
),
138 EFI_IFR_FLAG_CALLBACK
,
144 // Ensure user can return to the main page.
146 HiiCreateActionOpCode (
148 KEY_VALUE_NO_SAVE_AND_EXIT
,
149 STRING_TOKEN (STR_NO_SAVE_AND_EXIT
),
150 STRING_TOKEN (STR_NULL_STRING
),
151 EFI_IFR_FLAG_CALLBACK
,
156 CallbackData
->BmmHiiHandle
,
158 CallbackData
->BmmCurrentPageId
,
159 mStartOpCodeHandle
, // Label CallbackData->BmmCurrentPageId
160 mEndOpCodeHandle
// LABEL_END
165 Clean up the dynamic opcode at label and form specified by both LabelId.
167 @param LabelId It is both the Form ID and Label ID for opcode deletion.
168 @param CallbackData The BMM context data.
174 IN BMM_CALLBACK_DATA
*CallbackData
177 RefreshUpdateData ();
180 // Remove all op-codes from dynamic page
182 mStartLabel
->Number
= LabelId
;
184 CallbackData
->BmmHiiHandle
,
187 mStartOpCodeHandle
, // Label LabelId
188 mEndOpCodeHandle
// LABEL_END
193 Create a list of Goto Opcode for all terminal devices logged
194 by TerminaMenu. This list will be inserted to form FORM_CON_COM_SETUP_ID.
196 @param CallbackData The BMM context data.
200 IN BMM_CALLBACK_DATA
*CallbackData
203 BM_MENU_ENTRY
*NewMenuEntry
;
206 CallbackData
->BmmAskSaveOrNot
= TRUE
;
208 UpdatePageStart (CallbackData
);
210 for (Index
= 0; Index
< TerminalMenu
.MenuNumber
; Index
++) {
211 NewMenuEntry
= BOpt_GetMenuEntry (&TerminalMenu
, Index
);
213 HiiCreateGotoOpCode (
215 FORM_CON_COM_SETUP_ID
,
216 NewMenuEntry
->DisplayStringToken
,
217 STRING_TOKEN (STR_NULL_STRING
),
218 EFI_IFR_FLAG_CALLBACK
,
219 (UINT16
) (TERMINAL_OPTION_OFFSET
+ Index
)
223 UpdatePageEnd (CallbackData
);
228 Create a list of boot option from global BootOptionMenu. It
229 allow user to delete the boot option.
231 @param CallbackData The BMM context data.
236 IN BMM_CALLBACK_DATA
*CallbackData
239 BM_MENU_ENTRY
*NewMenuEntry
;
240 BM_LOAD_CONTEXT
*NewLoadContext
;
243 CallbackData
->BmmAskSaveOrNot
= TRUE
;
245 UpdatePageStart (CallbackData
);
247 ASSERT (BootOptionMenu
.MenuNumber
<= (sizeof (CallbackData
->BmmFakeNvData
.BootOptionDel
) / sizeof (CallbackData
->BmmFakeNvData
.BootOptionDel
[0])));
248 for (Index
= 0; Index
< BootOptionMenu
.MenuNumber
; Index
++) {
249 NewMenuEntry
= BOpt_GetMenuEntry (&BootOptionMenu
, Index
);
250 NewLoadContext
= (BM_LOAD_CONTEXT
*) NewMenuEntry
->VariableContext
;
251 if (NewLoadContext
->IsLegacy
) {
255 NewLoadContext
->Deleted
= FALSE
;
257 if (CallbackData
->BmmFakeNvData
.BootOptionDel
[Index
] && !CallbackData
->BmmFakeNvData
.BootOptionDelMark
[Index
]) {
259 // CallbackData->BmmFakeNvData.BootOptionDel[Index] == TRUE means browser knows this boot option is selected
260 // CallbackData->BmmFakeNvData.BootOptionDelMark[Index] = FALSE means BDS knows the selected boot option has
261 // deleted, browser maintains old useless info. So clear this info here, and later update this info to browser
262 // through HiiSetBrowserData function.
264 CallbackData
->BmmFakeNvData
.BootOptionDel
[Index
] = FALSE
;
267 HiiCreateCheckBoxOpCode (
269 (EFI_QUESTION_ID
) (BOOT_OPTION_DEL_QUESTION_ID
+ Index
),
270 VARSTORE_ID_BOOT_MAINT
,
271 (UINT16
) (BOOT_OPTION_DEL_VAR_OFFSET
+ Index
),
272 NewMenuEntry
->DisplayStringToken
,
273 NewMenuEntry
->HelpStringToken
,
274 EFI_IFR_FLAG_CALLBACK
,
279 UpdatePageEnd (CallbackData
);
283 Create a lit of driver option from global DriverMenu.
285 @param CallbackData The BMM context data.
289 UpdateDrvAddHandlePage (
290 IN BMM_CALLBACK_DATA
*CallbackData
293 BM_MENU_ENTRY
*NewMenuEntry
;
296 CallbackData
->BmmAskSaveOrNot
= FALSE
;
298 UpdatePageStart (CallbackData
);
300 for (Index
= 0; Index
< DriverMenu
.MenuNumber
; Index
++) {
301 NewMenuEntry
= BOpt_GetMenuEntry (&DriverMenu
, Index
);
303 HiiCreateGotoOpCode (
305 FORM_DRV_ADD_HANDLE_DESC_ID
,
306 NewMenuEntry
->DisplayStringToken
,
307 STRING_TOKEN (STR_NULL_STRING
),
308 EFI_IFR_FLAG_CALLBACK
,
309 (UINT16
) (HANDLE_OPTION_OFFSET
+ Index
)
313 UpdatePageEnd (CallbackData
);
317 Create a lit of driver option from global DriverOptionMenu. It
318 allow user to delete the driver option.
320 @param CallbackData The BMM context data.
325 IN BMM_CALLBACK_DATA
*CallbackData
328 BM_MENU_ENTRY
*NewMenuEntry
;
329 BM_LOAD_CONTEXT
*NewLoadContext
;
332 CallbackData
->BmmAskSaveOrNot
= TRUE
;
334 UpdatePageStart (CallbackData
);
336 ASSERT (DriverOptionMenu
.MenuNumber
<= (sizeof (CallbackData
->BmmFakeNvData
.DriverOptionDel
) / sizeof (CallbackData
->BmmFakeNvData
.DriverOptionDel
[0])));
337 for (Index
= 0; Index
< DriverOptionMenu
.MenuNumber
; Index
++) {
338 NewMenuEntry
= BOpt_GetMenuEntry (&DriverOptionMenu
, Index
);
340 NewLoadContext
= (BM_LOAD_CONTEXT
*) NewMenuEntry
->VariableContext
;
341 NewLoadContext
->Deleted
= FALSE
;
343 if (CallbackData
->BmmFakeNvData
.DriverOptionDel
[Index
] && !CallbackData
->BmmFakeNvData
.DriverOptionDelMark
[Index
]) {
345 // CallbackData->BmmFakeNvData.BootOptionDel[Index] == TRUE means browser knows this boot option is selected
346 // CallbackData->BmmFakeNvData.BootOptionDelMark[Index] = FALSE means BDS knows the selected boot option has
347 // deleted, browser maintains old useless info. So clear this info here, and later update this info to browser
348 // through HiiSetBrowserData function.
350 CallbackData
->BmmFakeNvData
.DriverOptionDel
[Index
] = FALSE
;
352 HiiCreateCheckBoxOpCode (
354 (EFI_QUESTION_ID
) (DRIVER_OPTION_DEL_QUESTION_ID
+ Index
),
355 VARSTORE_ID_BOOT_MAINT
,
356 (UINT16
) (DRIVER_OPTION_DEL_VAR_OFFSET
+ Index
),
357 NewMenuEntry
->DisplayStringToken
,
358 NewMenuEntry
->HelpStringToken
,
359 EFI_IFR_FLAG_CALLBACK
,
365 UpdatePageEnd (CallbackData
);
369 Prepare the page to allow user to add description for
372 @param CallbackData The BMM context data.
376 UpdateDriverAddHandleDescPage (
377 IN BMM_CALLBACK_DATA
*CallbackData
380 BM_MENU_ENTRY
*NewMenuEntry
;
382 CallbackData
->BmmFakeNvData
.DriverAddActive
= 0x01;
383 CallbackData
->BmmFakeNvData
.DriverAddForceReconnect
= 0x00;
384 CallbackData
->BmmAskSaveOrNot
= TRUE
;
385 NewMenuEntry
= CallbackData
->MenuEntry
;
387 UpdatePageStart (CallbackData
);
389 HiiCreateSubTitleOpCode (
391 NewMenuEntry
->DisplayStringToken
,
397 HiiCreateStringOpCode (
399 (EFI_QUESTION_ID
) DRV_ADD_HANDLE_DESC_QUESTION_ID
,
400 VARSTORE_ID_BOOT_MAINT
,
401 DRV_ADD_HANDLE_DESC_VAR_OFFSET
,
402 STRING_TOKEN (STR_LOAD_OPTION_DESC
),
403 STRING_TOKEN (STR_NULL_STRING
),
411 HiiCreateCheckBoxOpCode (
413 (EFI_QUESTION_ID
) DRV_ADD_RECON_QUESTION_ID
,
414 VARSTORE_ID_BOOT_MAINT
,
415 DRV_ADD_RECON_VAR_OFFSET
,
416 STRING_TOKEN (STR_LOAD_OPTION_FORCE_RECON
),
417 STRING_TOKEN (STR_LOAD_OPTION_FORCE_RECON
),
423 HiiCreateStringOpCode (
425 (EFI_QUESTION_ID
) DRIVER_ADD_OPTION_QUESTION_ID
,
426 VARSTORE_ID_BOOT_MAINT
,
427 DRIVER_ADD_OPTION_VAR_OFFSET
,
428 STRING_TOKEN (STR_OPTIONAL_DATA
),
429 STRING_TOKEN (STR_NULL_STRING
),
437 UpdatePageEnd (CallbackData
);
443 @param UpdatePageId The form ID to be updated.
444 @param ConsoleMenu The console menu list.
445 @param CallbackData The BMM context data.
450 IN UINT16 UpdatePageId
,
451 IN BM_MENU_OPTION
*ConsoleMenu
,
452 IN BMM_CALLBACK_DATA
*CallbackData
455 BM_MENU_ENTRY
*NewMenuEntry
;
456 BM_CONSOLE_CONTEXT
*NewConsoleContext
;
457 BM_TERMINAL_CONTEXT
*NewTerminalContext
;
462 UINT8
*OldConsoleCheck
;
463 UINTN ConsoleCheckSize
;
464 EFI_QUESTION_ID QuestionIdBase
;
465 UINT16 VariableOffsetBase
;
467 CallbackData
->BmmAskSaveOrNot
= TRUE
;
469 UpdatePageStart (CallbackData
);
472 OldConsoleCheck
= NULL
;
474 VariableOffsetBase
= 0;
475 ConsoleCheckSize
= 0;
477 switch (UpdatePageId
) {
479 ConsoleCheck
= &CallbackData
->BmmFakeNvData
.ConsoleInCheck
[0];
480 OldConsoleCheck
= &CallbackData
->BmmOldFakeNVData
.ConsoleInCheck
[0];
481 ConsoleCheckSize
= sizeof (CallbackData
->BmmFakeNvData
.ConsoleInCheck
);
482 QuestionIdBase
= CON_IN_DEVICE_QUESTION_ID
;
483 VariableOffsetBase
= CON_IN_DEVICE_VAR_OFFSET
;
486 case FORM_CON_OUT_ID
:
487 ConsoleCheck
= &CallbackData
->BmmFakeNvData
.ConsoleOutCheck
[0];
488 OldConsoleCheck
= &CallbackData
->BmmOldFakeNVData
.ConsoleOutCheck
[0];
489 ConsoleCheckSize
= sizeof (CallbackData
->BmmFakeNvData
.ConsoleOutCheck
);
490 QuestionIdBase
= CON_OUT_DEVICE_QUESTION_ID
;
491 VariableOffsetBase
= CON_OUT_DEVICE_VAR_OFFSET
;
494 case FORM_CON_ERR_ID
:
495 ConsoleCheck
= &CallbackData
->BmmFakeNvData
.ConsoleErrCheck
[0];
496 OldConsoleCheck
= &CallbackData
->BmmOldFakeNVData
.ConsoleErrCheck
[0];
497 ConsoleCheckSize
= sizeof (CallbackData
->BmmFakeNvData
.ConsoleErrCheck
);
498 QuestionIdBase
= CON_ERR_DEVICE_QUESTION_ID
;
499 VariableOffsetBase
= CON_ERR_DEVICE_VAR_OFFSET
;
502 ASSERT (ConsoleCheck
!= NULL
);
504 for (Index
= 0; ((Index
< ConsoleMenu
->MenuNumber
) && \
505 (Index
< MAX_MENU_NUMBER
)) ; Index
++) {
507 NewMenuEntry
= BOpt_GetMenuEntry (ConsoleMenu
, Index
);
508 NewConsoleContext
= (BM_CONSOLE_CONTEXT
*) NewMenuEntry
->VariableContext
;
509 if (NewConsoleContext
->IsActive
) {
510 CheckFlags
|= EFI_IFR_CHECKBOX_DEFAULT
;
511 ConsoleCheck
[Index
] = TRUE
;
513 ConsoleCheck
[Index
] = FALSE
;
515 HiiCreateCheckBoxOpCode (
517 (EFI_QUESTION_ID
) (QuestionIdBase
+ Index
),
518 VARSTORE_ID_BOOT_MAINT
,
519 (UINT16
) (VariableOffsetBase
+ Index
),
520 NewMenuEntry
->DisplayStringToken
,
521 NewMenuEntry
->HelpStringToken
,
522 EFI_IFR_FLAG_CALLBACK
,
528 for (Index2
= 0; ((Index2
< TerminalMenu
.MenuNumber
) && \
529 (Index2
< MAX_MENU_NUMBER
)); Index2
++) {
531 NewMenuEntry
= BOpt_GetMenuEntry (&TerminalMenu
, Index2
);
532 NewTerminalContext
= (BM_TERMINAL_CONTEXT
*) NewMenuEntry
->VariableContext
;
534 ASSERT (Index
< MAX_MENU_NUMBER
);
535 if (((NewTerminalContext
->IsConIn
!= 0) && (UpdatePageId
== FORM_CON_IN_ID
)) ||
536 ((NewTerminalContext
->IsConOut
!= 0) && (UpdatePageId
== FORM_CON_OUT_ID
)) ||
537 ((NewTerminalContext
->IsStdErr
!= 0) && (UpdatePageId
== FORM_CON_ERR_ID
))
539 CheckFlags
|= EFI_IFR_CHECKBOX_DEFAULT
;
540 ConsoleCheck
[Index
] = TRUE
;
542 ConsoleCheck
[Index
] = FALSE
;
544 HiiCreateCheckBoxOpCode (
546 (EFI_QUESTION_ID
) (QuestionIdBase
+ Index
),
547 VARSTORE_ID_BOOT_MAINT
,
548 (UINT16
) (VariableOffsetBase
+ Index
),
549 NewMenuEntry
->DisplayStringToken
,
550 NewMenuEntry
->HelpStringToken
,
551 EFI_IFR_FLAG_CALLBACK
,
559 CopyMem (OldConsoleCheck
, ConsoleCheck
, ConsoleCheckSize
);
561 UpdatePageEnd (CallbackData
);
565 Update the page's NV Map if user has changed the order
566 a list. This list can be Boot Order or Driver Order.
568 @param UpdatePageId The form ID to be updated.
569 @param OptionMenu The new list.
570 @param CallbackData The BMM context data.
575 IN UINT16 UpdatePageId
,
576 IN BM_MENU_OPTION
*OptionMenu
,
577 IN BMM_CALLBACK_DATA
*CallbackData
580 BM_MENU_ENTRY
*NewMenuEntry
;
583 VOID
*OptionsOpCodeHandle
;
584 BOOLEAN BootOptionFound
;
586 EFI_QUESTION_ID QuestionId
;
589 CallbackData
->BmmAskSaveOrNot
= TRUE
;
590 UpdatePageStart (CallbackData
);
595 switch (UpdatePageId
) {
597 case FORM_BOOT_CHG_ID
:
598 GetBootOrder (CallbackData
);
599 OptionOrder
= CallbackData
->BmmFakeNvData
.BootOptionOrder
;
600 QuestionId
= BOOT_OPTION_ORDER_QUESTION_ID
;
601 VarOffset
= BOOT_OPTION_ORDER_VAR_OFFSET
;
604 case FORM_DRV_CHG_ID
:
605 GetDriverOrder (CallbackData
);
606 OptionOrder
= CallbackData
->BmmFakeNvData
.DriverOptionOrder
;
607 QuestionId
= DRIVER_OPTION_ORDER_QUESTION_ID
;
608 VarOffset
= DRIVER_OPTION_ORDER_VAR_OFFSET
;
611 ASSERT (OptionOrder
!= NULL
);
613 OptionsOpCodeHandle
= HiiAllocateOpCodeHandle ();
614 ASSERT (OptionsOpCodeHandle
!= NULL
);
617 for (OptionIndex
= 0; (OptionOrder
[OptionIndex
] != 0 && OptionIndex
< MAX_MENU_NUMBER
); OptionIndex
++) {
618 BootOptionFound
= FALSE
;
619 for (Index
= 0; Index
< OptionMenu
->MenuNumber
; Index
++) {
620 NewMenuEntry
= BOpt_GetMenuEntry (OptionMenu
, Index
);
621 if ((UINT32
) (NewMenuEntry
->OptionNumber
+ 1) == OptionOrder
[OptionIndex
]) {
622 BootOptionFound
= TRUE
;
626 if (BootOptionFound
) {
627 HiiCreateOneOfOptionOpCode (
629 NewMenuEntry
->DisplayStringToken
,
631 EFI_IFR_TYPE_NUM_SIZE_32
,
632 OptionOrder
[OptionIndex
]
637 if (OptionMenu
->MenuNumber
> 0) {
638 HiiCreateOrderedListOpCode (
639 mStartOpCodeHandle
, // Container for dynamic created opcodes
640 QuestionId
, // Question ID
641 VARSTORE_ID_BOOT_MAINT
, // VarStore ID
642 VarOffset
, // Offset in Buffer Storage
643 STRING_TOKEN (STR_CHANGE_ORDER
), // Question prompt text
644 STRING_TOKEN (STR_CHANGE_ORDER
), // Question help text
646 0, // Ordered list flag, e.g. EFI_IFR_UNIQUE_SET
647 EFI_IFR_TYPE_NUM_SIZE_32
, // Data type of Question value
648 100, // Maximum container
649 OptionsOpCodeHandle
, // Option Opcode list
650 NULL
// Default Opcode is NULL
654 HiiFreeOpCodeHandle (OptionsOpCodeHandle
);
656 UpdatePageEnd (CallbackData
);
661 Refresh the text mode page.
663 @param CallbackData The BMM context data.
668 IN BMM_CALLBACK_DATA
*CallbackData
675 CHAR16 ModeString
[50];
679 EFI_STRING_ID
*ModeToken
;
681 VOID
*OptionsOpCodeHandle
;
682 EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL
*ConOut
;
684 ConOut
= gST
->ConOut
;
687 MaxMode
= (UINTN
) (ConOut
->Mode
->MaxMode
);
689 CallbackData
->BmmAskSaveOrNot
= TRUE
;
691 UpdatePageStart (CallbackData
);
696 for (Mode
= 0; Mode
< MaxMode
; Mode
++) {
697 Status
= ConOut
->QueryMode (ConOut
, Mode
, &Col
, &Row
);
698 if (EFI_ERROR (Status
)) {
704 if (ValidMode
== 0) {
708 OptionsOpCodeHandle
= HiiAllocateOpCodeHandle ();
709 ASSERT (OptionsOpCodeHandle
!= NULL
);
711 ModeToken
= AllocateZeroPool (sizeof (EFI_STRING_ID
) * ValidMode
);
712 ASSERT(ModeToken
!= NULL
);
715 // Determin which mode should be the first entry in menu
717 GetConsoleOutMode (CallbackData
);
720 // Build text mode options
722 for (Mode
= 0; Mode
< MaxMode
; Mode
++) {
723 Status
= ConOut
->QueryMode (ConOut
, Mode
, &Col
, &Row
);
724 if (EFI_ERROR (Status
)) {
729 // Build mode string Column x Row
731 UnicodeValueToString (ModeString
, 0, Col
, 0);
732 PStr
= &ModeString
[0];
733 StrnCatS (PStr
, sizeof (ModeString
) / sizeof (ModeString
[0]), L
" x ", StrLen(L
" x ") + 1);
734 PStr
= PStr
+ StrLen (PStr
);
735 UnicodeValueToString (PStr
, 0, Row
, 0);
737 ModeToken
[Index
] = HiiSetString (CallbackData
->BmmHiiHandle
, 0, ModeString
, NULL
);
739 if (Mode
== CallbackData
->BmmFakeNvData
.ConsoleOutMode
) {
740 HiiCreateOneOfOptionOpCode (
743 EFI_IFR_OPTION_DEFAULT
,
744 EFI_IFR_TYPE_NUM_SIZE_16
,
748 HiiCreateOneOfOptionOpCode (
752 EFI_IFR_TYPE_NUM_SIZE_16
,
759 HiiCreateOneOfOpCode (
761 (EFI_QUESTION_ID
) CON_MODE_QUESTION_ID
,
762 VARSTORE_ID_BOOT_MAINT
,
764 STRING_TOKEN (STR_CON_MODE_SETUP
),
765 STRING_TOKEN (STR_CON_MODE_SETUP
),
766 EFI_IFR_FLAG_RESET_REQUIRED
,
767 EFI_IFR_NUMERIC_SIZE_2
,
772 HiiFreeOpCodeHandle (OptionsOpCodeHandle
);
773 FreePool (ModeToken
);
775 UpdatePageEnd (CallbackData
);
779 Create the dynamic page which allows user to set the property such as Baud Rate, Data Bits,
780 Parity, Stop Bits, Terminal Type.
782 @param CallbackData The BMM context data.
787 IN BMM_CALLBACK_DATA
*CallbackData
792 BM_MENU_ENTRY
*NewMenuEntry
;
793 VOID
*OptionsOpCodeHandle
;
794 UINTN CurrentTerminal
;
796 CallbackData
->BmmAskSaveOrNot
= TRUE
;
798 UpdatePageStart (CallbackData
);
800 CurrentTerminal
= CallbackData
->CurrentTerminal
;
801 NewMenuEntry
= BOpt_GetMenuEntry (
806 if (NewMenuEntry
== NULL
) {
810 OptionsOpCodeHandle
= HiiAllocateOpCodeHandle ();
811 ASSERT (OptionsOpCodeHandle
!= NULL
);
813 for (Index
= 0; Index
< sizeof (BaudRateList
) / sizeof (BaudRateList
[0]); Index
++) {
815 if (BaudRateList
[Index
].Value
== 115200) {
816 CheckFlags
|= EFI_IFR_OPTION_DEFAULT
;
818 HiiCreateOneOfOptionOpCode (
820 BaudRateList
[Index
].StringToken
,
822 EFI_IFR_TYPE_NUM_SIZE_8
,
827 HiiCreateOneOfOpCode (
829 (EFI_QUESTION_ID
) (COM_BAUD_RATE_QUESTION_ID
+ CurrentTerminal
),
830 VARSTORE_ID_BOOT_MAINT
,
831 (UINT16
) (COM_BAUD_RATE_VAR_OFFSET
+ CurrentTerminal
),
832 STRING_TOKEN (STR_COM_BAUD_RATE
),
833 STRING_TOKEN (STR_COM_BAUD_RATE
),
834 EFI_IFR_FLAG_CALLBACK
,
835 EFI_IFR_NUMERIC_SIZE_1
,
840 HiiFreeOpCodeHandle (OptionsOpCodeHandle
);
841 OptionsOpCodeHandle
= HiiAllocateOpCodeHandle ();
842 ASSERT (OptionsOpCodeHandle
!= NULL
);
844 for (Index
= 0; Index
< sizeof (DataBitsList
) / sizeof (DataBitsList
[0]); Index
++) {
847 if (DataBitsList
[Index
].Value
== 8) {
848 CheckFlags
|= EFI_IFR_OPTION_DEFAULT
;
851 HiiCreateOneOfOptionOpCode (
853 DataBitsList
[Index
].StringToken
,
855 EFI_IFR_TYPE_NUM_SIZE_8
,
860 HiiCreateOneOfOpCode (
862 (EFI_QUESTION_ID
) (COM_DATA_RATE_QUESTION_ID
+ CurrentTerminal
),
863 VARSTORE_ID_BOOT_MAINT
,
864 (UINT16
) (COM_DATA_RATE_VAR_OFFSET
+ CurrentTerminal
),
865 STRING_TOKEN (STR_COM_DATA_BITS
),
866 STRING_TOKEN (STR_COM_DATA_BITS
),
867 EFI_IFR_FLAG_CALLBACK
,
868 EFI_IFR_NUMERIC_SIZE_1
,
873 HiiFreeOpCodeHandle (OptionsOpCodeHandle
);
874 OptionsOpCodeHandle
= HiiAllocateOpCodeHandle ();
875 ASSERT (OptionsOpCodeHandle
!= NULL
);
877 for (Index
= 0; Index
< sizeof (ParityList
) / sizeof (ParityList
[0]); Index
++) {
879 if (ParityList
[Index
].Value
== NoParity
) {
880 CheckFlags
|= EFI_IFR_OPTION_DEFAULT
;
883 HiiCreateOneOfOptionOpCode (
885 ParityList
[Index
].StringToken
,
887 EFI_IFR_TYPE_NUM_SIZE_8
,
892 HiiCreateOneOfOpCode (
894 (EFI_QUESTION_ID
) (COM_PARITY_QUESTION_ID
+ CurrentTerminal
),
895 VARSTORE_ID_BOOT_MAINT
,
896 (UINT16
) (COM_PARITY_VAR_OFFSET
+ CurrentTerminal
),
897 STRING_TOKEN (STR_COM_PARITY
),
898 STRING_TOKEN (STR_COM_PARITY
),
899 EFI_IFR_FLAG_CALLBACK
,
900 EFI_IFR_NUMERIC_SIZE_1
,
905 HiiFreeOpCodeHandle (OptionsOpCodeHandle
);
906 OptionsOpCodeHandle
= HiiAllocateOpCodeHandle ();
907 ASSERT (OptionsOpCodeHandle
!= NULL
);
909 for (Index
= 0; Index
< sizeof (StopBitsList
) / sizeof (StopBitsList
[0]); Index
++) {
911 if (StopBitsList
[Index
].Value
== OneStopBit
) {
912 CheckFlags
|= EFI_IFR_OPTION_DEFAULT
;
915 HiiCreateOneOfOptionOpCode (
917 StopBitsList
[Index
].StringToken
,
919 EFI_IFR_TYPE_NUM_SIZE_8
,
924 HiiCreateOneOfOpCode (
926 (EFI_QUESTION_ID
) (COM_STOP_BITS_QUESTION_ID
+ CurrentTerminal
),
927 VARSTORE_ID_BOOT_MAINT
,
928 (UINT16
) (COM_STOP_BITS_VAR_OFFSET
+ CurrentTerminal
),
929 STRING_TOKEN (STR_COM_STOP_BITS
),
930 STRING_TOKEN (STR_COM_STOP_BITS
),
931 EFI_IFR_FLAG_CALLBACK
,
932 EFI_IFR_NUMERIC_SIZE_1
,
937 HiiFreeOpCodeHandle (OptionsOpCodeHandle
);
938 OptionsOpCodeHandle
= HiiAllocateOpCodeHandle ();
939 ASSERT (OptionsOpCodeHandle
!= NULL
);
941 for (Index
= 0; Index
< sizeof (TerminalType
) / sizeof (TerminalType
[0]); Index
++) {
944 CheckFlags
|= EFI_IFR_OPTION_DEFAULT
;
947 HiiCreateOneOfOptionOpCode (
949 (EFI_STRING_ID
) TerminalType
[Index
],
951 EFI_IFR_TYPE_NUM_SIZE_8
,
956 HiiCreateOneOfOpCode (
958 (EFI_QUESTION_ID
) (COM_TERMINAL_QUESTION_ID
+ CurrentTerminal
),
959 VARSTORE_ID_BOOT_MAINT
,
960 (UINT16
) (COM_TERMINAL_VAR_OFFSET
+ CurrentTerminal
),
961 STRING_TOKEN (STR_COM_TERMI_TYPE
),
962 STRING_TOKEN (STR_COM_TERMI_TYPE
),
963 EFI_IFR_FLAG_CALLBACK
,
964 EFI_IFR_NUMERIC_SIZE_1
,
969 HiiFreeOpCodeHandle (OptionsOpCodeHandle
);
970 OptionsOpCodeHandle
= HiiAllocateOpCodeHandle ();
971 ASSERT (OptionsOpCodeHandle
!= NULL
);
973 for (Index
= 0; Index
< sizeof (mFlowControlType
) / sizeof (mFlowControlType
[0]); Index
++) {
976 CheckFlags
|= EFI_IFR_OPTION_DEFAULT
;
978 HiiCreateOneOfOptionOpCode (
980 (EFI_STRING_ID
) mFlowControlType
[Index
],
982 EFI_IFR_TYPE_NUM_SIZE_8
,
983 mFlowControlValue
[Index
]
987 HiiCreateOneOfOpCode (
989 (EFI_QUESTION_ID
) (COM_FLOWCONTROL_QUESTION_ID
+ CurrentTerminal
),
990 VARSTORE_ID_BOOT_MAINT
,
991 (UINT16
) (COM_FLOWCONTROL_VAR_OFFSET
+ CurrentTerminal
),
992 STRING_TOKEN (STR_COM_FLOW_CONTROL
),
993 STRING_TOKEN (STR_COM_FLOW_CONTROL
),
994 EFI_IFR_FLAG_CALLBACK
,
995 EFI_IFR_NUMERIC_SIZE_1
,
1000 HiiFreeOpCodeHandle (OptionsOpCodeHandle
);
1002 UpdatePageEnd (CallbackData
);
1006 Update add boot/driver option page.
1008 @param CallbackData The BMM context data.
1009 @param FormId The form ID to be updated.
1010 @param DevicePath Device path.
1015 IN BMM_CALLBACK_DATA
*CallbackData
,
1016 IN EFI_FORM_ID FormId
,
1017 IN EFI_DEVICE_PATH_PROTOCOL
*DevicePath
1021 EFI_STRING_ID StringToken
;
1025 if (DevicePath
!= NULL
){
1026 String
= ExtractFileNameFromDevicePath(DevicePath
);
1028 if (String
== NULL
) {
1029 String
= HiiGetString (CallbackData
->BmmHiiHandle
, STRING_TOKEN (STR_NULL_STRING
), NULL
);
1030 ASSERT (String
!= NULL
);
1033 StringToken
= HiiSetString (CallbackData
->BmmHiiHandle
, 0, String
, NULL
);
1036 if(FormId
== FORM_BOOT_ADD_ID
){
1037 if (!CallbackData
->BmmFakeNvData
.BootOptionChanged
) {
1038 ZeroMem (CallbackData
->BmmFakeNvData
.BootOptionalData
, sizeof (CallbackData
->BmmFakeNvData
.BootOptionalData
));
1039 ZeroMem (CallbackData
->BmmFakeNvData
.BootDescriptionData
, sizeof (CallbackData
->BmmFakeNvData
.BootDescriptionData
));
1041 } else if (FormId
== FORM_DRV_ADD_FILE_ID
){
1042 if (!CallbackData
->BmmFakeNvData
.DriverOptionChanged
) {
1043 ZeroMem (CallbackData
->BmmFakeNvData
.DriverOptionalData
, sizeof (CallbackData
->BmmFakeNvData
.DriverOptionalData
));
1044 ZeroMem (CallbackData
->BmmFakeNvData
.DriverDescriptionData
, sizeof (CallbackData
->BmmFakeNvData
.DriverDescriptionData
));
1048 RefreshUpdateData();
1049 mStartLabel
->Number
= FormId
;
1051 HiiCreateSubTitleOpCode (
1060 CallbackData
->BmmHiiHandle
,
1063 mStartOpCodeHandle
,// Label FormId
1064 mEndOpCodeHandle
// LABEL_END
1069 Dispatch the correct update page function to call based on
1072 @param UpdatePageId The form ID.
1073 @param CallbackData The BMM context data.
1078 IN UINT16 UpdatePageId
,
1079 IN BMM_CALLBACK_DATA
*CallbackData
1082 CleanUpPage (UpdatePageId
, CallbackData
);
1083 switch (UpdatePageId
) {
1084 case FORM_CON_IN_ID
:
1085 UpdateConsolePage (UpdatePageId
, &ConsoleInpMenu
, CallbackData
);
1088 case FORM_CON_OUT_ID
:
1089 UpdateConsolePage (UpdatePageId
, &ConsoleOutMenu
, CallbackData
);
1092 case FORM_CON_ERR_ID
:
1093 UpdateConsolePage (UpdatePageId
, &ConsoleErrMenu
, CallbackData
);
1096 case FORM_BOOT_CHG_ID
:
1097 UpdateOrderPage (UpdatePageId
, &BootOptionMenu
, CallbackData
);
1100 case FORM_DRV_CHG_ID
:
1101 UpdateOrderPage (UpdatePageId
, &DriverOptionMenu
, CallbackData
);
1110 Dispatch the display to the next page based on NewPageId.
1112 @param Private The BMM context data.
1113 @param NewPageId The original page ID.
1118 BMM_CALLBACK_DATA
*Private
,
1122 if ((NewPageId
< FILE_OPTION_OFFSET
) && (NewPageId
>= HANDLE_OPTION_OFFSET
)) {
1124 // If we select a handle to add driver option, advance to the add handle description page.
1126 NewPageId
= FORM_DRV_ADD_HANDLE_DESC_ID
;
1127 } else if ((NewPageId
== KEY_VALUE_SAVE_AND_EXIT
) || (NewPageId
== KEY_VALUE_NO_SAVE_AND_EXIT
)) {
1129 // Return to main page after "Save Changes" or "Discard Changes".
1131 NewPageId
= FORM_MAIN_ID
;
1132 } else if ((NewPageId
>= TERMINAL_OPTION_OFFSET
) && (NewPageId
< CONSOLE_OPTION_OFFSET
)) {
1133 NewPageId
= FORM_CON_COM_SETUP_ID
;
1136 if ((NewPageId
> 0) && (NewPageId
< MAXIMUM_FORM_ID
)) {
1137 Private
->BmmPreviousPageId
= Private
->BmmCurrentPageId
;
1138 Private
->BmmCurrentPageId
= NewPageId
;