# Copyright (c) 2007 - 2018, Intel Corporation. All rights reserved.<BR>\r
# Copyright (c) 2015, Hewlett Packard Enterprise Development, L.P.<BR>\r
#\r
-# This program and the accompanying materials\r
-# are licensed and made available under the terms and conditions of the BSD License\r
-# which accompanies this distribution. The full text of the license may be found at\r
-# http://opensource.org/licenses/bsd-license.php\r
-#\r
-# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
-# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
+# SPDX-License-Identifier: BSD-2-Clause-Patent\r
#\r
\r
##\r
\r
from Common.BuildToolError import *\r
from Common import EdkLogger\r
-from Common.Misc import PathClass, tdict\r
+from Common.Misc import PathClass, tdict, ProcessDuplicatedInf\r
from Common.StringUtils import NormPath, ReplaceMacro\r
from Common import GlobalData\r
from Common.Expression import *\r
from .RuleComplexFile import RuleComplexFile\r
from .RuleSimpleFile import RuleSimpleFile\r
from .EfiSection import EfiSection\r
-from .Vtf import Vtf\r
-from .ComponentStatement import ComponentStatement\r
from .OptionRom import OPTIONROM\r
from .OptRomInfStatement import OptRomInfStatement, OverrideAttribs\r
from .OptRomFileStatement import OptRomFileStatement\r
T_CHAR_TAB = '\t'\r
T_CHAR_DOUBLE_QUOTE = '\"'\r
T_CHAR_SINGLE_QUOTE = '\''\r
-T_CHAR_STAR = '*'\r
+T_CHAR_BRACE_R = '}'\r
\r
-SEPARATORS = {TAB_EQUAL_SPLIT, TAB_VALUE_SPLIT, TAB_COMMA_SPLIT, '{', '}'}\r
+SEPARATORS = {TAB_EQUAL_SPLIT, TAB_VALUE_SPLIT, TAB_COMMA_SPLIT, '{', T_CHAR_BRACE_R}\r
ALIGNMENTS = {"Auto", "8", "16", "32", "64", "128", "512", "1K", "4K", "32K", "64K", "128K",\r
"256K", "512K", "1M", "2M", "4M", "8M", "16M"}\r
ALIGNMENT_NOAUTO = ALIGNMENTS - {"Auto"}\r
self.FileName = FileName\r
self.FileLinesList = []\r
try:\r
- with open(FileName, "rb", 0) as fsock:\r
+ with open(FileName, "r") as fsock:\r
self.FileLinesList = fsock.readlines()\r
for index, line in enumerate(self.FileLinesList):\r
if not line.endswith(TAB_LINE_BREAK):\r
def __init__(self, FileName):\r
self.FileLinesList = []\r
try:\r
- with open(FileName, "rb", 0) as fsock:\r
+ with open(FileName, "r") as fsock:\r
self.FileLinesList = fsock.readlines()\r
\r
except:\r
self.FdNameNotSet = False\r
self.FvDict = {}\r
self.CapsuleDict = {}\r
- self.VtfList = []\r
self.RuleDict = {}\r
self.OptRomDict = {}\r
self.FmpPayloadDict = {}\r
# [FV.UiName]\r
# [Capsule.UiName]\r
# [Rule]: don't take rule section into account, macro is not allowed in this section\r
- # [VTF.arch.UiName, arch]\r
# [OptionRom.DriverName]\r
self._CurSection = []\r
Section = Section.strip()[1:-1].upper().replace(' ', '').strip(TAB_SPLIT)\r
\r
if Item == TAB_COMMON_DEFINES.upper():\r
self._CurSection = [TAB_COMMON, TAB_COMMON, TAB_COMMON]\r
- elif Item == 'VTF' and len(ItemList) == 3:\r
- UiName = ItemList[2]\r
- Pos = UiName.find(TAB_COMMA_SPLIT)\r
- if Pos != -1:\r
- UiName = UiName[:Pos]\r
- self._CurSection = ['VTF', UiName, ItemList[1]]\r
elif len(ItemList) > 1:\r
self._CurSection = [ItemList[0], ItemList[1], TAB_COMMON]\r
elif len(ItemList) > 0:\r
InComment = False\r
HashComment = False\r
# check for */ comment end\r
- elif InComment and not DoubleSlashComment and not HashComment and self._CurrentChar() == T_CHAR_STAR and self._NextChar() == TAB_BACK_SLASH:\r
+ elif InComment and not DoubleSlashComment and not HashComment and self._CurrentChar() == TAB_STAR and self._NextChar() == TAB_BACK_SLASH:\r
self._SetCurrentCharValue(TAB_SPACE_SPLIT)\r
self._GetOneChar()\r
self._SetCurrentCharValue(TAB_SPACE_SPLIT)\r
InComment = True\r
HashComment = True\r
# check for /* comment start\r
- elif self._CurrentChar() == TAB_BACK_SLASH and self._NextChar() == T_CHAR_STAR:\r
+ elif self._CurrentChar() == TAB_BACK_SLASH and self._NextChar() == TAB_STAR:\r
self._SetCurrentCharValue(TAB_SPACE_SPLIT)\r
self._GetOneChar()\r
self._SetCurrentCharValue(TAB_SPACE_SPLIT)\r
EndPos = CurLine.find(')', StartPos+2)\r
while StartPos != -1 and EndPos != -1 and self._Token not in {TAB_IF_DEF, TAB_IF_N_DEF, TAB_IF, TAB_ELSE_IF}:\r
MacroName = CurLine[StartPos+2: EndPos]\r
- MacorValue = self._GetMacroValue(MacroName)\r
- if MacorValue is not None:\r
- CurLine = CurLine.replace('$(' + MacroName + ')', MacorValue, 1)\r
- if MacorValue.find('$(') != -1:\r
+ MacroValue = self._GetMacroValue(MacroName)\r
+ if MacroValue is not None:\r
+ CurLine = CurLine.replace('$(' + MacroName + ')', MacroValue, 1)\r
+ if MacroValue.find('$(') != -1:\r
PreIndex = StartPos\r
else:\r
- PreIndex = StartPos + len(MacorValue)\r
+ PreIndex = StartPos + len(MacroValue)\r
else:\r
PreIndex = EndPos + 1\r
StartPos = CurLine.find('$(', PreIndex)\r
\r
## _GetNextToken() method\r
#\r
- # Get next token unit before a seperator\r
+ # Get next token unit before a separator\r
# If found, the string value is put into self._Token\r
#\r
# @param self The object pointer\r
StartLine = self.CurrentLineNumber\r
while StartLine == self.CurrentLineNumber:\r
TempChar = self._CurrentChar()\r
- # Try to find the end char that is not a space and not in seperator tuple.\r
+ # Try to find the end char that is not a space and not in separator tuple.\r
# That is, when we got a space or any char in the tuple, we got the end of token.\r
if not str(TempChar).isspace() and TempChar not in SEPARATORS:\r
self._GetOneChar()\r
- # if we happen to meet a seperator as the first char, we must proceed to get it.\r
- # That is, we get a token that is a seperator char. nomally it is the boundary of other tokens.\r
+ # if we happen to meet a separator as the first char, we must proceed to get it.\r
+ # That is, we get a token that is a separator char. normally it is the boundary of other tokens.\r
elif StartPos == self.CurrentOffsetWithinLine and TempChar in SEPARATORS:\r
self._GetOneChar()\r
break\r
\r
## _GetNextGuid() method\r
#\r
- # Get next token unit before a seperator\r
+ # Get next token unit before a separator\r
# If found, the GUID string is put into self._Token\r
#\r
# @param self The object pointer\r
def _GetNextGuid(self):\r
if not self._GetNextToken():\r
return False\r
- if gGuidPattern.match(self._Token) is not None:\r
+ if GlobalData.gGuidPattern.match(self._Token) is not None:\r
return True\r
else:\r
self._UndoToken()\r
while CurrentLine == self.CurrentLineNumber:\r
\r
TempChar = self._CurrentChar()\r
- # Try to find the end char that is not a space and not in seperator tuple.\r
+ # Try to find the end char that is not a space and not in separator tuple.\r
# That is, when we got a space or any char in the tuple, we got the end of token.\r
if not str(TempChar).isspace() and not TempChar in SEPARATORS:\r
if not self._UndoOneChar():\r
return\r
- # if we happen to meet a seperator as the first char, we must proceed to get it.\r
- # That is, we get a token that is a seperator char. nomally it is the boundary of other tokens.\r
+ # if we happen to meet a separator as the first char, we must proceed to get it.\r
+ # That is, we get a token that is a separator char. normally it is the boundary of other tokens.\r
elif StartPos == self.CurrentOffsetWithinLine and TempChar in SEPARATORS:\r
return\r
else:\r
\r
## _GetNextHexNumber() method\r
#\r
- # Get next HEX data before a seperator\r
+ # Get next HEX data before a separator\r
# If found, the HEX data is put into self._Token\r
#\r
# @param self The object pointer\r
def _GetNextHexNumber(self):\r
if not self._GetNextToken():\r
return False\r
- if gHexPatternAll.match(self._Token):\r
+ if GlobalData.gHexPatternAll.match(self._Token):\r
return True\r
else:\r
self._UndoToken()\r
\r
## _GetNextDecimalNumber() method\r
#\r
- # Get next decimal data before a seperator\r
+ # Get next decimal data before a separator\r
# If found, the decimal data is put into self._Token\r
#\r
# @param self The object pointer\r
#\r
# Keep processing sections of the FDF until no new sections or a syntax error is found\r
#\r
- while self._GetFd() or self._GetFv() or self._GetFmp() or self._GetCapsule() or self._GetVtf() or self._GetRule() or self._GetOptionRom():\r
+ while self._GetFd() or self._GetFv() or self._GetFmp() or self._GetCapsule() or self._GetRule() or self._GetOptionRom():\r
pass\r
\r
except Warning as X:\r
def SectionParser(self, section):\r
S = section.upper()\r
if not S.startswith("[DEFINES") and not S.startswith("[FD.") and not S.startswith("[FV.") and not S.startswith("[CAPSULE.") \\r
- and not S.startswith("[VTF.") and not S.startswith("[RULE.") and not S.startswith("[OPTIONROM.") and not S.startswith('[FMPPAYLOAD.'):\r
- raise Warning("Unknown section or section appear sequence error (The correct sequence should be [DEFINES], [FD.], [FV.], [Capsule.], [VTF.], [Rule.], [OptionRom.], [FMPPAYLOAD.])", self.FileName, self.CurrentLineNumber)\r
+ and not S.startswith("[RULE.") and not S.startswith("[OPTIONROM.") and not S.startswith('[FMPPAYLOAD.'):\r
+ raise Warning("Unknown section or section appear sequence error (The correct sequence should be [DEFINES], [FD.], [FV.], [Capsule.], [Rule.], [OptionRom.], [FMPPAYLOAD.])", self.FileName, self.CurrentLineNumber)\r
\r
## _GetDefines() method\r
#\r
S = self._Token.upper()\r
if S.startswith(TAB_SECTION_START) and not S.startswith("[FD."):\r
if not S.startswith("[FV.") and not S.startswith('[FMPPAYLOAD.') and not S.startswith("[CAPSULE.") \\r
- and not S.startswith("[VTF.") and not S.startswith("[RULE.") and not S.startswith("[OPTIONROM."):\r
+ and not S.startswith("[RULE.") and not S.startswith("[OPTIONROM."):\r
raise Warning("Unknown section", self.FileName, self.CurrentLineNumber)\r
self._UndoToken()\r
return False\r
self.SetPcdLocalation(pcdPair)\r
FileLineTuple = GetRealFileLine(self.FileName, self.CurrentLineNumber)\r
self.Profile.PcdFileLineDict[pcdPair] = FileLineTuple\r
- Obj.Size = long(Size, 0)\r
+ Obj.Size = int(Size, 0)\r
return True\r
\r
if self._IsKeyword("ErasePolarity"):\r
if not self._GetNextDecimalNumber() and not self._GetNextHexNumber():\r
raise Warning.Expected("address", self.FileName, self.CurrentLineNumber)\r
\r
- BsAddress = long(self._Token, 0)\r
+ BsAddress = int(self._Token, 0)\r
Obj.BsBaseAddress = BsAddress\r
\r
if self._IsKeyword("RtBaseAddress"):\r
if not self._GetNextDecimalNumber() and not self._GetNextHexNumber():\r
raise Warning.Expected("address", self.FileName, self.CurrentLineNumber)\r
\r
- RtAddress = long(self._Token, 0)\r
+ RtAddress = int(self._Token, 0)\r
Obj.RtBaseAddress = RtAddress\r
\r
## _GetBlockStatements() method\r
self.SetPcdLocalation(PcdPair)\r
FileLineTuple = GetRealFileLine(self.FileName, self.CurrentLineNumber)\r
self.Profile.PcdFileLineDict[PcdPair] = FileLineTuple\r
- BlockSize = long(BlockSize, 0)\r
+ BlockSize = int(BlockSize, 0)\r
\r
BlockNumber = None\r
if self._IsKeyword("NumBlocks"):\r
if not self._GetNextDecimalNumber() and not self._GetNextHexNumber():\r
raise Warning.Expected("block numbers", self.FileName, self.CurrentLineNumber)\r
\r
- BlockNumber = long(self._Token, 0)\r
+ BlockNumber = int(self._Token, 0)\r
\r
Obj.BlockSizeList.append((BlockSize, BlockNumber, BlockSizePcd))\r
return True\r
Expr += CurCh\r
self._GetOneChar()\r
try:\r
- return long(\r
+ return int(\r
ValueExpression(Expr,\r
self._CollectMacroPcd()\r
)(True), 0)\r
RegionOffsetPcdPattern.match(self._CurrentLine()[self.CurrentOffsetWithinLine:]))\r
if IsRegionPcd:\r
RegionObj.PcdOffset = self._GetNextPcdSettings()\r
- self.Profile.PcdDict[RegionObj.PcdOffset] = "0x%08X" % (RegionObj.Offset + long(theFd.BaseAddress, 0))\r
+ self.Profile.PcdDict[RegionObj.PcdOffset] = "0x%08X" % (RegionObj.Offset + int(theFd.BaseAddress, 0))\r
self.SetPcdLocalation(RegionObj.PcdOffset)\r
self._PcdDict['%s.%s' % (RegionObj.PcdOffset[1], RegionObj.PcdOffset[0])] = "0x%x" % RegionObj.Offset\r
FileLineTuple = GetRealFileLine(self.FileName, self.CurrentLineNumber)\r
DataString += self._Token\r
DataString += TAB_COMMA_SPLIT\r
\r
- if not self._IsToken("}"):\r
+ if not self._IsToken(T_CHAR_BRACE_R):\r
raise Warning.ExpectedCurlyClose(self.FileName, self.CurrentLineNumber)\r
\r
DataString = DataString.rstrip(TAB_COMMA_SPLIT)\r
DataString += self._Token\r
DataString += TAB_COMMA_SPLIT\r
\r
- if not self._IsToken("}"):\r
+ if not self._IsToken(T_CHAR_BRACE_R):\r
raise Warning.ExpectedCurlyClose(self.FileName, self.CurrentLineNumber)\r
\r
DataString = DataString.rstrip(TAB_COMMA_SPLIT)\r
DataString += self._Token\r
DataString += TAB_COMMA_SPLIT\r
\r
- if not self._IsToken("}"):\r
+ if not self._IsToken(T_CHAR_BRACE_R):\r
raise Warning.ExpectedCurlyClose(self.FileName, self.CurrentLineNumber)\r
\r
- if not self._IsToken("}"):\r
+ if not self._IsToken(T_CHAR_BRACE_R):\r
raise Warning.ExpectedCurlyClose(self.FileName, self.CurrentLineNumber)\r
\r
DataString = DataString.rstrip(TAB_COMMA_SPLIT)\r
\r
FvObj.FvExtEntryData.append(self._Token)\r
\r
- if not self._IsToken("}"):\r
+ if not self._IsToken(T_CHAR_BRACE_R):\r
raise Warning.ExpectedCurlyClose(self.FileName, self.CurrentLineNumber)\r
\r
return True\r
if not IsInf and not IsFile:\r
break\r
\r
- if not self._IsToken("}"):\r
+ if not self._IsToken(T_CHAR_BRACE_R):\r
raise Warning.ExpectedCurlyClose(self.FileName, self.CurrentLineNumber)\r
\r
FvObj.AprioriSectionList.append(AprSectionObj)\r
if ErrorCode != 0:\r
EdkLogger.error("GenFds", ErrorCode, ExtraData=ErrorInfo)\r
\r
- if not ffsInf.InfFileName in self.Profile.InfList:\r
- self.Profile.InfList.append(ffsInf.InfFileName)\r
+ NewFileName = ffsInf.InfFileName\r
+ if ffsInf.OverrideGuid:\r
+ NewFileName = ProcessDuplicatedInf(PathClass(ffsInf.InfFileName,GenFdsGlobalVariable.WorkSpaceDir), ffsInf.OverrideGuid, GenFdsGlobalVariable.WorkSpaceDir).Path\r
+\r
+ if not NewFileName in self.Profile.InfList:\r
+ self.Profile.InfList.append(NewFileName)\r
FileLineTuple = GetRealFileLine(self.FileName, self.CurrentLineNumber)\r
self.Profile.InfFileLineList.append(FileLineTuple)\r
if ffsInf.UseArch:\r
#\r
@staticmethod\r
def _FileCouldHaveRelocFlag (FileType):\r
- if FileType in {SUP_MODULE_SEC, SUP_MODULE_PEI_CORE, SUP_MODULE_PEIM, 'PEI_DXE_COMBO'}:\r
+ if FileType in {SUP_MODULE_SEC, SUP_MODULE_PEI_CORE, SUP_MODULE_PEIM, SUP_MODULE_MM_CORE_STANDALONE, 'PEI_DXE_COMBO'}:\r
return True\r
else:\r
return False\r
FfsFileObj.FileName = self._Token.replace('$(SPACE)', ' ')\r
self._VerifyFile(FfsFileObj.FileName)\r
\r
- if not self._IsToken("}"):\r
+ if not self._IsToken(T_CHAR_BRACE_R):\r
raise Warning.ExpectedCurlyClose(self.FileName, self.CurrentLineNumber)\r
\r
## _GetRAWData() method\r
raise Warning.Expected("Filename value", self.FileName, self.CurrentLineNumber)\r
\r
FileName = self._Token.replace('$(SPACE)', ' ')\r
- if FileName == '}':\r
+ if FileName == T_CHAR_BRACE_R:\r
self._UndoToken()\r
raise Warning.Expected("Filename value", self.FileName, self.CurrentLineNumber)\r
\r
FfsFileObj.FileName.append(File.Path)\r
FfsFileObj.SubAlignment.append(AlignValue)\r
\r
- if self._IsToken("}"):\r
+ if self._IsToken(T_CHAR_BRACE_R):\r
self._UndoToken()\r
break\r
\r
if not IsInf and not IsFile:\r
break\r
\r
- if not self._IsToken("}"):\r
+ if not self._IsToken(T_CHAR_BRACE_R):\r
raise Warning.ExpectedCurlyClose(self.FileName, self.CurrentLineNumber)\r
\r
FvImageSectionObj = FvImageSection()\r
raise Warning.ExpectedEquals(self.FileName, self.CurrentLineNumber)\r
if not self._IsToken("{"):\r
raise Warning.ExpectedCurlyOpen(self.FileName, self.CurrentLineNumber)\r
- if not self._SkipToToken("}"):\r
+ if not self._SkipToToken(T_CHAR_BRACE_R):\r
raise Warning.Expected("Depex expression ending '}'", self.FileName, self.CurrentLineNumber)\r
\r
- DepexSectionObj.Expression = self._SkippedChars.rstrip('}')\r
+ DepexSectionObj.Expression = self._SkippedChars.rstrip(T_CHAR_BRACE_R)\r
Obj.SectionList.append(DepexSectionObj)\r
\r
else:\r
break\r
\r
\r
- if not self._IsToken("}"):\r
+ if not self._IsToken(T_CHAR_BRACE_R):\r
raise Warning.ExpectedCurlyClose(self.FileName, self.CurrentLineNumber)\r
Obj.SectionList.append(CompressSectionObj)\r
return True\r
if not IsLeafSection and not IsEncapSection:\r
break\r
\r
- if not self._IsToken("}"):\r
+ if not self._IsToken(T_CHAR_BRACE_R):\r
raise Warning.ExpectedCurlyClose(self.FileName, self.CurrentLineNumber)\r
Obj.SectionList.append(GuidSectionObj)\r
\r
if FdfParser._Verify(Name, Value, 'UINT64'):\r
FmpData.MonotonicCount = Value\r
if FmpData.MonotonicCount.upper().startswith('0X'):\r
- FmpData.MonotonicCount = (long)(FmpData.MonotonicCount, 16)\r
+ FmpData.MonotonicCount = int(FmpData.MonotonicCount, 16)\r
else:\r
- FmpData.MonotonicCount = (long)(FmpData.MonotonicCount)\r
+ FmpData.MonotonicCount = int(FmpData.MonotonicCount)\r
if not self._GetNextToken():\r
break\r
else:\r
\r
if not self._IsKeyword("$(NAMED_GUID)"):\r
if not self._GetNextWord():\r
- raise Warning.Expected("$(NAMED_GUID)", self.FileName, self.CurrentLineNumber)\r
+ NamedGuid = self._CurrentLine()[self.CurrentOffsetWithinLine:].split()[0].strip()\r
+ if GlobalData.gGuidPatternEnd.match(NamedGuid):\r
+ self.CurrentOffsetWithinLine += len(NamedGuid)\r
+ self._Token = NamedGuid\r
+ else:\r
+ raise Warning.Expected("$(NAMED_GUID)", self.FileName, self.CurrentLineNumber)\r
if self._Token == 'PCD':\r
if not self._IsToken("("):\r
raise Warning.Expected("'('", self.FileName, self.CurrentLineNumber)\r
if not IsEncapsulate and not IsLeaf:\r
break\r
\r
- if not self._IsToken("}"):\r
+ if not self._IsToken(T_CHAR_BRACE_R):\r
raise Warning.ExpectedCurlyClose(self.FileName, self.CurrentLineNumber)\r
\r
return NewRule\r
#\r
def _GetEfiSection(self, Obj):\r
OldPos = self.GetFileBufferPos()\r
+ EfiSectionObj = EfiSection()\r
if not self._GetNextWord():\r
- return False\r
+ CurrentLine = self._CurrentLine()[self.CurrentOffsetWithinLine:].split()[0].strip()\r
+ if self._Token == '{' and Obj.FvFileType == "RAW" and TAB_SPLIT in CurrentLine:\r
+ if self._IsToken(TAB_VALUE_SPLIT):\r
+ EfiSectionObj.FileExtension = self._GetFileExtension()\r
+ elif self._GetNextToken():\r
+ EfiSectionObj.FileName = self._Token\r
+ EfiSectionObj.SectionType = BINARY_FILE_TYPE_RAW\r
+ Obj.SectionList.append(EfiSectionObj)\r
+ return True\r
+ else:\r
+ return False\r
SectionName = self._Token\r
\r
if SectionName not in {\r
if not IsInf and not IsFile:\r
break\r
\r
- if not self._IsToken("}"):\r
+ if not self._IsToken(T_CHAR_BRACE_R):\r
raise Warning.ExpectedCurlyClose(self.FileName, self.CurrentLineNumber)\r
FvImageSectionObj.Fv = FvObj\r
FvImageSectionObj.FvName = None\r
FvImageSectionObj.FvFileExtension = self._GetFileExtension()\r
elif self._GetNextToken():\r
if self._Token not in {\r
- "}", "COMPAT16", BINARY_FILE_TYPE_PE32,\r
+ T_CHAR_BRACE_R, "COMPAT16", BINARY_FILE_TYPE_PE32,\r
BINARY_FILE_TYPE_PIC, BINARY_FILE_TYPE_TE,\r
"FV_IMAGE", "RAW", BINARY_FILE_TYPE_DXE_DEPEX,\r
BINARY_FILE_TYPE_UI, "VERSION",\r
Obj.SectionList.append(FvImageSectionObj)\r
return True\r
\r
- EfiSectionObj = EfiSection()\r
EfiSectionObj.SectionType = SectionName\r
\r
if not self._GetNextToken():\r
EfiSectionObj.FileExtension = self._GetFileExtension()\r
elif self._GetNextToken():\r
if self._Token not in {\r
- "}", "COMPAT16", BINARY_FILE_TYPE_PE32,\r
+ T_CHAR_BRACE_R, "COMPAT16", BINARY_FILE_TYPE_PE32,\r
BINARY_FILE_TYPE_PIC, BINARY_FILE_TYPE_TE,\r
"FV_IMAGE", "RAW", BINARY_FILE_TYPE_DXE_DEPEX,\r
BINARY_FILE_TYPE_UI, "VERSION",\r
if not IsEncapsulate and not IsLeaf:\r
break\r
\r
- if not self._IsToken("}"):\r
+ if not self._IsToken(T_CHAR_BRACE_R):\r
raise Warning.ExpectedCurlyClose(self.FileName, self.CurrentLineNumber)\r
theRule.SectionList.append(CompressSectionObj)\r
\r
if not IsEncapsulate and not IsLeaf:\r
break\r
\r
- if not self._IsToken("}"):\r
+ if not self._IsToken(T_CHAR_BRACE_R):\r
raise Warning.ExpectedCurlyClose(self.FileName, self.CurrentLineNumber)\r
theRule.SectionList.append(GuidSectionObj)\r
\r
\r
return False\r
\r
- ## _GetVtf() method\r
- #\r
- # Get VTF section contents and store its data into VTF list of self.Profile\r
- #\r
- # @param self The object pointer\r
- # @retval True Successfully find a VTF\r
- # @retval False Not able to find a VTF\r
- #\r
- def _GetVtf(self):\r
- HW_ARCH_SET = {TAB_ARCH_IA32, TAB_ARCH_X64, TAB_ARCH_IPF, TAB_ARCH_ARM, TAB_ARCH_AARCH64}\r
- if not self._GetNextToken():\r
- return False\r
-\r
- S = self._Token.upper()\r
- if S.startswith(TAB_SECTION_START) and not S.startswith("[VTF."):\r
- self.SectionParser(S)\r
- self._UndoToken()\r
- return False\r
-\r
- self._UndoToken()\r
- if not self._IsToken("[VTF.", True):\r
- FileLineTuple = GetRealFileLine(self.FileName, self.CurrentLineNumber)\r
- #print 'Parsing String: %s in File %s, At line: %d, Offset Within Line: %d' \\r
- # % (self.Profile.FileLinesList[self.CurrentLineNumber - 1][self.CurrentOffsetWithinLine:], FileLineTuple[0], FileLineTuple[1], self.CurrentOffsetWithinLine)\r
- raise Warning.Expected("[VTF.]", self.FileName, self.CurrentLineNumber)\r
-\r
- if not self._SkipToToken(TAB_SPLIT):\r
- raise Warning.Expected("'.'", self.FileName, self.CurrentLineNumber)\r
-\r
- Arch = self._SkippedChars.rstrip(TAB_SPLIT).upper()\r
- if Arch not in HW_ARCH_SET:\r
- raise Warning("Unknown Arch '%s'" % Arch, self.FileName, self.CurrentLineNumber)\r
-\r
- if not self._GetNextWord():\r
- raise Warning.Expected("VTF name", self.FileName, self.CurrentLineNumber)\r
- Name = self._Token.upper()\r
-\r
- VtfObj = Vtf()\r
- VtfObj.UiName = Name\r
- VtfObj.KeyArch = Arch\r
-\r
- if self._IsToken(TAB_COMMA_SPLIT):\r
- if not self._GetNextWord():\r
- raise Warning.Expected("Arch list", self.FileName, self.CurrentLineNumber)\r
- if self._Token.upper() not in HW_ARCH_SET:\r
- raise Warning("Unknown Arch '%s'" % self._Token, self.FileName, self.CurrentLineNumber)\r
- VtfObj.ArchList = self._Token.upper()\r
-\r
- if not self._IsToken(TAB_SECTION_END):\r
- raise Warning.ExpectedBracketClose(self.FileName, self.CurrentLineNumber)\r
-\r
- if self._IsKeyword("IA32_RST_BIN"):\r
- if not self._IsToken(TAB_EQUAL_SPLIT):\r
- raise Warning.ExpectedEquals(self.FileName, self.CurrentLineNumber)\r
-\r
- if not self._GetNextToken():\r
- raise Warning.Expected("Reset file", self.FileName, self.CurrentLineNumber)\r
-\r
- VtfObj.ResetBin = self._Token\r
- if VtfObj.ResetBin.replace(TAB_WORKSPACE, '').find('$') == -1:\r
- #check for file path\r
- ErrorCode, ErrorInfo = PathClass(NormPath(VtfObj.ResetBin), GenFdsGlobalVariable.WorkSpaceDir).Validate()\r
- if ErrorCode != 0:\r
- EdkLogger.error("GenFds", ErrorCode, ExtraData=ErrorInfo)\r
-\r
- while self._GetComponentStatement(VtfObj):\r
- pass\r
-\r
- self.Profile.VtfList.append(VtfObj)\r
- return True\r
-\r
- ## _GetComponentStatement() method\r
- #\r
- # Get components in VTF\r
- #\r
- # @param self The object pointer\r
- # @param VtfObj for whom component is got\r
- # @retval True Successfully find a component\r
- # @retval False Not able to find a component\r
- #\r
- def _GetComponentStatement(self, VtfObj):\r
- if not self._IsKeyword("COMP_NAME"):\r
- return False\r
-\r
- if not self._IsToken(TAB_EQUAL_SPLIT):\r
- raise Warning.ExpectedEquals(self.FileName, self.CurrentLineNumber)\r
-\r
- if not self._GetNextWord():\r
- raise Warning.Expected("Component Name", self.FileName, self.CurrentLineNumber)\r
-\r
- CompStatementObj = ComponentStatement()\r
- CompStatementObj.CompName = self._Token\r
-\r
- if not self._IsKeyword("COMP_LOC"):\r
- raise Warning.Expected("COMP_LOC", self.FileName, self.CurrentLineNumber)\r
-\r
- if not self._IsToken(TAB_EQUAL_SPLIT):\r
- raise Warning.ExpectedEquals(self.FileName, self.CurrentLineNumber)\r
-\r
- CompStatementObj.CompLoc = ""\r
- if self._GetNextWord():\r
- CompStatementObj.CompLoc = self._Token\r
- if self._IsToken(TAB_VALUE_SPLIT):\r
- if not self._GetNextWord():\r
- raise Warning.Expected("Region Name", self.FileName, self.CurrentLineNumber)\r
-\r
- if self._Token not in {"F", "N", "S"}: #, "H", "L", "PH", "PL"): not support\r
- raise Warning("Unknown location type '%s'" % self._Token, self.FileName, self.CurrentLineNumber)\r
-\r
- CompStatementObj.FilePos = self._Token\r
- else:\r
- self.CurrentLineNumber += 1\r
- self.CurrentOffsetWithinLine = 0\r
-\r
- if not self._IsKeyword("COMP_TYPE"):\r
- raise Warning.Expected("COMP_TYPE", self.FileName, self.CurrentLineNumber)\r
-\r
- if not self._IsToken(TAB_EQUAL_SPLIT):\r
- raise Warning.ExpectedEquals(self.FileName, self.CurrentLineNumber)\r
-\r
- if not self._GetNextToken():\r
- raise Warning.Expected("Component type", self.FileName, self.CurrentLineNumber)\r
- if self._Token not in {"FIT", "PAL_B", "PAL_A", "OEM"}:\r
- if not self._Token.startswith("0x") or len(self._Token) < 3 or len(self._Token) > 4 or \\r
- not self._Token[2] in hexdigits or not self._Token[-1] in hexdigits:\r
- raise Warning("Unknown location type '%s'" % self._Token, self.FileName, self.CurrentLineNumber)\r
- CompStatementObj.CompType = self._Token\r
-\r
- if not self._IsKeyword("COMP_VER"):\r
- raise Warning.Expected("COMP_VER", self.FileName, self.CurrentLineNumber)\r
-\r
- if not self._IsToken(TAB_EQUAL_SPLIT):\r
- raise Warning.ExpectedEquals(self.FileName, self.CurrentLineNumber)\r
-\r
- if not self._GetNextToken():\r
- raise Warning.Expected("Component version", self.FileName, self.CurrentLineNumber)\r
-\r
- Pattern = compile('-$|[0-9a-fA-F]{1,2}\.[0-9a-fA-F]{1,2}$', DOTALL)\r
- if Pattern.match(self._Token) is None:\r
- raise Warning("Unknown version format '%s'" % self._Token, self.FileName, self.CurrentLineNumber)\r
- CompStatementObj.CompVer = self._Token\r
-\r
- if not self._IsKeyword("COMP_CS"):\r
- raise Warning.Expected("COMP_CS", self.FileName, self.CurrentLineNumber)\r
-\r
- if not self._IsToken(TAB_EQUAL_SPLIT):\r
- raise Warning.ExpectedEquals(self.FileName, self.CurrentLineNumber)\r
-\r
- if not self._GetNextToken():\r
- raise Warning.Expected("Component CS", self.FileName, self.CurrentLineNumber)\r
- if self._Token not in {"1", "0"}:\r
- raise Warning("Unknown Component CS '%s'" % self._Token, self.FileName, self.CurrentLineNumber)\r
- CompStatementObj.CompCs = self._Token\r
-\r
-\r
- if not self._IsKeyword("COMP_BIN"):\r
- raise Warning.Expected("COMP_BIN", self.FileName, self.CurrentLineNumber)\r
-\r
- if not self._IsToken(TAB_EQUAL_SPLIT):\r
- raise Warning.ExpectedEquals(self.FileName, self.CurrentLineNumber)\r
-\r
- if not self._GetNextToken():\r
- raise Warning.Expected("Component file", self.FileName, self.CurrentLineNumber)\r
-\r
- CompStatementObj.CompBin = self._Token\r
- if CompStatementObj.CompBin != '-' and CompStatementObj.CompBin.replace(TAB_WORKSPACE, '').find('$') == -1:\r
- #check for file path\r
- ErrorCode, ErrorInfo = PathClass(NormPath(CompStatementObj.CompBin), GenFdsGlobalVariable.WorkSpaceDir).Validate()\r
- if ErrorCode != 0:\r
- EdkLogger.error("GenFds", ErrorCode, ExtraData=ErrorInfo)\r
-\r
- if not self._IsKeyword("COMP_SYM"):\r
- raise Warning.Expected("COMP_SYM", self.FileName, self.CurrentLineNumber)\r
-\r
- if not self._IsToken(TAB_EQUAL_SPLIT):\r
- raise Warning.ExpectedEquals(self.FileName, self.CurrentLineNumber)\r
-\r
- if not self._GetNextToken():\r
- raise Warning.Expected("Component symbol file", self.FileName, self.CurrentLineNumber)\r
-\r
- CompStatementObj.CompSym = self._Token\r
- if CompStatementObj.CompSym != '-' and CompStatementObj.CompSym.replace(TAB_WORKSPACE, '').find('$') == -1:\r
- #check for file path\r
- ErrorCode, ErrorInfo = PathClass(NormPath(CompStatementObj.CompSym), GenFdsGlobalVariable.WorkSpaceDir).Validate()\r
- if ErrorCode != 0:\r
- EdkLogger.error("GenFds", ErrorCode, ExtraData=ErrorInfo)\r
-\r
- if not self._IsKeyword("COMP_SIZE"):\r
- raise Warning.Expected("COMP_SIZE", self.FileName, self.CurrentLineNumber)\r
-\r
- if not self._IsToken(TAB_EQUAL_SPLIT):\r
- raise Warning.ExpectedEquals(self.FileName, self.CurrentLineNumber)\r
-\r
- if self._IsToken("-"):\r
- CompStatementObj.CompSize = self._Token\r
- elif self._GetNextDecimalNumber():\r
- CompStatementObj.CompSize = self._Token\r
- elif self._GetNextHexNumber():\r
- CompStatementObj.CompSize = self._Token\r
- else:\r
- raise Warning("Unknown size '%s'" % self._Token, self.FileName, self.CurrentLineNumber)\r
-\r
- VtfObj.ComponentStatementList.append(CompStatementObj)\r
- return True\r
-\r
## _GetOptionRom() method\r
#\r
# Get OptionROM section contents and store its data into OptionROM list of self.Profile\r
if ErrorCode != 0:\r
EdkLogger.error("GenFds", ErrorCode, ExtraData=ErrorInfo)\r
\r
- if not ffsInf.InfFileName in self.Profile.InfList:\r
- self.Profile.InfList.append(ffsInf.InfFileName)\r
+ NewFileName = ffsInf.InfFileName\r
+ if ffsInf.OverrideGuid:\r
+ NewFileName = ProcessDuplicatedInf(PathClass(ffsInf.InfFileName,GenFdsGlobalVariable.WorkSpaceDir), ffsInf.OverrideGuid, GenFdsGlobalVariable.WorkSpaceDir).Path\r
+\r
+ if not NewFileName in self.Profile.InfList:\r
+ self.Profile.InfList.append(NewFileName)\r
FileLineTuple = GetRealFileLine(self.FileName, self.CurrentLineNumber)\r
self.Profile.InfFileLineList.append(FileLineTuple)\r
if ffsInf.UseArch:\r
if self._IsKeyword("PCI_DEVICE_ID"):\r
if not self._IsToken(TAB_EQUAL_SPLIT):\r
raise Warning.ExpectedEquals(self.FileName, self.CurrentLineNumber)\r
- if not self._GetNextHexNumber():\r
- raise Warning.Expected("Hex device id", self.FileName, self.CurrentLineNumber)\r
-\r
- Overrides.PciDeviceId = self._Token\r
+ # Get a list of PCI IDs\r
+ Overrides.PciDeviceId = ""\r
+ while (self._GetNextHexNumber()):\r
+ Overrides.PciDeviceId = "{} {}".format(Overrides.PciDeviceId, self._Token)\r
+ if not Overrides.PciDeviceId:\r
+ raise Warning.Expected("one or more Hex device ids", self.FileName, self.CurrentLineNumber)\r
continue\r
\r
if self._IsKeyword("PCI_REVISION"):\r
Overrides.NeedCompress = self._Token.upper() == 'TRUE'\r
continue\r
\r
- if self._IsToken("}"):\r
+ if self._IsToken(T_CHAR_BRACE_R):\r
break\r
else:\r
EdkLogger.error("FdfParser", FORMAT_INVALID, File=self.FileName, Line=self.CurrentLineNumber)\r