]> git.proxmox.com Git - mirror_edk2.git/blame - BaseTools/Source/Python/GenFds/Fd.py
BaseTools: Fix the Keyword error for <ExtendedFvEntry> in FDF File
[mirror_edk2.git] / BaseTools / Source / Python / GenFds / Fd.py
CommitLineData
30fdf114
LG
1## @file\r
2# process FD generation\r
3#\r
66d00b4d 4# Copyright (c) 2007 - 2017, Intel Corporation. All rights reserved.<BR>\r
30fdf114 5#\r
40d841f6 6# This program and the accompanying materials\r
30fdf114
LG
7# are licensed and made available under the terms and conditions of the BSD License\r
8# which accompanies this distribution. The full text of the license may be found at\r
9# http://opensource.org/licenses/bsd-license.php\r
10#\r
11# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
12# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
13#\r
14\r
15##\r
16# Import Modules\r
17#\r
18import Region\r
19import Fv\r
1be2ed90 20import Common.LongFilePathOs as os\r
30fdf114
LG
21import StringIO\r
22import sys\r
23from struct import *\r
24from GenFdsGlobalVariable import GenFdsGlobalVariable\r
25from CommonDataClass.FdfClass import FDClassObject\r
26from Common import EdkLogger\r
27from Common.BuildToolError import *\r
28from Common.Misc import SaveFileOnChange\r
fd171542 29from GenFds import GenFds\r
30fdf114
LG
30\r
31## generate FD\r
32#\r
33#\r
34class FD(FDClassObject):\r
35 ## The constructor\r
36 #\r
37 # @param self The object pointer\r
38 #\r
39 def __init__(self):\r
40 FDClassObject.__init__(self)\r
41\r
42 ## GenFd() method\r
43 #\r
44 # Generate FD\r
45 #\r
30fdf114
LG
46 # @retval string Generated FD file name\r
47 #\r
fd171542 48 def GenFd (self):\r
49 if self.FdUiName.upper() + 'fd' in GenFds.ImageBinDict.keys():\r
50 return GenFds.ImageBinDict[self.FdUiName.upper() + 'fd']\r
51\r
30fdf114
LG
52 #\r
53 # Print Information\r
54 #\r
c82fc2b5
YF
55 FdFileName = os.path.join(GenFdsGlobalVariable.FvDir, self.FdUiName + '.fd')\r
56 GenFdsGlobalVariable.InfLogger("Fd File Name:%s (%s)" %(self.FdUiName, FdFileName))\r
57\r
30fdf114
LG
58 Offset = 0x00\r
59 for item in self.BlockSizeList:\r
60 Offset = Offset + item[0] * item[1]\r
61 if Offset != self.Size:\r
62 EdkLogger.error("GenFds", GENFDS_ERROR, 'FD %s Size not consistent with block array' % self.FdUiName)\r
63 GenFdsGlobalVariable.VerboseLogger('Following Fv will be add to Fd !!!')\r
64 for FvObj in GenFdsGlobalVariable.FdfParser.Profile.FvDict:\r
65 GenFdsGlobalVariable.VerboseLogger(FvObj)\r
66\r
67 GenFdsGlobalVariable.VerboseLogger('################### Gen VTF ####################')\r
68 self.GenVtfFile()\r
69\r
66d00b4d
YZ
70 HasCapsuleRegion = False\r
71 for RegionObj in self.RegionList:\r
b303ea72 72 if RegionObj.RegionType == 'CAPSULE':\r
66d00b4d
YZ
73 HasCapsuleRegion = True\r
74 break\r
75 if HasCapsuleRegion:\r
76 TempFdBuffer = StringIO.StringIO('')\r
77 PreviousRegionStart = -1\r
78 PreviousRegionSize = 1\r
79\r
80 for RegionObj in self.RegionList :\r
81 if RegionObj.RegionType == 'CAPSULE':\r
82 continue\r
83 if RegionObj.Offset + RegionObj.Size <= PreviousRegionStart:\r
84 pass\r
85 elif RegionObj.Offset <= PreviousRegionStart or (RegionObj.Offset >=PreviousRegionStart and RegionObj.Offset < PreviousRegionStart + PreviousRegionSize):\r
86 pass\r
87 elif RegionObj.Offset > PreviousRegionStart + PreviousRegionSize:\r
88 GenFdsGlobalVariable.InfLogger('Padding region starting from offset 0x%X, with size 0x%X' %(PreviousRegionStart + PreviousRegionSize, RegionObj.Offset - (PreviousRegionStart + PreviousRegionSize)))\r
89 PadRegion = Region.Region()\r
90 PadRegion.Offset = PreviousRegionStart + PreviousRegionSize\r
91 PadRegion.Size = RegionObj.Offset - PadRegion.Offset\r
92 PadRegion.AddToBuffer(TempFdBuffer, self.BaseAddress, self.BlockSizeList, self.ErasePolarity, GenFds.ImageBinDict, self.vtfRawDict, self.DefineVarDict)\r
93 PreviousRegionStart = RegionObj.Offset\r
94 PreviousRegionSize = RegionObj.Size\r
95 #\r
96 # Call each region's AddToBuffer function\r
97 #\r
98 if PreviousRegionSize > self.Size:\r
99 pass\r
100 GenFdsGlobalVariable.VerboseLogger('Call each region\'s AddToBuffer function')\r
101 RegionObj.AddToBuffer (TempFdBuffer, self.BaseAddress, self.BlockSizeList, self.ErasePolarity, GenFds.ImageBinDict, self.vtfRawDict, self.DefineVarDict)\r
b303ea72 102 \r
30fdf114
LG
103 FdBuffer = StringIO.StringIO('')\r
104 PreviousRegionStart = -1\r
105 PreviousRegionSize = 1\r
106 for RegionObj in self.RegionList :\r
107 if RegionObj.Offset + RegionObj.Size <= PreviousRegionStart:\r
108 EdkLogger.error("GenFds", GENFDS_ERROR,\r
109 'Region offset 0x%X in wrong order with Region starting from 0x%X, size 0x%X\nRegions in FDF must have offsets appear in ascending order.'\\r
110 % (RegionObj.Offset, PreviousRegionStart, PreviousRegionSize))\r
111 elif RegionObj.Offset <= PreviousRegionStart or (RegionObj.Offset >=PreviousRegionStart and RegionObj.Offset < PreviousRegionStart + PreviousRegionSize):\r
112 EdkLogger.error("GenFds", GENFDS_ERROR,\r
113 'Region offset 0x%X overlaps with Region starting from 0x%X, size 0x%X' \\r
114 % (RegionObj.Offset, PreviousRegionStart, PreviousRegionSize))\r
115 elif RegionObj.Offset > PreviousRegionStart + PreviousRegionSize:\r
116 GenFdsGlobalVariable.InfLogger('Padding region starting from offset 0x%X, with size 0x%X' %(PreviousRegionStart + PreviousRegionSize, RegionObj.Offset - (PreviousRegionStart + PreviousRegionSize)))\r
117 PadRegion = Region.Region()\r
118 PadRegion.Offset = PreviousRegionStart + PreviousRegionSize\r
119 PadRegion.Size = RegionObj.Offset - PadRegion.Offset\r
fd171542 120 PadRegion.AddToBuffer(FdBuffer, self.BaseAddress, self.BlockSizeList, self.ErasePolarity, GenFds.ImageBinDict, self.vtfRawDict, self.DefineVarDict)\r
30fdf114
LG
121 PreviousRegionStart = RegionObj.Offset\r
122 PreviousRegionSize = RegionObj.Size\r
123 #\r
4afd3d04
LG
124 # Verify current region fits within allocated FD section Size\r
125 #\r
126 if PreviousRegionStart + PreviousRegionSize > self.Size:\r
127 EdkLogger.error("GenFds", GENFDS_ERROR,\r
128 'FD %s size too small to fit region with offset 0x%X and size 0x%X'\r
129 % (self.FdUiName, PreviousRegionStart, PreviousRegionSize))\r
130 #\r
30fdf114
LG
131 # Call each region's AddToBuffer function\r
132 #\r
30fdf114 133 GenFdsGlobalVariable.VerboseLogger('Call each region\'s AddToBuffer function')\r
fd171542 134 RegionObj.AddToBuffer (FdBuffer, self.BaseAddress, self.BlockSizeList, self.ErasePolarity, GenFds.ImageBinDict, self.vtfRawDict, self.DefineVarDict)\r
30fdf114 135 #\r
30fdf114
LG
136 # Write the buffer contents to Fd file\r
137 #\r
138 GenFdsGlobalVariable.VerboseLogger('Write the buffer contents to Fd file')\r
139 SaveFileOnChange(FdFileName, FdBuffer.getvalue())\r
30fdf114 140 FdBuffer.close();\r
fd171542 141 GenFds.ImageBinDict[self.FdUiName.upper() + 'fd'] = FdFileName\r
30fdf114
LG
142 return FdFileName\r
143\r
144 ## generate VTF\r
145 #\r
146 # @param self The object pointer\r
147 #\r
148 def GenVtfFile (self) :\r
149 #\r
150 # Get this Fd's all Fv name\r
151 #\r
152 FvAddDict ={}\r
153 FvList = []\r
154 for RegionObj in self.RegionList:\r
155 if RegionObj.RegionType == 'FV':\r
156 if len(RegionObj.RegionDataList) == 1:\r
157 RegionData = RegionObj.RegionDataList[0]\r
158 FvList.append(RegionData.upper())\r
159 FvAddDict[RegionData.upper()] = (int(self.BaseAddress,16) + \\r
160 RegionObj.Offset, RegionObj.Size)\r
161 else:\r
162 Offset = RegionObj.Offset\r
163 for RegionData in RegionObj.RegionDataList:\r
164 FvList.append(RegionData.upper())\r
165 FvObj = GenFdsGlobalVariable.FdfParser.Profile.FvDict.get(RegionData.upper())\r
166 if len(FvObj.BlockSizeList) < 1:\r
167 EdkLogger.error("GenFds", GENFDS_ERROR,\r
168 'FV.%s must point out FVs blocksize and Fv BlockNum' \\r
169 % FvObj.UiFvName)\r
170 else:\r
171 Size = 0\r
172 for blockStatement in FvObj.BlockSizeList:\r
173 Size = Size + blockStatement[0] * blockStatement[1]\r
174 FvAddDict[RegionData.upper()] = (int(self.BaseAddress,16) + \\r
175 Offset, Size)\r
176 Offset = Offset + Size\r
177 #\r
178 # Check whether this Fd need VTF\r
179 #\r
180 Flag = False\r
181 for VtfObj in GenFdsGlobalVariable.FdfParser.Profile.VtfList:\r
182 compLocList = VtfObj.GetFvList()\r
183 if set(compLocList).issubset(FvList):\r
184 Flag = True\r
185 break\r
186 if Flag == True:\r
187 self.vtfRawDict = VtfObj.GenVtf(FvAddDict)\r
188\r
189 ## generate flash map file\r
190 #\r
191 # @param self The object pointer\r
192 #\r
193 def GenFlashMap (self):\r
194 pass\r
195\r
196\r
197\r
198\r
199\r
200\r
201\r
202\r