Home | History | Annotate | Download | only in FrameworkHiiOnUefiHiiThunk
      1 /** @file
      2   Function and Macro defintions for IFR parsing. To get the default value from IFR package, the IFR
      3   opcode needs to be parsed. Most of code is taken from MdeModulePkg\Universal\SetupBrowserDxe\IfrParse.c.
      4   This parser is simplified from the origianl IfrParser.c in the following way:
      5 
      6   1) All data structure definition that have nothing to do with IFR Default value scanning (
      7      required to implement Framework HII's GetDefaultImage ()) is removed.
      8   2) Ignore the IFR opcode which is invalid for Form Package
      9      generated using Framework VFR file.
     10 
     11   Copyright (c) 2008 - 2010, Intel Corporation. All rights reserved.<BR>
     12   This program and the accompanying materials
     13   are licensed and made available under the terms and conditions of the BSD License
     14   which accompanies this distribution.  The full text of the license may be found at
     15   http://opensource.org/licenses/bsd-license.php
     16 
     17   THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
     18   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
     19 
     20 **/
     21 
     22 #ifndef _HII_THUNK_UEFI_IFR_PARSER_
     23 #define _HII_THUNK_UEFI_IFR_PARSER_
     24 
     25 
     26 //
     27 // IFR relative definition
     28 //
     29 #define EFI_HII_EXPRESSION_INCONSISTENT_IF   0
     30 #define EFI_HII_EXPRESSION_NO_SUBMIT_IF      1
     31 #define EFI_HII_EXPRESSION_GRAY_OUT_IF       2
     32 #define EFI_HII_EXPRESSION_SUPPRESS_IF       3
     33 #define EFI_HII_EXPRESSION_DISABLE_IF        4
     34 #define EFI_HII_EXPRESSION_VALUE             5
     35 #define EFI_HII_EXPRESSION_RULE              6
     36 
     37 #define EFI_HII_VARSTORE_BUFFER              0
     38 #define EFI_HII_VARSTORE_NAME_VALUE          1
     39 #define EFI_HII_VARSTORE_EFI_VARIABLE        2
     40 
     41 #define FORM_INCONSISTENT_VALIDATION         0
     42 #define FORM_NO_SUBMIT_VALIDATION            1
     43 
     44 extern EFI_GUID  gTianoHiiIfrGuid;
     45 
     46 #define ONE_OF_OPTION_MAP_ENTRY_FROM_LINK(Record) CR(Record, ONE_OF_OPTION_MAP_ENTRY, Link, ONE_OF_OPTION_MAP_ENTRY_SIGNATURE)
     47 #define ONE_OF_OPTION_MAP_ENTRY_SIGNATURE            SIGNATURE_32 ('O', 'O', 'M', 'E')
     48 typedef struct {
     49   UINT32              Signature;
     50   LIST_ENTRY          Link;
     51 
     52   UINT16              FwKey;
     53   EFI_IFR_TYPE_VALUE  Value;
     54 
     55 } ONE_OF_OPTION_MAP_ENTRY;
     56 
     57 
     58 
     59 #define ONE_OF_OPTION_MAP_FROM_LINK(Record) CR(Record, ONE_OF_OPTION_MAP, Link, ONE_OF_OPTION_MAP_SIGNATURE)
     60 #define ONE_OF_OPTION_MAP_SIGNATURE            SIGNATURE_32 ('O', 'O', 'O', 'M')
     61 typedef struct {
     62   UINT32            Signature;
     63   LIST_ENTRY        Link;
     64 
     65   UINT16            VarStoreId;
     66 
     67   UINT8             ValueType; //EFI_IFR_TYPE_NUM_*
     68 
     69   EFI_QUESTION_ID   QuestionId;
     70 
     71   LIST_ENTRY        OneOfOptionMapEntryListHead; //ONE_OF_OPTION_MAP_ENTRY
     72 } ONE_OF_OPTION_MAP;
     73 
     74 
     75 typedef struct {
     76   UINT8               Type;
     77   EFI_IFR_TYPE_VALUE  Value;
     78 } EFI_HII_VALUE;
     79 
     80 #define NAME_VALUE_NODE_SIGNATURE  SIGNATURE_32 ('N', 'V', 'S', 'T')
     81 
     82 #define FORMSET_STORAGE_SIGNATURE  SIGNATURE_32 ('F', 'S', 'T', 'G')
     83 
     84 typedef struct {
     85   UINTN            Signature;
     86   LIST_ENTRY       Link;
     87 
     88   UINT8            Type;           // Storage type
     89 
     90   UINT16           VarStoreId;
     91   EFI_GUID         Guid;
     92 
     93   CHAR16           *Name;          // For EFI_IFR_VARSTORE
     94   UINT16           Size;
     95 
     96   UINT32           Attributes;     // For EFI_IFR_VARSTORE_EFI: EFI Variable attribute
     97 
     98 } FORMSET_STORAGE;
     99 
    100 #define FORMSET_STORAGE_FROM_LINK(a)  CR (a, FORMSET_STORAGE, Link, FORMSET_STORAGE_SIGNATURE)
    101 
    102 #if 0
    103 
    104 #define EXPRESSION_OPCODE_SIGNATURE  SIGNATURE_32 ('E', 'X', 'O', 'P')
    105 
    106 typedef struct {
    107   UINTN             Signature;
    108   LIST_ENTRY        Link;
    109 
    110   UINT8             Operand;
    111 
    112   UINT8             Format;      // For EFI_IFR_TO_STRING, EFI_IFR_FIND
    113   UINT8             Flags;       // For EFI_IFR_SPAN
    114   UINT8             RuleId;      // For EFI_IFR_RULE_REF
    115 
    116   EFI_HII_VALUE     Value;       // For EFI_IFR_EQ_ID_VAL, EFI_IFR_UINT64, EFI_IFR_UINT32, EFI_IFR_UINT16, EFI_IFR_UINT8, EFI_IFR_STRING_REF1
    117 
    118   EFI_QUESTION_ID   QuestionId;  // For EFI_IFR_EQ_ID_ID, EFI_IFR_EQ_ID_VAL_LIST, EFI_IFR_QUESTION_REF1
    119   EFI_QUESTION_ID   QuestionId2;
    120 
    121   UINT16            ListLength;  // For EFI_IFR_EQ_ID_VAL_LIST
    122   UINT16            *ValueList;
    123 
    124   EFI_STRING_ID     DevicePath;  // For EFI_IFR_QUESTION_REF3_2, EFI_IFR_QUESTION_REF3_3
    125   EFI_GUID          Guid;
    126 } EXPRESSION_OPCODE;
    127 
    128 #define EXPRESSION_OPCODE_FROM_LINK(a)  CR (a, EXPRESSION_OPCODE, Link, EXPRESSION_OPCODE_SIGNATURE)
    129 
    130 #define FORM_EXPRESSION_SIGNATURE  SIGNATURE_32 ('F', 'E', 'X', 'P')
    131 
    132 typedef struct {
    133   UINTN             Signature;
    134   LIST_ENTRY        Link;
    135 
    136   UINT8             Type;            // Type for this expression
    137 
    138   UINT8             RuleId;          // For EFI_IFR_RULE only
    139   EFI_STRING_ID     Error;           // For EFI_IFR_NO_SUBMIT_IF, EFI_IFR_INCONSISTENT_IF only
    140 
    141   EFI_HII_VALUE     Result;          // Expression evaluation result
    142 
    143   LIST_ENTRY        OpCodeListHead;  // OpCodes consist of this expression (EXPRESSION_OPCODE)
    144 } FORM_EXPRESSION;
    145 
    146 #define FORM_EXPRESSION_FROM_LINK(a)  CR (a, FORM_EXPRESSION, Link, FORM_EXPRESSION_SIGNATURE)
    147 #endif
    148 
    149 #define QUESTION_DEFAULT_SIGNATURE  SIGNATURE_32 ('Q', 'D', 'F', 'T')
    150 
    151 typedef struct {
    152   UINTN               Signature;
    153   LIST_ENTRY          Link;
    154 
    155   UINT16              DefaultId;
    156   EFI_HII_VALUE       Value;              // Default value
    157 
    158 } QUESTION_DEFAULT;
    159 
    160 #define QUESTION_DEFAULT_FROM_LINK(a)  CR (a, QUESTION_DEFAULT, Link, QUESTION_DEFAULT_SIGNATURE)
    161 
    162 #define QUESTION_OPTION_SIGNATURE  SIGNATURE_32 ('Q', 'O', 'P', 'T')
    163 
    164 typedef struct {
    165   UINTN               Signature;
    166   LIST_ENTRY          Link;
    167 
    168   EFI_STRING_ID       Text;
    169   UINT8               Flags;
    170   EFI_HII_VALUE       Value;
    171   EFI_IMAGE_ID        ImageId;
    172 
    173 } QUESTION_OPTION;
    174 
    175 #define QUESTION_OPTION_FROM_LINK(a)  CR (a, QUESTION_OPTION, Link, QUESTION_OPTION_SIGNATURE)
    176 
    177 typedef union {
    178   EFI_STRING_ID       VarName;
    179   UINT16              VarOffset;
    180 } VAR_STORE_INFO;
    181 
    182 #define FORM_BROWSER_STATEMENT_SIGNATURE  SIGNATURE_32 ('F', 'S', 'T', 'A')
    183 typedef struct {
    184   UINTN                 Signature;
    185   LIST_ENTRY            Link;
    186 
    187   UINT8                 Operand;          // The operand (first byte) of this Statement or Question
    188 
    189   //
    190   // Statement Header
    191   //
    192   EFI_STRING_ID         Prompt;
    193   EFI_STRING_ID         Help;
    194   EFI_STRING_ID         TextTwo;          // For EFI_IFR_TEXT
    195 
    196   //
    197   // Question Header
    198   //
    199   EFI_QUESTION_ID       QuestionId;       // The value of zero is reserved
    200   EFI_VARSTORE_ID       VarStoreId;       // A value of zero indicates no variable storage
    201   FORMSET_STORAGE       *Storage;
    202   VAR_STORE_INFO        VarStoreInfo;
    203 
    204   UINT16                StorageWidth;
    205   UINT8                 QuestionFlags;
    206 
    207   EFI_HII_VALUE         HiiValue;         // Edit copy for checkbox, numberic, oneof
    208   UINT8                 *BufferValue;     // Edit copy for string, password, orderedlist
    209 
    210   //
    211   // OpCode specific members
    212   //
    213   UINT8                 Flags;            // for EFI_IFR_CHECKBOX, EFI_IFR_DATE, EFI_IFR_NUMERIC, EFI_IFR_ONE_OF,
    214                                           // EFI_IFR_ORDERED_LIST, EFI_IFR_STRING,EFI_IFR_SUBTITLE,EFI_IFR_TIME, EFI_IFR_BANNER
    215   UINT8                 MaxContainers;    // for EFI_IFR_ORDERED_LIST
    216 
    217   UINT16                BannerLineNumber; // for EFI_IFR_BANNER, 1-based line number
    218   EFI_STRING_ID         QuestionConfig;   // for EFI_IFR_ACTION, if 0 then no configuration string will be processed
    219 
    220   UINT64                Minimum;          // for EFI_IFR_ONE_OF/EFI_IFR_NUMERIC, it's Min/Max value
    221   UINT64                Maximum;          // for EFI_IFR_STRING/EFI_IFR_PASSWORD, it's Min/Max length
    222   UINT64                Step;
    223 
    224   EFI_DEFAULT_ID        DefaultId;        // for EFI_IFR_RESET_BUTTON
    225   EFI_FORM_ID           RefFormId;        // for EFI_IFR_REF
    226   EFI_QUESTION_ID       RefQuestionId;    // for EFI_IFR_REF2
    227   EFI_GUID              RefFormSetId;     // for EFI_IFR_REF3
    228   EFI_STRING_ID         RefDevicePath;    // for EFI_IFR_REF4
    229 
    230   //
    231   // Get from IFR parsing
    232   //
    233   LIST_ENTRY            DefaultListHead;     // nested EFI_IFR_DEFAULT list (QUESTION_DEFAULT), provide default values
    234   LIST_ENTRY            OptionListHead;      // nested EFI_IFR_ONE_OF_OPTION list (QUESTION_OPTION)
    235 
    236   EFI_IMAGE_ID          ImageId;             // nested EFI_IFR_IMAGE
    237   UINT8                 RefreshInterval;     // nested EFI_IFR_REFRESH, refresh interval(in seconds) for Question value, 0 means no refresh
    238   BOOLEAN               InSubtitle;          // nesting inside of EFI_IFR_SUBTITLE
    239 
    240 } FORM_BROWSER_STATEMENT;
    241 
    242 #define FORM_BROWSER_STATEMENT_FROM_LINK(a)  CR (a, FORM_BROWSER_STATEMENT, Link, FORM_BROWSER_STATEMENT_SIGNATURE)
    243 
    244 #define FORM_BROWSER_FORM_SIGNATURE  SIGNATURE_32 ('F', 'F', 'R', 'M')
    245 
    246 typedef struct {
    247   UINTN             Signature;
    248   LIST_ENTRY        Link;
    249 
    250   UINT16            FormId;
    251   EFI_STRING_ID     FormTitle;
    252 
    253   EFI_IMAGE_ID      ImageId;
    254 
    255 #if 0
    256   LIST_ENTRY        ExpressionListHead;   // List of Expressions (FORM_EXPRESSION)
    257 #endif
    258   LIST_ENTRY        StatementListHead;    // List of Statements and Questions (FORM_BROWSER_STATEMENT)
    259 } FORM_BROWSER_FORM;
    260 
    261 #define FORM_BROWSER_FORM_FROM_LINK(a)  CR (a, FORM_BROWSER_FORM, Link, FORM_BROWSER_FORM_SIGNATURE)
    262 
    263 #define FORMSET_DEFAULTSTORE_SIGNATURE  SIGNATURE_32 ('F', 'D', 'F', 'S')
    264 
    265 typedef struct {
    266   UINTN            Signature;
    267   LIST_ENTRY       Link;
    268 
    269   UINT16           DefaultId;
    270   EFI_STRING_ID    DefaultName;
    271 } FORMSET_DEFAULTSTORE;
    272 
    273 #define FORMSET_DEFAULTSTORE_FROM_LINK(a)  CR (a, FORMSET_DEFAULTSTORE, Link, FORMSET_DEFAULTSTORE_SIGNATURE)
    274 
    275 typedef struct {
    276   EFI_HII_HANDLE                  HiiHandle;
    277 
    278   UINTN                           IfrBinaryLength;
    279   UINT8                           *IfrBinaryData;
    280 
    281   EFI_GUID                        Guid;
    282   EFI_STRING_ID                   FormSetTitle;
    283   EFI_STRING_ID                   Help;
    284   UINT16                          Class;
    285   UINT16                          SubClass;
    286   EFI_IMAGE_ID                    ImageId;
    287 
    288   FORM_BROWSER_STATEMENT          *StatementBuffer;     // Buffer for all Statements and Questions
    289 #if 0
    290   EXPRESSION_OPCODE               *ExpressionBuffer;    // Buffer for all Expression OpCode
    291 #endif
    292 
    293   LIST_ENTRY                      StorageListHead;      // Storage list (FORMSET_STORAGE)
    294   LIST_ENTRY                      DefaultStoreListHead; // DefaultStore list (FORMSET_DEFAULTSTORE)
    295   LIST_ENTRY                      FormListHead;         // Form list (FORM_BROWSER_FORM)
    296 
    297   LIST_ENTRY                      OneOfOptionMapListHead; //ONE_OF_OPTION_MAP
    298 
    299   UINT16                          MaxQuestionId;
    300 
    301   //
    302   // Added for Framework HII Thunk.
    303   // Default Variable Storage built from a Framework VFR file using UEFI VFR Compiler in Compatibility mode is determined
    304   // by priority rules defined in GetFormsetDefaultVarstoreId (). See the function description for details.
    305   //
    306   EFI_VARSTORE_ID                 DefaultVarStoreId;
    307   CHAR16                          *OriginalDefaultVarStoreName;
    308 
    309   UINTN                           NumberOfStatement;
    310 
    311 } FORM_BROWSER_FORMSET;
    312 
    313 
    314 /**
    315   Parse opcodes in the formset IFR binary.
    316 
    317   @param  FormSet                Pointer of the FormSet data structure.
    318 
    319   @retval EFI_SUCCESS            Opcode parse success.
    320   @retval Other                  Opcode parse fail.
    321 
    322 **/
    323 EFI_STATUS
    324 ParseOpCodes (
    325   IN FORM_BROWSER_FORMSET              *FormSet
    326   );
    327 
    328 /**
    329   Free resources allocated for a FormSet
    330 
    331   @param  FormSet                Pointer of the FormSet
    332 
    333   @return None.
    334 
    335 **/
    336 VOID
    337 DestroyFormSet (
    338   IN OUT FORM_BROWSER_FORMSET  *FormSet
    339   );
    340 
    341 #endif
    342 
    343