| /** @file | |
| Extension Form Browser Protocol provides the services that can be used to | |
| register the different hot keys for the standard Browser actions described in UEFI specification. | |
| Copyright (c) 2013 - 2014, Intel Corporation. All rights reserved.<BR> | |
| This program and the accompanying materials are licensed and made available under | |
| the terms and conditions of the BSD License that accompanies this distribution. | |
| The full text of the license may be found at | |
| http://opensource.org/licenses/bsd-license.php. | |
| THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | |
| WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | |
| **/ | |
| #ifndef __FORM_BROWSER_EXTENSION2_H__ | |
| #define __FORM_BROWSER_EXTENSION2_H__ | |
| #include <Protocol/FormBrowserEx.h> | |
| #define EDKII_FORM_BROWSER_EXTENSION2_PROTOCOL_GUID \ | |
| { 0xa770c357, 0xb693, 0x4e6d, { 0xa6, 0xcf, 0xd2, 0x1c, 0x72, 0x8e, 0x55, 0xb }} | |
| typedef struct _EDKII_FORM_BROWSER_EXTENSION2_PROTOCOL EDKII_FORM_BROWSER_EXTENSION2_PROTOCOL; | |
| #define BROWSER_EXTENSION2_VERSION_1 0x10000 | |
| #define BROWSER_EXTENSION2_VERSION_1_1 0x10001 | |
| /** | |
| Check whether the browser data has been modified. | |
| @retval TRUE Browser data is modified. | |
| @retval FALSE No browser data is modified. | |
| **/ | |
| typedef | |
| BOOLEAN | |
| (EFIAPI *IS_BROWSER_DATA_MODIFIED) ( | |
| VOID | |
| ); | |
| /** | |
| Execute the action requested by the Action parameter. | |
| @param[in] Action Execute the request action. | |
| @param[in] DefaultId The default Id info when need to load default value. | |
| @retval EFI_SUCCESS Execute the request action succss. | |
| **/ | |
| typedef | |
| EFI_STATUS | |
| (EFIAPI *EXECUTE_ACTION) ( | |
| IN UINT32 Action, | |
| IN UINT16 DefaultId | |
| ); | |
| /** | |
| Check whether required reset when exit the browser | |
| @retval TRUE Browser required to reset after exit. | |
| @retval FALSE Browser not need to reset after exit. | |
| **/ | |
| typedef | |
| BOOLEAN | |
| (EFIAPI *IS_RESET_REQUIRED) ( | |
| VOID | |
| ); | |
| #define FORM_ENTRY_INFO_SIGNATURE SIGNATURE_32 ('f', 'e', 'i', 's') | |
| typedef struct { | |
| UINTN Signature; | |
| LIST_ENTRY Link; | |
| EFI_HII_HANDLE HiiHandle; | |
| EFI_GUID FormSetGuid; | |
| EFI_FORM_ID FormId; | |
| EFI_QUESTION_ID QuestionId; | |
| } FORM_ENTRY_INFO; | |
| #define FORM_ENTRY_INFO_FROM_LINK(a) CR (a, FORM_ENTRY_INFO, Link, FORM_ENTRY_INFO_SIGNATURE) | |
| #define FORM_QUESTION_ATTRIBUTE_OVERRIDE_SIGNATURE SIGNATURE_32 ('f', 'q', 'o', 's') | |
| typedef struct { | |
| UINTN Signature; | |
| LIST_ENTRY Link; | |
| EFI_QUESTION_ID QuestionId; // Find the question | |
| EFI_FORM_ID FormId; // Find the form | |
| EFI_GUID FormSetGuid; // Find the formset. | |
| EFI_HII_HANDLE HiiHandle; // Find the HII handle | |
| UINT32 Attribute; // Hide or grayout ... | |
| } QUESTION_ATTRIBUTE_OVERRIDE; | |
| #define FORM_QUESTION_ATTRIBUTE_OVERRIDE_FROM_LINK(a) CR (a, QUESTION_ATTRIBUTE_OVERRIDE, Link, FORM_QUESTION_ATTRIBUTE_OVERRIDE_SIGNATURE) | |
| struct _EDKII_FORM_BROWSER_EXTENSION2_PROTOCOL { | |
| /// | |
| /// Version for protocol future extension. | |
| /// | |
| UINT32 Version; | |
| SET_SCOPE SetScope; | |
| REGISTER_HOT_KEY RegisterHotKey; | |
| REGISTER_EXIT_HANDLER RegiserExitHandler; | |
| IS_BROWSER_DATA_MODIFIED IsBrowserDataModified; | |
| EXECUTE_ACTION ExecuteAction; | |
| /// | |
| /// A list of type FORMID_INFO is Browser View Form History List. | |
| /// | |
| LIST_ENTRY FormViewHistoryHead; | |
| /// | |
| /// A list of type QUESTION_ATTRIBUTE_OVERRIDE. | |
| /// | |
| LIST_ENTRY OverrideQestListHead; | |
| IS_RESET_REQUIRED IsResetRequired; | |
| }; | |
| extern EFI_GUID gEdkiiFormBrowserEx2ProtocolGuid; | |
| #endif | |