## @file\r
# process FD generation\r
#\r
-# Copyright (c) 2007, Intel Corporation. All rights reserved.<BR>\r
+# Copyright (c) 2007 - 2017, Intel Corporation. All rights reserved.<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
#\r
import Region\r
import Fv\r
-import os\r
+import Common.LongFilePathOs as os\r
import StringIO\r
import sys\r
from struct import *\r
#\r
# @retval string Generated FD file name\r
#\r
- def GenFd (self):\r
+ def GenFd (self, Flag = False):\r
if self.FdUiName.upper() + 'fd' in GenFds.ImageBinDict.keys():\r
return GenFds.ImageBinDict[self.FdUiName.upper() + 'fd']\r
\r
#\r
# Print Information\r
#\r
- GenFdsGlobalVariable.InfLogger("Fd File Name:%s" %self.FdUiName)\r
+ FdFileName = os.path.join(GenFdsGlobalVariable.FvDir, self.FdUiName + '.fd')\r
+ if not Flag:\r
+ GenFdsGlobalVariable.InfLogger("\nFd File Name:%s (%s)" %(self.FdUiName, FdFileName))\r
+\r
Offset = 0x00\r
for item in self.BlockSizeList:\r
Offset = Offset + item[0] * item[1]\r
GenFdsGlobalVariable.VerboseLogger('################### Gen VTF ####################')\r
self.GenVtfFile()\r
\r
- TempFdBuffer = StringIO.StringIO('')\r
- PreviousRegionStart = -1\r
- PreviousRegionSize = 1\r
- \r
- for RegionObj in self.RegionList :\r
+ HasCapsuleRegion = False\r
+ for RegionObj in self.RegionList:\r
if RegionObj.RegionType == 'CAPSULE':\r
- continue\r
- if RegionObj.Offset + RegionObj.Size <= PreviousRegionStart:\r
- pass\r
- elif RegionObj.Offset <= PreviousRegionStart or (RegionObj.Offset >=PreviousRegionStart and RegionObj.Offset < PreviousRegionStart + PreviousRegionSize):\r
- pass\r
- elif RegionObj.Offset > PreviousRegionStart + PreviousRegionSize:\r
- GenFdsGlobalVariable.InfLogger('Padding region starting from offset 0x%X, with size 0x%X' %(PreviousRegionStart + PreviousRegionSize, RegionObj.Offset - (PreviousRegionStart + PreviousRegionSize)))\r
- PadRegion = Region.Region()\r
- PadRegion.Offset = PreviousRegionStart + PreviousRegionSize\r
- PadRegion.Size = RegionObj.Offset - PadRegion.Offset\r
- PadRegion.AddToBuffer(TempFdBuffer, self.BaseAddress, self.BlockSizeList, self.ErasePolarity, GenFds.ImageBinDict, self.vtfRawDict, self.DefineVarDict)\r
- PreviousRegionStart = RegionObj.Offset\r
- PreviousRegionSize = RegionObj.Size\r
- #\r
- # Call each region's AddToBuffer function\r
- #\r
- if PreviousRegionSize > self.Size:\r
- pass\r
- GenFdsGlobalVariable.VerboseLogger('Call each region\'s AddToBuffer function')\r
- RegionObj.AddToBuffer (TempFdBuffer, self.BaseAddress, self.BlockSizeList, self.ErasePolarity, GenFds.ImageBinDict, self.vtfRawDict, self.DefineVarDict)\r
+ HasCapsuleRegion = True\r
+ break\r
+ if HasCapsuleRegion:\r
+ TempFdBuffer = StringIO.StringIO('')\r
+ PreviousRegionStart = -1\r
+ PreviousRegionSize = 1\r
+\r
+ for RegionObj in self.RegionList :\r
+ if RegionObj.RegionType == 'CAPSULE':\r
+ continue\r
+ if RegionObj.Offset + RegionObj.Size <= PreviousRegionStart:\r
+ pass\r
+ elif RegionObj.Offset <= PreviousRegionStart or (RegionObj.Offset >=PreviousRegionStart and RegionObj.Offset < PreviousRegionStart + PreviousRegionSize):\r
+ pass\r
+ elif RegionObj.Offset > PreviousRegionStart + PreviousRegionSize:\r
+ if not Flag:\r
+ GenFdsGlobalVariable.InfLogger('Padding region starting from offset 0x%X, with size 0x%X' %(PreviousRegionStart + PreviousRegionSize, RegionObj.Offset - (PreviousRegionStart + PreviousRegionSize)))\r
+ PadRegion = Region.Region()\r
+ PadRegion.Offset = PreviousRegionStart + PreviousRegionSize\r
+ PadRegion.Size = RegionObj.Offset - PadRegion.Offset\r
+ if not Flag:\r
+ PadRegion.AddToBuffer(TempFdBuffer, self.BaseAddress, self.BlockSizeList, self.ErasePolarity, GenFds.ImageBinDict, self.vtfRawDict, self.DefineVarDict)\r
+ PreviousRegionStart = RegionObj.Offset\r
+ PreviousRegionSize = RegionObj.Size\r
+ #\r
+ # Call each region's AddToBuffer function\r
+ #\r
+ if PreviousRegionSize > self.Size:\r
+ pass\r
+ GenFdsGlobalVariable.VerboseLogger('Call each region\'s AddToBuffer function')\r
+ RegionObj.AddToBuffer (TempFdBuffer, self.BaseAddress, self.BlockSizeList, self.ErasePolarity, GenFds.ImageBinDict, self.vtfRawDict, self.DefineVarDict)\r
\r
FdBuffer = StringIO.StringIO('')\r
PreviousRegionStart = -1\r
'Region offset 0x%X overlaps with Region starting from 0x%X, size 0x%X' \\r
% (RegionObj.Offset, PreviousRegionStart, PreviousRegionSize))\r
elif RegionObj.Offset > PreviousRegionStart + PreviousRegionSize:\r
- GenFdsGlobalVariable.InfLogger('Padding region starting from offset 0x%X, with size 0x%X' %(PreviousRegionStart + PreviousRegionSize, RegionObj.Offset - (PreviousRegionStart + PreviousRegionSize)))\r
+ if not Flag:\r
+ GenFdsGlobalVariable.InfLogger('Padding region starting from offset 0x%X, with size 0x%X' %(PreviousRegionStart + PreviousRegionSize, RegionObj.Offset - (PreviousRegionStart + PreviousRegionSize)))\r
PadRegion = Region.Region()\r
PadRegion.Offset = PreviousRegionStart + PreviousRegionSize\r
PadRegion.Size = RegionObj.Offset - PadRegion.Offset\r
- PadRegion.AddToBuffer(FdBuffer, self.BaseAddress, self.BlockSizeList, self.ErasePolarity, GenFds.ImageBinDict, self.vtfRawDict, self.DefineVarDict)\r
+ if not Flag:\r
+ PadRegion.AddToBuffer(FdBuffer, self.BaseAddress, self.BlockSizeList, self.ErasePolarity, GenFds.ImageBinDict, self.vtfRawDict, self.DefineVarDict)\r
PreviousRegionStart = RegionObj.Offset\r
PreviousRegionSize = RegionObj.Size\r
#\r
+ # Verify current region fits within allocated FD section Size\r
+ #\r
+ if PreviousRegionStart + PreviousRegionSize > self.Size:\r
+ EdkLogger.error("GenFds", GENFDS_ERROR,\r
+ 'FD %s size too small to fit region with offset 0x%X and size 0x%X'\r
+ % (self.FdUiName, PreviousRegionStart, PreviousRegionSize))\r
+ #\r
# Call each region's AddToBuffer function\r
#\r
- if PreviousRegionSize > self.Size:\r
- EdkLogger.error("GenFds", GENFDS_ERROR, 'FD %s size too small' % self.FdUiName)\r
GenFdsGlobalVariable.VerboseLogger('Call each region\'s AddToBuffer function')\r
- RegionObj.AddToBuffer (FdBuffer, self.BaseAddress, self.BlockSizeList, self.ErasePolarity, GenFds.ImageBinDict, self.vtfRawDict, self.DefineVarDict)\r
- #\r
- # Create a empty Fd file\r
- #\r
- GenFdsGlobalVariable.VerboseLogger ('Create an empty Fd file')\r
- FdFileName = os.path.join(GenFdsGlobalVariable.FvDir,self.FdUiName + '.fd')\r
+ RegionObj.AddToBuffer (FdBuffer, self.BaseAddress, self.BlockSizeList, self.ErasePolarity, GenFds.ImageBinDict, self.vtfRawDict, self.DefineVarDict,Flag=Flag)\r
#\r
# Write the buffer contents to Fd file\r
#\r
GenFdsGlobalVariable.VerboseLogger('Write the buffer contents to Fd file')\r
- SaveFileOnChange(FdFileName, FdBuffer.getvalue())\r
- FdBuffer.close();\r
+ if not Flag:\r
+ SaveFileOnChange(FdFileName, FdBuffer.getvalue())\r
+ FdBuffer.close()\r
GenFds.ImageBinDict[self.FdUiName.upper() + 'fd'] = FdFileName\r
return FdFileName\r
\r