]> git.proxmox.com Git - mirror_edk2.git/blobdiff - BaseTools/Source/Python/GenFds/FdfParser.py
Sync EDKII BaseTools to BaseTools project r1903.
[mirror_edk2.git] / BaseTools / Source / Python / GenFds / FdfParser.py
index 24732a0d5e2054a10294ec471ec3814b310c0595..4ce276124318613d88e2335bfbb69520e1f04698 100644 (file)
@@ -40,6 +40,7 @@ import OptionRom
 import OptRomInfStatement\r
 import OptRomFileStatement\r
 \r
+from GenFdsGlobalVariable import GenFdsGlobalVariable\r
 from Common.BuildToolError import *\r
 from Common import EdkLogger\r
 \r
@@ -172,6 +173,7 @@ class FileProfile :
         self.InfList = []\r
 \r
         self.FdDict = {}\r
+        self.FdNameNotSet = False\r
         self.FvDict = {}\r
         self.CapsuleDict = {}\r
         self.VtfList = []\r
@@ -1300,7 +1302,16 @@ class FdfParser:
             raise Warning("expected [FD.]", self.FileName, self.CurrentLineNumber)\r
 \r
         FdName = self.__GetUiName()\r
+        if FdName == "":\r
+            if len (self.Profile.FdDict) == 0:\r
+                FdName = GenFdsGlobalVariable.PlatformName\r
+                self.Profile.FdNameNotSet = True\r
+            else:\r
+                raise Warning("expected FdName in [FD.] section", self.FileName, self.CurrentLineNumber)\r
         self.CurrentFdName = FdName.upper()\r
+        \r
+        if self.CurrentFdName in self.Profile.FdDict:\r
+            raise Warning("Unexpected the same FD name", self.FileName, self.CurrentLineNumber)\r
 \r
         if not self.__IsToken( "]"):\r
             raise Warning("expected ']'", self.FileName, self.CurrentLineNumber)\r
@@ -1308,12 +1319,15 @@ class FdfParser:
         FdObj = Fd.FD()\r
         FdObj.FdUiName = self.CurrentFdName\r
         self.Profile.FdDict[self.CurrentFdName] = FdObj\r
+\r
+        if len (self.Profile.FdDict) > 1 and self.Profile.FdNameNotSet:\r
+            raise Warning("expected all FDs have their name", self.FileName, self.CurrentLineNumber)\r
+\r
         Status = self.__GetCreateFile(FdObj)\r
         if not Status:\r
             raise Warning("FD name error", self.FileName, self.CurrentLineNumber)\r
 \r
-        if not self.__GetTokenStatements(FdObj):\r
-            return False\r
+        self.__GetTokenStatements(FdObj)\r
 \r
         self.__GetDefineStatements(FdObj)\r
 \r
@@ -1368,8 +1382,6 @@ class FdfParser:
     #\r
     #   @param  self        The object pointer\r
     #   @param  Obj         for whom token statement is got\r
-    #   @retval True        Successfully find a token statement\r
-    #   @retval False       Not able to find a token statement\r
     #\r
     def __GetTokenStatements(self, Obj):\r
         if not self.__IsKeyword( "BaseAddress"):\r
@@ -1419,8 +1431,7 @@ class FdfParser:
 \r
         Obj.ErasePolarity = self.__Token\r
 \r
-        Status = self.__GetBlockStatements(Obj)\r
-        return Status\r
+        self.__GetBlockStatements(Obj)\r
 \r
     ## __GetAddressStatements() method\r
     #\r
@@ -1459,17 +1470,20 @@ class FdfParser:
     #\r
     #   @param  self        The object pointer\r
     #   @param  Obj         for whom block statement is got\r
-    #   @retval True        Successfully find\r
-    #   @retval False       Not able to find\r
     #\r
     def __GetBlockStatements(self, Obj):\r
 \r
         if not self.__GetBlockStatement(Obj):\r
