1#Name 2**GenCfgOpt.py** The python script that generates UPD text (**.txt**) files for 3the compiler, header files for the UPD regions, and generates a Boot Settings 4File (**BSF**), all from an EDK II Platform Description (**DSC**) file. 5 6#Synopsis 7``` 8GenCfgOpt UPDTXT PlatformDscFile BuildFvDir [TxtOutFile] [-D Macros] 9GenCfgOpt HEADER PlatformDscFile BuildFvDir [InputHFile] [-D Macros] 10GenCfgOpt GENBSF PlatformDscFile BuildFvDir BsfOutFile [-D Macros] 11``` 12 13#Description 14**GenCfgOpt.py** is a script that generates configuration options from an 15**EDK II Platform Description (DSC)** file. It has three functions. 16 17 1. It produces a **.txt** file that is used by the compiler that summarizes 18 the UPD section in the DSC file. 19 2. It generates header files for the UPD regions. 20 3. It generates a **Boot Settings File (BSF)** that can be used by the 21 **Binary Configuration Tool (BCT)** to provide a graphical user 22 interface for manipulating settings in the UPD regions. 23 24The **GenCfgOpt.py** script generates important files that are vital parts of 25your build process. The **UPDTXT** and **HEADER** use cases must be done before 26the **'build'** command; the **GENBSF** use case may be done at any time. 27 28The following sections explain the three use cases. 29 30## 1. GenCfgOpt.py UPDTXT 31The **UPDTXT** option creates a text file with all the UPD entries, offsets, 32size in bytes, and values. **GenCfgOpt** reads this information from the 33**[PcdsDynamicVpd.Upd]** section of the project's DSC file. The DSC file allows 34you to specify offsets and sizes for each entry, opening up the possibility of 35introducing gaps between entries. **GenCfgOpt** fills in these gaps with UPD 36entries that have the generic names **UnusedUpdSpaceN** where N begins with 0 37and increments. The command signature for **UPDTXT** is: 38 39``` 40GenCfgOpt UPDTXT PlatformDscFile BuildFvDir [TxtOutFile] [-D Macros] 41``` 42 43**PlatformDscFile** must be the location of the DSC file for the platform you're 44building. **BuildFvDir** is the location where the binary will be stored. The 45optional **TxtOutFile** is a name and location for the output of **GenCfgOpt**. 46The default name and location is the ```<UPD_TOOL_GUID>.txt``` in the directory 47specified by **BuildFvDir**. The macro ```UPD_TOOL_GUID``` must be defined in 48the DSC file or in the optional Macros arguments. Each optional macro argument 49must follow the form ```?D <MACRO_NAME>=<VALUE>```. 50 51**GenCfgOpt** checks to see if the UPD txt file has already been created and 52will only re-create it if the DSC was modified after it was created. 53 54## 2. GenCfgOpt.py HEADER 55The **HEADER** option creates header files in the build folder. Both header 56files define the ```_UPD_DATA_REGION``` data structures in FspUpd.h, FsptUpd.h, 57FspmUpd.h and FspsUpd.h. In these header files any undefined elements of 58structures will be added as **ReservedUpdSpaceN** beginning with N=0. The 59command signature for **HEADER** is 60 61```GenCfgOpt HEADER PlatformDscFile BuildFvDir [InputHFile] [-D Macros]``` 62 63**PlatformDscFile** and **BuildFvDir** are described in the previous section. 64The optional **InputHFile** is a header file that may contain data definitions 65that are used by variables in the UPD regions. This header file must contain 66the special keywords ```!EXPORT EXTERNAL_BOOTLOADER_STRUCT_BEGIN``` and 67```!EXPORT EXTERNAL_BOOTLOADER_STRUCT_END``` in comments. Everything between 68these two keywords will be included in the generated header file. 69The mechanism to specify whether a variable appears as **ReservedUpdSpaceN** in 70the FspUpd.h header file is in special commands that appear in the comments of 71the DSC file. The special commands begin with ```!HDR```, for header. The 72following table summarizes the two command options. 73 74### HEADER 75Use the **HEADER** command to hide specific variables in the public header file. 76In your project DSC file, use ```!HDR HEADER:{OFF}``` at the beginning of the 77section you wish to hide and ```!HDR HEADER:{ON}``` at the end. 78 79### STRUCT 80The **STRUCT** command allows you to specify a specific data type for a 81variable. You can specify a pointer to a data struct, for example. You define 82the data structure in the **InputHFile** between 83```!EXPORT EXTERNAL_BOOTLOADER_STRUCT_BEGIN``` and 84```!EXPORT EXTERNAL_BOOTLOADER_STRUCT_END```. 85 86#####Example: 87```!HDR STRUCT:{MY_DATA_STRUCT*}``` 88 89You then define ```MY_DATA_STRUCT``` in **InputHFile**. 90 91### EMBED 92The **EMBED** command allows you to put one or more UPD data into a specify data 93structure. You can utilize it as a group of UPD for example. You must specify a 94start and an end for the specify data structure. 95 96#####Example: 97``` 98 !HDR EMBED:{MY_DATA_STRUCT:MyDataStructure:START} 99 gTokenSpaceGuid.Upd1 | 0x0020 | 0x01 | 0x00 100 gTokenSpaceGuid.Upd2 | 0x0021 | 0x01 | 0x00 101 !HDR EMBED:{MY_DATA_STRUCT:MyDataStructure:END} 102 gTokenSpaceGuid.UpdN | 0x0022 | 0x01 | 0x00 103``` 104 105#####Result: 106``` 107 typedef struct { 108 /** Offset 0x0020 109 **/ 110 UINT8 Upd1; 111 /** Offset 0x0021 112 **/ 113 UINT8 Upd2; 114 /** Offset 0x0022 115 **/ 116 UINT8 UpdN; 117 } MY_DATA_STRUCT; 118 119 typedef struct _UPD_DATA_REGION { 120 ... 121 /** Offset 0x0020 122 **/ 123 MY_DATA_STRUCT MyDataStruct; 124 ... 125 } UPD_DATA_REGION; 126``` 127 128## 3. GenCfgOpt .py GENBSF 129The **GENBSF** option generates a BSF from the UPD entries in a package's DSC 130file. It does this by parsing special commands found in the comments of the DSC 131file. They roughly match the keywords that define the different sections of the 132BSF. 133 134The command signature for **GENBSF** is 135 136```GenCfgOpt GENBSF PlatformDscFile BuildFvDir BsfOutFile [-D Macros]``` 137 138In this case, the **BsfOutFile** parameter is required; it should be the 139relative path to where the BSF should be stored. 140 141Every BSF command in the DSC file begins with **!BSF** or **@Bsf**. The 142following table summarizes the options that come after **!BSF** or **@Bsf**: 143 144# BSF Commands Description 145###PAGES 146**PAGES** maps abbreviations to friendly-text descriptions of the pages in a BSF. 147 148#####Example: 149```!BSF PAGES:{PG1:?Page 1?, PG2:?Page 2?}``` or 150 151```@Bsf PAGES:{PG1:?Page 1?, PG2:?Page 2?}``` 152 153###PAGE 154This marks the beginning of a page. Use the abbreviation specified in **PAGES** 155command. 156 157#####Example: 158```!BSF PAGE:{PG1}``` or 159 160```@Bsf PAGE:{PG1}``` 161 162All the entries that come after this command are assumed to be on that page, 163until the next **PAGE** command 164 165###FIND 166FIND maps to the BSF **Find** command. It will be placed in the **StructDef** 167region of the BSF and should come at the beginning of the UPD sections of the 168DSC, immediately before the signatures that mark the beginning of these 169sections. The content should be the plain-text equivalent of the signature. The 170signature is usually 8 characters. 171 172#####Example: 173```!BSF FIND:{PROJSIG1}``` or 174 175```@Bsf FIND:{PROJSIG1}``` 176 177###BLOCK 178The BLOCK command maps to the **BeginInfoBlock** section of the BSF. There are 179two elements: a version number and a plain-text description. 180 181#####Example: 182```!BSF BLOCK:{NAME:"My platform name", VER:"0.1"}``` or 183 184```@Bsf BLOCK:{NAME:"My platform name", VER:"0.1"}``` 185 186###NAME 187**NAME** gives a plain-text for a variable. This is the text label that will 188appear next to the control in **BCT**. 189 190#####Example: 191```!BSF NAME:{Variable 0}``` or 192 193```@Bsf NAME:{Variable 0}``` 194 195If the **!BSF NAME** or **@Bsf NAME** command does not appear before an entry 196in the UPD region of the DSC file, then that entry will not appear in the BSF. 197 198###TYPE 199The **TYPE** command is used either by itself or with the **NAME** command. It 200is usually used by itself when defining an **EditNum** field for the BSF. You 201specify the type of data in the second parameter and the range of valid values 202in the third. 203 204#####Example: 205```!BSF TYPE:{EditNum, HEX, (0x00,0xFF)}``` or 206 207```@Bsf TYPE:{EditNum, HEX, (0x00,0xFF)}``` 208 209**TYPE** appears on the same line as the **NAME** command when using a combo-box. 210 211#####Example: 212```!BSF NAME:{Variable 1} TYPE:{Combo}``` or 213```@Bsf NAME:{Variable 1} TYPE:{Combo}``` 214 215There is a special **None** type that puts the variable in the **StructDef** 216region of the BSF, but doesn?t put it in any **Page** section. This makes the 217variable visible to BCT, but not to the end user. 218 219###HELP 220The **HELP** command defines what will appear in the help text for each control 221in BCT. 222 223#####Example: 224```!BSF HELP:{Enable/disable LAN controller.}``` or 225 226```@Bsf HELP:{Enable/disable LAN controller.}``` 227 228###OPTION 229The **OPTION** command allows you to custom-define combo boxes and map integer 230or hex values to friendly-text options. 231 232#####Example: 233```!BSF OPTION:{0:IDE, 1:AHCI, 2:RAID}``` 234 235```!BSF OPTION:{0x00:0 MB, 0x01:32 MB, 0x02:64 MB}``` 236 237or 238 239```@Bsf OPTION:{0:IDE, 1:AHCI, 2:RAID}``` 240 241```@Bsf OPTION:{0x00:0 MB, 0x01:32 MB, 0x02:64 MB}``` 242 243###FIELD 244The **FIELD** command can be used to define a section of a consolidated PCD 245such that the PCD will be displayed in several fields via BCT interface instead 246of one long entry. 247 248#####Example: 249```!BSF FIELD:{PcdDRAMSpeed:1}``` or 250 251```@Bsf FIELD:{PcdDRAMSpeed:1}``` 252 253###ORDER 254The **ORDER** command can be used to adjust the display order for the BSF items. 255By default the order value for a BSF item is assigned to be the UPD item 256```(Offset * 256)```. It can be overridden by declaring **ORDER** command using 257format ORDER: ```{HexMajor.HexMinor}```. In this case the order value will be 258```(HexMajor*256+HexMinor)```. The item order value will be used as the sort key 259during the BSF item display. 260 261#####Example: 262```!BSF ORDER:{0x0040.01}``` or 263 264```@Bsf ORDER:{0x0040.01}``` 265 266For **OPTION** and **HELP** commands, it allows to split the contents into 267multiple lines by adding multiple **OPTION** and **HELP** command lines. The 268lines except for the very first line need to start with **+** in the content to 269tell the tool to append this string to the previous one. 270 271For example, the statement 272 273```!BSF OPTION:{0x00:0 MB, 0x01:32 MB, 0x02:64 MB}``` 274 275is equivalent to: 276 277```!BSF OPTION:{0x00:0 MB, 0x01:32 MB,}``` 278 279```!BSF OPTION:{+ 0x02:64 MB}``` 280 281or 282 283```@Bsf OPTION:{0x00:0 MB, 0x01:32 MB, 0x02:64 MB}``` 284 285is equivalent to: 286 287```@Bsf OPTION:{0x00:0 MB, 0x01:32 MB,}``` 288 289```@Bsf OPTION:{+ 0x02:64 MB}``` 290 291The **NAME**, **OPTION**, **TYPE**, and **HELP** commands can all appear on the 292same line following the **!BSF** or **@Bsf** keyword or they may appear on 293separate lines to improve readability. 294 295There are four alternative ways to replace current BSF commands. 296### 1. ```# @Prompt``` 297An alternative way replacing **NAME** gives a plain-text for a 298variable. This is the text label that will appear next to the control in BCT. 299 300#####Example: 301```# @Prompt Variable 0``` 302 303The above example can replace the two methods as below. 304 305```!BSF NAME:{Variable 0}``` or 306 307```@Bsf NAME:{Variable 0}``` 308 309If the ```# @Prompt``` command does not appear before an entry in the UPD region 310of the DSC file, then that entry will not appear in the BSF. 311 312### 2. ```##``` 313An alternative way replacing **HELP** command defines what will appear in the 314help text for each control in BCT. 315 316#####Example: 317```## Enable/disable LAN controller.``` 318 319The above example can replace the two methods as below. 320 321```!BSF HELP:{Enable/disable LAN controller.}``` or 322 323```@Bsf HELP:{Enable/disable LAN controller.}``` 324 325### 3. ```# @ValidList``` 326An alternative way replacing **OPTION** command allows you to custom-define 327combo boxes and map integer or hex values to friendly-text options. 328 329#####Example: 330``` # @ValidList 0x80000003 | 0, 1, 2 | IDE, AHCI, RAID 331 Error Code | Options | Descriptions 332``` 333 334The above example can replace the two methods as below. 335 336```!BSF OPTION:{0:IDE, 1:AHCI, 2:RAID}``` or 337 338```@Bsf OPTION:{0:IDE, 1:AHCI, 2:RAID}``` 339 340### 4. ```# @ValidRange``` 341An alternative way replace **EditNum** field for the BSF. 342 343#####Example: 344```# @ValidRange 0x80000001 | 0x0 ? 0xFF 345 Error Code | Range 346``` 347 348The above example can replace the two methods as below. 349 350```!BSF TYPE:{EditNum, HEX, (0x00,0xFF)}``` or 351 352```@Bsf TYPE:{EditNum, HEX, (0x00,0xFF)}``` 353 354