Sync BaseTool trunk (version r2640) into EDKII BaseTools.
Signed-off-by: Gao, Liming <liming.gao@intel.com> Reviewed-by: Liu, Jiang A <jiang.a.liu@intel.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@15089 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
		
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							| @@ -1653,6 +1653,19 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | |||||||
|                                                             </xs:annotation> |                                                             </xs:annotation> | ||||||
|                                                             <xs:complexType> |                                                             <xs:complexType> | ||||||
|                                                             <xs:sequence> |                                                             <xs:sequence> | ||||||
|  |                                                             <xs:choice> | ||||||
|  |                                                               <xs:element minOccurs="0" maxOccurs="1" name="ValidValueList"> | ||||||
|  |                                                                 <xs:complexType> | ||||||
|  |                                                                   <xs:simpleContent> | ||||||
|  |                                                                     <xs:extension base="xs:normalizedString"> | ||||||
|  |                                                                     <xs:attribute name="Lang" type="xs:language" default="en-us" use="optional"/> | ||||||
|  |                                                                     </xs:extension> | ||||||
|  |                                                                   </xs:simpleContent> | ||||||
|  |                                                                 </xs:complexType> | ||||||
|  |                                                               </xs:element> | ||||||
|  |                                                               <xs:element minOccurs="0" maxOccurs="1" name="ValidValueRange" type="xs:normalizedString"/> | ||||||
|  |                                                               <xs:element minOccurs="0" maxOccurs="1" name="Expression" type="xs:normalizedString"/> | ||||||
|  |                                                             </xs:choice> | ||||||
|                                                             <xs:element minOccurs="1" maxOccurs="1" name="ErrorNumber"> |                                                             <xs:element minOccurs="1" maxOccurs="1" name="ErrorNumber"> | ||||||
|                                                             <xs:annotation> |                                                             <xs:annotation> | ||||||
|                                                             <xs:documentation xml:lang="en-us"> The minLength of 3 is |                                                             <xs:documentation xml:lang="en-us"> The minLength of 3 is | ||||||
| @@ -1731,6 +1744,19 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | |||||||
|                                                             </xs:annotation> |                                                             </xs:annotation> | ||||||
|                                                             <xs:complexType> |                                                             <xs:complexType> | ||||||
|                                                             <xs:sequence> |                                                             <xs:sequence> | ||||||
|  |                                                             <xs:choice> | ||||||
|  |                                                               <xs:element minOccurs="0" maxOccurs="1" name="ValidValueList"> | ||||||
|  |                                                                 <xs:complexType> | ||||||
|  |                                                                   <xs:simpleContent> | ||||||
|  |                                                                     <xs:extension base="xs:normalizedString"> | ||||||
|  |                                                                     <xs:attribute name="Lang" type="xs:language" default="en-us" use="optional"/> | ||||||
|  |                                                                       </xs:extension> | ||||||
|  |                                                                   </xs:simpleContent> | ||||||
|  |                                                                 </xs:complexType> | ||||||
|  |                                                               </xs:element> | ||||||
|  |                                                               <xs:element minOccurs="0" maxOccurs="1" name="ValidValueRange" type="xs:normalizedString"/> | ||||||
|  |                                                               <xs:element minOccurs="0" maxOccurs="1" name="Expression" type="xs:normalizedString"/> | ||||||
|  |                                                             </xs:choice> | ||||||
|                                                             <xs:element minOccurs="1" maxOccurs="1" name="ErrorNumber"> |                                                             <xs:element minOccurs="1" maxOccurs="1" name="ErrorNumber"> | ||||||
|                                                             <xs:annotation> |                                                             <xs:annotation> | ||||||
|                                                             <xs:documentation xml:lang="en-us"> The minLength of 3 is |                                                             <xs:documentation xml:lang="en-us"> The minLength of 3 is | ||||||
| @@ -1877,6 +1903,7 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | |||||||
|                                 <xs:complexType> |                                 <xs:complexType> | ||||||
|                                     <xs:sequence> |                                     <xs:sequence> | ||||||
|                                         <xs:element minOccurs="1" maxOccurs="1" name="CName" type="xs:NCName"/> |                                         <xs:element minOccurs="1" maxOccurs="1" name="CName" type="xs:NCName"/> | ||||||
|  |                                         <xs:element minOccurs="0" maxOccurs="1" name="GUID" type="RegistryFormatGuid"/> | ||||||
|                                         <xs:element minOccurs="0" maxOccurs="1" name="VariableName" |                                         <xs:element minOccurs="0" maxOccurs="1" name="VariableName" | ||||||
|                                             type="xs:normalizedString"> |                                             type="xs:normalizedString"> | ||||||
|                                             <xs:annotation> |                                             <xs:annotation> | ||||||
| @@ -1948,6 +1975,7 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | |||||||
|                                 <xs:complexType> |                                 <xs:complexType> | ||||||
|                                     <xs:sequence> |                                     <xs:sequence> | ||||||
|                                         <xs:element minOccurs="1" maxOccurs="1" name="CName" type="xs:NCName"/> |                                         <xs:element minOccurs="1" maxOccurs="1" name="CName" type="xs:NCName"/> | ||||||
|  |                                         <xs:element minOccurs="0" maxOccurs="1" name="GUID" type="RegistryFormatGuid"/>                                        | ||||||
|                                         <xs:element ref="HelpText" minOccurs="0" maxOccurs="unbounded"/> |                                         <xs:element ref="HelpText" minOccurs="0" maxOccurs="unbounded"/> | ||||||
|                                     </xs:sequence> |                                     </xs:sequence> | ||||||
|                                     <xs:attribute name="Usage" use="required"> |                                     <xs:attribute name="Usage" use="required"> | ||||||
| @@ -1985,6 +2013,7 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | |||||||
|                                 <xs:complexType> |                                 <xs:complexType> | ||||||
|                                     <xs:sequence> |                                     <xs:sequence> | ||||||
|                                         <xs:element minOccurs="1" maxOccurs="1" name="CName" type="xs:NCName"/> |                                         <xs:element minOccurs="1" maxOccurs="1" name="CName" type="xs:NCName"/> | ||||||
|  |                                         <xs:element minOccurs="0" maxOccurs="1" name="GUID" type="RegistryFormatGuid"/>                                         | ||||||
|                                         <xs:element ref="HelpText" minOccurs="0" maxOccurs="unbounded"/> |                                         <xs:element ref="HelpText" minOccurs="0" maxOccurs="unbounded"/> | ||||||
|                                     </xs:sequence> |                                     </xs:sequence> | ||||||
|                                     <xs:attribute name="Usage" use="required"> |                                     <xs:attribute name="Usage" use="required"> | ||||||
| @@ -2272,17 +2301,32 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | |||||||
|                                         different from the Distribution Package license. </xs:documentation> |                                         different from the Distribution Package license. </xs:documentation> | ||||||
|                                 </xs:annotation> |                                 </xs:annotation> | ||||||
|                             </xs:element> |                             </xs:element> | ||||||
|                             <xs:element minOccurs="0" maxOccurs="1" name="Abstract" type="xs:normalizedString"> |                             <xs:element minOccurs="0" maxOccurs="1" name="Abstract"> | ||||||
|                                 <xs:annotation> |                                 <xs:annotation> | ||||||
|                                     <xs:documentation xml:lang="en-us"> This is only required if the Abstract is |                                     <xs:documentation xml:lang="en-us"> This is only required if the Abstract is | ||||||
|                                         different from the Distribution Package Abstract. </xs:documentation> |                                         different from the Distribution Package Abstract. </xs:documentation> | ||||||
|                                 </xs:annotation> |                                 </xs:annotation> | ||||||
|  |                                 <xs:complexType> | ||||||
|  |                                     <xs:simpleContent> | ||||||
|  |                                         <xs:extension base="xs:normalizedString"> | ||||||
|  |                                             <xs:attribute name="Lang" type="xs:language" default="en-us" use="optional"/> | ||||||
|  |                                         </xs:extension>                                         | ||||||
|  |                                     </xs:simpleContent> | ||||||
|  |                                 </xs:complexType> | ||||||
|                             </xs:element> |                             </xs:element> | ||||||
|                             <xs:element minOccurs="0" maxOccurs="1" name="Description" type="xs:string"> |                             <xs:element minOccurs="0" maxOccurs="1" name="Description"> | ||||||
|                                 <xs:annotation> |                                 <xs:annotation> | ||||||
|                                     <xs:documentation xml:lang="en-us"> This is only required if the Description is |                                     <xs:documentation xml:lang="en-us"> This is only required if the Description is | ||||||
|                                         different from the Distribution Package Description. </xs:documentation> |                                         different from the Distribution Package Description. </xs:documentation> | ||||||
|                                 </xs:annotation> |                                 </xs:annotation> | ||||||
|  |                                 <xs:complexType> | ||||||
|  |                                     <xs:simpleContent> | ||||||
|  |                                         <xs:extension base="xs:string"> | ||||||
|  |                                             <xs:attribute name="Lang" type="xs:language" default="en-us" use="optional"/> | ||||||
|  |                                         </xs:extension>                                         | ||||||
|  |                                     </xs:simpleContent> | ||||||
|  |                                 </xs:complexType> | ||||||
|  |                                  | ||||||
|                             </xs:element> |                             </xs:element> | ||||||
|                         </xs:sequence> |                         </xs:sequence> | ||||||
|                     </xs:complexType> |                     </xs:complexType> | ||||||
| @@ -2474,6 +2518,7 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | |||||||
|             <xs:enumeration value="File"/> |             <xs:enumeration value="File"/> | ||||||
|             <xs:enumeration value="FV"/> |             <xs:enumeration value="FV"/> | ||||||
|             <xs:enumeration value="GUID"/> |             <xs:enumeration value="GUID"/> | ||||||
|  |             <xs:enumeration value="HII"/> | ||||||
|             <xs:enumeration value="Hii"/> |             <xs:enumeration value="Hii"/> | ||||||
|             <xs:enumeration value="HOB"/> |             <xs:enumeration value="HOB"/> | ||||||
|             <xs:enumeration value="SystemTable"/> |             <xs:enumeration value="SystemTable"/> | ||||||
| @@ -2694,10 +2739,15 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | |||||||
|                     </xs:documentation> |                     </xs:documentation> | ||||||
|                 </xs:annotation> |                 </xs:annotation> | ||||||
|             </xs:enumeration> |             </xs:enumeration> | ||||||
|  |             <xs:enumeration value="RedHat32"/> | ||||||
|  |             <xs:enumeration value="RedHat64"/> | ||||||
|  |             <xs:enumeration value="SuSE32"/> | ||||||
|  |             <xs:enumeration value="SuSE64"/> | ||||||
|             <xs:enumeration value="Linux32"/> |             <xs:enumeration value="Linux32"/> | ||||||
|             <xs:enumeration value="Linux64"/> |             <xs:enumeration value="Linux64"/> | ||||||
|             <xs:enumeration value="OS/X32"/> |             <xs:enumeration value="OS/X32"/> | ||||||
|             <xs:enumeration value="OS/X64"/> |             <xs:enumeration value="OS/X64"/> | ||||||
|  |             <xs:enumeration value="Generic"/> | ||||||
|             <xs:enumeration value="GenericWin"> |             <xs:enumeration value="GenericWin"> | ||||||
|                 <xs:annotation> |                 <xs:annotation> | ||||||
|                     <xs:documentation xml:lang="en-us"> Typically, this is used for Windows Batch files. |                     <xs:documentation xml:lang="en-us"> Typically, this is used for Windows Batch files. | ||||||
|   | |||||||
| @@ -166,7 +166,7 @@ | |||||||
|  |  | ||||||
|     <Command.GCC, Command.RVCT> |     <Command.GCC, Command.RVCT> | ||||||
|         "$(PP)" $(PP_FLAGS) $(INC) ${src} > ${d_path}(+)${s_base}.i |         "$(PP)" $(PP_FLAGS) $(INC) ${src} > ${d_path}(+)${s_base}.i | ||||||
|         Trim --source-code -o ${d_path}(+)${s_base}.iii ${d_path}(+)${s_base}.i |         Trim --trim-long --source-code -o ${d_path}(+)${s_base}.iii ${d_path}(+)${s_base}.i | ||||||
|         # For RVCTCYGWIN ASM_FLAGS must be first to work around pathing issues |         # For RVCTCYGWIN ASM_FLAGS must be first to work around pathing issues | ||||||
|         "$(ASM)" $(ASM_FLAGS) -o ${dst} $(INC) ${d_path}(+)${s_base}.iii |         "$(ASM)" $(ASM_FLAGS) -o ${dst} $(INC) ${d_path}(+)${s_base}.iii | ||||||
|  |  | ||||||
|   | |||||||
| @@ -159,6 +159,9 @@ DEFINE GCC46_X64_PREFIX        = /usr/bin/ | |||||||
| DEFINE GCC47_IA32_PREFIX       = /usr/bin/ | DEFINE GCC47_IA32_PREFIX       = /usr/bin/ | ||||||
| DEFINE GCC47_X64_PREFIX        = /usr/bin/ | DEFINE GCC47_X64_PREFIX        = /usr/bin/ | ||||||
|  |  | ||||||
|  | DEFINE GCC48_IA32_PREFIX       = /usr/bin/ | ||||||
|  | DEFINE GCC48_X64_PREFIX        = /usr/bin/ | ||||||
|  |  | ||||||
| DEFINE UNIX_IASL_BIN           = /usr/bin/iasl | DEFINE UNIX_IASL_BIN           = /usr/bin/iasl | ||||||
| #DEFINE UNIX_IASL_BIN           = $(HOME)/programs/iasl | #DEFINE UNIX_IASL_BIN           = $(HOME)/programs/iasl | ||||||
| DEFINE WIN_ASL_BIN_DIR         = C:\ASL | DEFINE WIN_ASL_BIN_DIR         = C:\ASL | ||||||
| @@ -304,6 +307,12 @@ DEFINE CLANG_BIN = /usr/bin/ | |||||||
| #                             Required to build platforms or ACPI tables: | #                             Required to build platforms or ACPI tables: | ||||||
| #                               Intel(r) ACPI Compiler v20101013 from | #                               Intel(r) ACPI Compiler v20101013 from | ||||||
| #                               http://www.acpica.org/downloads/previous_releases.php | #                               http://www.acpica.org/downloads/previous_releases.php | ||||||
|  | #   GCC48       -Linux-  Requires: | ||||||
|  | #                             GCC 4.8 | ||||||
|  | #                        Optional: | ||||||
|  | #                             Required to build platforms or ACPI tables: | ||||||
|  | #                               Intel(r) ACPI Compiler v20101013 from | ||||||
|  | #                               http://www.acpica.org/downloads/previous_releases.php | ||||||
| #   ELFGCC      -Linux-  Requires: | #   ELFGCC      -Linux-  Requires: | ||||||
| #                             GCC(this tool chain uses whatever version of gcc and binutils that is installed in /usr/bin) | #                             GCC(this tool chain uses whatever version of gcc and binutils that is installed in /usr/bin) | ||||||
| #                        Optional: | #                        Optional: | ||||||
| @@ -3133,6 +3142,7 @@ DEFINE GCC_DLINK_FLAGS_COMMON      = -nostdlib --pie | |||||||
| DEFINE GCC_IA32_X64_DLINK_COMMON   = DEF(GCC_DLINK_FLAGS_COMMON) --gc-sections | DEFINE GCC_IA32_X64_DLINK_COMMON   = DEF(GCC_DLINK_FLAGS_COMMON) --gc-sections | ||||||
| DEFINE GCC_ARM_AARCH64_DLINK_COMMON= -Ttext=0x0 --emit-relocs -nostdlib -u $(IMAGE_ENTRY_POINT) -e $(IMAGE_ENTRY_POINT) -Map $(DEST_DIR_DEBUG)/$(BASE_NAME).map | DEFINE GCC_ARM_AARCH64_DLINK_COMMON= -Ttext=0x0 --emit-relocs -nostdlib -u $(IMAGE_ENTRY_POINT) -e $(IMAGE_ENTRY_POINT) -Map $(DEST_DIR_DEBUG)/$(BASE_NAME).map | ||||||
| DEFINE GCC_IA32_X64_ASLDLINK_FLAGS = DEF(GCC_IA32_X64_DLINK_COMMON) --entry _ReferenceAcpiTable -u $(IMAGE_ENTRY_POINT) | DEFINE GCC_IA32_X64_ASLDLINK_FLAGS = DEF(GCC_IA32_X64_DLINK_COMMON) --entry _ReferenceAcpiTable -u $(IMAGE_ENTRY_POINT) | ||||||
|  | DEFINE GCC_ARM_AARCH64_ASLDLINK_FLAGS = DEF(GCC_ARM_AARCH64_DLINK_COMMON) --entry ReferenceAcpiTable -u $(IMAGE_ENTRY_POINT) | ||||||
| DEFINE GCC_IA32_X64_DLINK_FLAGS    = DEF(GCC_IA32_X64_DLINK_COMMON) --entry _$(IMAGE_ENTRY_POINT) --file-alignment 0x20 --section-alignment 0x20 -Map $(DEST_DIR_DEBUG)/$(BASE_NAME).map | DEFINE GCC_IA32_X64_DLINK_FLAGS    = DEF(GCC_IA32_X64_DLINK_COMMON) --entry _$(IMAGE_ENTRY_POINT) --file-alignment 0x20 --section-alignment 0x20 -Map $(DEST_DIR_DEBUG)/$(BASE_NAME).map | ||||||
| DEFINE GCC_IPF_DLINK_FLAGS         = -nostdlib -O2 --gc-sections --dll -static --entry $(IMAGE_ENTRY_POINT) --undefined $(IMAGE_ENTRY_POINT) -Map $(DEST_DIR_DEBUG)/$(BASE_NAME).map | DEFINE GCC_IPF_DLINK_FLAGS         = -nostdlib -O2 --gc-sections --dll -static --entry $(IMAGE_ENTRY_POINT) --undefined $(IMAGE_ENTRY_POINT) -Map $(DEST_DIR_DEBUG)/$(BASE_NAME).map | ||||||
| DEFINE GCC_IPF_OBJCOPY_FLAGS       = -I elf64-ia64-little -O efi-bsdrv-ia64 | DEFINE GCC_IPF_OBJCOPY_FLAGS       = -I elf64-ia64-little -O efi-bsdrv-ia64 | ||||||
| @@ -3176,6 +3186,7 @@ DEFINE GCC46_ASM_FLAGS               = DEF(GCC45_ASM_FLAGS) | |||||||
| DEFINE GCC46_ARM_ASM_FLAGS           = $(ARCHASM_FLAGS) $(PLATFORM_FLAGS) DEF(GCC_ASM_FLAGS) -mlittle-endian | DEFINE GCC46_ARM_ASM_FLAGS           = $(ARCHASM_FLAGS) $(PLATFORM_FLAGS) DEF(GCC_ASM_FLAGS) -mlittle-endian | ||||||
| DEFINE GCC46_ARM_CC_FLAGS            = $(ARCHCC_FLAGS) $(PLATFORM_FLAGS) DEF(GCC44_ALL_CC_FLAGS) -mword-relocations -mlittle-endian -mabi=aapcs -mapcs -fno-short-enums -save-temps -fsigned-char -mno-unaligned-access -Wno-address -fomit-frame-pointer | DEFINE GCC46_ARM_CC_FLAGS            = $(ARCHCC_FLAGS) $(PLATFORM_FLAGS) DEF(GCC44_ALL_CC_FLAGS) -mword-relocations -mlittle-endian -mabi=aapcs -mapcs -fno-short-enums -save-temps -fsigned-char -mno-unaligned-access -Wno-address -fomit-frame-pointer | ||||||
| DEFINE GCC46_ARM_DLINK_FLAGS         = DEF(GCC_ARM_AARCH64_DLINK_COMMON) --oformat=elf32-littlearm | DEFINE GCC46_ARM_DLINK_FLAGS         = DEF(GCC_ARM_AARCH64_DLINK_COMMON) --oformat=elf32-littlearm | ||||||
|  | DEFINE GCC46_ARM_ASLDLINK_FLAGS      = DEF(GCC_ARM_AARCH64_ASLDLINK_FLAGS) --oformat=elf32-littlearm | ||||||
|  |  | ||||||
| DEFINE GCC47_IA32_CC_FLAGS           = DEF(GCC46_IA32_CC_FLAGS) | DEFINE GCC47_IA32_CC_FLAGS           = DEF(GCC46_IA32_CC_FLAGS) | ||||||
| DEFINE GCC47_X64_CC_FLAGS            = DEF(GCC46_X64_CC_FLAGS) | DEFINE GCC47_X64_CC_FLAGS            = DEF(GCC46_X64_CC_FLAGS) | ||||||
| @@ -3190,6 +3201,24 @@ DEFINE GCC47_ARM_CC_FLAGS            = DEF(GCC46_ARM_CC_FLAGS) | |||||||
| DEFINE GCC47_AARCH64_CC_FLAGS        = $(ARCHCC_FLAGS) $(PLATFORM_FLAGS) DEF(GCC44_ALL_CC_FLAGS) -mcmodel=large -mlittle-endian -fno-short-enums -save-temps -fverbose-asm -fsigned-char -ffunction-sections -fdata-sections -fomit-frame-pointer -fno-builtin -Wno-address | DEFINE GCC47_AARCH64_CC_FLAGS        = $(ARCHCC_FLAGS) $(PLATFORM_FLAGS) DEF(GCC44_ALL_CC_FLAGS) -mcmodel=large -mlittle-endian -fno-short-enums -save-temps -fverbose-asm -fsigned-char -ffunction-sections -fdata-sections -fomit-frame-pointer -fno-builtin -Wno-address | ||||||
| DEFINE GCC47_ARM_DLINK_FLAGS         = DEF(GCC46_ARM_DLINK_FLAGS) | DEFINE GCC47_ARM_DLINK_FLAGS         = DEF(GCC46_ARM_DLINK_FLAGS) | ||||||
| DEFINE GCC47_AARCH64_DLINK_FLAGS     = DEF(GCC_ARM_AARCH64_DLINK_COMMON) | DEFINE GCC47_AARCH64_DLINK_FLAGS     = DEF(GCC_ARM_AARCH64_DLINK_COMMON) | ||||||
|  | DEFINE GCC47_ARM_ASLDLINK_FLAGS      = DEF(GCC46_ARM_ASLDLINK_FLAGS) | ||||||
|  | DEFINE GCC47_AARCH64_ASLDLINK_FLAGS  = DEF(GCC_ARM_AARCH64_ASLDLINK_FLAGS) | ||||||
|  |  | ||||||
|  | DEFINE GCC48_IA32_CC_FLAGS           = DEF(GCC47_IA32_CC_FLAGS) | ||||||
|  | DEFINE GCC48_X64_CC_FLAGS            = DEF(GCC47_X64_CC_FLAGS) | ||||||
|  | DEFINE GCC48_IA32_X64_DLINK_COMMON   = DEF(GCC47_IA32_X64_DLINK_COMMON) | ||||||
|  | DEFINE GCC48_IA32_X64_ASLDLINK_FLAGS = DEF(GCC47_IA32_X64_ASLDLINK_FLAGS) | ||||||
|  | DEFINE GCC48_IA32_X64_DLINK_FLAGS    = DEF(GCC47_IA32_X64_DLINK_FLAGS) | ||||||
|  | DEFINE GCC48_X64_DLINK_FLAGS         = DEF(GCC47_X64_DLINK_FLAGS) | ||||||
|  | DEFINE GCC48_ASM_FLAGS               = DEF(GCC47_ASM_FLAGS) | ||||||
|  | DEFINE GCC48_ARM_ASM_FLAGS           = DEF(GCC47_ARM_ASM_FLAGS) | ||||||
|  | DEFINE GCC48_AARCH64_ASM_FLAGS       = DEF(GCC47_AARCH64_ASM_FLAGS) | ||||||
|  | DEFINE GCC48_ARM_CC_FLAGS            = DEF(GCC47_ARM_CC_FLAGS) | ||||||
|  | DEFINE GCC48_AARCH64_CC_FLAGS        = DEF(GCC47_AARCH64_CC_FLAGS) | ||||||
|  | DEFINE GCC48_ARM_DLINK_FLAGS         = DEF(GCC47_ARM_DLINK_FLAGS) | ||||||
|  | DEFINE GCC48_AARCH64_DLINK_FLAGS     = DEF(GCC_ARM_AARCH64_DLINK_COMMON) | ||||||
|  | DEFINE GCC48_ARM_ASLDLINK_FLAGS      = DEF(GCC47_ARM_ASLDLINK_FLAGS) | ||||||
|  | DEFINE GCC48_AARCH64_ASLDLINK_FLAGS  = DEF(GCC_ARM_AARCH64_ASLDLINK_FLAGS) | ||||||
|  |  | ||||||
| #################################################################################### | #################################################################################### | ||||||
| # | # | ||||||
| @@ -3292,7 +3321,7 @@ DEFINE GCC47_AARCH64_DLINK_FLAGS     = DEF(GCC_ARM_AARCH64_DLINK_COMMON) | |||||||
| *_GCC44_*_ASLPP_FLAGS                  = DEF(GCC_ASLPP_FLAGS) | *_GCC44_*_ASLPP_FLAGS                  = DEF(GCC_ASLPP_FLAGS) | ||||||
| *_GCC44_*_ASLCC_FLAGS                  = DEF(GCC_ASLCC_FLAGS) | *_GCC44_*_ASLCC_FLAGS                  = DEF(GCC_ASLCC_FLAGS) | ||||||
| *_GCC44_*_VFRPP_FLAGS                  = DEF(GCC_VFRPP_FLAGS) | *_GCC44_*_VFRPP_FLAGS                  = DEF(GCC_VFRPP_FLAGS) | ||||||
| *_GCC44_*_APP_FLAGS                    = | *_GCC44_*_APP_FLAGS                    = DEF(GCC_PP_FLAGS) | ||||||
| *_GCC44_*_ASL_FLAGS                    = DEF(IASL_FLAGS) | *_GCC44_*_ASL_FLAGS                    = DEF(IASL_FLAGS) | ||||||
| *_GCC44_*_ASL_OUTFLAGS                 = DEF(IASL_OUTFLAGS) | *_GCC44_*_ASL_OUTFLAGS                 = DEF(IASL_OUTFLAGS) | ||||||
|  |  | ||||||
| @@ -3490,6 +3519,8 @@ DEFINE GCC47_AARCH64_DLINK_FLAGS     = DEF(GCC_ARM_AARCH64_DLINK_COMMON) | |||||||
| *_GCC46_ARM_ARCHCC_FLAGS         = -mthumb | *_GCC46_ARM_ARCHCC_FLAGS         = -mthumb | ||||||
| *_GCC46_ARM_PLATFORM_FLAGS       = -march=armv7-a | *_GCC46_ARM_PLATFORM_FLAGS       = -march=armv7-a | ||||||
|  |  | ||||||
|  | *_GCC46_ARM_ASLCC_FLAGS          = DEF(GCC_ASLCC_FLAGS) | ||||||
|  | *_GCC46_ARM_ASLDLINK_FLAGS       = DEF(GCC46_ARM_ASLDLINK_FLAGS) | ||||||
| *_GCC46_ARM_ASM_FLAGS            = DEF(GCC46_ARM_ASM_FLAGS) | *_GCC46_ARM_ASM_FLAGS            = DEF(GCC46_ARM_ASM_FLAGS) | ||||||
| *_GCC46_ARM_DLINK_FLAGS          = DEF(GCC46_ARM_DLINK_FLAGS) | *_GCC46_ARM_DLINK_FLAGS          = DEF(GCC46_ARM_DLINK_FLAGS) | ||||||
| *_GCC46_ARM_PLATFORM_FLAGS       = -march=armv7-a | *_GCC46_ARM_PLATFORM_FLAGS       = -march=armv7-a | ||||||
| @@ -3579,9 +3610,11 @@ RELEASE_GCC46_ARM_CC_FLAGS       = DEF(GCC46_ARM_CC_FLAGS) -Wno-unused-but-set-v | |||||||
| *_GCC47_ARM_ASLPP_PATH           = ENV(GCC47_ARM_PREFIX)gcc | *_GCC47_ARM_ASLPP_PATH           = ENV(GCC47_ARM_PREFIX)gcc | ||||||
| *_GCC47_ARM_RC_PATH              = ENV(GCC47_ARM_PREFIX)objcopy | *_GCC47_ARM_RC_PATH              = ENV(GCC47_ARM_PREFIX)objcopy | ||||||
|  |  | ||||||
| *_GCC46_ARM_ARCHCC_FLAGS         = -mthumb | *_GCC47_ARM_ARCHCC_FLAGS         = -mthumb | ||||||
| *_GCC46_ARM_PLATFORM_FLAGS       = -march=armv7-a | *_GCC47_ARM_PLATFORM_FLAGS       = -march=armv7-a | ||||||
|  |  | ||||||
|  | *_GCC47_ARM_ASLCC_FLAGS          = DEF(GCC_ASLCC_FLAGS) | ||||||
|  | *_GCC47_ARM_ASLDLINK_FLAGS       = DEF(GCC47_ARM_ASLDLINK_FLAGS) | ||||||
| *_GCC47_ARM_ASM_FLAGS            = DEF(GCC47_ARM_ASM_FLAGS) | *_GCC47_ARM_ASM_FLAGS            = DEF(GCC47_ARM_ASM_FLAGS) | ||||||
| *_GCC47_ARM_DLINK_FLAGS          = DEF(GCC47_ARM_DLINK_FLAGS) | *_GCC47_ARM_DLINK_FLAGS          = DEF(GCC47_ARM_DLINK_FLAGS) | ||||||
| *_GCC47_ARM_PLATFORM_FLAGS       = -march=armv7-a | *_GCC47_ARM_PLATFORM_FLAGS       = -march=armv7-a | ||||||
| @@ -3606,6 +3639,8 @@ RELEASE_GCC47_ARM_CC_FLAGS       = DEF(GCC47_ARM_CC_FLAGS) -Wno-unused-but-set-v | |||||||
| *_GCC47_AARCH64_ASLPP_PATH       = ENV(GCC47_AARCH64_PREFIX)gcc | *_GCC47_AARCH64_ASLPP_PATH       = ENV(GCC47_AARCH64_PREFIX)gcc | ||||||
| *_GCC47_AARCH64_RC_PATH          = ENV(GCC47_AARCH64_PREFIX)objcopy | *_GCC47_AARCH64_RC_PATH          = ENV(GCC47_AARCH64_PREFIX)objcopy | ||||||
|  |  | ||||||
|  | *_GCC47_AARCH64_ASLCC_FLAGS      = DEF(GCC_ASLCC_FLAGS) | ||||||
|  | *_GCC47_AARCH64_ASLDLINK_FLAGS   = DEF(GCC47_AARCH64_ASLDLINK_FLAGS) | ||||||
| *_GCC47_AARCH64_ASM_FLAGS        = DEF(GCC47_AARCH64_ASM_FLAGS) | *_GCC47_AARCH64_ASM_FLAGS        = DEF(GCC47_AARCH64_ASM_FLAGS) | ||||||
| *_GCC47_AARCH64_DLINK_FLAGS      = DEF(GCC47_AARCH64_DLINK_FLAGS) | *_GCC47_AARCH64_DLINK_FLAGS      = DEF(GCC47_AARCH64_DLINK_FLAGS) | ||||||
| *_GCC47_AARCH64_PLATFORM_FLAGS   = | *_GCC47_AARCH64_PLATFORM_FLAGS   = | ||||||
| @@ -3616,6 +3651,126 @@ RELEASE_GCC47_ARM_CC_FLAGS       = DEF(GCC47_ARM_CC_FLAGS) -Wno-unused-but-set-v | |||||||
|   DEBUG_GCC47_AARCH64_CC_FLAGS   = DEF(GCC47_AARCH64_CC_FLAGS) -O0 |   DEBUG_GCC47_AARCH64_CC_FLAGS   = DEF(GCC47_AARCH64_CC_FLAGS) -O0 | ||||||
| RELEASE_GCC47_AARCH64_CC_FLAGS   = DEF(GCC47_AARCH64_CC_FLAGS) -Wno-unused-but-set-variable | RELEASE_GCC47_AARCH64_CC_FLAGS   = DEF(GCC47_AARCH64_CC_FLAGS) -Wno-unused-but-set-variable | ||||||
|  |  | ||||||
|  | #################################################################################### | ||||||
|  | # | ||||||
|  | # GCC 4.8 - This configuration is used to compile under Linux to produce | ||||||
|  | #           PE/COFF binaries using GCC 4.8. | ||||||
|  | # | ||||||
|  | #################################################################################### | ||||||
|  | *_GCC48_*_*_FAMILY               = GCC | ||||||
|  |  | ||||||
|  | *_GCC48_*_MAKE_PATH                    = make | ||||||
|  | *_GCC48_*_ASL_PATH                     = DEF(UNIX_IASL_BIN) | ||||||
|  |  | ||||||
|  | *_GCC48_*_PP_FLAGS                     = DEF(GCC_PP_FLAGS) | ||||||
|  | *_GCC48_*_ASLPP_FLAGS                  = DEF(GCC_ASLPP_FLAGS) | ||||||
|  | *_GCC48_*_ASLCC_FLAGS                  = DEF(GCC_ASLCC_FLAGS) | ||||||
|  | *_GCC48_*_VFRPP_FLAGS                  = DEF(GCC_VFRPP_FLAGS) | ||||||
|  | *_GCC48_*_APP_FLAGS                    = | ||||||
|  | *_GCC48_*_ASL_FLAGS                    = DEF(IASL_FLAGS) | ||||||
|  | *_GCC48_*_ASL_OUTFLAGS                 = DEF(IASL_OUTFLAGS) | ||||||
|  |  | ||||||
|  | ################## | ||||||
|  | # GCC48 IA32 definitions | ||||||
|  | ################## | ||||||
|  | *_GCC48_IA32_OBJCOPY_PATH         = DEF(GCC48_IA32_PREFIX)objcopy | ||||||
|  | *_GCC48_IA32_CC_PATH              = DEF(GCC48_IA32_PREFIX)gcc | ||||||
|  | *_GCC48_IA32_SLINK_PATH           = DEF(GCC48_IA32_PREFIX)ar | ||||||
|  | *_GCC48_IA32_DLINK_PATH           = DEF(GCC48_IA32_PREFIX)ld | ||||||
|  | *_GCC48_IA32_ASLDLINK_PATH        = DEF(GCC48_IA32_PREFIX)ld | ||||||
|  | *_GCC48_IA32_ASM_PATH             = DEF(GCC48_IA32_PREFIX)gcc | ||||||
|  | *_GCC48_IA32_PP_PATH              = DEF(GCC48_IA32_PREFIX)gcc | ||||||
|  | *_GCC48_IA32_VFRPP_PATH           = DEF(GCC48_IA32_PREFIX)gcc | ||||||
|  | *_GCC48_IA32_ASLCC_PATH           = DEF(GCC48_IA32_PREFIX)gcc | ||||||
|  | *_GCC48_IA32_ASLPP_PATH           = DEF(GCC48_IA32_PREFIX)gcc | ||||||
|  | *_GCC48_IA32_RC_PATH              = DEF(GCC48_IA32_PREFIX)objcopy | ||||||
|  |  | ||||||
|  | *_GCC48_IA32_ASLCC_FLAGS          = DEF(GCC_ASLCC_FLAGS) -m32 | ||||||
|  | *_GCC48_IA32_ASLDLINK_FLAGS       = DEF(GCC48_IA32_X64_ASLDLINK_FLAGS) -m elf_i386 | ||||||
|  | *_GCC48_IA32_ASM_FLAGS            = DEF(GCC48_ASM_FLAGS) -m32 -march=i386 | ||||||
|  | *_GCC48_IA32_CC_FLAGS             = DEF(GCC48_IA32_CC_FLAGS) -Os | ||||||
|  | *_GCC48_IA32_DLINK_FLAGS          = DEF(GCC48_IA32_X64_DLINK_FLAGS) -m elf_i386 --oformat=elf32-i386 | ||||||
|  | *_GCC48_IA32_RC_FLAGS             = DEF(GCC_IA32_RC_FLAGS) | ||||||
|  | *_GCC48_IA32_OBJCOPY_FLAGS        =  | ||||||
|  |  | ||||||
|  | ################## | ||||||
|  | # GCC48 X64 definitions | ||||||
|  | ################## | ||||||
|  | *_GCC48_X64_OBJCOPY_PATH         = DEF(GCC48_X64_PREFIX)objcopy | ||||||
|  | *_GCC48_X64_CC_PATH              = DEF(GCC48_X64_PREFIX)gcc | ||||||
|  | *_GCC48_X64_SLINK_PATH           = DEF(GCC48_X64_PREFIX)ar | ||||||
|  | *_GCC48_X64_DLINK_PATH           = DEF(GCC48_X64_PREFIX)ld | ||||||
|  | *_GCC48_X64_ASLDLINK_PATH        = DEF(GCC48_X64_PREFIX)ld | ||||||
|  | *_GCC48_X64_ASM_PATH             = DEF(GCC48_X64_PREFIX)gcc | ||||||
|  | *_GCC48_X64_PP_PATH              = DEF(GCC48_X64_PREFIX)gcc | ||||||
|  | *_GCC48_X64_VFRPP_PATH           = DEF(GCC48_X64_PREFIX)gcc | ||||||
|  | *_GCC48_X64_ASLCC_PATH           = DEF(GCC48_X64_PREFIX)gcc | ||||||
|  | *_GCC48_X64_ASLPP_PATH           = DEF(GCC48_X64_PREFIX)gcc | ||||||
|  | *_GCC48_X64_RC_PATH              = DEF(GCC48_X64_PREFIX)objcopy | ||||||
|  |  | ||||||
|  | *_GCC48_X64_ASLCC_FLAGS          = DEF(GCC_ASLCC_FLAGS) -m64 | ||||||
|  | *_GCC48_X64_ASLDLINK_FLAGS       = DEF(GCC48_IA32_X64_ASLDLINK_FLAGS) -m elf_x86_64 | ||||||
|  | *_GCC48_X64_ASM_FLAGS            = DEF(GCC48_ASM_FLAGS) -m64 | ||||||
|  | *_GCC48_X64_CC_FLAGS             = DEF(GCC48_X64_CC_FLAGS) | ||||||
|  | *_GCC48_X64_DLINK_FLAGS          = DEF(GCC48_X64_DLINK_FLAGS) | ||||||
|  | *_GCC48_X64_RC_FLAGS             = DEF(GCC_X64_RC_FLAGS) | ||||||
|  | *_GCC48_X64_OBJCOPY_FLAGS        =  | ||||||
|  |  | ||||||
|  | ################## | ||||||
|  | # GCC48 ARM definitions | ||||||
|  | ################## | ||||||
|  | *_GCC48_ARM_CC_PATH              = ENV(GCC48_ARM_PREFIX)gcc | ||||||
|  | *_GCC48_ARM_SLINK_PATH           = ENV(GCC48_ARM_PREFIX)ar | ||||||
|  | *_GCC48_ARM_DLINK_PATH           = ENV(GCC48_ARM_PREFIX)ld | ||||||
|  | *_GCC48_ARM_ASLDLINK_PATH        = ENV(GCC48_ARM_PREFIX)ld | ||||||
|  | *_GCC48_ARM_ASM_PATH             = ENV(GCC48_ARM_PREFIX)gcc | ||||||
|  | *_GCC48_ARM_PP_PATH              = ENV(GCC48_ARM_PREFIX)gcc | ||||||
|  | *_GCC48_ARM_VFRPP_PATH           = ENV(GCC48_ARM_PREFIX)gcc | ||||||
|  | *_GCC48_ARM_ASLCC_PATH           = ENV(GCC48_ARM_PREFIX)gcc | ||||||
|  | *_GCC48_ARM_ASLPP_PATH           = ENV(GCC48_ARM_PREFIX)gcc | ||||||
|  | *_GCC48_ARM_RC_PATH              = ENV(GCC48_ARM_PREFIX)objcopy | ||||||
|  |  | ||||||
|  | *_GCC48_ARM_ARCHCC_FLAGS         = -mthumb | ||||||
|  | *_GCC48_ARM_PLATFORM_FLAGS       = -march=armv7-a | ||||||
|  |  | ||||||
|  | *_GCC48_ARM_ASLCC_FLAGS          = DEF(GCC_ASLCC_FLAGS) | ||||||
|  | *_GCC48_ARM_ASLDLINK_FLAGS       = DEF(GCC48_ARM_ASLDLINK_FLAGS) | ||||||
|  | *_GCC48_ARM_ASM_FLAGS            = DEF(GCC48_ARM_ASM_FLAGS) | ||||||
|  | *_GCC48_ARM_DLINK_FLAGS          = DEF(GCC48_ARM_DLINK_FLAGS) | ||||||
|  | *_GCC48_ARM_PLATFORM_FLAGS       = -march=armv7-a | ||||||
|  | *_GCC48_ARM_PP_FLAGS             = $(ARCHCC_FLAGS) $(PLATFORM_FLAGS) DEF(GCC_PP_FLAGS) | ||||||
|  | *_GCC48_ARM_RC_FLAGS             = DEF(GCC_ARM_RC_FLAGS) | ||||||
|  | *_GCC48_ARM_VFRPP_FLAGS          = $(ARCHCC_FLAGS) $(PLATFORM_FLAGS) DEF(GCC_VFRPP_FLAGS) | ||||||
|  |  | ||||||
|  |   DEBUG_GCC48_ARM_CC_FLAGS       = DEF(GCC48_ARM_CC_FLAGS) -O0 | ||||||
|  | RELEASE_GCC48_ARM_CC_FLAGS       = DEF(GCC48_ARM_CC_FLAGS) -Wno-unused-but-set-variable | ||||||
|  |  | ||||||
|  | ################## | ||||||
|  | # GCC48 AARCH64 definitions | ||||||
|  | ################## | ||||||
|  | *_GCC48_AARCH64_CC_PATH          = ENV(GCC48_AARCH64_PREFIX)gcc | ||||||
|  | *_GCC48_AARCH64_SLINK_PATH       = ENV(GCC48_AARCH64_PREFIX)ar | ||||||
|  | *_GCC48_AARCH64_DLINK_PATH       = ENV(GCC48_AARCH64_PREFIX)ld | ||||||
|  | *_GCC48_AARCH64_ASLDLINK_PATH    = ENV(GCC48_AARCH64_PREFIX)ld | ||||||
|  | *_GCC48_AARCH64_ASM_PATH         = ENV(GCC48_AARCH64_PREFIX)gcc | ||||||
|  | *_GCC48_AARCH64_PP_PATH          = ENV(GCC48_AARCH64_PREFIX)gcc | ||||||
|  | *_GCC48_AARCH64_VFRPP_PATH       = ENV(GCC48_AARCH64_PREFIX)gcc | ||||||
|  | *_GCC48_AARCH64_ASLCC_PATH       = ENV(GCC48_AARCH64_PREFIX)gcc | ||||||
|  | *_GCC48_AARCH64_ASLPP_PATH       = ENV(GCC48_AARCH64_PREFIX)gcc | ||||||
|  | *_GCC48_AARCH64_RC_PATH          = ENV(GCC48_AARCH64_PREFIX)objcopy | ||||||
|  |  | ||||||
|  | *_GCC48_AARCH64_ASLCC_FLAGS      = DEF(GCC_ASLCC_FLAGS) | ||||||
|  | *_GCC48_AARCH64_ASLDLINK_FLAGS   = DEF(GCC48_AARCH64_ASLDLINK_FLAGS) | ||||||
|  | *_GCC48_AARCH64_ASM_FLAGS        = DEF(GCC48_AARCH64_ASM_FLAGS) | ||||||
|  | *_GCC48_AARCH64_DLINK_FLAGS      = DEF(GCC48_AARCH64_DLINK_FLAGS) | ||||||
|  | *_GCC48_AARCH64_PLATFORM_FLAGS   = | ||||||
|  | *_GCC48_AARCH64_PP_FLAGS         = $(ARCHCC_FLAGS) $(PLATFORM_FLAGS) DEF(GCC_PP_FLAGS) | ||||||
|  | *_GCC48_AARCH64_RC_FLAGS         = DEF(GCC_AARCH64_RC_FLAGS) | ||||||
|  | *_GCC48_AARCH64_VFRPP_FLAGS      = $(ARCHCC_FLAGS) $(PLATFORM_FLAGS) DEF(GCC_VFRPP_FLAGS) | ||||||
|  |  | ||||||
|  |   DEBUG_GCC48_AARCH64_CC_FLAGS   = DEF(GCC48_AARCH64_CC_FLAGS) -O0 | ||||||
|  | RELEASE_GCC48_AARCH64_CC_FLAGS   = DEF(GCC48_AARCH64_CC_FLAGS) -Wno-unused-but-set-variable | ||||||
|  |  | ||||||
| #################################################################################### | #################################################################################### | ||||||
| # | # | ||||||
| # Cygwin GCC And Intel ACPI Compiler | # Cygwin GCC And Intel ACPI Compiler | ||||||
| @@ -5532,7 +5687,7 @@ RELEASE_RVCTCYGWIN_ARM_CC_FLAGS  = "$(CCPATH_FLAG)" $(ARCHCC_FLAGS) $(PLATFORM_F | |||||||
| *_ARMGCC_*_ASL_OUTFLAGS      = DEF(IASL_OUTFLAGS) | *_ARMGCC_*_ASL_OUTFLAGS      = DEF(IASL_OUTFLAGS) | ||||||
| *_ARMGCC_*_ASLPP_FLAGS       = -x c -E -P | *_ARMGCC_*_ASLPP_FLAGS       = -x c -E -P | ||||||
| *_ARMGCC_*_ASLCC_FLAGS       = -x c | *_ARMGCC_*_ASLCC_FLAGS       = -x c | ||||||
| *_ARMGCC_*_ASLDLINK_FLAGS    = DEF(GCC_DLINK_FLAGS_COMMON) --entry _ReferenceAcpiTable | *_ARMGCC_*_ASLDLINK_FLAGS    = DEF(GCC_DLINK_FLAGS_COMMON) --entry ReferenceAcpiTable | ||||||
|  |  | ||||||
| ################## | ################## | ||||||
| # ARM definitions | # ARM definitions | ||||||
| @@ -5626,7 +5781,7 @@ RELEASE_ARMGCC_AARCH64_CC_FLAGS = $(ARCHCC_FLAGS) $(PLATFORM_FLAGS) DEF(GCC_AARC | |||||||
| *_ARMLINUXGCC_*_ASL_OUTFLAGS       = DEF(IASL_OUTFLAGS) | *_ARMLINUXGCC_*_ASL_OUTFLAGS       = DEF(IASL_OUTFLAGS) | ||||||
| *_ARMLINUXGCC_*_ASLPP_FLAGS        = -x c -E -P | *_ARMLINUXGCC_*_ASLPP_FLAGS        = -x c -E -P | ||||||
| *_ARMLINUXGCC_*_ASLCC_FLAGS        = -x c | *_ARMLINUXGCC_*_ASLCC_FLAGS        = -x c | ||||||
| *_ARMLINUXGCC_*_ASLDLINK_FLAGS     = DEF(GCC_DLINK_FLAGS_COMMON) --entry _ReferenceAcpiTable | *_ARMLINUXGCC_*_ASLDLINK_FLAGS     = DEF(GCC_DLINK_FLAGS_COMMON) --entry ReferenceAcpiTable | ||||||
|  |  | ||||||
| ################## | ################## | ||||||
| # ARM definitions | # ARM definitions | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| /** @file | /** @file | ||||||
|  |  | ||||||
| Copyright (c) 1999 - 2011, Intel Corporation. All rights reserved.<BR> | Copyright (c) 1999 - 2013, Intel Corporation. All rights reserved.<BR> | ||||||
| This program and the accompanying materials are licensed and made available  | This program and the accompanying materials are licensed and made available  | ||||||
| under the terms and conditions of the BSD License which accompanies this  | under the terms and conditions of the BSD License which accompanies this  | ||||||
| distribution.  The full text of the license may be found at | distribution.  The full text of the license may be found at | ||||||
| @@ -237,6 +237,7 @@ Returns: | |||||||
|   PCI_3_0_DATA_STRUCTURE    *PciDs30; |   PCI_3_0_DATA_STRUCTURE    *PciDs30; | ||||||
|   UINT32                    Index; |   UINT32                    Index; | ||||||
|   UINT8                     ByteCheckSum; |   UINT8                     ByteCheckSum; | ||||||
|  |   UINT16                    CodeType; | ||||||
|   |   | ||||||
|   PciDs23 = NULL; |   PciDs23 = NULL; | ||||||
|   PciDs30 = NULL; |   PciDs30 = NULL; | ||||||
| @@ -337,8 +338,10 @@ Returns: | |||||||
|   // |   // | ||||||
|   if (mOptions.Pci23 == 1) { |   if (mOptions.Pci23 == 1) { | ||||||
|     PciDs23->ImageLength = (UINT16) (TotalSize / 512); |     PciDs23->ImageLength = (UINT16) (TotalSize / 512); | ||||||
|  |     CodeType = PciDs23->CodeType; | ||||||
|   } else { |   } else { | ||||||
|     PciDs30->ImageLength = (UINT16) (TotalSize / 512); |     PciDs30->ImageLength = (UINT16) (TotalSize / 512); | ||||||
|  |     CodeType = PciDs30->CodeType; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|   // |   // | ||||||
| @@ -359,6 +362,7 @@ Returns: | |||||||
| 		} | 		} | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   if (CodeType != PCI_CODE_TYPE_EFI_IMAGE) { | ||||||
|     ByteCheckSum = 0; |     ByteCheckSum = 0; | ||||||
|     for (Index = 0; Index < FileSize - 1; Index++) { |     for (Index = 0; Index < FileSize - 1; Index++) { | ||||||
|       ByteCheckSum = (UINT8) (ByteCheckSum + Buffer[Index]); |       ByteCheckSum = (UINT8) (ByteCheckSum + Buffer[Index]); | ||||||
| @@ -368,6 +372,7 @@ Returns: | |||||||
|     if (mOptions.Verbose) { |     if (mOptions.Verbose) { | ||||||
|       VerboseMsg("  Checksum = %02x\n\n", Buffer[FileSize - 1]); |       VerboseMsg("  Checksum = %02x\n\n", Buffer[FileSize - 1]); | ||||||
|     } |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|   // |   // | ||||||
|   // Now copy the input file contents out to the output file |   // Now copy the input file contents out to the output file | ||||||
| @@ -449,6 +454,8 @@ Returns: | |||||||
|   UINT16                        MachineType; |   UINT16                        MachineType; | ||||||
|   UINT16                        SubSystem; |   UINT16                        SubSystem; | ||||||
|   UINT32                        HeaderPadBytes; |   UINT32                        HeaderPadBytes; | ||||||
|  |   UINT32                        PadBytesBeforeImage; | ||||||
|  |   UINT32                        PadBytesAfterImage; | ||||||
|  |  | ||||||
|   // |   // | ||||||
|   // Try to open the input file |   // Try to open the input file | ||||||
| @@ -559,6 +566,18 @@ Returns: | |||||||
|     TotalSize = (TotalSize + 0x200) &~0x1ff; |     TotalSize = (TotalSize + 0x200) &~0x1ff; | ||||||
|   } |   } | ||||||
|   // |   // | ||||||
|  |   // Workaround: | ||||||
|  |   //   If compressed, put the pad bytes after the image, | ||||||
|  |   //   else put the pad bytes before the image. | ||||||
|  |   // | ||||||
|  |   if ((InFile->FileFlags & FILE_FLAG_COMPRESS) != 0) { | ||||||
|  |     PadBytesBeforeImage = 0; | ||||||
|  |     PadBytesAfterImage = TotalSize - (FileSize + HeaderSize); | ||||||
|  |   } else { | ||||||
|  |     PadBytesBeforeImage = TotalSize - (FileSize + HeaderSize); | ||||||
|  |     PadBytesAfterImage = 0; | ||||||
|  |   } | ||||||
|  |   // | ||||||
|   // Check size |   // Check size | ||||||
|   // |   // | ||||||
|   if (TotalSize > MAX_OPTION_ROM_SIZE) { |   if (TotalSize > MAX_OPTION_ROM_SIZE) { | ||||||
| @@ -581,7 +600,7 @@ Returns: | |||||||
|   RomHdr.EfiSignature         = EFI_PCI_EXPANSION_ROM_HEADER_EFISIGNATURE; |   RomHdr.EfiSignature         = EFI_PCI_EXPANSION_ROM_HEADER_EFISIGNATURE; | ||||||
|   RomHdr.EfiSubsystem         = SubSystem; |   RomHdr.EfiSubsystem         = SubSystem; | ||||||
|   RomHdr.EfiMachineType       = MachineType; |   RomHdr.EfiMachineType       = MachineType; | ||||||
|   RomHdr.EfiImageHeaderOffset = (UINT16) HeaderSize; |   RomHdr.EfiImageHeaderOffset = (UINT16) (HeaderSize + PadBytesBeforeImage); | ||||||
|   RomHdr.PcirOffset           = (UINT16) (sizeof (RomHdr) + HeaderPadBytes); |   RomHdr.PcirOffset           = (UINT16) (sizeof (RomHdr) + HeaderPadBytes); | ||||||
|   // |   // | ||||||
|   // Set image as compressed or not |   // Set image as compressed or not | ||||||
| @@ -686,11 +705,18 @@ Returns: | |||||||
|       goto BailOut; |       goto BailOut; | ||||||
|     }  |     }  | ||||||
|   } |   } | ||||||
|   // |  | ||||||
|   // Keep track of how many bytes left to write |  | ||||||
|   // |  | ||||||
|   TotalSize -= HeaderSize; |  | ||||||
|  |  | ||||||
|  |   // | ||||||
|  |   // Pad head to make it a multiple of 512 bytes | ||||||
|  |   // | ||||||
|  |   while (PadBytesBeforeImage > 0) { | ||||||
|  |     if (putc (~0, OutFptr) == EOF) { | ||||||
|  |       Error (NULL, 0, 2000, "Failed to write trailing pad bytes output file!", NULL); | ||||||
|  |       Status = STATUS_ERROR; | ||||||
|  |       goto BailOut; | ||||||
|  |     } | ||||||
|  |     PadBytesBeforeImage--; | ||||||
|  |   } | ||||||
|   // |   // | ||||||
|   // Now dump the input file's contents to the output file |   // Now dump the input file's contents to the output file | ||||||
|   // |   // | ||||||
| @@ -700,18 +726,17 @@ Returns: | |||||||
|     goto BailOut; |     goto BailOut; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   TotalSize -= FileSize; |  | ||||||
|   // |   // | ||||||
|   // Pad the rest of the image to make it a multiple of 512 bytes |   // Pad the rest of the image to make it a multiple of 512 bytes | ||||||
|   // |   // | ||||||
|   while (TotalSize > 0) { |   while (PadBytesAfterImage > 0) { | ||||||
|     if (putc (~0, OutFptr) == EOF) { |     if (putc (~0, OutFptr) == EOF) { | ||||||
|       Error (NULL, 0, 2000, "Failed to write trailing pad bytes output file!", NULL); |       Error (NULL, 0, 2000, "Failed to write trailing pad bytes output file!", NULL); | ||||||
|       Status = STATUS_ERROR; |       Status = STATUS_ERROR; | ||||||
|       goto BailOut; |       goto BailOut; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     TotalSize--; |     PadBytesAfterImage--; | ||||||
|   } |   } | ||||||
|  |  | ||||||
| BailOut: | BailOut: | ||||||
| @@ -1205,7 +1230,7 @@ Returns: | |||||||
|   // |   // | ||||||
|   // Copyright declaration |   // Copyright declaration | ||||||
|   //  |   //  | ||||||
|   fprintf (stdout, "Copyright (c) 2007 - 2011, Intel Corporation. All rights reserved.\n\n"); |   fprintf (stdout, "Copyright (c) 2007 - 2013, Intel Corporation. All rights reserved.\n\n"); | ||||||
|  |  | ||||||
|   // |   // | ||||||
|   // Details Option |   // Details Option | ||||||
|   | |||||||
| @@ -458,9 +458,9 @@ Returns: | |||||||
|  |  | ||||||
|   case 0: |   case 0: | ||||||
|     // |     // | ||||||
|     // 8 byte alignment, mini alignment requirement for FFS file.  |     // 1 byte alignment | ||||||
|     // |     // | ||||||
|     *Alignment = 3; |     *Alignment = 0; | ||||||
|     break; |     break; | ||||||
|  |  | ||||||
|   case 1: |   case 1: | ||||||
| @@ -2212,7 +2212,8 @@ Returns: | |||||||
|                   mFvDataInfo.FvNameGuid.Data4[7]); |                   mFvDataInfo.FvNameGuid.Data4[7]); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   if (CompareGuid (&mFvDataInfo.FvFileSystemGuid, &mEfiFirmwareFileSystem2Guid) == 0) { |   if (CompareGuid (&mFvDataInfo.FvFileSystemGuid, &mEfiFirmwareFileSystem2Guid) == 0 || | ||||||
|  |     CompareGuid (&mFvDataInfo.FvFileSystemGuid, &mEfiFirmwareFileSystem3Guid) == 0) { | ||||||
|     mFvDataInfo.IsPiFvImage = TRUE; |     mFvDataInfo.IsPiFvImage = TRUE; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -168,7 +168,7 @@ Abstract: | |||||||
| // VTF (Firmware Volume Top File) signatures | // VTF (Firmware Volume Top File) signatures | ||||||
| // | // | ||||||
| #define IA32_X64_VTF_SIGNATURE_OFFSET    0x14 | #define IA32_X64_VTF_SIGNATURE_OFFSET    0x14 | ||||||
| #define IA32_X64_VTF0_SIGNATURE EFI_SIGNATURE_32('V','T','F',0) | #define IA32_X64_VTF0_SIGNATURE SIGNATURE_32('V','T','F',0) | ||||||
|  |  | ||||||
| // | // | ||||||
| // Defines to calculate the offset for PEI CORE entry points | // Defines to calculate the offset for PEI CORE entry points | ||||||
|   | |||||||
| @@ -14,4 +14,4 @@ | |||||||
|  |  | ||||||
| **/ | **/ | ||||||
|  |  | ||||||
| #define __BUILD_VERSION "Build 2610" | #define __BUILD_VERSION "Build 2640" | ||||||
|   | |||||||
| @@ -111,7 +111,7 @@ typedef struct { | |||||||
|   EFI_FV_BLOCK_MAP_ENTRY    BlockMap[1]; |   EFI_FV_BLOCK_MAP_ENTRY    BlockMap[1]; | ||||||
| } EFI_FIRMWARE_VOLUME_HEADER; | } EFI_FIRMWARE_VOLUME_HEADER; | ||||||
|  |  | ||||||
| #define EFI_FVH_SIGNATURE EFI_SIGNATURE_32 ('_', 'F', 'V', 'H') | #define EFI_FVH_SIGNATURE SIGNATURE_32 ('_', 'F', 'V', 'H') | ||||||
|  |  | ||||||
| /// | /// | ||||||
| /// Firmware Volume Header Revision definition | /// Firmware Volume Header Revision definition | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| /** @file | /** @file | ||||||
|   Defines data types and constants introduced in UEFI. |   Defines data types and constants introduced in UEFI. | ||||||
|  |  | ||||||
|   Copyright (c) 2006 - 2007, Intel Corporation. All rights reserved.<BR> |   Copyright (c) 2006 - 2013, Intel Corporation. All rights reserved.<BR> | ||||||
|  |  | ||||||
|   This program and the accompanying materials are licensed and made available |   This program and the accompanying materials are licensed and made available | ||||||
|   under the terms and conditions of the BSD License which accompanies this |   under the terms and conditions of the BSD License which accompanies this | ||||||
| @@ -146,10 +146,10 @@ typedef union { | |||||||
| // | // | ||||||
| // Define macros to build data structure signatures from characters. | // Define macros to build data structure signatures from characters. | ||||||
| // | // | ||||||
| #define EFI_SIGNATURE_16(A, B)        ((A) | (B << 8)) | #define SIGNATURE_16(A, B)        ((A) | (B << 8)) | ||||||
| #define EFI_SIGNATURE_32(A, B, C, D)  (EFI_SIGNATURE_16 (A, B) | (EFI_SIGNATURE_16 (C, D) << 16)) | #define SIGNATURE_32(A, B, C, D)  (SIGNATURE_16 (A, B) | (SIGNATURE_16 (C, D) << 16)) | ||||||
| #define EFI_SIGNATURE_64(A, B, C, D, E, F, G, H) \ | #define SIGNATURE_64(A, B, C, D, E, F, G, H) \ | ||||||
|     (EFI_SIGNATURE_32 (A, B, C, D) | ((UINT64) (EFI_SIGNATURE_32 (E, F, G, H)) << 32)) |     (SIGNATURE_32 (A, B, C, D) | ((UINT64) (SIGNATURE_32 (E, F, G, H)) << 32)) | ||||||
|  |  | ||||||
|  |  | ||||||
| // | // | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ | |||||||
|  |  | ||||||
|   @bug Fix text - doc as defined in MSFT EFI specification. |   @bug Fix text - doc as defined in MSFT EFI specification. | ||||||
|  |  | ||||||
|   Copyright (c) 2006 - 2008, Intel Corporation. All rights reserved.<BR> |   Copyright (c) 2006 - 2013, Intel Corporation. All rights reserved.<BR> | ||||||
|   Portions copyright (c) 2011 - 2013, ARM Ltd. All rights reserved.<BR> |   Portions copyright (c) 2011 - 2013, ARM Ltd. All rights reserved.<BR> | ||||||
|  |  | ||||||
|   This program and the accompanying materials are licensed and made available |   This program and the accompanying materials are licensed and made available | ||||||
| @@ -648,7 +648,7 @@ typedef struct { | |||||||
| /// | /// | ||||||
| /// Debug Data Structure defined by Apple Mach-O to Coff utility | /// Debug Data Structure defined by Apple Mach-O to Coff utility | ||||||
| /// | /// | ||||||
| #define CODEVIEW_SIGNATURE_MTOC  EFI_SIGNATURE_32('M', 'T', 'O', 'C') | #define CODEVIEW_SIGNATURE_MTOC  SIGNATURE_32('M', 'T', 'O', 'C') | ||||||
| typedef struct { | typedef struct { | ||||||
|   UINT32    Signature;                       ///< "MTOC" |   UINT32    Signature;                       ///< "MTOC" | ||||||
|   EFI_GUID  MachOUuid; |   EFI_GUID  MachOUuid; | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| /** @file | /** @file | ||||||
|   Support for PCI 2.2 standard. |   Support for PCI 2.2 standard. | ||||||
|  |  | ||||||
|   Copyright (c) 2006 - 2008, Intel Corporation. All rights reserved.<BR> |   Copyright (c) 2006 - 2013, Intel Corporation. All rights reserved.<BR> | ||||||
|  |  | ||||||
|   This program and the accompanying materials are licensed and made available |   This program and the accompanying materials are licensed and made available | ||||||
|   under the terms and conditions of the BSD License which accompanies this |   under the terms and conditions of the BSD License which accompanies this | ||||||
| @@ -335,7 +335,7 @@ typedef union { | |||||||
| #pragma pack() | #pragma pack() | ||||||
|  |  | ||||||
| #define PCI_EXPANSION_ROM_HEADER_SIGNATURE              0xaa55 | #define PCI_EXPANSION_ROM_HEADER_SIGNATURE              0xaa55 | ||||||
| #define PCI_DATA_STRUCTURE_SIGNATURE                    EFI_SIGNATURE_32 ('P', 'C', 'I', 'R') | #define PCI_DATA_STRUCTURE_SIGNATURE                    SIGNATURE_32 ('P', 'C', 'I', 'R') | ||||||
| #define PCI_CODE_TYPE_PCAT_IMAGE                        0x00 | #define PCI_CODE_TYPE_PCAT_IMAGE                        0x00 | ||||||
| #define PCI_CODE_TYPE_EFI_IMAGE                         0x03 | #define PCI_CODE_TYPE_EFI_IMAGE                         0x03 | ||||||
| #define EFI_PCI_EXPANSION_ROM_HEADER_COMPRESSED         0x0001 | #define EFI_PCI_EXPANSION_ROM_HEADER_COMPRESSED         0x0001 | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ | |||||||
|    |    | ||||||
|   VfrCompiler main class and main function. |   VfrCompiler main class and main function. | ||||||
|  |  | ||||||
| Copyright (c) 2004 - 2012, Intel Corporation. All rights reserved.<BR> | Copyright (c) 2004 - 2013, Intel Corporation. All rights reserved.<BR> | ||||||
| This program and the accompanying materials                           | This program and the accompanying materials                           | ||||||
| are licensed and made available under the terms and conditions of the BSD License          | are licensed and made available under the terms and conditions of the BSD License          | ||||||
| which accompanies this distribution.  The full text of the license may be found at         | which accompanies this distribution.  The full text of the license may be found at         | ||||||
| @@ -406,8 +406,8 @@ CVfrCompiler::Usage ( | |||||||
|   UINT32 Index; |   UINT32 Index; | ||||||
|   CONST  CHAR8 *Help[] = { |   CONST  CHAR8 *Help[] = { | ||||||
|     " ",  |     " ",  | ||||||
|     "VfrCompile version " VFR_COMPILER_VERSION __BUILD_VERSION VFR_COMPILER_UPDATE_TIME, |     "VfrCompile version " VFR_COMPILER_VERSION __BUILD_VERSION, | ||||||
|     "Copyright (c) 2004-2011 Intel Corporation. All rights reserved.", |     "Copyright (c) 2004-2013 Intel Corporation. All rights reserved.", | ||||||
|     " ", |     " ", | ||||||
|     "Usage: VfrCompile [options] VfrFile", |     "Usage: VfrCompile [options] VfrFile", | ||||||
|     " ", |     " ", | ||||||
|   | |||||||
| @@ -23,8 +23,7 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | |||||||
| #include "ParseInf.h" | #include "ParseInf.h" | ||||||
|  |  | ||||||
| #define PROGRAM_NAME                       "VfrCompile" | #define PROGRAM_NAME                       "VfrCompile" | ||||||
| #define VFR_COMPILER_VERSION               " 2.00 (UEFI 2.3.1)" | #define VFR_COMPILER_VERSION               " 2.00 (UEFI 2.4) " | ||||||
| #define VFR_COMPILER_UPDATE_TIME           " updated on 2011/07/15" |  | ||||||
| // | // | ||||||
| // This is how we invoke the C preprocessor on the VFR source file | // This is how we invoke the C preprocessor on the VFR source file | ||||||
| // to resolve #defines, #includes, etc. To make C source files | // to resolve #defines, #includes, etc. To make C source files | ||||||
|   | |||||||
| @@ -855,17 +855,6 @@ CFormPkg::DeclarePendingQuestion ( | |||||||
|       // Get VarStoreType |       // Get VarStoreType | ||||||
|       // |       // | ||||||
|       ReturnCode = lCVfrDataStorage.GetVarStoreId (FName, &Info.mVarStoreId); |       ReturnCode = lCVfrDataStorage.GetVarStoreId (FName, &Info.mVarStoreId); | ||||||
|       if (ReturnCode == VFR_RETURN_UNDEFINED) { |  | ||||||
|         lCVfrDataStorage.DeclareBufferVarStore ( |  | ||||||
|                            FName,  |  | ||||||
|                            LocalFormSetGuid,  |  | ||||||
|                            &lCVfrVarDataTypeDB,  |  | ||||||
|                            FName, |  | ||||||
|                            EFI_VARSTORE_ID_INVALID, |  | ||||||
|                            FALSE |  | ||||||
|                            ); |  | ||||||
|         ReturnCode = lCVfrDataStorage.GetVarStoreId (FName, &Info.mVarStoreId, LocalFormSetGuid);  |  | ||||||
|       } |  | ||||||
|       if (ReturnCode != VFR_RETURN_SUCCESS) { |       if (ReturnCode != VFR_RETURN_SUCCESS) { | ||||||
|         gCVfrErrorHandle.PrintMsg (pNode->mLineNo, FName, "Error", "Var Store Type is not defined"); |         gCVfrErrorHandle.PrintMsg (pNode->mLineNo, FName, "Error", "Var Store Type is not defined"); | ||||||
|         return ReturnCode; |         return ReturnCode; | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| ## @file | ## @file | ||||||
| # Generate AutoGen.h, AutoGen.c and *.depex files | # Generate AutoGen.h, AutoGen.c and *.depex files | ||||||
| # | # | ||||||
| # Copyright (c) 2007 - 2013, Intel Corporation. All rights reserved.<BR> | # Copyright (c) 2007 - 2014, Intel Corporation. All rights reserved.<BR> | ||||||
| # This program and the accompanying materials | # This program and the accompanying materials | ||||||
| # are licensed and made available under the terms and conditions of the BSD License | # are licensed and made available under the terms and conditions of the BSD License | ||||||
| # which accompanies this distribution.  The full text of the license may be found at | # which accompanies this distribution.  The full text of the license may be found at | ||||||
| @@ -334,6 +334,7 @@ class WorkspaceAutoGen(AutoGen): | |||||||
|             # Explicitly collect platform's dynamic PCDs |             # Explicitly collect platform's dynamic PCDs | ||||||
|             # |             # | ||||||
|             Pa.CollectPlatformDynamicPcds() |             Pa.CollectPlatformDynamicPcds() | ||||||
|  |             Pa.CollectFixedAtBuildPcds() | ||||||
|             self.AutoGenObjectList.append(Pa) |             self.AutoGenObjectList.append(Pa) | ||||||
|          |          | ||||||
|         # |         # | ||||||
| @@ -785,6 +786,7 @@ class PlatformAutoGen(AutoGen): | |||||||
|         self._PcdTokenNumber = None    # (TokenCName, TokenSpaceGuidCName) : GeneratedTokenNumber |         self._PcdTokenNumber = None    # (TokenCName, TokenSpaceGuidCName) : GeneratedTokenNumber | ||||||
|         self._DynamicPcdList = None    # [(TokenCName1, TokenSpaceGuidCName1), (TokenCName2, TokenSpaceGuidCName2), ...] |         self._DynamicPcdList = None    # [(TokenCName1, TokenSpaceGuidCName1), (TokenCName2, TokenSpaceGuidCName2), ...] | ||||||
|         self._NonDynamicPcdList = None # [(TokenCName1, TokenSpaceGuidCName1), (TokenCName2, TokenSpaceGuidCName2), ...] |         self._NonDynamicPcdList = None # [(TokenCName1, TokenSpaceGuidCName1), (TokenCName2, TokenSpaceGuidCName2), ...] | ||||||
|  |         self._NonDynamicPcdDict = {} | ||||||
|  |  | ||||||
|         self._ToolDefinitions = None |         self._ToolDefinitions = None | ||||||
|         self._ToolDefFile = None          # toolcode : tool path |         self._ToolDefFile = None          # toolcode : tool path | ||||||
| @@ -851,6 +853,32 @@ class PlatformAutoGen(AutoGen): | |||||||
|                             (self.MetaFile, self.Arch)) |                             (self.MetaFile, self.Arch)) | ||||||
|         self.IsMakeFileCreated = True |         self.IsMakeFileCreated = True | ||||||
|  |  | ||||||
|  |     ## Deal with Shared FixedAtBuild Pcds | ||||||
|  |     # | ||||||
|  |     def CollectFixedAtBuildPcds(self): | ||||||
|  |         for LibAuto in self.LibraryAutoGenList: | ||||||
|  |             FixedAtBuildPcds = {}   | ||||||
|  |             ShareFixedAtBuildPcdsSameValue = {}  | ||||||
|  |             for Module in LibAuto._ReferenceModules:                 | ||||||
|  |                 for Pcd in Module.FixedAtBuildPcds + LibAuto.FixedAtBuildPcds: | ||||||
|  |                     key = ".".join((Pcd.TokenSpaceGuidCName,Pcd.TokenCName))   | ||||||
|  |                     if key not in FixedAtBuildPcds: | ||||||
|  |                         ShareFixedAtBuildPcdsSameValue[key] = True | ||||||
|  |                         FixedAtBuildPcds[key] = Pcd.DefaultValue | ||||||
|  |                     else: | ||||||
|  |                         if FixedAtBuildPcds[key] != Pcd.DefaultValue: | ||||||
|  |                             ShareFixedAtBuildPcdsSameValue[key] = False       | ||||||
|  |             for Pcd in LibAuto.FixedAtBuildPcds: | ||||||
|  |                 key = ".".join((Pcd.TokenSpaceGuidCName,Pcd.TokenCName)) | ||||||
|  |                 if (Pcd.TokenCName,Pcd.TokenSpaceGuidCName) not in self.NonDynamicPcdDict: | ||||||
|  |                     continue | ||||||
|  |                 else: | ||||||
|  |                     DscPcd = self.NonDynamicPcdDict[(Pcd.TokenCName,Pcd.TokenSpaceGuidCName)] | ||||||
|  |                     if DscPcd.Type != "FixedAtBuild": | ||||||
|  |                         continue | ||||||
|  |                 if key in ShareFixedAtBuildPcdsSameValue and ShareFixedAtBuildPcdsSameValue[key]:                     | ||||||
|  |                     LibAuto.ConstPcd[key] = Pcd.DefaultValue | ||||||
|  |  | ||||||
|     ## Collect dynamic PCDs |     ## Collect dynamic PCDs | ||||||
|     # |     # | ||||||
|     #  Gather dynamic PCDs list from each module and their settings from platform |     #  Gather dynamic PCDs list from each module and their settings from platform | ||||||
| @@ -1296,6 +1324,13 @@ class PlatformAutoGen(AutoGen): | |||||||
|             self._PackageList = list(self._PackageList) |             self._PackageList = list(self._PackageList) | ||||||
|         return self._PackageList |         return self._PackageList | ||||||
|  |  | ||||||
|  |     def _GetNonDynamicPcdDict(self): | ||||||
|  |         if self._NonDynamicPcdDict: | ||||||
|  |             return self._NonDynamicPcdDict | ||||||
|  |         for Pcd in self.NonDynamicPcdList: | ||||||
|  |             self._NonDynamicPcdDict[(Pcd.TokenCName,Pcd.TokenSpaceGuidCName)] = Pcd | ||||||
|  |         return self._NonDynamicPcdDict | ||||||
|  |  | ||||||
|     ## Get list of non-dynamic PCDs |     ## Get list of non-dynamic PCDs | ||||||
|     def _GetNonDynamicPcdList(self): |     def _GetNonDynamicPcdList(self): | ||||||
|         if self._NonDynamicPcdList == None: |         if self._NonDynamicPcdList == None: | ||||||
| @@ -1373,6 +1408,8 @@ class PlatformAutoGen(AutoGen): | |||||||
|             for La in Ma.LibraryAutoGenList: |             for La in Ma.LibraryAutoGenList: | ||||||
|                 if La not in self._LibraryAutoGenList: |                 if La not in self._LibraryAutoGenList: | ||||||
|                     self._LibraryAutoGenList.append(La) |                     self._LibraryAutoGenList.append(La) | ||||||
|  |                 if Ma not in La._ReferenceModules: | ||||||
|  |                     La._ReferenceModules.append(Ma) | ||||||
|  |  | ||||||
|     ## Summarize ModuleAutoGen objects of all modules to be built for this platform |     ## Summarize ModuleAutoGen objects of all modules to be built for this platform | ||||||
|     def _GetModuleAutoGenList(self): |     def _GetModuleAutoGenList(self): | ||||||
| @@ -1911,6 +1948,7 @@ class PlatformAutoGen(AutoGen): | |||||||
|     PcdTokenNumber      = property(_GetPcdTokenNumbers)    # (TokenCName, TokenSpaceGuidCName) : GeneratedTokenNumber |     PcdTokenNumber      = property(_GetPcdTokenNumbers)    # (TokenCName, TokenSpaceGuidCName) : GeneratedTokenNumber | ||||||
|     DynamicPcdList      = property(_GetDynamicPcdList)    # [(TokenCName1, TokenSpaceGuidCName1), (TokenCName2, TokenSpaceGuidCName2), ...] |     DynamicPcdList      = property(_GetDynamicPcdList)    # [(TokenCName1, TokenSpaceGuidCName1), (TokenCName2, TokenSpaceGuidCName2), ...] | ||||||
|     NonDynamicPcdList   = property(_GetNonDynamicPcdList)    # [(TokenCName1, TokenSpaceGuidCName1), (TokenCName2, TokenSpaceGuidCName2), ...] |     NonDynamicPcdList   = property(_GetNonDynamicPcdList)    # [(TokenCName1, TokenSpaceGuidCName1), (TokenCName2, TokenSpaceGuidCName2), ...] | ||||||
|  |     NonDynamicPcdDict   = property(_GetNonDynamicPcdDict) | ||||||
|     PackageList         = property(_GetPackageList) |     PackageList         = property(_GetPackageList) | ||||||
|  |  | ||||||
|     ToolDefinition      = property(_GetToolDefinition)    # toolcode : tool path |     ToolDefinition      = property(_GetToolDefinition)    # toolcode : tool path | ||||||
| @@ -2028,11 +2066,34 @@ class ModuleAutoGen(AutoGen): | |||||||
|         self._FileTypes               = None |         self._FileTypes               = None | ||||||
|         self._BuildRules              = None |         self._BuildRules              = None | ||||||
|          |          | ||||||
|  |         ## The Modules referenced to this Library | ||||||
|  |         #  Only Library has this attribute | ||||||
|  |         self._ReferenceModules        = []         | ||||||
|  |          | ||||||
|  |         ## Store the FixedAtBuild Pcds | ||||||
|  |         #   | ||||||
|  |         self._FixedAtBuildPcds         = [] | ||||||
|  |         self.ConstPcd                  = {} | ||||||
|         return True |         return True | ||||||
|  |  | ||||||
|     def __repr__(self): |     def __repr__(self): | ||||||
|         return "%s [%s]" % (self.MetaFile, self.Arch) |         return "%s [%s]" % (self.MetaFile, self.Arch) | ||||||
|  |  | ||||||
|  |     # Get FixedAtBuild Pcds of this Module | ||||||
|  |     def _GetFixedAtBuildPcds(self): | ||||||
|  |         if self._FixedAtBuildPcds: | ||||||
|  |             return self._FixedAtBuildPcds | ||||||
|  |         for Pcd in self.ModulePcdList: | ||||||
|  |             if self.IsLibrary: | ||||||
|  |                 if not (Pcd.Pending == False and Pcd.Type == "FixedAtBuild"): | ||||||
|  |                     continue | ||||||
|  |             elif Pcd.Type != "FixedAtBuild": | ||||||
|  |                 continue | ||||||
|  |             if Pcd not in self._FixedAtBuildPcds: | ||||||
|  |                 self._FixedAtBuildPcds.append(Pcd) | ||||||
|  |                  | ||||||
|  |         return self._FixedAtBuildPcds         | ||||||
|  |  | ||||||
|     # Macros could be used in build_rule.txt (also Makefile) |     # Macros could be used in build_rule.txt (also Makefile) | ||||||
|     def _GetMacros(self): |     def _GetMacros(self): | ||||||
|         if self._Macro == None: |         if self._Macro == None: | ||||||
| @@ -3103,6 +3164,8 @@ class ModuleAutoGen(AutoGen): | |||||||
|     BuildOptionIncPathList  = property(_GetBuildOptionIncPathList) |     BuildOptionIncPathList  = property(_GetBuildOptionIncPathList) | ||||||
|     BuildCommand            = property(_GetBuildCommand) |     BuildCommand            = property(_GetBuildCommand) | ||||||
|      |      | ||||||
|  |     FixedAtBuildPcds         = property(_GetFixedAtBuildPcds) | ||||||
|  |  | ||||||
| # This acts like the main() function for the script, unless it is 'import'ed into another script. | # This acts like the main() function for the script, unless it is 'import'ed into another script. | ||||||
| if __name__ == '__main__': | if __name__ == '__main__': | ||||||
|     pass |     pass | ||||||
|   | |||||||
| @@ -1069,10 +1069,15 @@ def CreateLibraryPcdCode(Info, AutoGenC, AutoGenH, Pcd): | |||||||
|         AutoGenH.Append('#define %s  %s_gPcd_BinaryPatch_%s\n' %(GetModeName, Type, TokenCName)) |         AutoGenH.Append('#define %s  %s_gPcd_BinaryPatch_%s\n' %(GetModeName, Type, TokenCName)) | ||||||
|         AutoGenH.Append('#define %s(Value)  (%s = (Value))\n' % (SetModeName, PcdVariableName)) |         AutoGenH.Append('#define %s(Value)  (%s = (Value))\n' % (SetModeName, PcdVariableName)) | ||||||
|     if PcdItemType == TAB_PCDS_FIXED_AT_BUILD or PcdItemType == TAB_PCDS_FEATURE_FLAG: |     if PcdItemType == TAB_PCDS_FIXED_AT_BUILD or PcdItemType == TAB_PCDS_FEATURE_FLAG: | ||||||
|  |         key = ".".join((Pcd.TokenSpaceGuidCName,Pcd.TokenCName)) | ||||||
|  |          | ||||||
|         AutoGenH.Append('extern const %s _gPcd_FixedAtBuild_%s%s;\n' %(DatumType, TokenCName, Array)) |         AutoGenH.Append('extern const %s _gPcd_FixedAtBuild_%s%s;\n' %(DatumType, TokenCName, Array)) | ||||||
|         AutoGenH.Append('#define %s  %s_gPcd_FixedAtBuild_%s\n' %(GetModeName, Type, TokenCName)) |         AutoGenH.Append('#define %s  %s_gPcd_FixedAtBuild_%s\n' %(GetModeName, Type, TokenCName)) | ||||||
|         AutoGenH.Append('//#define %s  ASSERT(FALSE)  // It is not allowed to set value for a FIXED_AT_BUILD PCD\n' % SetModeName) |         AutoGenH.Append('//#define %s  ASSERT(FALSE)  // It is not allowed to set value for a FIXED_AT_BUILD PCD\n' % SetModeName) | ||||||
|          |          | ||||||
|  |         if PcdItemType == TAB_PCDS_FIXED_AT_BUILD and key in Info.ConstPcd: | ||||||
|  |             AutoGenH.Append('#define _PCD_VALUE_%s %s\n' %(TokenCName, Pcd.DefaultValue)) | ||||||
|  |          | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Create code for library constructor | ## Create code for library constructor | ||||||
|   | |||||||
| @@ -528,13 +528,20 @@ class DbSizeTableItemList (DbItemList): | |||||||
|         if RawDataList is None: |         if RawDataList is None: | ||||||
|             RawDataList = []         |             RawDataList = []         | ||||||
|         DbItemList.__init__(self, ItemSize, DataList, RawDataList) |         DbItemList.__init__(self, ItemSize, DataList, RawDataList) | ||||||
|  |     def GetListSize(self): | ||||||
|  |         length = 0 | ||||||
|  |         for Data in self.RawDataList: | ||||||
|  |             length += (1 + len(Data[1])) | ||||||
|  |         return length * self.ItemSize | ||||||
|     def PackData(self): |     def PackData(self): | ||||||
|         PackStr = "=HH" |         PackStr = "=H" | ||||||
|         Buffer = '' |         Buffer = '' | ||||||
|         for Data in self.RawDataList: |         for Data in self.RawDataList: | ||||||
|             Buffer += pack(PackStr,  |             Buffer += pack(PackStr,  | ||||||
|                            GetIntegerValue(Data[0]), |                            GetIntegerValue(Data[0])) | ||||||
|                            GetIntegerValue(Data[1])) |             for subData in Data[1]: | ||||||
|  |                 Buffer += pack(PackStr,  | ||||||
|  |                            GetIntegerValue(subData)) | ||||||
|         return Buffer |         return Buffer | ||||||
|  |  | ||||||
| ## DbStringItemList | ## DbStringItemList | ||||||
| @@ -732,7 +739,7 @@ def BuildExDataBase(Dict): | |||||||
|     DbPcdNameOffsetTable = DbItemList(4,RawDataList = PcdNameOffsetTable) |     DbPcdNameOffsetTable = DbItemList(4,RawDataList = PcdNameOffsetTable) | ||||||
|      |      | ||||||
|     SizeTableValue = zip(Dict['SIZE_TABLE_MAXIMUM_LENGTH'], Dict['SIZE_TABLE_CURRENT_LENGTH']) |     SizeTableValue = zip(Dict['SIZE_TABLE_MAXIMUM_LENGTH'], Dict['SIZE_TABLE_CURRENT_LENGTH']) | ||||||
|     DbSizeTableValue = DbSizeTableItemList(4, RawDataList = SizeTableValue) |     DbSizeTableValue = DbSizeTableItemList(2, RawDataList = SizeTableValue) | ||||||
|     InitValueUint16 = Dict['INIT_DB_VALUE_UINT16'] |     InitValueUint16 = Dict['INIT_DB_VALUE_UINT16'] | ||||||
|     DbInitValueUint16 = DbComItemList(2, RawDataList = InitValueUint16) |     DbInitValueUint16 = DbComItemList(2, RawDataList = InitValueUint16) | ||||||
|     VardefValueUint16 = Dict['VARDEF_DB_VALUE_UINT16'] |     VardefValueUint16 = Dict['VARDEF_DB_VALUE_UINT16'] | ||||||
| @@ -812,7 +819,7 @@ def BuildExDataBase(Dict): | |||||||
|         SkuIndexIndexTable = [(0) for i in xrange(len(Dict['SKU_INDEX_VALUE']))] |         SkuIndexIndexTable = [(0) for i in xrange(len(Dict['SKU_INDEX_VALUE']))] | ||||||
|         SkuIndexIndexTable[0] = 0  #Dict['SKU_INDEX_VALUE'][0][0] |         SkuIndexIndexTable[0] = 0  #Dict['SKU_INDEX_VALUE'][0][0] | ||||||
|         for i in range(1,len(Dict['SKU_INDEX_VALUE'])): |         for i in range(1,len(Dict['SKU_INDEX_VALUE'])): | ||||||
|             SkuIndexIndexTable[i] = SkuIndexIndexTable[i-1]+Dict['SKU_INDEX_VALUE'][i-1][0] |             SkuIndexIndexTable[i] = SkuIndexIndexTable[i-1]+Dict['SKU_INDEX_VALUE'][i-1][0] + 1 | ||||||
|     for (LocalTokenNumberTableIndex, (Offset, Table)) in enumerate(LocalTokenNumberTable): |     for (LocalTokenNumberTableIndex, (Offset, Table)) in enumerate(LocalTokenNumberTable): | ||||||
|         DbIndex = 0 |         DbIndex = 0 | ||||||
|         DbOffset = FixedHeaderLen |         DbOffset = FixedHeaderLen | ||||||
| @@ -829,7 +836,7 @@ def BuildExDataBase(Dict): | |||||||
|         LocalTokenNumberTable[LocalTokenNumberTableIndex] = DbOffset|int(TokenTypeValue) |         LocalTokenNumberTable[LocalTokenNumberTableIndex] = DbOffset|int(TokenTypeValue) | ||||||
|         # if PCD_TYPE_SKU_ENABLED, then we need to fix up the SkuTable |         # if PCD_TYPE_SKU_ENABLED, then we need to fix up the SkuTable | ||||||
|          |          | ||||||
|         SkuIndexTabalOffset = SkuIdTableOffset + Dict['SKUID_VALUE'][0] |         SkuIndexTabalOffset = SkuIdTableOffset + Dict['SKUID_VALUE'][0] + 1 | ||||||
|         if (TokenTypeValue & (0x2 << 28)): |         if (TokenTypeValue & (0x2 << 28)): | ||||||
|             SkuTable[SkuHeaderIndex] = (DbOffset|int(TokenTypeValue & ~(0x2<<28)), SkuIndexTabalOffset + SkuIndexIndexTable[SkuHeaderIndex]) |             SkuTable[SkuHeaderIndex] = (DbOffset|int(TokenTypeValue & ~(0x2<<28)), SkuIndexTabalOffset + SkuIndexIndexTable[SkuHeaderIndex]) | ||||||
|             LocalTokenNumberTable[LocalTokenNumberTableIndex] = (SkuTableOffset + SkuHeaderIndex * 8) | int(TokenTypeValue) |             LocalTokenNumberTable[LocalTokenNumberTableIndex] = (SkuTableOffset + SkuHeaderIndex * 8) | int(TokenTypeValue) | ||||||
| @@ -842,6 +849,7 @@ def BuildExDataBase(Dict): | |||||||
|  |  | ||||||
|     # resolve variable table offset  |     # resolve variable table offset  | ||||||
|     for VariableEntries in VariableTable: |     for VariableEntries in VariableTable: | ||||||
|  |         skuindex = 0 | ||||||
|         for VariableEntryPerSku in VariableEntries: |         for VariableEntryPerSku in VariableEntries: | ||||||
|             (VariableHeadGuidIndex, VariableHeadStringIndex, SKUVariableOffset, VariableOffset, VariableRefTable) = VariableEntryPerSku[:] |             (VariableHeadGuidIndex, VariableHeadStringIndex, SKUVariableOffset, VariableOffset, VariableRefTable) = VariableEntryPerSku[:] | ||||||
|             DbIndex = 0 |             DbIndex = 0 | ||||||
| @@ -853,7 +861,9 @@ def BuildExDataBase(Dict): | |||||||
|                 DbOffset += DbItemTotal[DbIndex].GetListSize() |                 DbOffset += DbItemTotal[DbIndex].GetListSize() | ||||||
|             else: |             else: | ||||||
|                 assert(False) |                 assert(False) | ||||||
|              |             if isinstance(VariableRefTable[0],list): | ||||||
|  |                 DbOffset += skuindex * 4    | ||||||
|  |             skuindex += 1 | ||||||
|             if DbIndex >= InitTableNum: |             if DbIndex >= InitTableNum: | ||||||
|                 assert(False) |                 assert(False) | ||||||
|  |  | ||||||
| @@ -995,10 +1005,6 @@ def CreatePcdDatabaseCode (Info, AutoGenC, AutoGenH): | |||||||
|     DbFile.write(PcdDbBuffer) |     DbFile.write(PcdDbBuffer) | ||||||
|     Changed = SaveFileOnChange(DbFileName, DbFile.getvalue(), True) |     Changed = SaveFileOnChange(DbFileName, DbFile.getvalue(), True) | ||||||
|  |  | ||||||
|  |  | ||||||
| def CArrayToArray(carray): |  | ||||||
|     return "{%s, 0x00}" % ", ".join(["0x%02x" % ord(C) for C in carray]) |  | ||||||
|  |  | ||||||
| ## Create PCD database in DXE or PEI phase | ## Create PCD database in DXE or PEI phase | ||||||
| # | # | ||||||
| #   @param      Platform    The platform object | #   @param      Platform    The platform object | ||||||
| @@ -1094,6 +1100,8 @@ def CreatePcdDatabasePhaseSpecificAutoGen (Platform, Phase): | |||||||
|     Dict['PCD_TOKENSPACE_MAP'] = [] |     Dict['PCD_TOKENSPACE_MAP'] = [] | ||||||
|     Dict['PCD_NAME_OFFSET'] = [] |     Dict['PCD_NAME_OFFSET'] = [] | ||||||
|      |      | ||||||
|  |     PCD_STRING_INDEX_MAP = {} | ||||||
|  |      | ||||||
|     StringTableIndex = 0 |     StringTableIndex = 0 | ||||||
|     StringTableSize = 0 |     StringTableSize = 0 | ||||||
|     NumberOfLocalTokens = 0 |     NumberOfLocalTokens = 0 | ||||||
| @@ -1105,6 +1113,7 @@ def CreatePcdDatabasePhaseSpecificAutoGen (Platform, Phase): | |||||||
|     GuidList = [] |     GuidList = [] | ||||||
|     i = 0 |     i = 0 | ||||||
|     for Pcd in Platform.DynamicPcdList: |     for Pcd in Platform.DynamicPcdList: | ||||||
|  |         VoidStarTypeCurrSize = [] | ||||||
|         i += 1 |         i += 1 | ||||||
|         CName = Pcd.TokenCName |         CName = Pcd.TokenCName | ||||||
|         TokenSpaceGuidCName = Pcd.TokenSpaceGuidCName |         TokenSpaceGuidCName = Pcd.TokenSpaceGuidCName | ||||||
| @@ -1156,6 +1165,7 @@ def CreatePcdDatabasePhaseSpecificAutoGen (Platform, Phase): | |||||||
|         SkuIndexTableTmp = [] |         SkuIndexTableTmp = [] | ||||||
|         SkuIndexTableTmp.append(0)   |         SkuIndexTableTmp.append(0)   | ||||||
|         SkuIdIndex = 1   |         SkuIdIndex = 1   | ||||||
|  |         VariableHeadList = [] | ||||||
|         for SkuName in Pcd.SkuInfoList: |         for SkuName in Pcd.SkuInfoList: | ||||||
|             Sku = Pcd.SkuInfoList[SkuName] |             Sku = Pcd.SkuInfoList[SkuName] | ||||||
|             SkuId = Sku.SkuId |             SkuId = Sku.SkuId | ||||||
| @@ -1171,11 +1181,14 @@ def CreatePcdDatabasePhaseSpecificAutoGen (Platform, Phase): | |||||||
|             if len(Sku.VariableName) > 0: |             if len(Sku.VariableName) > 0: | ||||||
|                 Pcd.TokenTypeList += ['PCD_TYPE_HII'] |                 Pcd.TokenTypeList += ['PCD_TYPE_HII'] | ||||||
|                 Pcd.InitString = 'INIT' |                 Pcd.InitString = 'INIT' | ||||||
|                 # store VariableName to stringTable and calculate the VariableHeadStringIndex |                 # Store all variable names of one HII PCD under different SKU to stringTable | ||||||
|                 if Sku.VariableName.startswith('{'): |                 # and calculate the VariableHeadStringIndex | ||||||
|                     VariableNameStructure = CArrayToArray(Sku.VariableName) |                 if SkuIdIndex - 2 == 0: | ||||||
|                 else: |                     for SkuName in Pcd.SkuInfoList: | ||||||
|                     VariableNameStructure = StringToArray(Sku.VariableName) |                         SkuInfo = Pcd.SkuInfoList[SkuName] | ||||||
|  |                         if SkuInfo.SkuId == None or SkuInfo.SkuId == '': | ||||||
|  |                             continue | ||||||
|  |                         VariableNameStructure = StringToArray(SkuInfo.VariableName) | ||||||
|                         if VariableNameStructure not in Dict['STRING_TABLE_VALUE']: |                         if VariableNameStructure not in Dict['STRING_TABLE_VALUE']: | ||||||
|                             Dict['STRING_TABLE_CNAME'].append(CName) |                             Dict['STRING_TABLE_CNAME'].append(CName) | ||||||
|                             Dict['STRING_TABLE_GUID'].append(TokenSpaceGuid) |                             Dict['STRING_TABLE_GUID'].append(TokenSpaceGuid) | ||||||
| @@ -1183,15 +1196,21 @@ def CreatePcdDatabasePhaseSpecificAutoGen (Platform, Phase): | |||||||
|                                 Dict['STRING_TABLE_INDEX'].append('') |                                 Dict['STRING_TABLE_INDEX'].append('') | ||||||
|                             else: |                             else: | ||||||
|                                 Dict['STRING_TABLE_INDEX'].append('_%d' % StringTableIndex) |                                 Dict['STRING_TABLE_INDEX'].append('_%d' % StringTableIndex) | ||||||
|  |                             VarNameSize = len(VariableNameStructure.replace(',',' ').split()) | ||||||
|                     Dict['STRING_TABLE_LENGTH'].append((len(Sku.VariableName) - 3 + 1) * 2 ) |                             Dict['STRING_TABLE_LENGTH'].append(VarNameSize ) | ||||||
|                             Dict['STRING_TABLE_VALUE'].append(VariableNameStructure) |                             Dict['STRING_TABLE_VALUE'].append(VariableNameStructure) | ||||||
|  |                             StringHeadOffsetList.append(str(StringTableSize) + 'U') | ||||||
|  |                             VarStringDbOffsetList = [] | ||||||
|  |                             VarStringDbOffsetList.append(StringTableSize) | ||||||
|  |                             Dict['STRING_DB_VALUE'].append(VarStringDbOffsetList)       | ||||||
|                             StringTableIndex += 1 |                             StringTableIndex += 1 | ||||||
|                     StringTableSize += (len(Sku.VariableName) - 3 + 1) * 2 |                             StringTableSize += len(VariableNameStructure.replace(',',' ').split()) | ||||||
|                         VariableHeadStringIndex = 0 |                         VariableHeadStringIndex = 0 | ||||||
|                         for Index in range(Dict['STRING_TABLE_VALUE'].index(VariableNameStructure)): |                         for Index in range(Dict['STRING_TABLE_VALUE'].index(VariableNameStructure)): | ||||||
|                             VariableHeadStringIndex += Dict['STRING_TABLE_LENGTH'][Index] |                             VariableHeadStringIndex += Dict['STRING_TABLE_LENGTH'][Index] | ||||||
|  |                         VariableHeadList.append(VariableHeadStringIndex) | ||||||
|                          |                          | ||||||
|  |                 VariableHeadStringIndex = VariableHeadList[SkuIdIndex - 2] | ||||||
|                 # store VariableGuid to GuidTable and get the VariableHeadGuidIndex |                 # store VariableGuid to GuidTable and get the VariableHeadGuidIndex | ||||||
|                 VariableGuidStructure = Sku.VariableGuidValue |                 VariableGuidStructure = Sku.VariableGuidValue | ||||||
|                 VariableGuid = GuidStructureStringToGuidValueName(VariableGuidStructure) |                 VariableGuid = GuidStructureStringToGuidValueName(VariableGuidStructure) | ||||||
| @@ -1256,11 +1275,8 @@ def CreatePcdDatabasePhaseSpecificAutoGen (Platform, Phase): | |||||||
|                 # Also add the VOID* string of VPD PCD to SizeTable  |                 # Also add the VOID* string of VPD PCD to SizeTable  | ||||||
|                 if Pcd.DatumType == 'VOID*': |                 if Pcd.DatumType == 'VOID*': | ||||||
|                     NumberOfSizeItems += 1 |                     NumberOfSizeItems += 1 | ||||||
|                     Dict['SIZE_TABLE_CNAME'].append(CName) |  | ||||||
|                     Dict['SIZE_TABLE_GUID'].append(TokenSpaceGuid) |  | ||||||
|                     # For VPD type of PCD, its current size is equal to its MAX size. |                     # For VPD type of PCD, its current size is equal to its MAX size. | ||||||
|                     Dict['SIZE_TABLE_CURRENT_LENGTH'].append(str(Pcd.MaxDatumSize) + 'U') |                     VoidStarTypeCurrSize = [str(Pcd.MaxDatumSize) + 'U']                  | ||||||
|                     Dict['SIZE_TABLE_MAXIMUM_LENGTH'].append(str(Pcd.MaxDatumSize) + 'U') |  | ||||||
|                 continue |                 continue | ||||||
|            |            | ||||||
|             if Pcd.DatumType == 'VOID*': |             if Pcd.DatumType == 'VOID*': | ||||||
| @@ -1278,29 +1294,36 @@ def CreatePcdDatabasePhaseSpecificAutoGen (Platform, Phase): | |||||||
|                     else: |                     else: | ||||||
|                         Dict['STRING_TABLE_INDEX'].append('_%d' % StringTableIndex) |                         Dict['STRING_TABLE_INDEX'].append('_%d' % StringTableIndex) | ||||||
|                     if Sku.DefaultValue[0] == 'L': |                     if Sku.DefaultValue[0] == 'L': | ||||||
|                         Size = (len(Sku.DefaultValue) - 3 + 1) * 2  |                         DefaultValueBinStructure = StringToArray(Sku.DefaultValue) | ||||||
|                         Dict['STRING_TABLE_VALUE'].append(StringToArray(Sku.DefaultValue)) |                         Size = len(DefaultValueBinStructure.replace(',',' ').split()) | ||||||
|  |                         Dict['STRING_TABLE_VALUE'].append(DefaultValueBinStructure) | ||||||
|                     elif Sku.DefaultValue[0] == '"': |                     elif Sku.DefaultValue[0] == '"': | ||||||
|  |                         DefaultValueBinStructure = StringToArray(Sku.DefaultValue) | ||||||
|                         Size = len(Sku.DefaultValue) -2 + 1 |                         Size = len(Sku.DefaultValue) -2 + 1 | ||||||
|                         Dict['STRING_TABLE_VALUE'].append(StringToArray(Sku.DefaultValue)) |                         Dict['STRING_TABLE_VALUE'].append(DefaultValueBinStructure) | ||||||
|                     elif Sku.DefaultValue[0] == '{': |                     elif Sku.DefaultValue[0] == '{': | ||||||
|                         Size = len(Sku.DefaultValue.replace(',',' ').split()) |                         DefaultValueBinStructure = StringToArray(Sku.DefaultValue) | ||||||
|                         Dict['STRING_TABLE_VALUE'].append(Sku.DefaultValue) |                         Size = len(Sku.DefaultValue.split(",")) | ||||||
|  |                         Dict['STRING_TABLE_VALUE'].append(DefaultValueBinStructure) | ||||||
|                      |                      | ||||||
|                     StringHeadOffsetList.append(str(StringTableSize) + 'U') |                     StringHeadOffsetList.append(str(StringTableSize) + 'U') | ||||||
|                     StringDbOffsetList.append(StringTableSize) |                     StringDbOffsetList.append(StringTableSize) | ||||||
|                     Dict['SIZE_TABLE_CNAME'].append(CName) |  | ||||||
|                     Dict['SIZE_TABLE_GUID'].append(TokenSpaceGuid) |  | ||||||
|                     Dict['SIZE_TABLE_CURRENT_LENGTH'].append(str(Size) + 'U') |  | ||||||
|                     Dict['SIZE_TABLE_MAXIMUM_LENGTH'].append(str(Pcd.MaxDatumSize) + 'U') |  | ||||||
|                     if Pcd.MaxDatumSize != '': |                     if Pcd.MaxDatumSize != '': | ||||||
|                         MaxDatumSize = int(Pcd.MaxDatumSize, 0) |                         MaxDatumSize = int(Pcd.MaxDatumSize, 0) | ||||||
|                         if MaxDatumSize < Size: |                         if MaxDatumSize < Size: | ||||||
|  |                             EdkLogger.error("build", AUTOGEN_ERROR, | ||||||
|  |                                             "The maximum size of VOID* type PCD '%s.%s' is less than its actual size occupied." % (Pcd.TokenSpaceGuidCName, Pcd.TokenCName), | ||||||
|  |                                             ExtraData="[%s]" % str(Platform)) | ||||||
|  |                     else: | ||||||
|                         MaxDatumSize = Size |                         MaxDatumSize = Size | ||||||
|                         Size = MaxDatumSize |                     StringTabLen = MaxDatumSize | ||||||
|                     Dict['STRING_TABLE_LENGTH'].append(Size) |                     if StringTabLen % 2: | ||||||
|  |                         StringTabLen += 1 | ||||||
|  |                     if Sku.VpdOffset == '': | ||||||
|  |                         VoidStarTypeCurrSize.append(str(Size) + 'U') | ||||||
|  |                     Dict['STRING_TABLE_LENGTH'].append(StringTabLen) | ||||||
|                     StringTableIndex += 1 |                     StringTableIndex += 1 | ||||||
|                     StringTableSize += (Size) |                     StringTableSize += (StringTabLen) | ||||||
|             else: |             else: | ||||||
|                 if "PCD_TYPE_HII" not in Pcd.TokenTypeList: |                 if "PCD_TYPE_HII" not in Pcd.TokenTypeList: | ||||||
|                     Pcd.TokenTypeList += ['PCD_TYPE_DATA'] |                     Pcd.TokenTypeList += ['PCD_TYPE_DATA'] | ||||||
| @@ -1326,8 +1349,14 @@ def CreatePcdDatabasePhaseSpecificAutoGen (Platform, Phase): | |||||||
|                 DbValueList.append(Sku.DefaultValue) |                 DbValueList.append(Sku.DefaultValue) | ||||||
|  |  | ||||||
|         Pcd.TokenTypeList = list(set(Pcd.TokenTypeList)) |         Pcd.TokenTypeList = list(set(Pcd.TokenTypeList)) | ||||||
|  |         if Pcd.DatumType == 'VOID*':   | ||||||
|  |             Dict['SIZE_TABLE_CNAME'].append(CName) | ||||||
|  |             Dict['SIZE_TABLE_GUID'].append(TokenSpaceGuid) | ||||||
|  |             Dict['SIZE_TABLE_MAXIMUM_LENGTH'].append(str(Pcd.MaxDatumSize) + 'U') | ||||||
|  |             Dict['SIZE_TABLE_CURRENT_LENGTH'].append(VoidStarTypeCurrSize) | ||||||
|          |          | ||||||
|         SkuIndexTableTmp[0] = len(SkuIndexTableTmp) |          | ||||||
|  |         SkuIndexTableTmp[0] = len(SkuIndexTableTmp) - 1 | ||||||
|         if len(Pcd.SkuInfoList) > 1: |         if len(Pcd.SkuInfoList) > 1: | ||||||
|             Dict['SKU_INDEX_VALUE'].append(SkuIndexTableTmp)             |             Dict['SKU_INDEX_VALUE'].append(SkuIndexTableTmp)             | ||||||
|  |  | ||||||
| @@ -1352,6 +1381,7 @@ def CreatePcdDatabasePhaseSpecificAutoGen (Platform, Phase): | |||||||
|             Dict['STRING_HEAD_NUMSKUS_DECL'].append(len(Pcd.SkuInfoList)) |             Dict['STRING_HEAD_NUMSKUS_DECL'].append(len(Pcd.SkuInfoList)) | ||||||
|             Dict['STRING_HEAD_VALUE'].append(', '.join(StringHeadOffsetList)) |             Dict['STRING_HEAD_VALUE'].append(', '.join(StringHeadOffsetList)) | ||||||
|             Dict['STRING_DB_VALUE'].append(StringDbOffsetList) |             Dict['STRING_DB_VALUE'].append(StringDbOffsetList) | ||||||
|  |             PCD_STRING_INDEX_MAP[len(Dict['STRING_HEAD_CNAME_DECL']) -1 ] = len(Dict['STRING_DB_VALUE']) -1 | ||||||
|         if 'PCD_TYPE_DATA' in Pcd.TokenTypeList: |         if 'PCD_TYPE_DATA' in Pcd.TokenTypeList: | ||||||
|             Dict[Pcd.InitString+'_CNAME_DECL_'+Pcd.DatumType].append(CName) |             Dict[Pcd.InitString+'_CNAME_DECL_'+Pcd.DatumType].append(CName) | ||||||
|             Dict[Pcd.InitString+'_GUID_DECL_'+Pcd.DatumType].append(TokenSpaceGuid) |             Dict[Pcd.InitString+'_GUID_DECL_'+Pcd.DatumType].append(TokenSpaceGuid) | ||||||
| @@ -1405,11 +1435,12 @@ def CreatePcdDatabasePhaseSpecificAutoGen (Platform, Phase): | |||||||
|             TokenSpaceGuidCNameArray = StringToArray('"' + TokenSpaceGuidCName + '"' ) |             TokenSpaceGuidCNameArray = StringToArray('"' + TokenSpaceGuidCName + '"' ) | ||||||
|             if TokenSpaceGuidCNameArray not in Dict['PCD_TOKENSPACE']: |             if TokenSpaceGuidCNameArray not in Dict['PCD_TOKENSPACE']: | ||||||
|                 Dict['PCD_TOKENSPACE'].append(TokenSpaceGuidCNameArray) |                 Dict['PCD_TOKENSPACE'].append(TokenSpaceGuidCNameArray) | ||||||
|                 Dict['PCD_TOKENSPACE_LENGTH'].append( len(TokenSpaceGuidCName) + 1 ) |                 Dict['PCD_TOKENSPACE_LENGTH'].append( len(TokenSpaceGuidCNameArray.split(",")) ) | ||||||
|             Dict['PCD_TOKENSPACE_MAP'][GeneratedTokenNumber] = Dict['PCD_TOKENSPACE'].index(TokenSpaceGuidCNameArray) |             Dict['PCD_TOKENSPACE_MAP'][GeneratedTokenNumber] = Dict['PCD_TOKENSPACE'].index(TokenSpaceGuidCNameArray) | ||||||
|             Dict['PCD_CNAME'][GeneratedTokenNumber] = StringToArray('"' + CName + '"' ) |             CNameBinArray = StringToArray('"' + CName + '"' ) | ||||||
|  |             Dict['PCD_CNAME'][GeneratedTokenNumber] = CNameBinArray | ||||||
|              |              | ||||||
|             Dict['PCD_CNAME_LENGTH'][GeneratedTokenNumber] = len(CName) + 1 |             Dict['PCD_CNAME_LENGTH'][GeneratedTokenNumber] = len(CNameBinArray.split(",")) | ||||||
|          |          | ||||||
|          |          | ||||||
|         Pcd.TokenTypeList = list(set(Pcd.TokenTypeList)) |         Pcd.TokenTypeList = list(set(Pcd.TokenTypeList)) | ||||||
| @@ -1427,6 +1458,7 @@ def CreatePcdDatabasePhaseSpecificAutoGen (Platform, Phase): | |||||||
|         if 'PCD_TYPE_STRING' in Pcd.TokenTypeList and 'PCD_TYPE_HII' not in Pcd.TokenTypeList: |         if 'PCD_TYPE_STRING' in Pcd.TokenTypeList and 'PCD_TYPE_HII' not in Pcd.TokenTypeList: | ||||||
|             # Find index by CName, TokenSpaceGuid |             # Find index by CName, TokenSpaceGuid | ||||||
|             Offset = GetMatchedIndex(CName, Dict['STRING_HEAD_CNAME_DECL'], TokenSpaceGuid, Dict['STRING_HEAD_GUID_DECL']) |             Offset = GetMatchedIndex(CName, Dict['STRING_HEAD_CNAME_DECL'], TokenSpaceGuid, Dict['STRING_HEAD_GUID_DECL']) | ||||||
|  |             Offset = PCD_STRING_INDEX_MAP[Offset] | ||||||
|             assert(Offset != -1) |             assert(Offset != -1) | ||||||
|             Table = Dict['STRING_DB_VALUE'] |             Table = Dict['STRING_DB_VALUE'] | ||||||
|         if 'PCD_TYPE_DATA' in Pcd.TokenTypeList: |         if 'PCD_TYPE_DATA' in Pcd.TokenTypeList: | ||||||
| @@ -1475,13 +1507,13 @@ def CreatePcdDatabasePhaseSpecificAutoGen (Platform, Phase): | |||||||
|             Dict['PCD_TOKENSPACE_OFFSET'].append(TokenSpaceIndex)    |             Dict['PCD_TOKENSPACE_OFFSET'].append(TokenSpaceIndex)    | ||||||
|         for index in range(len(Dict['PCD_TOKENSPACE'])): |         for index in range(len(Dict['PCD_TOKENSPACE'])): | ||||||
|             StringTableSize += Dict['PCD_TOKENSPACE_LENGTH'][index] |             StringTableSize += Dict['PCD_TOKENSPACE_LENGTH'][index] | ||||||
|          |             StringTableIndex += 1 | ||||||
|         for index in range(len(Dict['PCD_CNAME'])): |         for index in range(len(Dict['PCD_CNAME'])): | ||||||
|             Dict['PCD_CNAME_OFFSET'].append(StringTableSize)         |             Dict['PCD_CNAME_OFFSET'].append(StringTableSize)         | ||||||
|             Dict['PCD_NAME_OFFSET'].append(Dict['PCD_TOKENSPACE_OFFSET'][index]) |             Dict['PCD_NAME_OFFSET'].append(Dict['PCD_TOKENSPACE_OFFSET'][index]) | ||||||
|             Dict['PCD_NAME_OFFSET'].append(StringTableSize) |             Dict['PCD_NAME_OFFSET'].append(StringTableSize) | ||||||
|             StringTableSize += Dict['PCD_CNAME_LENGTH'][index] |             StringTableSize += Dict['PCD_CNAME_LENGTH'][index] | ||||||
|              |             StringTableIndex += 1 | ||||||
|     if GuidList != []: |     if GuidList != []: | ||||||
|         Dict['GUID_TABLE_EMPTY'] = 'FALSE' |         Dict['GUID_TABLE_EMPTY'] = 'FALSE' | ||||||
|         Dict['GUID_TABLE_SIZE'] = str(len(GuidList)) + 'U' |         Dict['GUID_TABLE_SIZE'] = str(len(GuidList)) + 'U' | ||||||
| @@ -1501,7 +1533,7 @@ def CreatePcdDatabasePhaseSpecificAutoGen (Platform, Phase): | |||||||
|     if Dict['SIZE_TABLE_CNAME'] == []: |     if Dict['SIZE_TABLE_CNAME'] == []: | ||||||
|         Dict['SIZE_TABLE_CNAME'].append('') |         Dict['SIZE_TABLE_CNAME'].append('') | ||||||
|         Dict['SIZE_TABLE_GUID'].append('') |         Dict['SIZE_TABLE_GUID'].append('') | ||||||
|         Dict['SIZE_TABLE_CURRENT_LENGTH'].append('0U') |         Dict['SIZE_TABLE_CURRENT_LENGTH'].append(['0U']) | ||||||
|         Dict['SIZE_TABLE_MAXIMUM_LENGTH'].append('0U') |         Dict['SIZE_TABLE_MAXIMUM_LENGTH'].append('0U') | ||||||
|  |  | ||||||
|     if NumberOfLocalTokens != 0: |     if NumberOfLocalTokens != 0: | ||||||
| @@ -1524,7 +1556,7 @@ def CreatePcdDatabasePhaseSpecificAutoGen (Platform, Phase): | |||||||
|     if NumberOfSkuEnabledPcd != 0:  |     if NumberOfSkuEnabledPcd != 0:  | ||||||
|         Dict['SKU_HEAD_SIZE'] = str(NumberOfSkuEnabledPcd) + 'U' |         Dict['SKU_HEAD_SIZE'] = str(NumberOfSkuEnabledPcd) + 'U' | ||||||
|      |      | ||||||
|     Dict['SKUID_VALUE'][0] = len(Dict['SKUID_VALUE']) |     Dict['SKUID_VALUE'][0] = len(Dict['SKUID_VALUE']) - 1 | ||||||
|      |      | ||||||
|     AutoGenH.Append(gPcdDatabaseAutoGenH.Replace(Dict)) |     AutoGenH.Append(gPcdDatabaseAutoGenH.Replace(Dict)) | ||||||
|     if NumberOfLocalTokens == 0: |     if NumberOfLocalTokens == 0: | ||||||
|   | |||||||
| @@ -13,4 +13,4 @@ | |||||||
| # WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | # WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||||
| # | # | ||||||
|  |  | ||||||
| gBUILD_VERSION = "Build 2610" | gBUILD_VERSION = "Build 2640" | ||||||
|   | |||||||
| @@ -486,6 +486,8 @@ PCDS_DYNAMICEX_DEFAULT = "PcdsDynamicExDefault" | |||||||
| PCDS_DYNAMICEX_VPD = "PcdsDynamicExVpd" | PCDS_DYNAMICEX_VPD = "PcdsDynamicExVpd" | ||||||
| PCDS_DYNAMICEX_HII = "PcdsDynamicExHii" | PCDS_DYNAMICEX_HII = "PcdsDynamicExHii" | ||||||
|  |  | ||||||
|  | SECTIONS_HAVE_ITEM_PCD = [PCDS_DYNAMIC_DEFAULT.upper(),PCDS_DYNAMIC_VPD.upper(),PCDS_DYNAMIC_HII.upper(), \ | ||||||
|  |                           PCDS_DYNAMICEX_DEFAULT.upper(),PCDS_DYNAMICEX_VPD.upper(),PCDS_DYNAMICEX_HII.upper()] | ||||||
| # Section allowed to have items after arch | # Section allowed to have items after arch | ||||||
| SECTIONS_HAVE_ITEM_AFTER_ARCH = [TAB_LIBRARY_CLASSES.upper(), TAB_DEPEX.upper(), TAB_USER_EXTENSIONS.upper(), | SECTIONS_HAVE_ITEM_AFTER_ARCH = [TAB_LIBRARY_CLASSES.upper(), TAB_DEPEX.upper(), TAB_USER_EXTENSIONS.upper(), | ||||||
|                                  PCDS_DYNAMIC_DEFAULT.upper(), |                                  PCDS_DYNAMIC_DEFAULT.upper(), | ||||||
|   | |||||||
| @@ -1238,9 +1238,16 @@ def AnalyzeDscPcd(Setting, PcdType, DataType=''): | |||||||
|         Value = FieldList[0] |         Value = FieldList[0] | ||||||
|         Size = '' |         Size = '' | ||||||
|         if len(FieldList) > 1: |         if len(FieldList) > 1: | ||||||
|  |             Type = FieldList[1] | ||||||
|  |             # Fix the PCD type when no DataType input | ||||||
|  |             if Type == 'VOID*': | ||||||
|  |                 DataType = 'VOID*' | ||||||
|  |             else: | ||||||
|                 Size = FieldList[1] |                 Size = FieldList[1] | ||||||
|  |         if len(FieldList) > 2: | ||||||
|  |             Size = FieldList[2] | ||||||
|         if DataType == 'VOID*': |         if DataType == 'VOID*': | ||||||
|             IsValid = (len(FieldList) <= 2) |             IsValid = (len(FieldList) <= 3) | ||||||
|         else: |         else: | ||||||
|             IsValid = (len(FieldList) <= 1) |             IsValid = (len(FieldList) <= 1) | ||||||
|         return [Value, '', Size], IsValid, 0 |         return [Value, '', Size], IsValid, 0 | ||||||
| @@ -1255,7 +1262,12 @@ def AnalyzeDscPcd(Setting, PcdType, DataType=''): | |||||||
|             Size = FieldList[2] |             Size = FieldList[2] | ||||||
|         else: |         else: | ||||||
|             if Type == 'VOID*': |             if Type == 'VOID*': | ||||||
|                 Size = str(len(Value)) |                 if Value.startswith("L"): | ||||||
|  |                     Size = str((len(Value)- 3 + 1) * 2) | ||||||
|  |                 elif Value.startswith("{"): | ||||||
|  |                     Size = str(len(Value.split(","))) | ||||||
|  |                 else: | ||||||
|  |                     Size = str(len(Value) -2 + 1 ) | ||||||
|         if DataType == 'VOID*': |         if DataType == 'VOID*': | ||||||
|             IsValid = (len(FieldList) <= 3) |             IsValid = (len(FieldList) <= 3) | ||||||
|         else: |         else: | ||||||
|   | |||||||
| @@ -401,16 +401,6 @@ def CleanString2(Line, CommentCharacter=DataType.TAB_COMMENT_SPLIT, AllowCppStyl | |||||||
|             Comment = Line[Index:].strip() |             Comment = Line[Index:].strip() | ||||||
|             Line = Line[0:Index].strip() |             Line = Line[0:Index].strip() | ||||||
|             break |             break | ||||||
|     if Comment: |  | ||||||
|         # Remove prefixed and trailing comment characters |  | ||||||
|         Start = 0 |  | ||||||
|         End = len(Comment) |  | ||||||
|         while Start < End and Comment.startswith(CommentCharacter, Start, End): |  | ||||||
|             Start += 1 |  | ||||||
|         while End >= 0 and Comment.endswith(CommentCharacter, Start, End): |  | ||||||
|             End -= 1 |  | ||||||
|         Comment = Comment[Start:End] |  | ||||||
|         Comment = Comment.strip() |  | ||||||
|  |  | ||||||
|     return Line, Comment |     return Line, Comment | ||||||
|  |  | ||||||
| @@ -811,11 +801,25 @@ def StringToArray(String): | |||||||
|             return "{%s, 0x00, 0x00}" % ", ".join(["0x%02x, 0x00" % ord(C) for C in String[2:-1]]) |             return "{%s, 0x00, 0x00}" % ", ".join(["0x%02x, 0x00" % ord(C) for C in String[2:-1]]) | ||||||
|     elif String.startswith('"'): |     elif String.startswith('"'): | ||||||
|         if String == "\"\"": |         if String == "\"\"": | ||||||
|             return "{0x00}"; |             return "{0x00,0x00}" | ||||||
|         else: |         else: | ||||||
|  |             StringLen = len(String[1:-1]) | ||||||
|  |             if StringLen % 2: | ||||||
|                 return "{%s, 0x00}" % ", ".join(["0x%02x" % ord(C) for C in String[1:-1]]) |                 return "{%s, 0x00}" % ", ".join(["0x%02x" % ord(C) for C in String[1:-1]]) | ||||||
|             else: |             else: | ||||||
|  |                 return "{%s, 0x00,0x00}" % ", ".join(["0x%02x" % ord(C) for C in String[1:-1]]) | ||||||
|  |     elif String.startswith('{'): | ||||||
|  |         StringLen = len(String.split(",")) | ||||||
|  |         if StringLen % 2: | ||||||
|  |             return "{%s, 0x00}" % ", ".join([ C for C in String[1:-1].split(',')]) | ||||||
|  |         else: | ||||||
|  |             return "{%s}" % ", ".join([ C for C in String[1:-1].split(',')]) | ||||||
|  |          | ||||||
|  |     else: | ||||||
|  |         if len(String.split()) % 2: | ||||||
|             return '{%s, 0}' % ', '.join(String.split()) |             return '{%s, 0}' % ', '.join(String.split()) | ||||||
|  |         else: | ||||||
|  |             return '{%s, 0,0}' % ', '.join(String.split()) | ||||||
|  |  | ||||||
| def StringArrayLength(String): | def StringArrayLength(String): | ||||||
|     if isinstance(String, unicode): |     if isinstance(String, unicode): | ||||||
|   | |||||||
| @@ -97,6 +97,7 @@ MODEL_META_DATA_COMMENT = 5016 | |||||||
| MODEL_META_DATA_GLOBAL_DEFINE = 5017 | MODEL_META_DATA_GLOBAL_DEFINE = 5017 | ||||||
| MODEL_META_DATA_SECTION_HEADER = 5100 | MODEL_META_DATA_SECTION_HEADER = 5100 | ||||||
| MODEL_META_DATA_SUBSECTION_HEADER = 5200 | MODEL_META_DATA_SUBSECTION_HEADER = 5200 | ||||||
|  | MODEL_META_DATA_TAIL_COMMENT = 5300 | ||||||
|  |  | ||||||
| MODEL_EXTERNAL_DEPENDENCY = 10000 | MODEL_EXTERNAL_DEPENDENCY = 10000 | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| ## @file | ## @file | ||||||
| # generate capsule | # generate capsule | ||||||
| # | # | ||||||
| #  Copyright (c) 2007, Intel Corporation. All rights reserved.<BR> | #  Copyright (c) 2007-2013, Intel Corporation. All rights reserved.<BR> | ||||||
| # | # | ||||||
| #  This program and the accompanying materials | #  This program and the accompanying materials | ||||||
| #  are licensed and made available under the terms and conditions of the BSD License | #  are licensed and made available under the terms and conditions of the BSD License | ||||||
| @@ -135,3 +135,23 @@ class CapsuleAnyFile (CapsuleData): | |||||||
|     # |     # | ||||||
|     def GenCapsuleSubItem(self): |     def GenCapsuleSubItem(self): | ||||||
|         return self.FileName |         return self.FileName | ||||||
|  |      | ||||||
|  | ## Afile class for capsule data | ||||||
|  | # | ||||||
|  | # | ||||||
|  | class CapsuleAfile (CapsuleData): | ||||||
|  |     ## The constructor | ||||||
|  |     # | ||||||
|  |     #   @param  self        The object pointer | ||||||
|  |     # | ||||||
|  |     def __init__(self) : | ||||||
|  |         self.Ffs = None | ||||||
|  |         self.FileName = None | ||||||
|  |  | ||||||
|  |     ## generate Afile capsule data | ||||||
|  |     # | ||||||
|  |     #   @param  self        The object pointer | ||||||
|  |     #   @retval string      Generated file name | ||||||
|  |     # | ||||||
|  |     def GenCapsuleSubItem(self): | ||||||
|  |         return self.FileName | ||||||
| @@ -1,7 +1,7 @@ | |||||||
| ## @file | ## @file | ||||||
| # parse FDF file | # parse FDF file | ||||||
| # | # | ||||||
| #  Copyright (c) 2007 - 2013, Intel Corporation. All rights reserved.<BR> | #  Copyright (c) 2007 - 2014, Intel Corporation. All rights reserved.<BR> | ||||||
| # | # | ||||||
| #  This program and the accompanying materials | #  This program and the accompanying materials | ||||||
| #  are licensed and made available under the terms and conditions of the BSD License | #  are licensed and made available under the terms and conditions of the BSD License | ||||||
| @@ -77,6 +77,7 @@ SEPERATOR_TUPLE = ('=', '|', ',', '{', '}') | |||||||
|  |  | ||||||
| RegionSizePattern = re.compile("\s*(?P<base>(?:0x|0X)?[a-fA-F0-9]+)\s*\|\s*(?P<size>(?:0x|0X)?[a-fA-F0-9]+)\s*") | RegionSizePattern = re.compile("\s*(?P<base>(?:0x|0X)?[a-fA-F0-9]+)\s*\|\s*(?P<size>(?:0x|0X)?[a-fA-F0-9]+)\s*") | ||||||
| RegionSizeGuidPattern = re.compile("\s*(?P<base>\w+\.\w+)\s*\|\s*(?P<size>\w+\.\w+)\s*") | RegionSizeGuidPattern = re.compile("\s*(?P<base>\w+\.\w+)\s*\|\s*(?P<size>\w+\.\w+)\s*") | ||||||
|  | RegionOffsetPcdPattern = re.compile("\s*(?P<base>\w+\.\w+)\s*$") | ||||||
| ShortcutPcdPattern = re.compile("\s*\w+\s*=\s*(?P<value>(?:0x|0X)?[a-fA-F0-9]+)\s*\|\s*(?P<name>\w+\.\w+)\s*") | ShortcutPcdPattern = re.compile("\s*\w+\s*=\s*(?P<value>(?:0x|0X)?[a-fA-F0-9]+)\s*\|\s*(?P<name>\w+\.\w+)\s*") | ||||||
|  |  | ||||||
| IncludeFileList = [] | IncludeFileList = [] | ||||||
| @@ -1732,8 +1733,7 @@ class FdfParser: | |||||||
|         try: |         try: | ||||||
|             return long( |             return long( | ||||||
|                 ValueExpression(Expr, |                 ValueExpression(Expr, | ||||||
|                                 dict(['%s.%s' % (Pcd[1], Pcd[0]), Val]  |                                 self.__CollectMacroPcd() | ||||||
|                                      for Pcd, Val in self.Profile.PcdDict.iteritems()) |  | ||||||
|                                 )(True),0) |                                 )(True),0) | ||||||
|         except Exception: |         except Exception: | ||||||
|             self.SetFileBufferPos(StartPos) |             self.SetFileBufferPos(StartPos) | ||||||
| @@ -1769,14 +1769,24 @@ class FdfParser: | |||||||
|             return True |             return True | ||||||
|  |  | ||||||
|         if not self.__Token in ("SET", "FV", "FILE", "DATA", "CAPSULE"): |         if not self.__Token in ("SET", "FV", "FILE", "DATA", "CAPSULE"): | ||||||
|  |             # | ||||||
|  |             # If next token is a word which is not a valid FV type, it might be part of [PcdOffset[|PcdSize]] | ||||||
|  |             # Or it might be next region's offset described by an expression which starts with a PCD. | ||||||
|  |             #    PcdOffset[|PcdSize] or OffsetPcdExpression|Size | ||||||
|  |             # | ||||||
|             self.__UndoToken() |             self.__UndoToken() | ||||||
|  |             IsRegionPcd = (RegionSizeGuidPattern.match(self.__CurrentLine()[self.CurrentOffsetWithinLine:]) or | ||||||
|  |                            RegionOffsetPcdPattern.match(self.__CurrentLine()[self.CurrentOffsetWithinLine:])) | ||||||
|  |             if IsRegionPcd: | ||||||
|                 RegionObj.PcdOffset = self.__GetNextPcdName() |                 RegionObj.PcdOffset = self.__GetNextPcdName() | ||||||
|                 self.Profile.PcdDict[RegionObj.PcdOffset] = "0x%08X" % (RegionObj.Offset + long(Fd.BaseAddress, 0)) |                 self.Profile.PcdDict[RegionObj.PcdOffset] = "0x%08X" % (RegionObj.Offset + long(Fd.BaseAddress, 0)) | ||||||
|  |                 self.__PcdDict['%s.%s' % (RegionObj.PcdOffset[1], RegionObj.PcdOffset[0])] = "0x%x" % RegionObj.Offset | ||||||
|                 FileLineTuple = GetRealFileLine(self.FileName, self.CurrentLineNumber) |                 FileLineTuple = GetRealFileLine(self.FileName, self.CurrentLineNumber) | ||||||
|                 self.Profile.PcdFileLineDict[RegionObj.PcdOffset] = FileLineTuple |                 self.Profile.PcdFileLineDict[RegionObj.PcdOffset] = FileLineTuple | ||||||
|                 if self.__IsToken( "|"): |                 if self.__IsToken( "|"): | ||||||
|                     RegionObj.PcdSize = self.__GetNextPcdName() |                     RegionObj.PcdSize = self.__GetNextPcdName() | ||||||
|                     self.Profile.PcdDict[RegionObj.PcdSize] = "0x%08X" % RegionObj.Size |                     self.Profile.PcdDict[RegionObj.PcdSize] = "0x%08X" % RegionObj.Size | ||||||
|  |                     self.__PcdDict['%s.%s' % (RegionObj.PcdSize[1], RegionObj.PcdSize[0])] = "0x%x" % RegionObj.Size | ||||||
|                     FileLineTuple = GetRealFileLine(self.FileName, self.CurrentLineNumber) |                     FileLineTuple = GetRealFileLine(self.FileName, self.CurrentLineNumber) | ||||||
|                     self.Profile.PcdFileLineDict[RegionObj.PcdSize] = FileLineTuple |                     self.Profile.PcdFileLineDict[RegionObj.PcdSize] = FileLineTuple | ||||||
|  |  | ||||||
| @@ -1805,6 +1815,9 @@ class FdfParser: | |||||||
|             self.__UndoToken() |             self.__UndoToken() | ||||||
|             self.__GetRegionDataType( RegionObj) |             self.__GetRegionDataType( RegionObj) | ||||||
|         else: |         else: | ||||||
|  |             self.__UndoToken() | ||||||
|  |             if self.__GetRegionLayout(Fd): | ||||||
|  |                 return True | ||||||
|             raise Warning("A valid region type was not found. " |             raise Warning("A valid region type was not found. " | ||||||
|                           "Valid types are [SET, FV, CAPSULE, FILE, DATA]. This error occurred", |                           "Valid types are [SET, FV, CAPSULE, FILE, DATA]. This error occurred", | ||||||
|                           self.FileName, self.CurrentLineNumber) |                           self.FileName, self.CurrentLineNumber) | ||||||
| @@ -2158,8 +2171,9 @@ class FdfParser: | |||||||
|     #   @retval None |     #   @retval None | ||||||
|     # |     # | ||||||
|     def __GetFvAttributes(self, FvObj): |     def __GetFvAttributes(self, FvObj): | ||||||
|  |         IsWordToken = False | ||||||
|         while self.__GetNextWord(): |         while self.__GetNextWord(): | ||||||
|  |             IsWordToken = True | ||||||
|             name = self.__Token |             name = self.__Token | ||||||
|             if name not in ("ERASE_POLARITY", "MEMORY_MAPPED", \ |             if name not in ("ERASE_POLARITY", "MEMORY_MAPPED", \ | ||||||
|                            "STICKY_WRITE", "LOCK_CAP", "LOCK_STATUS", "WRITE_ENABLED_CAP", \ |                            "STICKY_WRITE", "LOCK_CAP", "LOCK_STATUS", "WRITE_ENABLED_CAP", \ | ||||||
| @@ -2178,7 +2192,7 @@ class FdfParser: | |||||||
|  |  | ||||||
|             FvObj.FvAttributeDict[name] = self.__Token |             FvObj.FvAttributeDict[name] = self.__Token | ||||||
|  |  | ||||||
|         return True |         return IsWordToken | ||||||
|      |      | ||||||
|     ## __GetFvNameGuid() method |     ## __GetFvNameGuid() method | ||||||
|     # |     # | ||||||
| @@ -2562,22 +2576,7 @@ class FdfParser: | |||||||
|             FfsFileObj.CurrentLineNum = self.CurrentLineNumber |             FfsFileObj.CurrentLineNum = self.CurrentLineNumber | ||||||
|             FfsFileObj.CurrentLineContent = self.__CurrentLine() |             FfsFileObj.CurrentLineContent = self.__CurrentLine() | ||||||
|             FfsFileObj.FileName = self.__Token |             FfsFileObj.FileName = self.__Token | ||||||
|             if FfsFileObj.FileName.replace('$(WORKSPACE)', '').find('$') == -1: |             self.__VerifyFile(FfsFileObj.FileName) | ||||||
|                 # |  | ||||||
|                 # For file in OUTPUT_DIRECTORY will not check whether it exist or not at AutoGen phase. |  | ||||||
|                 # |  | ||||||
|                 if not GlobalData.gAutoGenPhase: |  | ||||||
|                     #do case sensitive check for file path |  | ||||||
|                     ErrorCode, ErrorInfo = PathClass(NormPath(FfsFileObj.FileName), GenFdsGlobalVariable.WorkSpaceDir).Validate() |  | ||||||
|                     if ErrorCode != 0: |  | ||||||
|                         EdkLogger.error("GenFds", ErrorCode, ExtraData=ErrorInfo) |  | ||||||
|                 else: |  | ||||||
|                     if not self.__GetMacroValue("OUTPUT_DIRECTORY") in FfsFileObj.FileName: |  | ||||||
|                         #do case sensitive check for file path |  | ||||||
|                         ErrorCode, ErrorInfo = PathClass(NormPath(FfsFileObj.FileName), GenFdsGlobalVariable.WorkSpaceDir).Validate() |  | ||||||
|                         if ErrorCode != 0: |  | ||||||
|                             EdkLogger.error("GenFds", ErrorCode, ExtraData=ErrorInfo)                     |  | ||||||
|  |  | ||||||
|  |  | ||||||
|         if not self.__IsToken( "}"): |         if not self.__IsToken( "}"): | ||||||
|             raise Warning("expected '}'", self.FileName, self.CurrentLineNumber) |             raise Warning("expected '}'", self.FileName, self.CurrentLineNumber) | ||||||
| @@ -2823,11 +2822,7 @@ class FdfParser: | |||||||
|                 if not self.__GetNextToken(): |                 if not self.__GetNextToken(): | ||||||
|                     raise Warning("expected section file path", self.FileName, self.CurrentLineNumber) |                     raise Warning("expected section file path", self.FileName, self.CurrentLineNumber) | ||||||
|                 DataSectionObj.SectFileName = self.__Token |                 DataSectionObj.SectFileName = self.__Token | ||||||
|                 if DataSectionObj.SectFileName.replace('$(WORKSPACE)', '').find('$') == -1: |                 self.__VerifyFile(DataSectionObj.SectFileName) | ||||||
|                     #do case sensitive check for file path |  | ||||||
|                     ErrorCode, ErrorInfo = PathClass(NormPath(DataSectionObj.SectFileName), GenFdsGlobalVariable.WorkSpaceDir).Validate() |  | ||||||
|                     if ErrorCode != 0: |  | ||||||
|                         EdkLogger.error("GenFds", ErrorCode, ExtraData=ErrorInfo) |  | ||||||
|             else: |             else: | ||||||
|                 if not self.__GetCglSection(DataSectionObj): |                 if not self.__GetCglSection(DataSectionObj): | ||||||
|                     return False |                     return False | ||||||
| @@ -2836,6 +2831,21 @@ class FdfParser: | |||||||
|  |  | ||||||
|         return True |         return True | ||||||
|  |  | ||||||
|  |     ## __VerifyFile | ||||||
|  |     # | ||||||
|  |     #    Check if file exists or not: | ||||||
|  |     #      If current phase if GenFds, the file must exist; | ||||||
|  |     #      If current phase is AutoGen and the file is not in $(OUTPUT_DIRECTORY), the file must exist | ||||||
|  |     #    @param FileName: File path to be verified. | ||||||
|  |     # | ||||||
|  |     def __VerifyFile(self, FileName): | ||||||
|  |         if FileName.replace('$(WORKSPACE)', '').find('$') != -1: | ||||||
|  |             return | ||||||
|  |         if not GlobalData.gAutoGenPhase or not self.__GetMacroValue("OUTPUT_DIRECTORY") in FileName: | ||||||
|  |             ErrorCode, ErrorInfo = PathClass(NormPath(FileName), GenFdsGlobalVariable.WorkSpaceDir).Validate() | ||||||
|  |             if ErrorCode != 0: | ||||||
|  |                 EdkLogger.error("GenFds", ErrorCode, ExtraData=ErrorInfo) | ||||||
|  |  | ||||||
|     ## __GetCglSection() method |     ## __GetCglSection() method | ||||||
|     # |     # | ||||||
|     #   Get compressed or GUIDed section for Obj |     #   Get compressed or GUIDed section for Obj | ||||||
| @@ -3066,12 +3076,14 @@ class FdfParser: | |||||||
|                     Value += self.__Token.strip() |                     Value += self.__Token.strip() | ||||||
|             elif Name == 'OEM_CAPSULE_FLAGS': |             elif Name == 'OEM_CAPSULE_FLAGS': | ||||||
|                 Value = self.__Token.strip() |                 Value = self.__Token.strip() | ||||||
|  |                 if not Value.upper().startswith('0X'): | ||||||
|  |                     raise Warning("expected hex value between 0x0000 and 0xFFFF", self.FileName, self.CurrentLineNumber) | ||||||
|                 try: |                 try: | ||||||
|                     Value = int(Value, 0) |                     Value = int(Value, 0) | ||||||
|                 except ValueError: |                 except ValueError: | ||||||
|                     raise Warning("expected integer value between 0x0000 and 0xFFFF", self.FileName, self.CurrentLineNumber) |                     raise Warning("expected hex value between 0x0000 and 0xFFFF", self.FileName, self.CurrentLineNumber) | ||||||
|                 if not 0x0000 <= Value <= 0xFFFF: |                 if not 0x0000 <= Value <= 0xFFFF: | ||||||
|                     raise Warning("expected integer value between 0x0000 and 0xFFFF", self.FileName, self.CurrentLineNumber) |                     raise Warning("expected hex value between 0x0000 and 0xFFFF", self.FileName, self.CurrentLineNumber) | ||||||
|                 Value = self.__Token.strip() |                 Value = self.__Token.strip() | ||||||
|             else: |             else: | ||||||
|                 Value = self.__Token.strip() |                 Value = self.__Token.strip() | ||||||
| @@ -3095,7 +3107,8 @@ class FdfParser: | |||||||
|             IsFv = self.__GetFvStatement(Obj) |             IsFv = self.__GetFvStatement(Obj) | ||||||
|             IsFd = self.__GetFdStatement(Obj) |             IsFd = self.__GetFdStatement(Obj) | ||||||
|             IsAnyFile = self.__GetAnyFileStatement(Obj) |             IsAnyFile = self.__GetAnyFileStatement(Obj) | ||||||
|             if not (IsInf or IsFile or IsFv or IsFd or IsAnyFile): |             IsAfile = self.__GetAfileStatement(Obj) | ||||||
|  |             if not (IsInf or IsFile or IsFv or IsFd or IsAnyFile or IsAfile): | ||||||
|                 break |                 break | ||||||
|  |  | ||||||
|     ## __GetFvStatement() method |     ## __GetFvStatement() method | ||||||
| @@ -3188,6 +3201,47 @@ class FdfParser: | |||||||
|         CapsuleObj.CapsuleDataList.append(CapsuleAnyFile) |         CapsuleObj.CapsuleDataList.append(CapsuleAnyFile) | ||||||
|         return True |         return True | ||||||
|      |      | ||||||
|  |     ## __GetAfileStatement() method | ||||||
|  |     # | ||||||
|  |     #   Get Afile for capsule | ||||||
|  |     # | ||||||
|  |     #   @param  self        The object pointer | ||||||
|  |     #   @param  CapsuleObj  for whom Afile is got | ||||||
|  |     #   @retval True        Successfully find a Afile statement | ||||||
|  |     #   @retval False       Not able to find a Afile statement | ||||||
|  |     # | ||||||
|  |     def __GetAfileStatement(self, CapsuleObj): | ||||||
|  |  | ||||||
|  |         if not self.__IsKeyword("APPEND"): | ||||||
|  |             return False | ||||||
|  |  | ||||||
|  |         if not self.__IsToken("="): | ||||||
|  |             raise Warning("expected '='", self.FileName, self.CurrentLineNumber) | ||||||
|  |  | ||||||
|  |         if not self.__GetNextToken(): | ||||||
|  |             raise Warning("expected Afile name", self.FileName, self.CurrentLineNumber) | ||||||
|  |          | ||||||
|  |         AfileName = self.__Token | ||||||
|  |         AfileBaseName = os.path.basename(AfileName) | ||||||
|  |          | ||||||
|  |         if os.path.splitext(AfileBaseName)[1]  not in [".bin",".BIN",".Bin",".dat",".DAT",".Dat",".data",".DATA",".Data"]: | ||||||
|  |             raise Warning('invalid binary file type, should be one of "bin","BIN","Bin","dat","DAT","Dat","data","DATA","Data"', \ | ||||||
|  |                           self.FileName, self.CurrentLineNumber) | ||||||
|  |          | ||||||
|  |         if not os.path.isabs(AfileName): | ||||||
|  |             AfileName = GenFdsGlobalVariable.ReplaceWorkspaceMacro(AfileName) | ||||||
|  |             self.__VerifyFile(AfileName) | ||||||
|  |         else: | ||||||
|  |             if not os.path.exists(AfileName): | ||||||
|  |                 raise Warning('%s does not exist' % AfileName, self.FileName, self.CurrentLineNumber) | ||||||
|  |             else: | ||||||
|  |                 pass | ||||||
|  |  | ||||||
|  |         CapsuleAfile = CapsuleData.CapsuleAfile() | ||||||
|  |         CapsuleAfile.FileName = AfileName | ||||||
|  |         CapsuleObj.CapsuleDataList.append(CapsuleAfile) | ||||||
|  |         return True | ||||||
|  |  | ||||||
|     ## __GetRule() method |     ## __GetRule() method | ||||||
|     # |     # | ||||||
|     #   Get Rule section contents and store its data into rule list of self.Profile |     #   Get Rule section contents and store its data into rule list of self.Profile | ||||||
|   | |||||||
| @@ -43,6 +43,8 @@ from PatchPcdValue.PatchPcdValue import PatchBinaryFile | |||||||
| # | # | ||||||
| # | # | ||||||
| class FfsInfStatement(FfsInfStatementClassObject): | class FfsInfStatement(FfsInfStatementClassObject): | ||||||
|  |     ## The mapping dictionary from datum type to its maximum number. | ||||||
|  |     _MAX_SIZE_TYPE = {"BOOLEAN":0x01, "UINT8":0xFF, "UINT16":0xFFFF, "UINT32":0xFFFFFFFF, "UINT64":0xFFFFFFFFFFFFFFFF} | ||||||
|     ## The constructor |     ## The constructor | ||||||
|     # |     # | ||||||
|     #   @param  self        The object pointer |     #   @param  self        The object pointer | ||||||
| @@ -204,10 +206,15 @@ class FfsInfStatement(FfsInfStatementClassObject): | |||||||
|  |  | ||||||
|         if Inf._Defs != None and len(Inf._Defs) > 0: |         if Inf._Defs != None and len(Inf._Defs) > 0: | ||||||
|             self.OptRomDefs.update(Inf._Defs) |             self.OptRomDefs.update(Inf._Defs) | ||||||
|  |  | ||||||
|         self.PatchPcds = [] |         self.PatchPcds = [] | ||||||
|         InfPcds = Inf.Pcds |         InfPcds = Inf.Pcds | ||||||
|         Platform = GenFdsGlobalVariable.WorkSpace.BuildObject[GenFdsGlobalVariable.ActivePlatform, self.CurrentArch, GenFdsGlobalVariable.TargetName, GenFdsGlobalVariable.ToolChainTag] |         Platform = GenFdsGlobalVariable.WorkSpace.BuildObject[GenFdsGlobalVariable.ActivePlatform, self.CurrentArch, GenFdsGlobalVariable.TargetName, GenFdsGlobalVariable.ToolChainTag] | ||||||
|         FdfPcdDict = GenFdsGlobalVariable.FdfParser.Profile.PcdDict |         FdfPcdDict = GenFdsGlobalVariable.FdfParser.Profile.PcdDict | ||||||
|  |  | ||||||
|  |         # Workaround here: both build and GenFds tool convert the workspace path to lower case | ||||||
|  |         # But INF file path in FDF and DSC file may have real case characters. | ||||||
|  |         # Try to convert the path to lower case to see if PCDs value are override by DSC. | ||||||
|         DscModules = {} |         DscModules = {} | ||||||
|         for DscModule in Platform.Modules: |         for DscModule in Platform.Modules: | ||||||
|             DscModules[str(DscModule).lower()] = Platform.Modules[DscModule] |             DscModules[str(DscModule).lower()] = Platform.Modules[DscModule] | ||||||
| @@ -217,6 +224,7 @@ class FfsInfStatement(FfsInfStatementClassObject): | |||||||
|                 continue |                 continue | ||||||
|             if Pcd.Type != 'PatchableInModule': |             if Pcd.Type != 'PatchableInModule': | ||||||
|                 continue |                 continue | ||||||
|  |             # Override Patchable PCD value by the value from DSC | ||||||
|             PatchPcd = None |             PatchPcd = None | ||||||
|             InfLowerPath = str(PathClassObj).lower() |             InfLowerPath = str(PathClassObj).lower() | ||||||
|             if InfLowerPath in DscModules and PcdKey in DscModules[InfLowerPath].Pcds: |             if InfLowerPath in DscModules and PcdKey in DscModules[InfLowerPath].Pcds: | ||||||
| @@ -227,16 +235,22 @@ class FfsInfStatement(FfsInfStatementClassObject): | |||||||
|             if PatchPcd and Pcd.Type == PatchPcd.Type: |             if PatchPcd and Pcd.Type == PatchPcd.Type: | ||||||
|                 DefaultValue = PatchPcd.DefaultValue |                 DefaultValue = PatchPcd.DefaultValue | ||||||
|                 DscOverride = True |                 DscOverride = True | ||||||
|  |  | ||||||
|  |             # Override Patchable PCD value by the value from FDF | ||||||
|             FdfOverride = False |             FdfOverride = False | ||||||
|             if PcdKey in FdfPcdDict: |             if PcdKey in FdfPcdDict: | ||||||
|                 DefaultValue = FdfPcdDict[PcdKey] |                 DefaultValue = FdfPcdDict[PcdKey] | ||||||
|                 FdfOverride = True |                 FdfOverride = True | ||||||
|  |  | ||||||
|             if not DscOverride and not FdfOverride: |             if not DscOverride and not FdfOverride: | ||||||
|                 continue |                 continue | ||||||
|  |             # Check value, if value are equal, no need to patch | ||||||
|             if Pcd.DatumType == "VOID*": |             if Pcd.DatumType == "VOID*": | ||||||
|                 if Pcd.DefaultValue == DefaultValue or DefaultValue in [None, '']: |                 if Pcd.DefaultValue == DefaultValue or DefaultValue in [None, '']: | ||||||
|                     continue |                     continue | ||||||
|  |                 # Get the string size from FDF or DSC | ||||||
|                 if DefaultValue[0] == 'L': |                 if DefaultValue[0] == 'L': | ||||||
|  |                     # Remove L"", but the '\0' must be appended | ||||||
|                     MaxDatumSize = str((len(DefaultValue) - 2) * 2) |                     MaxDatumSize = str((len(DefaultValue) - 2) * 2) | ||||||
|                 elif DefaultValue[0] == '{': |                 elif DefaultValue[0] == '{': | ||||||
|                     MaxDatumSize = str(len(DefaultValue.split(','))) |                     MaxDatumSize = str(len(DefaultValue.split(','))) | ||||||
| @@ -244,6 +258,7 @@ class FfsInfStatement(FfsInfStatementClassObject): | |||||||
|                     MaxDatumSize = str(len(DefaultValue) - 1) |                     MaxDatumSize = str(len(DefaultValue) - 1) | ||||||
|                 if DscOverride: |                 if DscOverride: | ||||||
|                     Pcd.MaxDatumSize = PatchPcd.MaxDatumSize |                     Pcd.MaxDatumSize = PatchPcd.MaxDatumSize | ||||||
|  |                 # If no defined the maximum size in DSC, try to get current size from INF | ||||||
|                 if Pcd.MaxDatumSize in ['', None]: |                 if Pcd.MaxDatumSize in ['', None]: | ||||||
|                     Pcd.MaxDatumSize = str(len(Pcd.DefaultValue.split(','))) |                     Pcd.MaxDatumSize = str(len(Pcd.DefaultValue.split(','))) | ||||||
|             else: |             else: | ||||||
| @@ -259,6 +274,7 @@ class FfsInfStatement(FfsInfStatementClassObject): | |||||||
|                         continue |                         continue | ||||||
|                 except: |                 except: | ||||||
|                     continue |                     continue | ||||||
|  |             # Check the Pcd size and data type | ||||||
|             if Pcd.DatumType == "VOID*": |             if Pcd.DatumType == "VOID*": | ||||||
|                 if int(MaxDatumSize) > int(Pcd.MaxDatumSize): |                 if int(MaxDatumSize) > int(Pcd.MaxDatumSize): | ||||||
|                     EdkLogger.error("GenFds", GENFDS_ERROR, "The size of VOID* type PCD '%s.%s' exceeds its maximum size %d bytes." \ |                     EdkLogger.error("GenFds", GENFDS_ERROR, "The size of VOID* type PCD '%s.%s' exceeds its maximum size %d bytes." \ | ||||||
| @@ -306,7 +322,7 @@ class FfsInfStatement(FfsInfStatementClassObject): | |||||||
|             return EfiFile |             return EfiFile | ||||||
|         Basename = os.path.basename(EfiFile) |         Basename = os.path.basename(EfiFile) | ||||||
|         Output = os.path.join(self.OutputPath, Basename) |         Output = os.path.join(self.OutputPath, Basename) | ||||||
|         CopyLongFilePath(EfiFile, Output) |         shutil.copy(EfiFile, Output) | ||||||
|         for Pcd in self.PatchPcds: |         for Pcd in self.PatchPcds: | ||||||
|             RetVal, RetStr = PatchBinaryFile(Output, int(Pcd.Offset, 0), Pcd.DatumType, Pcd.DefaultValue, Pcd.MaxDatumSize) |             RetVal, RetStr = PatchBinaryFile(Output, int(Pcd.Offset, 0), Pcd.DatumType, Pcd.DefaultValue, Pcd.MaxDatumSize) | ||||||
|             if RetVal: |             if RetVal: | ||||||
|   | |||||||
| @@ -86,6 +86,8 @@ class FV (FvClassObject): | |||||||
|                                 GenFdsGlobalVariable.ErrorLogger("Capsule %s in FD region can't contain a FV %s in FD region." % (self.CapsuleName, self.UiFvName.upper())) |                                 GenFdsGlobalVariable.ErrorLogger("Capsule %s in FD region can't contain a FV %s in FD region." % (self.CapsuleName, self.UiFvName.upper())) | ||||||
|  |  | ||||||
|         GenFdsGlobalVariable.InfLogger( "\nGenerating %s FV" %self.UiFvName) |         GenFdsGlobalVariable.InfLogger( "\nGenerating %s FV" %self.UiFvName) | ||||||
|  |         GenFdsGlobalVariable.LargeFileInFvFlags.append(False) | ||||||
|  |         FFSGuid = None | ||||||
|          |          | ||||||
|         if self.FvBaseAddress != None: |         if self.FvBaseAddress != None: | ||||||
|             BaseAddress = self.FvBaseAddress |             BaseAddress = self.FvBaseAddress | ||||||
| @@ -130,12 +132,15 @@ class FV (FvClassObject): | |||||||
|         OrigFvInfo = None |         OrigFvInfo = None | ||||||
|         if os.path.exists (FvInfoFileName): |         if os.path.exists (FvInfoFileName): | ||||||
|             OrigFvInfo = open(FvInfoFileName, 'r').read() |             OrigFvInfo = open(FvInfoFileName, 'r').read() | ||||||
|  |         if GenFdsGlobalVariable.LargeFileInFvFlags[-1]: | ||||||
|  |             FFSGuid = GenFdsGlobalVariable.EFI_FIRMWARE_FILE_SYSTEM3_GUID; | ||||||
|         GenFdsGlobalVariable.GenerateFirmwareVolume( |         GenFdsGlobalVariable.GenerateFirmwareVolume( | ||||||
|                                 FvOutputFile, |                                 FvOutputFile, | ||||||
|                                 [self.InfFileName], |                                 [self.InfFileName], | ||||||
|                                 AddressFile=FvInfoFileName, |                                 AddressFile=FvInfoFileName, | ||||||
|                                 FfsList=FfsFileList, |                                 FfsList=FfsFileList, | ||||||
|                                 ForceRebase=self.FvForceRebase |                                 ForceRebase=self.FvForceRebase, | ||||||
|  |                                 FileSystemGuid=FFSGuid | ||||||
|                                 ) |                                 ) | ||||||
|  |  | ||||||
|         NewFvInfo = None |         NewFvInfo = None | ||||||
| @@ -159,13 +164,16 @@ class FV (FvClassObject): | |||||||
|                 for FfsFile in self.FfsList : |                 for FfsFile in self.FfsList : | ||||||
|                     FileName = FfsFile.GenFfs(MacroDict, FvChildAddr, BaseAddress) |                     FileName = FfsFile.GenFfs(MacroDict, FvChildAddr, BaseAddress) | ||||||
|                  |                  | ||||||
|  |                 if GenFdsGlobalVariable.LargeFileInFvFlags[-1]: | ||||||
|  |                     FFSGuid = GenFdsGlobalVariable.EFI_FIRMWARE_FILE_SYSTEM3_GUID; | ||||||
|                 #Update GenFv again |                 #Update GenFv again | ||||||
|                 GenFdsGlobalVariable.GenerateFirmwareVolume( |                 GenFdsGlobalVariable.GenerateFirmwareVolume( | ||||||
|                                         FvOutputFile, |                                         FvOutputFile, | ||||||
|                                         [self.InfFileName], |                                         [self.InfFileName], | ||||||
|                                         AddressFile=FvInfoFileName, |                                         AddressFile=FvInfoFileName, | ||||||
|                                         FfsList=FfsFileList, |                                         FfsList=FfsFileList, | ||||||
|                                         ForceRebase=self.FvForceRebase |                                         ForceRebase=self.FvForceRebase, | ||||||
|  |                                         FileSystemGuid=FFSGuid | ||||||
|                                         ) |                                         ) | ||||||
|  |  | ||||||
|         # |         # | ||||||
| @@ -194,6 +202,7 @@ class FV (FvClassObject): | |||||||
|             self.FvAlignment = str (FvAlignmentValue) |             self.FvAlignment = str (FvAlignmentValue) | ||||||
|         FvFileObj.close() |         FvFileObj.close() | ||||||
|         GenFds.ImageBinDict[self.UiFvName.upper() + 'fv'] = FvOutputFile |         GenFds.ImageBinDict[self.UiFvName.upper() + 'fv'] = FvOutputFile | ||||||
|  |         GenFdsGlobalVariable.LargeFileInFvFlags.pop() | ||||||
|         return FvOutputFile |         return FvOutputFile | ||||||
|  |  | ||||||
|     ## __InitializeInf__() |     ## __InitializeInf__() | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| ## @file | ## @file | ||||||
| # generate flash image | # generate flash image | ||||||
| # | # | ||||||
| #  Copyright (c) 2007 - 2010, Intel Corporation. All rights reserved.<BR> | #  Copyright (c) 2007 - 2013, Intel Corporation. All rights reserved.<BR> | ||||||
| # | # | ||||||
| #  This program and the accompanying materials | #  This program and the accompanying materials | ||||||
| #  are licensed and made available under the terms and conditions of the BSD License | #  are licensed and made available under the terms and conditions of the BSD License | ||||||
| @@ -41,7 +41,7 @@ from Common.BuildVersion import gBUILD_VERSION | |||||||
| ## Version and Copyright | ## Version and Copyright | ||||||
| versionNumber = "1.0" + ' ' + gBUILD_VERSION | versionNumber = "1.0" + ' ' + gBUILD_VERSION | ||||||
| __version__ = "%prog Version " + versionNumber | __version__ = "%prog Version " + versionNumber | ||||||
| __copyright__ = "Copyright (c) 2007 - 2010, Intel Corporation  All rights reserved." | __copyright__ = "Copyright (c) 2007 - 2013, Intel Corporation  All rights reserved." | ||||||
|  |  | ||||||
| ## Tool entrance method | ## Tool entrance method | ||||||
| # | # | ||||||
|   | |||||||
| @@ -66,6 +66,19 @@ class GenFdsGlobalVariable: | |||||||
|     ToolChainFamily = "MSFT" |     ToolChainFamily = "MSFT" | ||||||
|     __BuildRuleDatabase = None |     __BuildRuleDatabase = None | ||||||
|      |      | ||||||
|  |     # | ||||||
|  |     # The list whose element are flags to indicate if large FFS or SECTION files exist in FV. | ||||||
|  |     # At the beginning of each generation of FV, false flag is appended to the list, | ||||||
|  |     # after the call to GenerateSection returns, check the size of the output file, | ||||||
|  |     # if it is greater than 0xFFFFFF, the tail flag in list is set to true, | ||||||
|  |     # and EFI_FIRMWARE_FILE_SYSTEM3_GUID is passed to C GenFv. | ||||||
|  |     # At the end of generation of FV, pop the flag. | ||||||
|  |     # List is used as a stack to handle nested FV generation. | ||||||
|  |     # | ||||||
|  |     LargeFileInFvFlags = [] | ||||||
|  |     EFI_FIRMWARE_FILE_SYSTEM3_GUID = '5473C07A-3DCB-4dca-BD6F-1E9689E7349A' | ||||||
|  |     LARGE_FILE_SIZE = 0x1000000 | ||||||
|  |  | ||||||
|     SectionHeader = struct.Struct("3B 1B") |     SectionHeader = struct.Struct("3B 1B") | ||||||
|      |      | ||||||
|     ## LoadBuildRule |     ## LoadBuildRule | ||||||
| @@ -390,12 +403,14 @@ class GenFdsGlobalVariable: | |||||||
|             Cmd += Input |             Cmd += Input | ||||||
|  |  | ||||||
|             SaveFileOnChange(CommandFile, ' '.join(Cmd), False) |             SaveFileOnChange(CommandFile, ' '.join(Cmd), False) | ||||||
|             if not GenFdsGlobalVariable.NeedsUpdate(Output, list(Input) + [CommandFile]): |             if GenFdsGlobalVariable.NeedsUpdate(Output, list(Input) + [CommandFile]): | ||||||
|                 return |  | ||||||
|                 GenFdsGlobalVariable.DebugLogger(EdkLogger.DEBUG_5, "%s needs update because of newer %s" % (Output, Input)) |                 GenFdsGlobalVariable.DebugLogger(EdkLogger.DEBUG_5, "%s needs update because of newer %s" % (Output, Input)) | ||||||
|  |  | ||||||
|                 GenFdsGlobalVariable.CallExternalTool(Cmd, "Failed to generate section") |                 GenFdsGlobalVariable.CallExternalTool(Cmd, "Failed to generate section") | ||||||
|  |  | ||||||
|  |             if (os.path.getsize(Output) >= GenFdsGlobalVariable.LARGE_FILE_SIZE and | ||||||
|  |                 GenFdsGlobalVariable.LargeFileInFvFlags): | ||||||
|  |                 GenFdsGlobalVariable.LargeFileInFvFlags[-1] = True  | ||||||
|  |  | ||||||
|     @staticmethod |     @staticmethod | ||||||
|     def GetAlignment (AlignString): |     def GetAlignment (AlignString): | ||||||
|         if AlignString == None: |         if AlignString == None: | ||||||
| @@ -432,7 +447,7 @@ class GenFdsGlobalVariable: | |||||||
|  |  | ||||||
|     @staticmethod |     @staticmethod | ||||||
|     def GenerateFirmwareVolume(Output, Input, BaseAddress=None, ForceRebase=None, Capsule=False, Dump=False, |     def GenerateFirmwareVolume(Output, Input, BaseAddress=None, ForceRebase=None, Capsule=False, Dump=False, | ||||||
|                                AddressFile=None, MapFile=None, FfsList=[]): |                                AddressFile=None, MapFile=None, FfsList=[], FileSystemGuid=None): | ||||||
|         if not GenFdsGlobalVariable.NeedsUpdate(Output, Input+FfsList): |         if not GenFdsGlobalVariable.NeedsUpdate(Output, Input+FfsList): | ||||||
|             return |             return | ||||||
|         GenFdsGlobalVariable.DebugLogger(EdkLogger.DEBUG_5, "%s needs update because of newer %s" % (Output, Input)) |         GenFdsGlobalVariable.DebugLogger(EdkLogger.DEBUG_5, "%s needs update because of newer %s" % (Output, Input)) | ||||||
| @@ -454,6 +469,8 @@ class GenFdsGlobalVariable: | |||||||
|             Cmd += ["-a", AddressFile] |             Cmd += ["-a", AddressFile] | ||||||
|         if MapFile not in [None, '']: |         if MapFile not in [None, '']: | ||||||
|             Cmd += ["-m", MapFile] |             Cmd += ["-m", MapFile] | ||||||
|  |         if FileSystemGuid: | ||||||
|  |             Cmd += ["-g", FileSystemGuid] | ||||||
|         Cmd += ["-o", Output] |         Cmd += ["-o", Output] | ||||||
|         for I in Input: |         for I in Input: | ||||||
|             Cmd += ["-i", I] |             Cmd += ["-i", I] | ||||||
|   | |||||||
| @@ -17,4 +17,4 @@ | |||||||
| Build version information | Build version information | ||||||
| ''' | ''' | ||||||
|  |  | ||||||
| gBUILD_VERSION = "Build 2610" | gBUILD_VERSION = "Build 2640" | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| ## @file | ## @file | ||||||
| # This file is used to define class for data type structure | # This file is used to define class for data type structure | ||||||
| # | # | ||||||
| # Copyright (c) 2011, Intel Corporation. All rights reserved.<BR> | # Copyright (c) 2011 - 2013, Intel Corporation. All rights reserved.<BR> | ||||||
| # | # | ||||||
| # This program and the accompanying materials are licensed and made available  | # This program and the accompanying materials are licensed and made available  | ||||||
| # under the terms and conditions of the BSD License which accompanies this  | # under the terms and conditions of the BSD License which accompanies this  | ||||||
| @@ -340,6 +340,7 @@ TAB_SLASH = '\\' | |||||||
| TAB_BACK_SLASH = '/' | TAB_BACK_SLASH = '/' | ||||||
| TAB_SPECIAL_COMMENT = '##' | TAB_SPECIAL_COMMENT = '##' | ||||||
| TAB_HEADER_COMMENT = '@file' | TAB_HEADER_COMMENT = '@file' | ||||||
|  | TAB_BINARY_HEADER_COMMENT = '@BinaryHeader' | ||||||
| TAB_STAR = "*" | TAB_STAR = "*" | ||||||
|  |  | ||||||
| TAB_EDK_SOURCE = '$(EDK_SOURCE)' | TAB_EDK_SOURCE = '$(EDK_SOURCE)' | ||||||
| @@ -735,7 +736,12 @@ TAB_INF_PATCH_PCD = 'PatchPcd' | |||||||
| TAB_INF_PCD = 'Pcd' | TAB_INF_PCD = 'Pcd' | ||||||
| TAB_INF_PCD_EX = 'PcdEx' | TAB_INF_PCD_EX = 'PcdEx' | ||||||
| TAB_INF_GUIDTYPE_VAR = 'Variable' | TAB_INF_GUIDTYPE_VAR = 'Variable' | ||||||
|  | TAB_INF_ABSTRACT = 'STR_MODULE_ABSTRACT' | ||||||
|  | TAB_INF_DESCRIPTION = 'STR_MODULE_DESCRIPTION' | ||||||
|  | TAB_INF_LICENSE = 'STR_MODULE_LICENSE' | ||||||
|  | TAB_INF_BINARY_ABSTRACT = 'STR_MODULE_BINARY_ABSTRACT' | ||||||
|  | TAB_INF_BINARY_DESCRIPTION = 'STR_MODULE_BINARY_DESCRIPTION' | ||||||
|  | TAB_INF_BINARY_LICENSE = 'STR_MODULE_BINARY_LICENSE' | ||||||
| # | # | ||||||
| # Dec Definitions | # Dec Definitions | ||||||
| # | # | ||||||
| @@ -745,7 +751,12 @@ TAB_DEC_DEFINES_PACKAGE_NAME = 'PACKAGE_NAME' | |||||||
| TAB_DEC_DEFINES_PACKAGE_GUID = 'PACKAGE_GUID' | TAB_DEC_DEFINES_PACKAGE_GUID = 'PACKAGE_GUID' | ||||||
| TAB_DEC_DEFINES_PACKAGE_VERSION = 'PACKAGE_VERSION' | TAB_DEC_DEFINES_PACKAGE_VERSION = 'PACKAGE_VERSION' | ||||||
| TAB_DEC_DEFINES_PKG_UNI_FILE    = 'PKG_UNI_FILE' | TAB_DEC_DEFINES_PKG_UNI_FILE    = 'PKG_UNI_FILE' | ||||||
|  | TAB_DEC_PACKAGE_ABSTRACT = 'STR_PACKAGE_ABSTRACT' | ||||||
|  | TAB_DEC_PACKAGE_DESCRIPTION = 'STR_PACKAGE_DESCRIPTION' | ||||||
|  | TAB_DEC_PACKAGE_LICENSE = 'STR_PACKAGE_LICENSE' | ||||||
|  | TAB_DEC_BINARY_ABSTRACT = 'STR_PACKAGE_BINARY_ABSTRACT' | ||||||
|  | TAB_DEC_BINARY_DESCRIPTION = 'STR_PACKAGE_BINARY_DESCRIPTION' | ||||||
|  | TAB_DEC_BINARY_LICENSE = 'STR_PACKAGE_ASBUILT_LICENSE' | ||||||
| # | # | ||||||
| # Dsc Definitions | # Dsc Definitions | ||||||
| # | # | ||||||
| @@ -814,6 +825,8 @@ TAB_HEADER_ABSTRACT = 'Abstract' | |||||||
| TAB_HEADER_DESCRIPTION = 'Description'  | TAB_HEADER_DESCRIPTION = 'Description'  | ||||||
| TAB_HEADER_COPYRIGHT = 'Copyright' | TAB_HEADER_COPYRIGHT = 'Copyright' | ||||||
| TAB_HEADER_LICENSE = 'License' | TAB_HEADER_LICENSE = 'License' | ||||||
|  | TAB_BINARY_HEADER_IDENTIFIER = 'BinaryHeader' | ||||||
|  | TAB_BINARY_HEADER_USERID = 'TianoCore' | ||||||
| # | # | ||||||
| # Build database path | # Build database path | ||||||
| # | # | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| ## @file | ## @file | ||||||
| # This file is used to define strings used in the UPT tool | # This file is used to define strings used in the UPT tool | ||||||
| # | # | ||||||
| # Copyright (c) 2011, Intel Corporation. All rights reserved.<BR> | # Copyright (c) 2011 - 2013, Intel Corporation. All rights reserved.<BR> | ||||||
| # | # | ||||||
| # This program and the accompanying materials are licensed and made available  | # This program and the accompanying materials are licensed and made available  | ||||||
| # under the terms and conditions of the BSD License which accompanies this  | # under the terms and conditions of the BSD License which accompanies this  | ||||||
| @@ -42,7 +42,7 @@ MSG_USAGE_STRING = _("\n" | |||||||
| MSG_VERSION_NUMBER = _("1.0") | MSG_VERSION_NUMBER = _("1.0") | ||||||
| MSG_VERSION = _("Intel(r) UEFI Packaging Tool (Intel(r) UEFIPT) - Revision " + \ | MSG_VERSION = _("Intel(r) UEFI Packaging Tool (Intel(r) UEFIPT) - Revision " + \ | ||||||
|                 MSG_VERSION_NUMBER) |                 MSG_VERSION_NUMBER) | ||||||
| MSG_COPYRIGHT = _("Copyright (c) 2011 Intel Corporation All Rights Reserved.") | MSG_COPYRIGHT = _("Copyright (c) 2011 - 2013 Intel Corporation All Rights Reserved.") | ||||||
| MSG_VERSION_COPYRIGHT = _("\n  %s\n  %s" % (MSG_VERSION, MSG_COPYRIGHT)) | MSG_VERSION_COPYRIGHT = _("\n  %s\n  %s" % (MSG_VERSION, MSG_COPYRIGHT)) | ||||||
| MSG_USAGE = _("%s [options]\n%s" % ("upt.exe", MSG_VERSION_COPYRIGHT)) | MSG_USAGE = _("%s [options]\n%s" % ("upt.exe", MSG_VERSION_COPYRIGHT)) | ||||||
| MSG_DESCRIPTION = _("The Intel(r) UEFIUPT is used to create, " + \ | MSG_DESCRIPTION = _("The Intel(r) UEFIUPT is used to create, " + \ | ||||||
| @@ -530,6 +530,10 @@ ERR_COPYRIGHT_MISSING            = \ | |||||||
| _("Header comment section must have copyright information") | _("Header comment section must have copyright information") | ||||||
| ERR_LICENSE_MISSING              = \ | ERR_LICENSE_MISSING              = \ | ||||||
| _("Header comment section must have license information") | _("Header comment section must have license information") | ||||||
|  | ERR_INVALID_BINARYHEADER_FORMAT  = \ | ||||||
|  | _("Binary Header comment section must have abstract,description,copyright,license information") | ||||||
|  | ERR_MULTIPLE_BINARYHEADER_EXIST = \ | ||||||
|  | _("the inf file at most support one BinaryHeader at the fileheader section.") | ||||||
| ERR_INVALID_COMMENT_FORMAT       = _("Comment must start with #") | ERR_INVALID_COMMENT_FORMAT       = _("Comment must start with #") | ||||||
| ERR_USER_ABORT                   = _("User has stopped the application") | ERR_USER_ABORT                   = _("User has stopped the application") | ||||||
| ERR_DIST_EXT_ERROR               = \ | ERR_DIST_EXT_ERROR               = \ | ||||||
| @@ -547,6 +551,8 @@ ERR_INSTALL_FILE_DEC_FILE_ERROR = _("Could not obtain the TokenSpaceGuidCName an | |||||||
| ERR_NOT_SUPPORTED_SA_MODULE = _("Stand-alone module distribution does not allow EDK 1 INF") | ERR_NOT_SUPPORTED_SA_MODULE = _("Stand-alone module distribution does not allow EDK 1 INF") | ||||||
| ERR_INSTALL_DIST_NOT_FOUND               = \ | ERR_INSTALL_DIST_NOT_FOUND               = \ | ||||||
| _("Distribution file to be installed is not found in current working directory or workspace: %s") | _("Distribution file to be installed is not found in current working directory or workspace: %s") | ||||||
|  | ERR_BINARY_HEADER_ORDER           = _("Binary header must follow the file header.") | ||||||
|  | ERR_NO_SOURCE_HEADER              = _("File header statement \"## @file\" must exist at the first place.") | ||||||
|  |  | ||||||
| # | # | ||||||
| # Expression error message | # Expression error message | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| ## @file | ## @file | ||||||
| # This file is used to parse DEC file. It will consumed by DecParser | # This file is used to parse DEC file. It will consumed by DecParser | ||||||
| # | # | ||||||
| # Copyright (c) 2011, Intel Corporation. All rights reserved.<BR> | # Copyright (c) 2011 - 2013, Intel Corporation. All rights reserved.<BR> | ||||||
| # | # | ||||||
| # This program and the accompanying materials are licensed and made available  | # This program and the accompanying materials are licensed and made available  | ||||||
| # under the terms and conditions of the BSD License which accompanies this  | # under the terms and conditions of the BSD License which accompanies this  | ||||||
| @@ -19,6 +19,7 @@ import Logger.Log as Logger | |||||||
| from Logger.ToolError import FILE_PARSE_FAILURE | from Logger.ToolError import FILE_PARSE_FAILURE | ||||||
| from Logger.ToolError import FILE_OPEN_FAILURE | from Logger.ToolError import FILE_OPEN_FAILURE | ||||||
| from Logger import StringTable as ST | from Logger import StringTable as ST | ||||||
|  | from Logger.ToolError import FORMAT_INVALID | ||||||
|  |  | ||||||
| import Library.DataType as DT | import Library.DataType as DT | ||||||
| from Library.ParserValidate import IsValidToken | from Library.ParserValidate import IsValidToken | ||||||
| @@ -735,6 +736,7 @@ class Dec(_DecBase, _DecComments): | |||||||
|         _DecComments.__init__(self) |         _DecComments.__init__(self) | ||||||
|         _DecBase.__init__(self, RawData) |         _DecBase.__init__(self, RawData) | ||||||
|          |          | ||||||
|  |         self.BinaryHeadComment = []         | ||||||
|         self._Define    = _DecDefine(RawData) |         self._Define    = _DecDefine(RawData) | ||||||
|         self._Include   = _DecInclude(RawData) |         self._Include   = _DecInclude(RawData) | ||||||
|         self._Guid      = _DecGuid(RawData) |         self._Guid      = _DecGuid(RawData) | ||||||
| @@ -778,8 +780,13 @@ class Dec(_DecBase, _DecComments): | |||||||
|     # Parse DEC file |     # Parse DEC file | ||||||
|     # |     # | ||||||
|     def ParseDecComment(self): |     def ParseDecComment(self): | ||||||
|  |         IsFileHeader = False | ||||||
|  |         IsBinaryHeader = False | ||||||
|  |         FileHeaderLineIndex = -1 | ||||||
|  |         BinaryHeaderLineIndex = -1 | ||||||
|         while not self._RawData.IsEndOfFile(): |         while not self._RawData.IsEndOfFile(): | ||||||
|             Line, Comment = CleanString(self._RawData.GetNextLine()) |             Line, Comment = CleanString(self._RawData.GetNextLine()) | ||||||
|  |  | ||||||
|             # |             # | ||||||
|             # Header must be pure comment |             # Header must be pure comment | ||||||
|             # |             # | ||||||
| @@ -787,14 +794,55 @@ class Dec(_DecBase, _DecComments): | |||||||
|                 self._RawData.UndoNextLine() |                 self._RawData.UndoNextLine() | ||||||
|                 break |                 break | ||||||
|              |              | ||||||
|             if Comment: |             if Comment and Comment.startswith(DT.TAB_SPECIAL_COMMENT) and Comment.find(DT.TAB_HEADER_COMMENT) > 0 \ | ||||||
|  |                 and not Comment[2:Comment.find(DT.TAB_HEADER_COMMENT)].strip(): | ||||||
|  |                 IsFileHeader = True | ||||||
|  |                 IsBinaryHeader = False | ||||||
|  |                 FileHeaderLineIndex = self._RawData.LineIndex | ||||||
|  |                  | ||||||
|  |             # | ||||||
|  |             # Get license information before '@file'  | ||||||
|  |             #    | ||||||
|  |             if not IsFileHeader and not IsBinaryHeader and Comment and Comment.startswith(DT.TAB_COMMENT_SPLIT) and \ | ||||||
|  |             DT.TAB_BINARY_HEADER_COMMENT not in Comment: | ||||||
|  |                 self._HeadComment.append((Comment, self._RawData.LineIndex)) | ||||||
|  |              | ||||||
|  |             if Comment and IsFileHeader and \ | ||||||
|  |             not(Comment.startswith(DT.TAB_SPECIAL_COMMENT) \ | ||||||
|  |             and Comment.find(DT.TAB_BINARY_HEADER_COMMENT) > 0): | ||||||
|                 self._HeadComment.append((Comment, self._RawData.LineIndex)) |                 self._HeadComment.append((Comment, self._RawData.LineIndex)) | ||||||
|             # |             # | ||||||
|             # Double '#' indicates end of header comments |             # Double '#' indicates end of header comments | ||||||
|             # |             # | ||||||
|             if not Comment or Comment == DT.TAB_SPECIAL_COMMENT: |             if (not Comment or Comment == DT.TAB_SPECIAL_COMMENT) and IsFileHeader: | ||||||
|  |                 IsFileHeader = False   | ||||||
|  |                 continue | ||||||
|  |              | ||||||
|  |             if Comment and Comment.startswith(DT.TAB_SPECIAL_COMMENT) \ | ||||||
|  |             and Comment.find(DT.TAB_BINARY_HEADER_COMMENT) > 0: | ||||||
|  |                 IsBinaryHeader = True | ||||||
|  |                 IsFileHeader = False | ||||||
|  |                 BinaryHeaderLineIndex = self._RawData.LineIndex | ||||||
|  |                  | ||||||
|  |             if Comment and IsBinaryHeader: | ||||||
|  |                 self.BinaryHeadComment.append((Comment, self._RawData.LineIndex)) | ||||||
|  |             # | ||||||
|  |             # Double '#' indicates end of header comments | ||||||
|  |             # | ||||||
|  |             if (not Comment or Comment == DT.TAB_SPECIAL_COMMENT) and IsBinaryHeader: | ||||||
|  |                 IsBinaryHeader = False | ||||||
|                 break |                 break | ||||||
|              |              | ||||||
|  |             if FileHeaderLineIndex > -1 and not IsFileHeader and not IsBinaryHeader: | ||||||
|  |                 break | ||||||
|  |  | ||||||
|  |         if FileHeaderLineIndex > BinaryHeaderLineIndex and FileHeaderLineIndex > -1 and BinaryHeaderLineIndex > -1: | ||||||
|  |             self._LoggerError(ST.ERR_BINARY_HEADER_ORDER) | ||||||
|  |              | ||||||
|  |         if FileHeaderLineIndex == -1: | ||||||
|  |             Logger.Error(TOOL_NAME, FORMAT_INVALID,  | ||||||
|  |                          ST.ERR_NO_SOURCE_HEADER, | ||||||
|  |                          File=self._RawData.Filename)         | ||||||
|         return |         return | ||||||
|      |      | ||||||
|     def _StopCurrentParsing(self, Line): |     def _StopCurrentParsing(self, Line): | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| ## @file | ## @file | ||||||
| # This file contained the parser for INF file | # This file contained the parser for INF file | ||||||
| # | # | ||||||
| # Copyright (c) 2011, Intel Corporation. All rights reserved.<BR> | # Copyright (c) 2011 - 2013, Intel Corporation. All rights reserved.<BR> | ||||||
| # | # | ||||||
| # This program and the accompanying materials are licensed and made available  | # This program and the accompanying materials are licensed and made available  | ||||||
| # under the terms and conditions of the BSD License which accompanies this  | # under the terms and conditions of the BSD License which accompanies this  | ||||||
| @@ -128,6 +128,10 @@ class InfParser(InfSectionParser): | |||||||
|         # |         # | ||||||
|         HeaderCommentStart = False  |         HeaderCommentStart = False  | ||||||
|         HeaderCommentEnd   = False |         HeaderCommentEnd   = False | ||||||
|  |         HeaderStarLineNo = -1 | ||||||
|  |         BinaryHeaderCommentStart = False  | ||||||
|  |         BinaryHeaderCommentEnd   = False | ||||||
|  |         BinaryHeaderStarLineNo = -1 | ||||||
|          |          | ||||||
|         # |         # | ||||||
|         # While Section ends. parse whole section contents. |         # While Section ends. parse whole section contents. | ||||||
| @@ -196,19 +200,13 @@ class InfParser(InfSectionParser): | |||||||
|             # |             # | ||||||
|             if Line.startswith(DT.TAB_SPECIAL_COMMENT) and \ |             if Line.startswith(DT.TAB_SPECIAL_COMMENT) and \ | ||||||
|                (Line.find(DT.TAB_HEADER_COMMENT) > -1) and \ |                (Line.find(DT.TAB_HEADER_COMMENT) > -1) and \ | ||||||
|                not HeaderCommentStart: |                not HeaderCommentStart and not HeaderCommentEnd: | ||||||
|                 if CurrentSection != DT.MODEL_UNKNOWN: |  | ||||||
|                     Logger.Error("Parser",  |  | ||||||
|                                  PARSER_ERROR,  |  | ||||||
|                                  ST.ERR_INF_PARSER_HEADER_FILE,  |  | ||||||
|                                  File=Filename,  |  | ||||||
|                                  Line=LineNo,  |  | ||||||
|                                  RaiseError = Logger.IS_RAISE_ERROR) |  | ||||||
|                 else: |  | ||||||
|                 CurrentSection = DT.MODEL_META_DATA_FILE_HEADER |                 CurrentSection = DT.MODEL_META_DATA_FILE_HEADER | ||||||
|                 # |                 # | ||||||
|                 # Append the first line to section lines. |                 # Append the first line to section lines. | ||||||
|                 # |                 # | ||||||
|  |                 HeaderStarLineNo = LineNo | ||||||
|                 SectionLines.append((Line, LineNo)) |                 SectionLines.append((Line, LineNo)) | ||||||
|                 HeaderCommentStart = True |                 HeaderCommentStart = True | ||||||
|                 continue         |                 continue         | ||||||
| @@ -226,17 +224,72 @@ class InfParser(InfSectionParser): | |||||||
|             # |             # | ||||||
|             if (Line.startswith(DT.TAB_SPECIAL_COMMENT) or not Line.strip().startswith("#")) and HeaderCommentStart \ |             if (Line.startswith(DT.TAB_SPECIAL_COMMENT) or not Line.strip().startswith("#")) and HeaderCommentStart \ | ||||||
|                 and not HeaderCommentEnd: |                 and not HeaderCommentEnd: | ||||||
|                 SectionLines.append((Line, LineNo)) |                 HeaderCommentEnd = True | ||||||
|  |                 BinaryHeaderCommentStart = False  | ||||||
|  |                 BinaryHeaderCommentEnd   = False | ||||||
|                 HeaderCommentStart = False |                 HeaderCommentStart = False | ||||||
|  |                 if Line.find(DT.TAB_BINARY_HEADER_COMMENT) > -1: | ||||||
|  |                     self.InfHeaderParser(SectionLines, self.InfHeader, self.FileName)  | ||||||
|  |                     SectionLines = [] | ||||||
|  |                 else: | ||||||
|  |                     SectionLines.append((Line, LineNo)) | ||||||
|                 # |                 # | ||||||
|                 # Call Header comment parser. |                 # Call Header comment parser. | ||||||
|                 # |                 # | ||||||
|                 self.InfHeaderParser(SectionLines, self.InfHeader, self.FileName) |                 self.InfHeaderParser(SectionLines, self.InfHeader, self.FileName) | ||||||
|                 SectionLines = [] |                 SectionLines = [] | ||||||
|  |                 continue | ||||||
|  |  | ||||||
|  |             # | ||||||
|  |             # check whether binary header comment section started | ||||||
|  |             # | ||||||
|  |             if Line.startswith(DT.TAB_SPECIAL_COMMENT) and \ | ||||||
|  |                 (Line.find(DT.TAB_BINARY_HEADER_COMMENT) > -1) and \ | ||||||
|  |                 not BinaryHeaderCommentStart: | ||||||
|  |                 SectionLines = [] | ||||||
|  |                 CurrentSection = DT.MODEL_META_DATA_FILE_HEADER | ||||||
|  |                 # | ||||||
|  |                 # Append the first line to section lines. | ||||||
|  |                 # | ||||||
|  |                 BinaryHeaderStarLineNo = LineNo | ||||||
|  |                 SectionLines.append((Line, LineNo)) | ||||||
|  |                 BinaryHeaderCommentStart = True | ||||||
|                 HeaderCommentEnd = True                |                 HeaderCommentEnd = True                | ||||||
|                 continue                    |                 continue                    | ||||||
|   |   | ||||||
|             # |             # | ||||||
|  |             # check whether there are more than one binary header exist | ||||||
|  |             # | ||||||
|  |             if Line.startswith(DT.TAB_SPECIAL_COMMENT) and BinaryHeaderCommentStart and \ | ||||||
|  |                 not BinaryHeaderCommentEnd and (Line.find(DT.TAB_BINARY_HEADER_COMMENT) > -1): | ||||||
|  |                 Logger.Error('Parser', | ||||||
|  |                              FORMAT_INVALID, | ||||||
|  |                              ST.ERR_MULTIPLE_BINARYHEADER_EXIST, | ||||||
|  |                              File=Filename) | ||||||
|  |              | ||||||
|  |             # | ||||||
|  |             # Collect Binary Header content. | ||||||
|  |             # | ||||||
|  |             if (Line.startswith(DT.TAB_COMMENT_SPLIT) and CurrentSection == DT.MODEL_META_DATA_FILE_HEADER) and\ | ||||||
|  |                 BinaryHeaderCommentStart and not Line.startswith(DT.TAB_SPECIAL_COMMENT) and not\ | ||||||
|  |                 BinaryHeaderCommentEnd and NextLine != '': | ||||||
|  |                 SectionLines.append((Line, LineNo)) | ||||||
|  |                 continue | ||||||
|  |             # | ||||||
|  |             # Binary Header content end | ||||||
|  |             # | ||||||
|  |             if (Line.startswith(DT.TAB_SPECIAL_COMMENT) or not Line.strip().startswith(DT.TAB_COMMENT_SPLIT)) and \ | ||||||
|  |                 BinaryHeaderCommentStart and not BinaryHeaderCommentEnd: | ||||||
|  |                 SectionLines.append((Line, LineNo)) | ||||||
|  |                 BinaryHeaderCommentStart = False | ||||||
|  |                 # | ||||||
|  |                 # Call Binary Header comment parser. | ||||||
|  |                 # | ||||||
|  |                 self.InfHeaderParser(SectionLines, self.InfBinaryHeader, self.FileName, True) | ||||||
|  |                 SectionLines = [] | ||||||
|  |                 BinaryHeaderCommentEnd   = True                | ||||||
|  |                 continue                    | ||||||
|  |             # | ||||||
|             # Find a new section tab |             # Find a new section tab | ||||||
|             # Or at the last line of INF file,  |             # Or at the last line of INF file,  | ||||||
|             # need to process the last section. |             # need to process the last section. | ||||||
| @@ -255,6 +308,10 @@ class InfParser(InfSectionParser): | |||||||
|             # |             # | ||||||
|             if (Line.startswith(DT.TAB_SECTION_START) and \ |             if (Line.startswith(DT.TAB_SECTION_START) and \ | ||||||
|                Line.find(DT.TAB_SECTION_END) > -1) or LastSectionFalg:                   |                Line.find(DT.TAB_SECTION_END) > -1) or LastSectionFalg:                   | ||||||
|  |                  | ||||||
|  |                 HeaderCommentEnd = True         | ||||||
|  |                 BinaryHeaderCommentEnd = True        | ||||||
|  |                  | ||||||
|                 if not LastSectionFalg: |                 if not LastSectionFalg: | ||||||
|                     # |                     # | ||||||
|                     # check to prevent '#' inside section header |                     # check to prevent '#' inside section header | ||||||
| @@ -333,18 +390,17 @@ class InfParser(InfSectionParser): | |||||||
|                 # Clear section lines |                 # Clear section lines | ||||||
|                 # |                 # | ||||||
|                 SectionLines = []                                              |                 SectionLines = []                                              | ||||||
|         # |          | ||||||
|         # End of for |         if HeaderStarLineNo == -1: | ||||||
|         # |  | ||||||
|         # |  | ||||||
|         # Found the first section, No file header. |  | ||||||
|         # |  | ||||||
|         if DefineSectionParsedFlag and not HeaderCommentEnd: |  | ||||||
|             Logger.Error("InfParser",  |             Logger.Error("InfParser",  | ||||||
|                          FORMAT_INVALID,  |                          FORMAT_INVALID,  | ||||||
|                          ST.ERR_INF_PARSER_HEADER_MISSGING,  |                          ST.ERR_NO_SOURCE_HEADER,  | ||||||
|  |                          File=self.FullPath) | ||||||
|  |         if BinaryHeaderStarLineNo > -1 and HeaderStarLineNo > -1  and HeaderStarLineNo > BinaryHeaderStarLineNo: | ||||||
|  |             Logger.Error("InfParser",  | ||||||
|  |                         FORMAT_INVALID, | ||||||
|  |                         ST.ERR_BINARY_HEADER_ORDER, | ||||||
|                         File=self.FullPath)          |                         File=self.FullPath)          | ||||||
|          |  | ||||||
|         # |         # | ||||||
|         # EDKII INF should not have EDKI style comment |         # EDKII INF should not have EDKI style comment | ||||||
|         # |         # | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| ## @file | ## @file | ||||||
| # This file is used to parse a PCD file of .PKG file | # This file is used to parse a PCD file of .PKG file | ||||||
| # | # | ||||||
| # Copyright (c) 2011, Intel Corporation. All rights reserved.<BR> | # Copyright (c) 2011 - 2013, Intel Corporation. All rights reserved.<BR> | ||||||
| # | # | ||||||
| # This program and the accompanying materials are licensed and made available  | # This program and the accompanying materials are licensed and made available  | ||||||
| # under the terms and conditions of the BSD License which accompanies this  | # under the terms and conditions of the BSD License which accompanies this  | ||||||
| @@ -357,8 +357,10 @@ class MiscellaneousFileXml(object): | |||||||
|             Executable = XmlAttribute(XmlNode(SubItem, '%s/Filename' % Key), 'Executable') |             Executable = XmlAttribute(XmlNode(SubItem, '%s/Filename' % Key), 'Executable') | ||||||
|             if Executable.upper() == "TRUE": |             if Executable.upper() == "TRUE": | ||||||
|                 Executable = True |                 Executable = True | ||||||
|             else: |             elif Executable.upper() == "FALSE": | ||||||
|                 Executable = False |                 Executable = False | ||||||
|  |             else: | ||||||
|  |                 Executable = '' | ||||||
|             self.Files.append([Filename, Executable]) |             self.Files.append([Filename, Executable]) | ||||||
|  |  | ||||||
|         MiscFile = MiscFileObject() |         MiscFile = MiscFileObject() | ||||||
| @@ -392,8 +394,10 @@ class MiscellaneousFileXml(object): | |||||||
|             OsType = XmlAttribute(XmlNode(SubItem, '%s/Filename' % Key), 'OS') |             OsType = XmlAttribute(XmlNode(SubItem, '%s/Filename' % Key), 'OS') | ||||||
|             if Executable.upper() == "TRUE": |             if Executable.upper() == "TRUE": | ||||||
|                 Executable = True |                 Executable = True | ||||||
|             else: |             elif Executable.upper() == "FALSE": | ||||||
|                 Executable = False |                 Executable = False | ||||||
|  |             else: | ||||||
|  |                 Executable = '' | ||||||
|             self.Files.append([Filename, Executable, OsType]) |             self.Files.append([Filename, Executable, OsType]) | ||||||
|  |  | ||||||
|         MiscFile = MiscFileObject() |         MiscFile = MiscFileObject() | ||||||
|   | |||||||
| @@ -278,7 +278,7 @@ class MetaFileParser(object): | |||||||
|         for Item in GetSplitValueList(self._CurrentLine[1:-1], TAB_COMMA_SPLIT): |         for Item in GetSplitValueList(self._CurrentLine[1:-1], TAB_COMMA_SPLIT): | ||||||
|             if Item == '': |             if Item == '': | ||||||
|                 continue |                 continue | ||||||
|             ItemList = GetSplitValueList(Item, TAB_SPLIT) |             ItemList = GetSplitValueList(Item, TAB_SPLIT,2) | ||||||
|             # different section should not mix in one section |             # different section should not mix in one section | ||||||
|             if self._SectionName != '' and self._SectionName != ItemList[0].upper(): |             if self._SectionName != '' and self._SectionName != ItemList[0].upper(): | ||||||
|                 EdkLogger.error('Parser', FORMAT_INVALID, "Different section names in the same section", |                 EdkLogger.error('Parser', FORMAT_INVALID, "Different section names in the same section", | ||||||
| @@ -305,6 +305,9 @@ class MetaFileParser(object): | |||||||
|  |  | ||||||
|             # S2 may be Platform or ModuleType |             # S2 may be Platform or ModuleType | ||||||
|             if len(ItemList) > 2: |             if len(ItemList) > 2: | ||||||
|  |                 if self._SectionName.upper() in SECTIONS_HAVE_ITEM_PCD: | ||||||
|  |                     S2 = ItemList[2] | ||||||
|  |                 else: | ||||||
|                     S2 = ItemList[2].upper() |                     S2 = ItemList[2].upper() | ||||||
|             else: |             else: | ||||||
|                 S2 = 'COMMON' |                 S2 = 'COMMON' | ||||||
| @@ -496,6 +499,8 @@ class InfParser(MetaFileParser): | |||||||
|         # parse the file line by line |         # parse the file line by line | ||||||
|         IsFindBlockComment = False |         IsFindBlockComment = False | ||||||
|         GetHeaderComment = False |         GetHeaderComment = False | ||||||
|  |         TailComments = [] | ||||||
|  |         SectionComments = [] | ||||||
|         Comments = [] |         Comments = [] | ||||||
|  |  | ||||||
|         for Index in range(0, len(Content)): |         for Index in range(0, len(Content)): | ||||||
| @@ -507,6 +512,9 @@ class InfParser(MetaFileParser): | |||||||
|             if Line == '': |             if Line == '': | ||||||
|                 if Comment: |                 if Comment: | ||||||
|                     Comments.append((Comment, Index + 1)) |                     Comments.append((Comment, Index + 1)) | ||||||
|  |                 elif GetHeaderComment: | ||||||
|  |                     SectionComments.extend(Comments) | ||||||
|  |                     Comments = [] | ||||||
|                 continue |                 continue | ||||||
|             if Line.find(DataType.TAB_COMMENT_EDK_START) > -1: |             if Line.find(DataType.TAB_COMMENT_EDK_START) > -1: | ||||||
|                 IsFindBlockComment = True |                 IsFindBlockComment = True | ||||||
| @@ -527,6 +535,8 @@ class InfParser(MetaFileParser): | |||||||
|                         self._Store(MODEL_META_DATA_HEADER_COMMENT, Cmt, '', '', 'COMMON', |                         self._Store(MODEL_META_DATA_HEADER_COMMENT, Cmt, '', '', 'COMMON', | ||||||
|                                     'COMMON', self._Owner[-1], LNo, -1, LNo, -1, 0) |                                     'COMMON', self._Owner[-1], LNo, -1, LNo, -1, 0) | ||||||
|                     GetHeaderComment = True |                     GetHeaderComment = True | ||||||
|  |                 else: | ||||||
|  |                     TailComments.extend(SectionComments + Comments) | ||||||
|                 Comments = [] |                 Comments = [] | ||||||
|                 self._SectionHeaderParser() |                 self._SectionHeaderParser() | ||||||
|                 # Check invalid sections |                 # Check invalid sections | ||||||
| @@ -602,9 +612,16 @@ class InfParser(MetaFileParser): | |||||||
|                     self._Store(MODEL_META_DATA_COMMENT, Comment, '', '', Arch, Platform, |                     self._Store(MODEL_META_DATA_COMMENT, Comment, '', '', Arch, Platform, | ||||||
|                                 LastItem, LineNo, -1, LineNo, -1, 0) |                                 LastItem, LineNo, -1, LineNo, -1, 0) | ||||||
|             Comments = [] |             Comments = [] | ||||||
|  |             SectionComments = [] | ||||||
|  |         TailComments.extend(SectionComments + Comments) | ||||||
|         if IsFindBlockComment: |         if IsFindBlockComment: | ||||||
|             EdkLogger.error("Parser", FORMAT_INVALID, "Open block comments (starting with /*) are expected to end with */", |             EdkLogger.error("Parser", FORMAT_INVALID, "Open block comments (starting with /*) are expected to end with */", | ||||||
|                             File=self.MetaFile) |                             File=self.MetaFile) | ||||||
|  |  | ||||||
|  |         # If there are tail comments in INF file, save to database whatever the comments are | ||||||
|  |         for Comment in TailComments: | ||||||
|  |             self._Store(MODEL_META_DATA_TAIL_COMMENT, Comment[0], '', '', 'COMMON', | ||||||
|  |                                 'COMMON', self._Owner[-1], -1, -1, -1, -1, 0) | ||||||
|         self._Done() |         self._Done() | ||||||
|  |  | ||||||
|     ## Data parser for the format in which there's path |     ## Data parser for the format in which there's path | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| ## @file | ## @file | ||||||
| # This file is used to create a database used by build tool | # This file is used to create a database used by build tool | ||||||
| # | # | ||||||
| # Copyright (c) 2008 - 2011, Intel Corporation. All rights reserved.<BR> | # Copyright (c) 2008 - 2014, Intel Corporation. All rights reserved.<BR> | ||||||
| # This program and the accompanying materials | # This program and the accompanying materials | ||||||
| # are licensed and made available under the terms and conditions of the BSD License | # are licensed and made available under the terms and conditions of the BSD License | ||||||
| # which accompanies this distribution.  The full text of the license may be found at | # which accompanies this distribution.  The full text of the license may be found at | ||||||
| @@ -36,6 +36,7 @@ from MetaFileParser import * | |||||||
| from BuildClassObject import * | from BuildClassObject import * | ||||||
| from WorkspaceCommon import GetDeclaredPcd | from WorkspaceCommon import GetDeclaredPcd | ||||||
| from Common.Misc import AnalyzeDscPcd | from Common.Misc import AnalyzeDscPcd | ||||||
|  | import re | ||||||
|  |  | ||||||
| ## Platform build information from DSC file | ## Platform build information from DSC file | ||||||
| # | # | ||||||
| @@ -328,6 +329,8 @@ class DscBuildData(PlatformBuildClassObject): | |||||||
|             return False |             return False | ||||||
|              |              | ||||||
|     def _GetSkuIdentifier(self): |     def _GetSkuIdentifier(self): | ||||||
|  |         if self._SkuName: | ||||||
|  |             return self._SkuName | ||||||
|         if self._SkuIdentifier == None: |         if self._SkuIdentifier == None: | ||||||
|             if self._Header == None: |             if self._Header == None: | ||||||
|                 self._GetHeaderInfo() |                 self._GetHeaderInfo() | ||||||
| @@ -337,15 +340,13 @@ class DscBuildData(PlatformBuildClassObject): | |||||||
|         if self._SkuName == None: |         if self._SkuName == None: | ||||||
|             if self._Header == None: |             if self._Header == None: | ||||||
|                 self._GetHeaderInfo() |                 self._GetHeaderInfo() | ||||||
|             if self._SkuName == None or self._SkuName not in self.SkuIds: |             if (self._SkuName == None or self._SkuName not in self.SkuIds): | ||||||
|                 self._SkuName = 'DEFAULT' |                 self._SkuName = 'DEFAULT' | ||||||
|         return self._SkuName |         return self._SkuName | ||||||
|  |  | ||||||
|     ## Override SKUID_IDENTIFIER |     ## Override SKUID_IDENTIFIER | ||||||
|     def _SetSkuName(self, Value): |     def _SetSkuName(self, Value): | ||||||
|         if Value in self.SkuIds: |  | ||||||
|         self._SkuName = Value |         self._SkuName = Value | ||||||
|             # Needs to re-retrieve the PCD information |  | ||||||
|         self._Pcds = None |         self._Pcds = None | ||||||
|  |  | ||||||
|     def _GetFdfFile(self): |     def _GetFdfFile(self): | ||||||
| @@ -460,7 +461,7 @@ class DscBuildData(PlatformBuildClassObject): | |||||||
|                 if Record[1] in [None, '']: |                 if Record[1] in [None, '']: | ||||||
|                     EdkLogger.error('build', FORMAT_INVALID, 'No Sku ID name', |                     EdkLogger.error('build', FORMAT_INVALID, 'No Sku ID name', | ||||||
|                                     File=self.MetaFile, Line=Record[-1]) |                                     File=self.MetaFile, Line=Record[-1]) | ||||||
|                 self._SkuIds[Record[1].upper()] = Record[0] |                 self._SkuIds[Record[1]] = Record[0] | ||||||
|             if 'DEFAULT' not in self._SkuIds: |             if 'DEFAULT' not in self._SkuIds: | ||||||
|                 self._SkuIds['DEFAULT'] = '0' |                 self._SkuIds['DEFAULT'] = '0' | ||||||
|             if 'COMMON' not in self._SkuIds: |             if 'COMMON' not in self._SkuIds: | ||||||
| @@ -731,7 +732,6 @@ class DscBuildData(PlatformBuildClassObject): | |||||||
|         RecordList = self._RawData[Type, self._Arch] |         RecordList = self._RawData[Type, self._Arch] | ||||||
|         PcdValueDict = sdict() |         PcdValueDict = sdict() | ||||||
|         for TokenSpaceGuid, PcdCName, Setting, Arch, SkuName, Dummy3, Dummy4 in RecordList: |         for TokenSpaceGuid, PcdCName, Setting, Arch, SkuName, Dummy3, Dummy4 in RecordList: | ||||||
|             SkuName = SkuName.upper() |  | ||||||
|             if SkuName in (SkuObj.SystemSkuId,'DEFAULT','COMMON'): |             if SkuName in (SkuObj.SystemSkuId,'DEFAULT','COMMON'): | ||||||
|                 PcdSet.add((PcdCName, TokenSpaceGuid, SkuName,Dummy4)) |                 PcdSet.add((PcdCName, TokenSpaceGuid, SkuName,Dummy4)) | ||||||
|                 PcdDict[Arch, PcdCName, TokenSpaceGuid,SkuName] = Setting |                 PcdDict[Arch, PcdCName, TokenSpaceGuid,SkuName] = Setting | ||||||
| @@ -798,7 +798,6 @@ class DscBuildData(PlatformBuildClassObject): | |||||||
|          |          | ||||||
|         AvailableSkuIdSet.update({'DEFAULT':0,'COMMON':0}) |         AvailableSkuIdSet.update({'DEFAULT':0,'COMMON':0}) | ||||||
|         for TokenSpaceGuid, PcdCName, Setting, Arch, SkuName, Dummy3, Dummy4 in RecordList: |         for TokenSpaceGuid, PcdCName, Setting, Arch, SkuName, Dummy3, Dummy4 in RecordList: | ||||||
|             SkuName = SkuName.upper() |  | ||||||
|             if SkuName not in AvailableSkuIdSet: |             if SkuName not in AvailableSkuIdSet: | ||||||
|                 continue |                 continue | ||||||
|              |              | ||||||
| @@ -816,6 +815,16 @@ class DscBuildData(PlatformBuildClassObject): | |||||||
|             if (PcdCName,TokenSpaceGuid) in Pcds.keys():  |             if (PcdCName,TokenSpaceGuid) in Pcds.keys():  | ||||||
|                 pcdObject = Pcds[PcdCName,TokenSpaceGuid] |                 pcdObject = Pcds[PcdCName,TokenSpaceGuid] | ||||||
|                 pcdObject.SkuInfoList[SkuName] = SkuInfo |                 pcdObject.SkuInfoList[SkuName] = SkuInfo | ||||||
|  |                 if MaxDatumSize.strip(): | ||||||
|  |                     CurrentMaxSize = int(MaxDatumSize.strip(),0) | ||||||
|  |                 else: | ||||||
|  |                     CurrentMaxSize = 0 | ||||||
|  |                 if pcdObject.MaxDatumSize: | ||||||
|  |                     PcdMaxSize = int(pcdObject.MaxDatumSize,0) | ||||||
|  |                 else: | ||||||
|  |                     PcdMaxSize = 0 | ||||||
|  |                 if CurrentMaxSize > PcdMaxSize: | ||||||
|  |                     pcdObject.MaxDatumSize = str(CurrentMaxSize) | ||||||
|             else:                |             else:                | ||||||
|                 Pcds[PcdCName, TokenSpaceGuid] = PcdClassObject( |                 Pcds[PcdCName, TokenSpaceGuid] = PcdClassObject( | ||||||
|                                                     PcdCName, |                                                     PcdCName, | ||||||
| @@ -831,8 +840,8 @@ class DscBuildData(PlatformBuildClassObject): | |||||||
|                                                     ) |                                                     ) | ||||||
|          |          | ||||||
|         for pcd in Pcds.values(): |         for pcd in Pcds.values(): | ||||||
|             if 'DEFAULT' not in pcd.SkuInfoList.keys() and 'COMMON' not in pcd.SkuInfoList.keys(): |  | ||||||
|             pcdDecObject = self._DecPcds[pcd.TokenCName,pcd.TokenSpaceGuidCName] |             pcdDecObject = self._DecPcds[pcd.TokenCName,pcd.TokenSpaceGuidCName] | ||||||
|  |             if 'DEFAULT' not in pcd.SkuInfoList.keys() and 'COMMON' not in pcd.SkuInfoList.keys():                 | ||||||
|                 valuefromDec = pcdDecObject.DefaultValue |                 valuefromDec = pcdDecObject.DefaultValue | ||||||
|                 SkuInfo = SkuInfoClass('DEFAULT', '0', '', '', '', '', '', valuefromDec) |                 SkuInfo = SkuInfoClass('DEFAULT', '0', '', '', '', '', '', valuefromDec) | ||||||
|                 pcd.SkuInfoList['DEFAULT'] = SkuInfo |                 pcd.SkuInfoList['DEFAULT'] = SkuInfo | ||||||
| @@ -846,16 +855,6 @@ class DscBuildData(PlatformBuildClassObject): | |||||||
|                     pcd.SkuInfoList[SkuObj.SystemSkuId] = pcd.SkuInfoList['DEFAULT'] |                     pcd.SkuInfoList[SkuObj.SystemSkuId] = pcd.SkuInfoList['DEFAULT'] | ||||||
|                 del(pcd.SkuInfoList['DEFAULT']) |                 del(pcd.SkuInfoList['DEFAULT']) | ||||||
|                 |                 | ||||||
|             if SkuObj.SkuUsageType == SkuObj.MULTIPLE: |  | ||||||
|                     if pcd.DatumType == "VOID*":  |  | ||||||
|                         MaxSize = int(pcd.MaxDatumSize,0) |  | ||||||
|                         for (skuname,skuobj) in pcd.SkuInfoList.items(): |  | ||||||
|                             datalen = len(skuobj.DefaultValue) |  | ||||||
|                             if datalen>MaxSize: |  | ||||||
|                                 MaxSize = datalen |  | ||||||
|                         pcd.MaxDatumSize = str(MaxSize) |  | ||||||
|                      |  | ||||||
|                  |  | ||||||
|         return Pcds |         return Pcds | ||||||
|  |  | ||||||
|     ## Retrieve dynamic HII PCD settings |     ## Retrieve dynamic HII PCD settings | ||||||
| @@ -881,7 +880,6 @@ class DscBuildData(PlatformBuildClassObject): | |||||||
|          |          | ||||||
|         AvailableSkuIdSet.update({'DEFAULT':0,'COMMON':0}) |         AvailableSkuIdSet.update({'DEFAULT':0,'COMMON':0}) | ||||||
|         for TokenSpaceGuid, PcdCName, Setting, Arch, SkuName, Dummy3, Dummy4 in RecordList: |         for TokenSpaceGuid, PcdCName, Setting, Arch, SkuName, Dummy3, Dummy4 in RecordList: | ||||||
|             SkuName = SkuName.upper() |  | ||||||
|             if SkuName not in AvailableSkuIdSet: |             if SkuName not in AvailableSkuIdSet: | ||||||
|                 continue |                 continue | ||||||
|             PcdSet.add((PcdCName, TokenSpaceGuid, SkuName,Dummy4)) |             PcdSet.add((PcdCName, TokenSpaceGuid, SkuName,Dummy4)) | ||||||
| @@ -893,6 +891,20 @@ class DscBuildData(PlatformBuildClassObject): | |||||||
|             if Setting == None: |             if Setting == None: | ||||||
|                 continue |                 continue | ||||||
|             VariableName, VariableGuid, VariableOffset, DefaultValue = self._ValidatePcd(PcdCName, TokenSpaceGuid, Setting, Type, Dummy4) |             VariableName, VariableGuid, VariableOffset, DefaultValue = self._ValidatePcd(PcdCName, TokenSpaceGuid, Setting, Type, Dummy4) | ||||||
|  |              | ||||||
|  |             ExceedMax = False | ||||||
|  |             if VariableOffset.isdigit(): | ||||||
|  |                 if int(VariableOffset,10) > 0xFFFF: | ||||||
|  |                     ExceedMax = True | ||||||
|  |             elif re.match(r'[\t\s]*0[xX][a-fA-F0-9]+$',VariableOffset): | ||||||
|  |                 if int(VariableOffset,16) > 0xFFFF: | ||||||
|  |                     ExceedMax = True | ||||||
|  |             else: | ||||||
|  |                 EdkLogger.error('Build', FORMAT_INVALID, "Invalid syntax or format of the variable offset value is incorrect for %s." % ".".join((TokenSpaceGuid,PcdCName))) | ||||||
|  |              | ||||||
|  |             if ExceedMax: | ||||||
|  |                 EdkLogger.error('Build', OPTION_VALUE_INVALID, "The variable offset value must not exceed the maximum value of 0xFFFF (UINT16) for %s." % ".".join((TokenSpaceGuid,PcdCName))) | ||||||
|  |              | ||||||
|             SkuInfo = SkuInfoClass(SkuName, self.SkuIds[SkuName], VariableName, VariableGuid, VariableOffset, DefaultValue) |             SkuInfo = SkuInfoClass(SkuName, self.SkuIds[SkuName], VariableName, VariableGuid, VariableOffset, DefaultValue) | ||||||
|             if (PcdCName,TokenSpaceGuid) in Pcds.keys():   |             if (PcdCName,TokenSpaceGuid) in Pcds.keys():   | ||||||
|                 pcdObject = Pcds[PcdCName,TokenSpaceGuid] |                 pcdObject = Pcds[PcdCName,TokenSpaceGuid] | ||||||
| @@ -914,8 +926,12 @@ class DscBuildData(PlatformBuildClassObject): | |||||||
|  |  | ||||||
|         for pcd in Pcds.values(): |         for pcd in Pcds.values(): | ||||||
|             SkuInfoObj = pcd.SkuInfoList.values()[0] |             SkuInfoObj = pcd.SkuInfoList.values()[0] | ||||||
|             if 'DEFAULT' not in pcd.SkuInfoList.keys() and 'COMMON' not in pcd.SkuInfoList.keys(): |  | ||||||
|             pcdDecObject = self._DecPcds[pcd.TokenCName,pcd.TokenSpaceGuidCName] |             pcdDecObject = self._DecPcds[pcd.TokenCName,pcd.TokenSpaceGuidCName] | ||||||
|  |             # Only fix the value while no value provided in DSC file. | ||||||
|  |             for sku in pcd.SkuInfoList.values(): | ||||||
|  |                 if (sku.HiiDefaultValue == "" or sku.HiiDefaultValue==None): | ||||||
|  |                     sku.HiiDefaultValue = pcdDecObject.DefaultValue | ||||||
|  |             if 'DEFAULT' not in pcd.SkuInfoList.keys() and 'COMMON' not in pcd.SkuInfoList.keys():               | ||||||
|                 valuefromDec = pcdDecObject.DefaultValue |                 valuefromDec = pcdDecObject.DefaultValue | ||||||
|                 SkuInfo = SkuInfoClass('DEFAULT', '0', SkuInfoObj.VariableName, SkuInfoObj.VariableGuid, SkuInfoObj.VariableOffset, valuefromDec) |                 SkuInfo = SkuInfoClass('DEFAULT', '0', SkuInfoObj.VariableName, SkuInfoObj.VariableGuid, SkuInfoObj.VariableOffset, valuefromDec) | ||||||
|                 pcd.SkuInfoList['DEFAULT'] = SkuInfo |                 pcd.SkuInfoList['DEFAULT'] = SkuInfo | ||||||
| @@ -929,6 +945,24 @@ class DscBuildData(PlatformBuildClassObject): | |||||||
|                 if 'DEFAULT' in pcd.SkuInfoList.keys() and SkuObj.SystemSkuId not in pcd.SkuInfoList.keys(): |                 if 'DEFAULT' in pcd.SkuInfoList.keys() and SkuObj.SystemSkuId not in pcd.SkuInfoList.keys(): | ||||||
|                     pcd.SkuInfoList[SkuObj.SystemSkuId] = pcd.SkuInfoList['DEFAULT'] |                     pcd.SkuInfoList[SkuObj.SystemSkuId] = pcd.SkuInfoList['DEFAULT'] | ||||||
|                 del(pcd.SkuInfoList['DEFAULT']) |                 del(pcd.SkuInfoList['DEFAULT']) | ||||||
|  |              | ||||||
|  |              | ||||||
|  |             if pcd.MaxDatumSize.strip():  | ||||||
|  |                 MaxSize = int(pcd.MaxDatumSize,0) | ||||||
|  |             else: | ||||||
|  |                 MaxSize = 0 | ||||||
|  |             if pcdDecObject.DatumType == 'VOID*': | ||||||
|  |                 for (skuname,skuobj) in pcd.SkuInfoList.items(): | ||||||
|  |                     datalen = 0 | ||||||
|  |                     if skuobj.HiiDefaultValue.startswith("L"): | ||||||
|  |                         datalen = (len(skuobj.HiiDefaultValue)- 3 + 1) * 2 | ||||||
|  |                     elif skuobj.HiiDefaultValue.startswith("{"): | ||||||
|  |                         datalen = len(skuobj.HiiDefaultValue.split(",")) | ||||||
|  |                     else: | ||||||
|  |                         datalen = len(skuobj.HiiDefaultValue) -2 + 1  | ||||||
|  |                     if datalen>MaxSize: | ||||||
|  |                         MaxSize = datalen | ||||||
|  |                 pcd.MaxDatumSize = str(MaxSize) | ||||||
|         return Pcds |         return Pcds | ||||||
|  |  | ||||||
|     ## Retrieve dynamic VPD PCD settings |     ## Retrieve dynamic VPD PCD settings | ||||||
| @@ -954,7 +988,6 @@ class DscBuildData(PlatformBuildClassObject): | |||||||
|          |          | ||||||
|         AvailableSkuIdSet.update({'DEFAULT':0,'COMMON':0}) |         AvailableSkuIdSet.update({'DEFAULT':0,'COMMON':0}) | ||||||
|         for TokenSpaceGuid, PcdCName, Setting, Arch, SkuName, Dummy3, Dummy4 in RecordList: |         for TokenSpaceGuid, PcdCName, Setting, Arch, SkuName, Dummy3, Dummy4 in RecordList: | ||||||
|             SkuName = SkuName.upper() |  | ||||||
|             if SkuName not in AvailableSkuIdSet: |             if SkuName not in AvailableSkuIdSet: | ||||||
|                 continue |                 continue | ||||||
|  |  | ||||||
| @@ -976,6 +1009,16 @@ class DscBuildData(PlatformBuildClassObject): | |||||||
|             if (PcdCName,TokenSpaceGuid) in Pcds.keys():   |             if (PcdCName,TokenSpaceGuid) in Pcds.keys():   | ||||||
|                 pcdObject = Pcds[PcdCName,TokenSpaceGuid] |                 pcdObject = Pcds[PcdCName,TokenSpaceGuid] | ||||||
|                 pcdObject.SkuInfoList[SkuName] = SkuInfo |                 pcdObject.SkuInfoList[SkuName] = SkuInfo | ||||||
|  |                 if MaxDatumSize.strip(): | ||||||
|  |                     CurrentMaxSize = int(MaxDatumSize.strip(),0) | ||||||
|  |                 else: | ||||||
|  |                     CurrentMaxSize = 0 | ||||||
|  |                 if pcdObject.MaxDatumSize: | ||||||
|  |                     PcdMaxSize = int(pcdObject.MaxDatumSize,0) | ||||||
|  |                 else: | ||||||
|  |                     PcdMaxSize = 0 | ||||||
|  |                 if CurrentMaxSize > PcdMaxSize: | ||||||
|  |                     pcdObject.MaxDatumSize = str(CurrentMaxSize) | ||||||
|             else: |             else: | ||||||
|                 Pcds[PcdCName, TokenSpaceGuid] = PcdClassObject( |                 Pcds[PcdCName, TokenSpaceGuid] = PcdClassObject( | ||||||
|                                                 PcdCName, |                                                 PcdCName, | ||||||
| @@ -991,8 +1034,8 @@ class DscBuildData(PlatformBuildClassObject): | |||||||
|                                                 ) |                                                 ) | ||||||
|         for pcd in Pcds.values(): |         for pcd in Pcds.values(): | ||||||
|             SkuInfoObj = pcd.SkuInfoList.values()[0] |             SkuInfoObj = pcd.SkuInfoList.values()[0] | ||||||
|             if 'DEFAULT' not in pcd.SkuInfoList.keys() and 'COMMON' not in pcd.SkuInfoList.keys(): |  | ||||||
|             pcdDecObject = self._DecPcds[pcd.TokenCName,pcd.TokenSpaceGuidCName] |             pcdDecObject = self._DecPcds[pcd.TokenCName,pcd.TokenSpaceGuidCName] | ||||||
|  |             if 'DEFAULT' not in pcd.SkuInfoList.keys() and 'COMMON' not in pcd.SkuInfoList.keys(): | ||||||
|                 valuefromDec = pcdDecObject.DefaultValue |                 valuefromDec = pcdDecObject.DefaultValue | ||||||
|                 SkuInfo = SkuInfoClass('DEFAULT', '0', '', '', '','',SkuInfoObj.VpdOffset, valuefromDec) |                 SkuInfo = SkuInfoClass('DEFAULT', '0', '', '', '','',SkuInfoObj.VpdOffset, valuefromDec) | ||||||
|                 pcd.SkuInfoList['DEFAULT'] = SkuInfo |                 pcd.SkuInfoList['DEFAULT'] = SkuInfo | ||||||
| @@ -1006,14 +1049,6 @@ class DscBuildData(PlatformBuildClassObject): | |||||||
|                     pcd.SkuInfoList[SkuObj.SystemSkuId] = pcd.SkuInfoList['DEFAULT'] |                     pcd.SkuInfoList[SkuObj.SystemSkuId] = pcd.SkuInfoList['DEFAULT'] | ||||||
|                 del(pcd.SkuInfoList['DEFAULT']) |                 del(pcd.SkuInfoList['DEFAULT']) | ||||||
|              |              | ||||||
|             if SkuObj.SkuUsageType == SkuObj.MULTIPLE: |  | ||||||
|                     if pcd.MaxDatumSize.strip():  |  | ||||||
|                         MaxSize = int(pcd.MaxDatumSize,0) |  | ||||||
|                         for (skuname,skuobj) in pcd.SkuInfoList.items(): |  | ||||||
|                             datalen = len(skuobj.DefaultValue) |  | ||||||
|                             if datalen>MaxSize: |  | ||||||
|                                 MaxSize = datalen |  | ||||||
|                         pcd.MaxDatumSize = str(MaxSize) |  | ||||||
|         return Pcds |         return Pcds | ||||||
|  |  | ||||||
|     ## Add external modules |     ## Add external modules | ||||||
| @@ -1520,6 +1555,7 @@ class InfBuildData(ModuleBuildClassObject): | |||||||
|     ## Set all internal used members of InfBuildData to None |     ## Set all internal used members of InfBuildData to None | ||||||
|     def _Clear(self): |     def _Clear(self): | ||||||
|         self._HeaderComments = None |         self._HeaderComments = None | ||||||
|  |         self._TailComments = None | ||||||
|         self._Header_               = None |         self._Header_               = None | ||||||
|         self._AutoGenVersion        = None |         self._AutoGenVersion        = None | ||||||
|         self._BaseName              = None |         self._BaseName              = None | ||||||
| @@ -1612,7 +1648,13 @@ class InfBuildData(ModuleBuildClassObject): | |||||||
|             for Record in RecordList: |             for Record in RecordList: | ||||||
|                 self._HeaderComments.append(Record[0]) |                 self._HeaderComments.append(Record[0]) | ||||||
|         return self._HeaderComments |         return self._HeaderComments | ||||||
|  |     def _GetTailComments(self): | ||||||
|  |         if not self._TailComments: | ||||||
|  |             self._TailComments = [] | ||||||
|  |             RecordList = self._RawData[MODEL_META_DATA_TAIL_COMMENT] | ||||||
|  |             for Record in RecordList: | ||||||
|  |                 self._TailComments.append(Record[0]) | ||||||
|  |         return self._TailComments | ||||||
|     ## Retrieve all information in [Defines] section |     ## Retrieve all information in [Defines] section | ||||||
|     # |     # | ||||||
|     #   (Retriving all [Defines] information in one-shot is just to save time.) |     #   (Retriving all [Defines] information in one-shot is just to save time.) | ||||||
| @@ -1769,7 +1811,7 @@ class InfBuildData(ModuleBuildClassObject): | |||||||
|                         else: |                         else: | ||||||
|                             Tool = ToolList[0] |                             Tool = ToolList[0] | ||||||
|                         ToolChain = "*_*_*_%s_FLAGS" % Tool |                         ToolChain = "*_*_*_%s_FLAGS" % Tool | ||||||
|                         ToolChainFamily = 'MSFT'    # Edk.x only support MSFT tool chain |                         ToolChainFamily = ''  | ||||||
|                         #ignore not replaced macros in value |                         #ignore not replaced macros in value | ||||||
|                         ValueList = GetSplitList(' ' + Value, '/D') |                         ValueList = GetSplitList(' ' + Value, '/D') | ||||||
|                         Dummy = ValueList[0] |                         Dummy = ValueList[0] | ||||||
| @@ -2447,6 +2489,7 @@ class InfBuildData(ModuleBuildClassObject): | |||||||
|     Platform = property(_GetPlatform, _SetPlatform) |     Platform = property(_GetPlatform, _SetPlatform) | ||||||
|  |  | ||||||
|     HeaderComments = property(_GetHeaderComments) |     HeaderComments = property(_GetHeaderComments) | ||||||
|  |     TailComments = property(_GetTailComments) | ||||||
|     AutoGenVersion          = property(_GetInfVersion) |     AutoGenVersion          = property(_GetInfVersion) | ||||||
|     BaseName                = property(_GetBaseName) |     BaseName                = property(_GetBaseName) | ||||||
|     ModuleType              = property(_GetModuleType) |     ModuleType              = property(_GetModuleType) | ||||||
|   | |||||||
| @@ -259,7 +259,7 @@ class DepexParser(object): | |||||||
|             Statement = gOpCodeList[struct.unpack("B", OpCode)[0]] |             Statement = gOpCodeList[struct.unpack("B", OpCode)[0]] | ||||||
|             if Statement in ["BEFORE", "AFTER", "PUSH"]: |             if Statement in ["BEFORE", "AFTER", "PUSH"]: | ||||||
|                 GuidValue = "%08X-%04X-%04X-%02X%02X-%02X%02X%02X%02X%02X%02X" % \ |                 GuidValue = "%08X-%04X-%04X-%02X%02X-%02X%02X%02X%02X%02X%02X" % \ | ||||||
|                             struct.unpack("LHHBBBBBBBB", DepexFile.read(16)) |                             struct.unpack("=LHHBBBBBBBB", DepexFile.read(16)) | ||||||
|                 GuidString = self._GuidDb.get(GuidValue, GuidValue) |                 GuidString = self._GuidDb.get(GuidValue, GuidValue) | ||||||
|                 Statement = "%s %s" % (Statement, GuidString) |                 Statement = "%s %s" % (Statement, GuidString) | ||||||
|             DepexStatement.append(Statement) |             DepexStatement.append(Statement) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user