-            raise Warning("expected block statement", self.FileName, self.CurrentLineNumber)\r
+            #set default block size is 1\r
+            Obj.BlockSizeList.append((1, Obj.Size, None))\r
+            return\r
 \r
         while self.__GetBlockStatement(Obj):\r
             pass\r
-        return True\r
+        \r
+        for Item in Obj.BlockSizeList:\r
+            if Item[0] == None or Item[1] == None:\r
+                raise Warning("expected block statement for Fd Section", self.FileName, self.CurrentLineNumber)\r
 \r
     ## __GetBlockStatement() method\r
     #\r
@@ -1496,7 +1510,7 @@ class FdfParser:
             PcdPair = self.__GetNextPcdName()\r
             BlockSizePcd = PcdPair\r
             self.Profile.PcdDict[PcdPair] = BlockSize\r
-        BlockSize = long(self.__Token, 0)\r
+        BlockSize = long(BlockSize, 0)\r
 \r
         BlockNumber = None\r
         if self.__IsKeyword( "NumBlocks"):\r
@@ -2113,9 +2127,6 @@ class FdfParser:
             raise Warning("expected INF file path", self.FileName, self.CurrentLineNumber)\r
         ffsInf.InfFileName = self.__Token\r
 \r
-#        if ffsInf.InfFileName.find('$') >= 0:\r
-#            ffsInf.InfFileName = GenFdsGlobalVariable.GenFdsGlobalVariable.MacroExtend(ffsInf.InfFileName, MacroDict)\r
-\r
         if not ffsInf.InfFileName in self.Profile.InfList:\r
             self.Profile.InfList.append(ffsInf.InfFileName)\r
 \r
@@ -2427,6 +2438,8 @@ class FdfParser:
 \r
         AlignValue = None\r
         if self.__GetAlignment():\r
+            if self.__Token not in ("Auto", "8", "16", "32", "64", "128", "512", "1K", "4K", "32K" ,"64K"):\r
+                raise Warning("Incorrect alignment '%s'" % self.__Token, self.FileName, self.CurrentLineNumber)\r
             AlignValue = self.__Token\r
 \r
         BuildNum = None\r
@@ -2440,6 +2453,8 @@ class FdfParser:
             BuildNum = self.__Token\r
 \r
         if self.__IsKeyword( "VERSION"):\r
+            if AlignValue == 'Auto':\r
+                raise Warning("Auto alignment can only be used in PE32 or TE section ", self.FileName, self.CurrentLineNumber)\r
             if not self.__IsToken( "="):\r
                 raise Warning("expected '='", self.FileName, self.CurrentLineNumber)\r
             if not self.__GetNextToken():\r
@@ -2452,8 +2467,10 @@ class FdfParser:
             else:\r
                 VerSectionObj.FileName = self.__Token\r
             Obj.SectionList.append(VerSectionObj)\r
-\r
+            \r
         elif self.__IsKeyword( "UI"):\r
+            if AlignValue == 'Auto':\r
+                raise Warning("Auto alignment can only be used in PE32 or TE section ", self.FileName, self.CurrentLineNumber)\r
             if not self.__IsToken( "="):\r
                 raise Warning("expected '='", self.FileName, self.CurrentLineNumber)\r
             if not self.__GetNextToken():\r
@@ -2467,6 +2484,8 @@ class FdfParser:
             Obj.SectionList.append(UiSectionObj)\r
 \r
         elif self.__IsKeyword( "FV_IMAGE"):\r
+            if AlignValue == 'Auto':\r
+                raise Warning("Auto alignment can only be used in PE32 or TE section ", self.FileName, self.CurrentLineNumber)\r
             if not self.__IsToken( "="):\r
                 raise Warning("expected '='", self.FileName, self.CurrentLineNumber)\r
             if not self.__GetNextToken():\r
@@ -2508,6 +2527,8 @@ class FdfParser:
             Obj.SectionList.append(FvImageSectionObj)\r
 \r
         elif self.__IsKeyword("PEI_DEPEX_EXP") or self.__IsKeyword("DXE_DEPEX_EXP") or self.__IsKeyword("SMM_DEPEX_EXP"):\r
+            if AlignValue == 'Auto':\r
+                raise Warning("Auto alignment can only be used in PE32 or TE section ", self.FileName, self.CurrentLineNumber)\r
             DepexSectionObj = DepexSection.DepexSection()\r
             DepexSectionObj.Alignment = AlignValue\r
             DepexSectionObj.DepexType = self.__Token\r
@@ -2523,7 +2544,6 @@ class FdfParser:
             Obj.SectionList.append(DepexSectionObj)\r
 \r
         else:\r
-\r
             if not self.__GetNextWord():\r
                 raise Warning("expected section type", self.FileName, self.CurrentLineNumber)\r
 \r
@@ -2535,6 +2555,9 @@ class FdfParser:
             if self.__Token not in ("COMPAT16", "PE32", "PIC", "TE", "FV_IMAGE", "RAW", "DXE_DEPEX",\\r
                                "UI", "VERSION", "PEI_DEPEX", "SUBTYPE_GUID", "SMM_DEPEX"):\r
                 raise Warning("Unknown section type '%s'" % self.__Token, self.FileName, self.CurrentLineNumber)\r
+            if AlignValue == 'Auto'and (not self.__Token == 'PE32') and (not self.__Token == 'TE'):\r
+                raise Warning("Auto alignment can only be used in PE32 or TE section ", self.FileName, self.CurrentLineNumber)\r
+\r
             # DataSection\r
             DataSectionObj = DataSection.DataSection()\r
             DataSectionObj.Alignment = AlignValue\r
@@ -2684,6 +2707,8 @@ class FdfParser:
 \r
         AlignValue = None\r
         if self.__GetAlignment():\r
+            if self.__Token not in ("8", "16", "32", "64", "128", "512", "1K", "4K", "32K" ,"64K"):\r
+                raise Warning("Incorrect alignment '%s'" % self.__Token, self.FileName, self.CurrentLineNumber)\r
             AlignValue = self.__Token\r
 \r
         if not self.__GetCglSection(FfsFileObj, AlignValue):\r
@@ -3013,9 +3038,11 @@ class FdfParser:
 \r
         AlignValue = ""\r
         if self.__GetAlignment():\r
-            if self.__Token not in ("8", "16", "32", "64", "128", "512", "1K", "4K", "32K" ,"64K"):\r
+            if self.__Token not in ("Auto", "8", "16", "32", "64", "128", "512", "1K", "4K", "32K" ,"64K"):\r
                 raise Warning("Incorrect alignment '%s'" % self.__Token, self.FileName, self.CurrentLineNumber)\r
-            AlignValue = self.__Token\r
+            #For FFS, Auto is default option same to ""\r
+            if not self.__Token == "Auto":\r
+                AlignValue = self.__Token\r
 \r
         if self.__IsToken("{"):\r
             # Complex file rule expected\r
@@ -3040,24 +3067,6 @@ class FdfParser:
 \r
             return Rule\r
 \r
-        elif self.__IsToken("|"):\r
-            # Ext rule expected\r
-            Ext = self.__GetFileExtension()\r
-\r
-            Rule = RuleSimpleFile.RuleSimpleFile()\r
-\r
-            Rule.FvFileType = Type\r
-            Rule.NameGuid = NameGuid\r
-            Rule.Alignment = AlignValue\r
-            Rule.CheckSum = CheckSum\r
-            Rule.Fixed = Fixed\r
-            Rule.FileExtension = Ext\r
-            Rule.KeyStringList = KeyStringList\r
-            if KeepReloc != None:\r
-                Rule.KeepReloc = KeepReloc\r
-\r
-            return Rule\r
-\r
         else:\r
             # Simple file rule expected\r
             if not self.__GetNextWord():\r
@@ -3076,12 +3085,18 @@ class FdfParser:
             if self.__IsKeyword("CheckSum", True):\r
                 CheckSum = True\r
 \r
+            SectAlignment = ""\r
             if self.__GetAlignment():\r
-                if self.__Token not in ("8", "16", "32", "64", "128", "512", "1K", "4K", "32K" ,"64K"):\r
+                if self.__Token not in ("Auto", "8", "16", "32", "64", "128", "512", "1K", "4K", "32K" ,"64K"):\r
                     raise Warning("Incorrect alignment '%s'" % self.__Token, self.FileName, self.CurrentLineNumber)\r
-                AlignValue = self.__Token\r
+                if self.__Token == 'Auto' and (not SectionName == 'PE32') and (not SectionName == 'TE'):\r
+                    raise Warning("Auto alignment can only be used in PE32 or TE section ", self.FileName, self.CurrentLineNumber)\r
+                SectAlignment = self.__Token\r
 \r
-            if not self.__GetNextToken():\r
+            Ext = None\r
+            if self.__IsToken('|'):\r
+                Ext = self.__GetFileExtension()\r
+            elif not self.__GetNextToken():\r
                 raise Warning("expected File name", self.FileName, self.CurrentLineNumber)\r
 \r
             Rule = RuleSimpleFile.RuleSimpleFile()\r
@@ -3089,12 +3104,14 @@ class FdfParser:
             Rule.FvFileType = Type\r
             Rule.NameGuid = NameGuid\r
             Rule.Alignment = AlignValue\r
+            Rule.SectAlignment = SectAlignment\r
             Rule.CheckSum = CheckSum\r
             Rule.Fixed = Fixed\r
-            Rule.FileName = self.__Token\r
             Rule.KeyStringList = KeyStringList\r
             if KeepReloc != None:\r
                 Rule.KeepReloc = KeepReloc\r
+            Rule.FileExtension = Ext\r
+            Rule.FileName = self.__Token\r
             return Rule\r
 \r
     ## __GetEfiSection() method\r
@@ -3148,14 +3165,6 @@ class FdfParser:
                     raise Warning("expected 'FV'", self.FileName, self.CurrentLineNumber)\r
                 FvImageSectionObj.FvFileType = self.__Token\r
 \r
-                if self.__GetAlignment():\r
-                    if self.__Token not in ("8", "16", "32", "64", "128", "512", "1K", "4K", "32K" ,"64K"):\r
-                        raise Warning("Incorrect alignment '%s'" % self.__Token, self.FileName, self.CurrentLineNumber)\r
-                    FvImageSectionObj.Alignment = self.__Token\r
-\r
-                if self.__IsKeyword("FV"):\r
-                    FvImageSectionObj.FvFileType = self.__Token\r
-\r
                 if self.__GetAlignment():\r
                     if self.__Token not in ("8", "16", "32", "64", "128", "512", "1K", "4K", "32K" ,"64K"):\r
                         raise Warning("Incorrect alignment '%s'" % self.__Token, self.FileName, self.CurrentLineNumber)\r
@@ -3224,6 +3233,10 @@ class FdfParser:
                 EfiSectionObj.BuildNum = self.__Token\r
 \r
         if self.__GetAlignment():\r
+            if self.__Token not in ("Auto", "8", "16", "32", "64", "128", "512", "1K", "4K", "32K" ,"64K"):\r
+                raise Warning("Incorrect alignment '%s'" % self.__Token, self.FileName, self.CurrentLineNumber)\r
+            if self.__Token == 'Auto' and (not SectionName == 'PE32') and (not SectionName == 'TE'):\r
+                raise Warning("Auto alignment can only be used in PE32 or TE section ", self.FileName, self.CurrentLineNumber)\r
             EfiSectionObj.Alignment = self.__Token\r
 \r
         if self.__IsKeyword('RELOCS_STRIPPED') or self.__IsKeyword('RELOCS_RETAINED'):\r