2014-01-27 06:23:15 +01:00
## @file
# generate flash image
#
2018-03-01 03:23:14 +01:00
# Copyright (c) 2007 - 2018, Intel Corporation. All rights reserved.<BR>
2014-01-27 06:23:15 +01:00
#
# This program and the accompanying materials
# 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
# http://opensource.org/licenses/bsd-license.php
#
# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
#
##
# Import Modules
#
from optparse import OptionParser
import sys
2014-08-15 05:06:48 +02:00
import Common . LongFilePathOs as os
2014-01-27 06:23:15 +01:00
import linecache
import FdfParser
import Common . BuildToolError as BuildToolError
from GenFdsGlobalVariable import GenFdsGlobalVariable
from Workspace . WorkspaceDatabase import WorkspaceDatabase
from Workspace . BuildClassObject import PcdClassObject
import RuleComplexFile
from EfiSection import EfiSection
import StringIO
import Common . TargetTxtClassObject as TargetTxtClassObject
import Common . ToolDefClassObject as ToolDefClassObject
2017-02-15 07:47:47 +01:00
from Common . DataType import *
2014-01-27 06:23:15 +01:00
import Common . GlobalData as GlobalData
from Common import EdkLogger
from Common . String import *
2015-12-01 05:22:16 +01:00
from Common . Misc import DirCache , PathClass
2014-01-27 06:23:15 +01:00
from Common . Misc import SaveFileOnChange
2014-08-28 15:53:34 +02:00
from Common . Misc import ClearDuplicatedInf
2014-07-01 09:10:10 +02:00
from Common . Misc import GuidStructureStringToGuidString
2014-01-27 06:23:15 +01:00
from Common . BuildVersion import gBUILD_VERSION
2015-10-08 11:27:14 +02:00
from Common . MultipleWorkspace import MultipleWorkspace as mws
2017-11-15 17:06:45 +01:00
import FfsFileStatement
import glob
from struct import unpack
2014-01-27 06:23:15 +01:00
## Version and Copyright
versionNumber = " 1.0 " + ' ' + gBUILD_VERSION
__version__ = " % prog Version " + versionNumber
2017-02-15 07:47:47 +01:00
__copyright__ = " Copyright (c) 2007 - 2017, Intel Corporation All rights reserved. "
2014-01-27 06:23:15 +01:00
## Tool entrance method
#
# This method mainly dispatch specific methods per the command line options.
# If no error found, return zero value so the caller of this tool can know
# if it's executed successfully or not.
#
# @retval 0 Tool was successful
# @retval 1 Tool failed
#
def main ( ) :
global Options
Options = myOptionParser ( )
global Workspace
Workspace = " "
ArchList = None
ReturnCode = 0
EdkLogger . Initialize ( )
try :
2018-03-26 22:25:43 +02:00
if Options . verbose is not None :
2014-01-27 06:23:15 +01:00
EdkLogger . SetLevel ( EdkLogger . VERBOSE )
GenFdsGlobalVariable . VerboseMode = True
2018-03-26 22:25:43 +02:00
if Options . FixedAddress is not None :
2014-01-27 06:23:15 +01:00
GenFdsGlobalVariable . FixedLoadAddress = True
2018-03-26 22:25:43 +02:00
if Options . quiet is not None :
2014-01-27 06:23:15 +01:00
EdkLogger . SetLevel ( EdkLogger . QUIET )
2018-03-26 22:25:43 +02:00
if Options . debug is not None :
2014-01-27 06:23:15 +01:00
EdkLogger . SetLevel ( Options . debug + 1 )
GenFdsGlobalVariable . DebugLevel = Options . debug
else :
EdkLogger . SetLevel ( EdkLogger . INFO )
2018-03-26 22:25:43 +02:00
if ( Options . Workspace is None ) :
2014-01-27 06:23:15 +01:00
EdkLogger . error ( " GenFds " , OPTION_MISSING , " WORKSPACE not defined " ,
ExtraData = " Please use ' -w ' switch to pass it or set the WORKSPACE environment variable. " )
elif not os . path . exists ( Options . Workspace ) :
EdkLogger . error ( " GenFds " , PARAMETER_INVALID , " WORKSPACE is invalid " ,
ExtraData = " Please use ' -w ' switch to pass it or set the WORKSPACE environment variable. " )
else :
Workspace = os . path . normcase ( Options . Workspace )
GenFdsGlobalVariable . WorkSpaceDir = Workspace
2018-04-17 16:40:15 +02:00
if ' EDK_SOURCE ' in os . environ :
2014-01-27 06:23:15 +01:00
GenFdsGlobalVariable . EdkSourceDir = os . path . normcase ( os . environ [ ' EDK_SOURCE ' ] )
if ( Options . debug ) :
2015-12-01 05:22:16 +01:00
GenFdsGlobalVariable . VerboseLogger ( " Using Workspace: " + Workspace )
2017-11-22 08:42:25 +01:00
if Options . GenfdsMultiThread :
GenFdsGlobalVariable . EnableGenfdsMultiThread = True
2014-01-27 06:23:15 +01:00
os . chdir ( GenFdsGlobalVariable . WorkSpaceDir )
2015-10-08 11:27:14 +02:00
# set multiple workspace
PackagesPath = os . getenv ( " PACKAGES_PATH " )
mws . setWs ( GenFdsGlobalVariable . WorkSpaceDir , PackagesPath )
2014-01-27 06:23:15 +01:00
if ( Options . filename ) :
FdfFilename = Options . filename
FdfFilename = GenFdsGlobalVariable . ReplaceWorkspaceMacro ( FdfFilename )
if FdfFilename [ 0 : 2 ] == ' .. ' :
FdfFilename = os . path . realpath ( FdfFilename )
2015-12-01 05:22:16 +01:00
if not os . path . isabs ( FdfFilename ) :
2015-10-08 11:27:14 +02:00
FdfFilename = mws . join ( GenFdsGlobalVariable . WorkSpaceDir , FdfFilename )
2014-01-27 06:23:15 +01:00
if not os . path . exists ( FdfFilename ) :
EdkLogger . error ( " GenFds " , FILE_NOT_FOUND , ExtraData = FdfFilename )
GenFdsGlobalVariable . FdfFile = FdfFilename
GenFdsGlobalVariable . FdfFileTimeStamp = os . path . getmtime ( FdfFilename )
else :
EdkLogger . error ( " GenFds " , OPTION_MISSING , " Missing FDF filename " )
if ( Options . BuildTarget ) :
GenFdsGlobalVariable . TargetName = Options . BuildTarget
if ( Options . ToolChain ) :
GenFdsGlobalVariable . ToolChainTag = Options . ToolChain
if ( Options . activePlatform ) :
ActivePlatform = Options . activePlatform
ActivePlatform = GenFdsGlobalVariable . ReplaceWorkspaceMacro ( ActivePlatform )
if ActivePlatform [ 0 : 2 ] == ' .. ' :
ActivePlatform = os . path . realpath ( ActivePlatform )
if not os . path . isabs ( ActivePlatform ) :
2015-10-08 11:27:14 +02:00
ActivePlatform = mws . join ( GenFdsGlobalVariable . WorkSpaceDir , ActivePlatform )
2014-01-27 06:23:15 +01:00
if not os . path . exists ( ActivePlatform ) :
EdkLogger . error ( " GenFds " , FILE_NOT_FOUND , " ActivePlatform doesn ' t exist! " )
else :
EdkLogger . error ( " GenFds " , OPTION_MISSING , " Missing active platform " )
2018-03-09 08:18:35 +01:00
GlobalData . BuildOptionPcd = Options . OptionPcd if Options . OptionPcd else { }
2016-04-18 09:38:15 +02:00
GenFdsGlobalVariable . ActivePlatform = PathClass ( NormPath ( ActivePlatform ) )
2014-01-27 06:23:15 +01:00
2014-08-28 15:53:34 +02:00
if ( Options . ConfDirectory ) :
# Get alternate Conf location, if it is absolute, then just use the absolute directory name
ConfDirectoryPath = os . path . normpath ( Options . ConfDirectory )
if ConfDirectoryPath . startswith ( ' " ' ) :
ConfDirectoryPath = ConfDirectoryPath [ 1 : ]
if ConfDirectoryPath . endswith ( ' " ' ) :
ConfDirectoryPath = ConfDirectoryPath [ : - 1 ]
if not os . path . isabs ( ConfDirectoryPath ) :
# Since alternate directory name is not absolute, the alternate directory is located within the WORKSPACE
# This also handles someone specifying the Conf directory in the workspace. Using --conf=Conf
ConfDirectoryPath = os . path . join ( GenFdsGlobalVariable . WorkSpaceDir , ConfDirectoryPath )
else :
2018-04-17 16:40:15 +02:00
if " CONF_PATH " in os . environ :
2016-08-18 04:07:36 +02:00
ConfDirectoryPath = os . path . normcase ( os . environ [ " CONF_PATH " ] )
else :
# Get standard WORKSPACE/Conf, use the absolute path to the WORKSPACE/Conf
ConfDirectoryPath = mws . join ( GenFdsGlobalVariable . WorkSpaceDir , ' Conf ' )
2014-08-28 15:53:34 +02:00
GenFdsGlobalVariable . ConfDir = ConfDirectoryPath
2018-03-01 03:23:14 +01:00
if not GlobalData . gConfDirectory :
GlobalData . gConfDirectory = GenFdsGlobalVariable . ConfDir
2014-08-28 15:53:34 +02:00
BuildConfigurationFile = os . path . normpath ( os . path . join ( ConfDirectoryPath , " target.txt " ) )
2014-01-27 06:23:15 +01:00
if os . path . isfile ( BuildConfigurationFile ) == True :
2016-05-06 09:20:23 +02:00
TargetTxt = TargetTxtClassObject . TargetTxtClassObject ( )
TargetTxt . LoadTargetTxtFile ( BuildConfigurationFile )
# if no build target given in command line, get it from target.txt
if not GenFdsGlobalVariable . TargetName :
BuildTargetList = TargetTxt . TargetTxtDictionary [ DataType . TAB_TAT_DEFINES_TARGET ]
if len ( BuildTargetList ) != 1 :
EdkLogger . error ( " GenFds " , OPTION_VALUE_INVALID , ExtraData = " Only allows one instance for Target. " )
GenFdsGlobalVariable . TargetName = BuildTargetList [ 0 ]
# if no tool chain given in command line, get it from target.txt
if not GenFdsGlobalVariable . ToolChainTag :
ToolChainList = TargetTxt . TargetTxtDictionary [ DataType . TAB_TAT_DEFINES_TOOL_CHAIN_TAG ]
2018-03-26 22:25:43 +02:00
if ToolChainList is None or len ( ToolChainList ) == 0 :
2016-05-06 09:20:23 +02:00
EdkLogger . error ( " GenFds " , RESOURCE_NOT_AVAILABLE , ExtraData = " No toolchain given. Don ' t know how to build. " )
if len ( ToolChainList ) != 1 :
EdkLogger . error ( " GenFds " , OPTION_VALUE_INVALID , ExtraData = " Only allows one instance for ToolChain. " )
GenFdsGlobalVariable . ToolChainTag = ToolChainList [ 0 ]
2014-01-27 06:23:15 +01:00
else :
EdkLogger . error ( " GenFds " , FILE_NOT_FOUND , ExtraData = BuildConfigurationFile )
2014-08-28 15:53:34 +02:00
#Set global flag for build mode
GlobalData . gIgnoreSource = Options . IgnoreSources
2014-01-27 06:23:15 +01:00
if Options . Macros :
for Pair in Options . Macros :
2014-08-28 15:53:34 +02:00
if Pair . startswith ( ' " ' ) :
Pair = Pair [ 1 : ]
if Pair . endswith ( ' " ' ) :
Pair = Pair [ : - 1 ]
2014-01-27 06:23:15 +01:00
List = Pair . split ( ' = ' )
if len ( List ) == 2 :
2016-05-06 09:20:23 +02:00
if not List [ 1 ] . strip ( ) :
EdkLogger . error ( " GenFds " , OPTION_VALUE_INVALID , ExtraData = " No Value given for Macro %s " % List [ 0 ] )
2014-01-27 06:23:15 +01:00
if List [ 0 ] . strip ( ) == " EFI_SOURCE " :
GlobalData . gEfiSource = List [ 1 ] . strip ( )
GlobalData . gGlobalDefines [ " EFI_SOURCE " ] = GlobalData . gEfiSource
continue
elif List [ 0 ] . strip ( ) == " EDK_SOURCE " :
GlobalData . gEdkSource = List [ 1 ] . strip ( )
GlobalData . gGlobalDefines [ " EDK_SOURCE " ] = GlobalData . gEdkSource
continue
elif List [ 0 ] . strip ( ) in [ " WORKSPACE " , " TARGET " , " TOOLCHAIN " ] :
GlobalData . gGlobalDefines [ List [ 0 ] . strip ( ) ] = List [ 1 ] . strip ( )
else :
GlobalData . gCommandLineDefines [ List [ 0 ] . strip ( ) ] = List [ 1 ] . strip ( )
else :
GlobalData . gCommandLineDefines [ List [ 0 ] . strip ( ) ] = " TRUE "
os . environ [ " WORKSPACE " ] = Workspace
2016-05-06 09:20:23 +02:00
# Use the -t and -b option as gGlobalDefines's TOOLCHAIN and TARGET if they are not defined
2018-04-17 16:40:15 +02:00
if " TARGET " not in GlobalData . gGlobalDefines :
2016-05-06 09:20:23 +02:00
GlobalData . gGlobalDefines [ " TARGET " ] = GenFdsGlobalVariable . TargetName
2018-04-17 16:40:15 +02:00
if " TOOLCHAIN " not in GlobalData . gGlobalDefines :
2016-05-06 09:20:23 +02:00
GlobalData . gGlobalDefines [ " TOOLCHAIN " ] = GenFdsGlobalVariable . ToolChainTag
2018-04-17 16:40:15 +02:00
if " TOOL_CHAIN_TAG " not in GlobalData . gGlobalDefines :
2016-05-06 09:20:23 +02:00
GlobalData . gGlobalDefines [ ' TOOL_CHAIN_TAG ' ] = GenFdsGlobalVariable . ToolChainTag
2014-01-27 06:23:15 +01:00
""" call Workspace build create database """
2014-08-28 15:53:34 +02:00
GlobalData . gDatabasePath = os . path . normpath ( os . path . join ( ConfDirectoryPath , GlobalData . gDatabasePath ) )
BuildWorkSpace = WorkspaceDatabase ( GlobalData . gDatabasePath )
2014-01-27 06:23:15 +01:00
BuildWorkSpace . InitDatabase ( )
#
# Get files real name in workspace dir
#
GlobalData . gAllFiles = DirCache ( Workspace )
GlobalData . gWorkspace = Workspace
if ( Options . archList ) :
ArchList = Options . archList . split ( ' , ' )
else :
# EdkLogger.error("GenFds", OPTION_MISSING, "Missing build ARCH")
2018-04-16 15:52:13 +02:00
ArchList = BuildWorkSpace . BuildObject [ GenFdsGlobalVariable . ActivePlatform , TAB_COMMON , Options . BuildTarget , Options . ToolChain ] . SupArchList
2014-01-27 06:23:15 +01:00
2018-04-16 15:52:13 +02:00
TargetArchList = set ( BuildWorkSpace . BuildObject [ GenFdsGlobalVariable . ActivePlatform , TAB_COMMON , Options . BuildTarget , Options . ToolChain ] . SupArchList ) & set ( ArchList )
2014-01-27 06:23:15 +01:00
if len ( TargetArchList ) == 0 :
2018-04-16 15:52:13 +02:00
EdkLogger . error ( " GenFds " , GENFDS_ERROR , " Target ARCH %s not in platform supported ARCH %s " % ( str ( ArchList ) , str ( BuildWorkSpace . BuildObject [ GenFdsGlobalVariable . ActivePlatform , TAB_COMMON ] . SupArchList ) ) )
2014-01-27 06:23:15 +01:00
for Arch in ArchList :
GenFdsGlobalVariable . OutputDirFromDscDict [ Arch ] = NormPath ( BuildWorkSpace . BuildObject [ GenFdsGlobalVariable . ActivePlatform , Arch , Options . BuildTarget , Options . ToolChain ] . OutputDirectory )
GenFdsGlobalVariable . PlatformName = BuildWorkSpace . BuildObject [ GenFdsGlobalVariable . ActivePlatform , Arch , Options . BuildTarget , Options . ToolChain ] . PlatformName
if ( Options . outputDir ) :
OutputDirFromCommandLine = GenFdsGlobalVariable . ReplaceWorkspaceMacro ( Options . outputDir )
if not os . path . isabs ( OutputDirFromCommandLine ) :
OutputDirFromCommandLine = os . path . join ( GenFdsGlobalVariable . WorkSpaceDir , OutputDirFromCommandLine )
for Arch in ArchList :
GenFdsGlobalVariable . OutputDirDict [ Arch ] = OutputDirFromCommandLine
else :
for Arch in ArchList :
GenFdsGlobalVariable . OutputDirDict [ Arch ] = os . path . join ( GenFdsGlobalVariable . OutputDirFromDscDict [ Arch ] , GenFdsGlobalVariable . TargetName + ' _ ' + GenFdsGlobalVariable . ToolChainTag )
for Key in GenFdsGlobalVariable . OutputDirDict :
OutputDir = GenFdsGlobalVariable . OutputDirDict [ Key ]
if OutputDir [ 0 : 2 ] == ' .. ' :
OutputDir = os . path . realpath ( OutputDir )
if OutputDir [ 1 ] != ' : ' :
OutputDir = os . path . join ( GenFdsGlobalVariable . WorkSpaceDir , OutputDir )
if not os . path . exists ( OutputDir ) :
EdkLogger . error ( " GenFds " , FILE_NOT_FOUND , ExtraData = OutputDir )
GenFdsGlobalVariable . OutputDirDict [ Key ] = OutputDir
""" Parse Fdf file, has to place after build Workspace as FDF may contain macros from DSC file """
FdfParserObj = FdfParser . FdfParser ( FdfFilename )
FdfParserObj . ParseFile ( )
if FdfParserObj . CycleReferenceCheck ( ) :
EdkLogger . error ( " GenFds " , FORMAT_NOT_SUPPORTED , " Cycle Reference Detected in FDF file " )
if ( Options . uiFdName ) :
2018-04-17 16:40:15 +02:00
if Options . uiFdName . upper ( ) in FdfParserObj . Profile . FdDict :
2014-01-27 06:23:15 +01:00
GenFds . OnlyGenerateThisFd = Options . uiFdName
else :
EdkLogger . error ( " GenFds " , OPTION_VALUE_INVALID ,
" No such an FD in FDF file: %s " % Options . uiFdName )
if ( Options . uiFvName ) :
2018-04-17 16:40:15 +02:00
if Options . uiFvName . upper ( ) in FdfParserObj . Profile . FvDict :
2014-01-27 06:23:15 +01:00
GenFds . OnlyGenerateThisFv = Options . uiFvName
else :
EdkLogger . error ( " GenFds " , OPTION_VALUE_INVALID ,
" No such an FV in FDF file: %s " % Options . uiFvName )
if ( Options . uiCapName ) :
2018-04-17 16:40:15 +02:00
if Options . uiCapName . upper ( ) in FdfParserObj . Profile . CapsuleDict :
2014-01-27 06:23:15 +01:00
GenFds . OnlyGenerateThisCap = Options . uiCapName
else :
EdkLogger . error ( " GenFds " , OPTION_VALUE_INVALID ,
" No such a Capsule in FDF file: %s " % Options . uiCapName )
2016-04-20 03:32:52 +02:00
GenFdsGlobalVariable . WorkSpace = BuildWorkSpace
2018-03-26 22:25:43 +02:00
if ArchList is not None :
2016-04-20 03:32:52 +02:00
GenFdsGlobalVariable . ArchList = ArchList
2018-01-31 09:49:14 +01:00
# Dsc Build Data will handle Pcd Settings from CommandLine.
2016-04-20 03:32:52 +02:00
2014-01-27 06:23:15 +01:00
""" Modify images from build output if the feature of loading driver at fixed address is on. """
if GenFdsGlobalVariable . FixedLoadAddress :
GenFds . PreprocessImage ( BuildWorkSpace , GenFdsGlobalVariable . ActivePlatform )
2017-03-13 08:11:38 +01:00
# Record the FV Region info that may specific in the FD
if FdfParserObj . Profile . FvDict and FdfParserObj . Profile . FdDict :
for Fv in FdfParserObj . Profile . FvDict :
FvObj = FdfParserObj . Profile . FvDict [ Fv ]
for Fd in FdfParserObj . Profile . FdDict :
FdObj = FdfParserObj . Profile . FdDict [ Fd ]
for RegionObj in FdObj . RegionList :
2018-04-26 18:57:56 +02:00
if RegionObj . RegionType != BINARY_FILE_TYPE_FV :
2017-03-13 08:11:38 +01:00
continue
for RegionData in RegionObj . RegionDataList :
if FvObj . UiFvName . upper ( ) == RegionData . upper ( ) :
if FvObj . FvRegionInFD :
if FvObj . FvRegionInFD != RegionObj . Size :
EdkLogger . error ( " GenFds " , FORMAT_INVALID , " The FV %s ' s region is specified in multiple FD with different value. " % FvObj . UiFvName )
else :
FvObj . FvRegionInFD = RegionObj . Size
RegionObj . BlockInfoOfRegion ( FdObj . BlockSizeList , FvObj )
2014-01-27 06:23:15 +01:00
""" Call GenFds """
GenFds . GenFd ( ' ' , FdfParserObj , BuildWorkSpace , ArchList )
""" Generate GUID cross reference file """
2017-11-15 17:06:45 +01:00
GenFds . GenerateGuidXRefFile ( BuildWorkSpace , ArchList , FdfParserObj )
2014-01-27 06:23:15 +01:00
""" Display FV space info. """
GenFds . DisplayFvSpaceInfo ( FdfParserObj )
except FdfParser . Warning , X :
2015-12-01 05:22:16 +01:00
EdkLogger . error ( X . ToolName , FORMAT_INVALID , File = X . FileName , Line = X . LineNumber , ExtraData = X . Message , RaiseError = False )
2014-01-27 06:23:15 +01:00
ReturnCode = FORMAT_INVALID
except FatalError , X :
2018-03-26 22:25:43 +02:00
if Options . debug is not None :
2014-01-27 06:23:15 +01:00
import traceback
EdkLogger . quiet ( traceback . format_exc ( ) )
ReturnCode = X . args [ 0 ]
except :
import traceback
EdkLogger . error (
" \n Python " ,
CODE_ERROR ,
" Tools code failure " ,
2016-02-29 03:32:07 +01:00
ExtraData = " Please send email to edk2-devel@lists.01.org for help, attaching following call stack trace! \n " ,
2014-01-27 06:23:15 +01:00
RaiseError = False
)
EdkLogger . quiet ( traceback . format_exc ( ) )
ReturnCode = CODE_ERROR
2014-08-28 15:53:34 +02:00
finally :
ClearDuplicatedInf ( )
2014-01-27 06:23:15 +01:00
return ReturnCode
gParamCheck = [ ]
def SingleCheckCallback ( option , opt_str , value , parser ) :
if option not in gParamCheck :
setattr ( parser . values , option . dest , value )
gParamCheck . append ( option )
else :
parser . error ( " Option %s only allows one instance in command line! " % option )
2016-04-20 03:32:52 +02:00
2016-08-15 07:52:12 +02:00
## FindExtendTool()
#
# Find location of tools to process data
#
# @param KeyStringList Filter for inputs of section generation
# @param CurrentArchList Arch list
# @param NameGuid The Guid name
#
def FindExtendTool ( KeyStringList , CurrentArchList , NameGuid ) :
2017-02-15 07:47:47 +01:00
ToolDb = ToolDefClassObject . ToolDefDict ( GenFdsGlobalVariable . ConfDir ) . ToolsDefTxtDatabase
2016-08-15 07:52:12 +02:00
# if user not specify filter, try to deduce it from global data.
2018-03-26 22:25:43 +02:00
if KeyStringList is None or KeyStringList == [ ] :
2016-08-15 07:52:12 +02:00
Target = GenFdsGlobalVariable . TargetName
ToolChain = GenFdsGlobalVariable . ToolChainTag
if ToolChain not in ToolDb [ ' TOOL_CHAIN_TAG ' ] :
EdkLogger . error ( " GenFds " , GENFDS_ERROR , " Can not find external tool because tool tag %s is not defined in tools_def.txt! " % ToolChain )
KeyStringList = [ Target + ' _ ' + ToolChain + ' _ ' + CurrentArchList [ 0 ] ]
for Arch in CurrentArchList :
if Target + ' _ ' + ToolChain + ' _ ' + Arch not in KeyStringList :
KeyStringList . append ( Target + ' _ ' + ToolChain + ' _ ' + Arch )
if GenFdsGlobalVariable . GuidToolDefinition :
2018-04-17 16:40:15 +02:00
if NameGuid in GenFdsGlobalVariable . GuidToolDefinition :
2016-08-15 07:52:12 +02:00
return GenFdsGlobalVariable . GuidToolDefinition [ NameGuid ]
ToolDefinition = ToolDefClassObject . ToolDefDict ( GenFdsGlobalVariable . ConfDir ) . ToolsDefTxtDictionary
ToolPathTmp = None
ToolOption = None
2017-02-15 07:47:47 +01:00
ToolPathKey = None
ToolOptionKey = None
KeyList = None
2016-08-15 07:52:12 +02:00
for ToolDef in ToolDefinition . items ( ) :
2018-02-26 09:19:30 +01:00
if NameGuid . lower ( ) == ToolDef [ 1 ] . lower ( ) :
2016-08-15 07:52:12 +02:00
KeyList = ToolDef [ 0 ] . split ( ' _ ' )
Key = KeyList [ 0 ] + \
' _ ' + \
KeyList [ 1 ] + \
' _ ' + \
KeyList [ 2 ]
2018-04-26 18:57:56 +02:00
if Key in KeyStringList and KeyList [ 4 ] == TAB_GUID :
2017-02-15 07:47:47 +01:00
ToolPathKey = Key + ' _ ' + KeyList [ 3 ] + ' _PATH '
ToolOptionKey = Key + ' _ ' + KeyList [ 3 ] + ' _FLAGS '
ToolPath = ToolDefinition . get ( ToolPathKey )
ToolOption = ToolDefinition . get ( ToolOptionKey )
2018-03-26 22:25:43 +02:00
if ToolPathTmp is None :
2016-08-15 07:52:12 +02:00
ToolPathTmp = ToolPath
else :
if ToolPathTmp != ToolPath :
EdkLogger . error ( " GenFds " , GENFDS_ERROR , " Don ' t know which tool to use, %s or %s ? " % ( ToolPathTmp , ToolPath ) )
2017-02-15 07:47:47 +01:00
BuildOption = { }
for Arch in CurrentArchList :
Platform = GenFdsGlobalVariable . WorkSpace . BuildObject [ GenFdsGlobalVariable . ActivePlatform , Arch , GenFdsGlobalVariable . TargetName , GenFdsGlobalVariable . ToolChainTag ]
# key is (ToolChainFamily, ToolChain, CodeBase)
for item in Platform . BuildOptions :
if ' _PATH ' in item [ 1 ] or ' _FLAGS ' in item [ 1 ] or ' _GUID ' in item [ 1 ] :
if not item [ 0 ] or ( item [ 0 ] and GenFdsGlobalVariable . ToolChainFamily == item [ 0 ] ) :
if item [ 1 ] not in BuildOption :
BuildOption [ item [ 1 ] ] = Platform . BuildOptions [ item ]
if BuildOption :
ToolList = [ TAB_TOD_DEFINES_TARGET , TAB_TOD_DEFINES_TOOL_CHAIN_TAG , TAB_TOD_DEFINES_TARGET_ARCH ]
for Index in range ( 2 , - 1 , - 1 ) :
for Key in dict ( BuildOption ) :
List = Key . split ( ' _ ' )
if List [ Index ] == ' * ' :
for String in ToolDb [ ToolList [ Index ] ] :
if String in [ Arch , GenFdsGlobalVariable . TargetName , GenFdsGlobalVariable . ToolChainTag ] :
List [ Index ] = String
NewKey = ' %s _ %s _ %s _ %s _ %s ' % tuple ( List )
if NewKey not in BuildOption :
BuildOption [ NewKey ] = BuildOption [ Key ]
continue
del BuildOption [ Key ]
elif List [ Index ] not in ToolDb [ ToolList [ Index ] ] :
del BuildOption [ Key ]
if BuildOption :
if not KeyList :
for Op in BuildOption :
if NameGuid == BuildOption [ Op ] :
KeyList = Op . split ( ' _ ' )
Key = KeyList [ 0 ] + ' _ ' + KeyList [ 1 ] + ' _ ' + KeyList [ 2 ]
2018-04-26 18:57:56 +02:00
if Key in KeyStringList and KeyList [ 4 ] == TAB_GUID :
2017-02-15 07:47:47 +01:00
ToolPathKey = Key + ' _ ' + KeyList [ 3 ] + ' _PATH '
ToolOptionKey = Key + ' _ ' + KeyList [ 3 ] + ' _FLAGS '
2018-04-17 16:40:15 +02:00
if ToolPathKey in BuildOption :
ToolPathTmp = BuildOption [ ToolPathKey ]
if ToolOptionKey in BuildOption :
ToolOption = BuildOption [ ToolOptionKey ]
2017-02-15 07:47:47 +01:00
2016-08-15 07:52:12 +02:00
GenFdsGlobalVariable . GuidToolDefinition [ NameGuid ] = ( ToolPathTmp , ToolOption )
return ToolPathTmp , ToolOption
2014-01-27 06:23:15 +01:00
## Parse command line options
#
# Using standard Python module optparse to parse command line option of this tool.
#
# @retval Opt A optparse.Values object containing the parsed options
# @retval Args Target of build command
#
def myOptionParser ( ) :
usage = " % prog [options] -f input_file -a arch_list -b build_target -p active_platform -t tool_chain_tag -D \" MacroName [= MacroValue] \" "
2015-12-01 05:22:16 +01:00
Parser = OptionParser ( usage = usage , description = __copyright__ , version = " % prog " + str ( versionNumber ) )
2014-01-27 06:23:15 +01:00
Parser . add_option ( " -f " , " --file " , dest = " filename " , type = " string " , help = " Name of FDF file to convert " , action = " callback " , callback = SingleCheckCallback )
Parser . add_option ( " -a " , " --arch " , dest = " archList " , help = " comma separated list containing one or more of: IA32, X64, IPF, ARM, AARCH64 or EBC which should be built, overrides target.txt?s TARGET_ARCH " )
Parser . add_option ( " -q " , " --quiet " , action = " store_true " , type = None , help = " Disable all messages except FATAL ERRORS. " )
Parser . add_option ( " -v " , " --verbose " , action = " store_true " , type = None , help = " Turn on verbose output with informational messages printed. " )
Parser . add_option ( " -d " , " --debug " , action = " store " , type = " int " , help = " Enable debug messages at specified level. " )
Parser . add_option ( " -p " , " --platform " , type = " string " , dest = " activePlatform " , help = " Set the ACTIVE_PLATFORM, overrides target.txt ACTIVE_PLATFORM setting. " ,
action = " callback " , callback = SingleCheckCallback )
Parser . add_option ( " -w " , " --workspace " , type = " string " , dest = " Workspace " , default = os . environ . get ( ' WORKSPACE ' ) , help = " Set the WORKSPACE " ,
action = " callback " , callback = SingleCheckCallback )
Parser . add_option ( " -o " , " --outputDir " , type = " string " , dest = " outputDir " , help = " Name of Build Output directory " ,
action = " callback " , callback = SingleCheckCallback )
Parser . add_option ( " -r " , " --rom_image " , dest = " uiFdName " , help = " Build the image using the [FD] section named by FdUiName. " )
Parser . add_option ( " -i " , " --FvImage " , dest = " uiFvName " , help = " Build the FV image using the [FV] section named by UiFvName " )
Parser . add_option ( " -C " , " --CapsuleImage " , dest = " uiCapName " , help = " Build the Capsule image using the [Capsule] section named by UiCapName " )
Parser . add_option ( " -b " , " --buildtarget " , type = " string " , dest = " BuildTarget " , help = " Set the build TARGET, overrides target.txt TARGET setting. " ,
action = " callback " , callback = SingleCheckCallback )
Parser . add_option ( " -t " , " --tagname " , type = " string " , dest = " ToolChain " , help = " Using the tools: TOOL_CHAIN_TAG name to build the platform. " ,
action = " callback " , callback = SingleCheckCallback )
Parser . add_option ( " -D " , " --define " , action = " append " , type = " string " , dest = " Macros " , help = " Macro: \" Name [= Value] \" . " )
Parser . add_option ( " -s " , " --specifyaddress " , dest = " FixedAddress " , action = " store_true " , type = None , help = " Specify driver load address. " )
2014-08-28 15:53:34 +02:00
Parser . add_option ( " --conf " , action = " store " , type = " string " , dest = " ConfDirectory " , help = " Specify the customized Conf directory. " )
Parser . add_option ( " --ignore-sources " , action = " store_true " , dest = " IgnoreSources " , default = False , help = " Focus to a binary build and ignore all source files " )
2016-04-20 03:32:52 +02:00
Parser . add_option ( " --pcd " , action = " append " , dest = " OptionPcd " , help = " Set PCD value by command line. Format: \" PcdName=Value \" " )
2017-11-22 08:42:25 +01:00
Parser . add_option ( " --genfds-multi-thread " , action = " store_true " , dest = " GenfdsMultiThread " , default = False , help = " Enable GenFds multi thread to generate ffs file. " )
2014-08-28 15:53:34 +02:00
2014-01-27 06:23:15 +01:00
( Options , args ) = Parser . parse_args ( )
return Options
## The class implementing the EDK2 flash image generation process
#
# This process includes:
# 1. Collect workspace information, includes platform and module information
# 2. Call methods of Fd class to generate FD
# 3. Call methods of Fv class to generate FV that not belong to FD
#
class GenFds :
FdfParsef = None
# FvName, FdName, CapName in FDF, Image file name
ImageBinDict = { }
OnlyGenerateThisFd = None
OnlyGenerateThisFv = None
OnlyGenerateThisCap = None
## GenFd()
#
# @param OutputDir Output directory
# @param FdfParser FDF contents parser
# @param Workspace The directory of workspace
# @param ArchList The Arch list of platform
#
def GenFd ( OutputDir , FdfParser , WorkSpace , ArchList ) :
GenFdsGlobalVariable . SetDir ( ' ' , FdfParser , WorkSpace , ArchList )
GenFdsGlobalVariable . VerboseLogger ( " Generate all Fd images and their required FV and Capsule images! " )
2018-04-17 16:40:15 +02:00
if GenFds . OnlyGenerateThisCap is not None and GenFds . OnlyGenerateThisCap . upper ( ) in GenFdsGlobalVariable . FdfParser . Profile . CapsuleDict :
CapsuleObj = GenFdsGlobalVariable . FdfParser . Profile . CapsuleDict [ GenFds . OnlyGenerateThisCap . upper ( ) ]
2018-03-26 22:25:43 +02:00
if CapsuleObj is not None :
2014-01-27 06:23:15 +01:00
CapsuleObj . GenCapsule ( )
return
2018-04-17 16:40:15 +02:00
if GenFds . OnlyGenerateThisFd is not None and GenFds . OnlyGenerateThisFd . upper ( ) in GenFdsGlobalVariable . FdfParser . Profile . FdDict :
FdObj = GenFdsGlobalVariable . FdfParser . Profile . FdDict [ GenFds . OnlyGenerateThisFd . upper ( ) ]
2018-03-26 22:25:43 +02:00
if FdObj is not None :
2014-01-27 06:23:15 +01:00
FdObj . GenFd ( )
return
2018-03-26 22:25:43 +02:00
elif GenFds . OnlyGenerateThisFd is None and GenFds . OnlyGenerateThisFv is None :
2018-04-17 16:40:15 +02:00
for FdObj in GenFdsGlobalVariable . FdfParser . Profile . FdDict . values ( ) :
2014-01-27 06:23:15 +01:00
FdObj . GenFd ( )
GenFdsGlobalVariable . VerboseLogger ( " \n Generate other FV images! " )
2018-04-17 16:40:15 +02:00
if GenFds . OnlyGenerateThisFv is not None and GenFds . OnlyGenerateThisFv . upper ( ) in GenFdsGlobalVariable . FdfParser . Profile . FvDict :
FvObj = GenFdsGlobalVariable . FdfParser . Profile . FvDict [ GenFds . OnlyGenerateThisFv . upper ( ) ]
2018-03-26 22:25:43 +02:00
if FvObj is not None :
2014-01-27 06:23:15 +01:00
Buffer = StringIO . StringIO ( )
FvObj . AddToBuffer ( Buffer )
Buffer . close ( )
return
2018-03-26 22:25:43 +02:00
elif GenFds . OnlyGenerateThisFv is None :
2018-04-17 16:40:15 +02:00
for FvObj in GenFdsGlobalVariable . FdfParser . Profile . FvDict . values ( ) :
2014-01-27 06:23:15 +01:00
Buffer = StringIO . StringIO ( ' ' )
FvObj . AddToBuffer ( Buffer )
Buffer . close ( )
2018-03-26 22:25:43 +02:00
if GenFds . OnlyGenerateThisFv is None and GenFds . OnlyGenerateThisFd is None and GenFds . OnlyGenerateThisCap is None :
2014-01-27 06:23:15 +01:00
if GenFdsGlobalVariable . FdfParser . Profile . CapsuleDict != { } :
GenFdsGlobalVariable . VerboseLogger ( " \n Generate other Capsule images! " )
2018-04-17 16:40:15 +02:00
for CapsuleObj in GenFdsGlobalVariable . FdfParser . Profile . CapsuleDict . values ( ) :
2014-01-27 06:23:15 +01:00
CapsuleObj . GenCapsule ( )
if GenFdsGlobalVariable . FdfParser . Profile . OptRomDict != { } :
GenFdsGlobalVariable . VerboseLogger ( " \n Generate all Option ROM! " )
2018-04-17 16:40:15 +02:00
for OptRomObj in GenFdsGlobalVariable . FdfParser . Profile . OptRomDict . values ( ) :
2014-01-27 06:23:15 +01:00
OptRomObj . AddToBuffer ( None )
2017-11-22 08:42:25 +01:00
@staticmethod
def GenFfsMakefile ( OutputDir , FdfParser , WorkSpace , ArchList , GlobalData ) :
GenFdsGlobalVariable . SetEnv ( FdfParser , WorkSpace , ArchList , GlobalData )
2018-04-17 16:40:15 +02:00
for FdObj in GenFdsGlobalVariable . FdfParser . Profile . FdDict . values ( ) :
2017-11-22 08:42:25 +01:00
FdObj . GenFd ( Flag = True )
2018-04-17 16:40:15 +02:00
for FvObj in GenFdsGlobalVariable . FdfParser . Profile . FvDict . values ( ) :
2017-11-22 08:42:25 +01:00
FvObj . AddToBuffer ( Buffer = None , Flag = True )
if GenFdsGlobalVariable . FdfParser . Profile . OptRomDict != { } :
2018-04-17 16:40:15 +02:00
for OptRomObj in GenFdsGlobalVariable . FdfParser . Profile . OptRomDict . values ( ) :
2017-11-22 08:42:25 +01:00
OptRomObj . AddToBuffer ( Buffer = None , Flag = True )
return GenFdsGlobalVariable . FfsCmdDict
2014-01-27 06:23:15 +01:00
## GetFvBlockSize()
#
# @param FvObj Whose block size to get
# @retval int Block size value
#
def GetFvBlockSize ( FvObj ) :
DefaultBlockSize = 0x1
FdObj = None
2018-04-17 16:40:15 +02:00
if GenFds . OnlyGenerateThisFd is not None and GenFds . OnlyGenerateThisFd . upper ( ) in GenFdsGlobalVariable . FdfParser . Profile . FdDict :
2014-01-27 06:23:15 +01:00
FdObj = GenFdsGlobalVariable . FdfParser . Profile . FdDict [ GenFds . OnlyGenerateThisFd . upper ( ) ]
2018-03-26 22:25:43 +02:00
if FdObj is None :
2014-01-27 06:23:15 +01:00
for ElementFd in GenFdsGlobalVariable . FdfParser . Profile . FdDict . values ( ) :
for ElementRegion in ElementFd . RegionList :
2018-04-26 18:57:56 +02:00
if ElementRegion . RegionType == BINARY_FILE_TYPE_FV :
2014-01-27 06:23:15 +01:00
for ElementRegionData in ElementRegion . RegionDataList :
2018-03-26 22:25:43 +02:00
if ElementRegionData is not None and ElementRegionData . upper ( ) == FvObj . UiFvName :
2014-01-27 06:23:15 +01:00
if FvObj . BlockSizeList != [ ] :
return FvObj . BlockSizeList [ 0 ] [ 0 ]
else :
return ElementRegion . BlockSizeOfRegion ( ElementFd . BlockSizeList )
if FvObj . BlockSizeList != [ ] :
return FvObj . BlockSizeList [ 0 ] [ 0 ]
return DefaultBlockSize
else :
for ElementRegion in FdObj . RegionList :
2018-04-26 18:57:56 +02:00
if ElementRegion . RegionType == BINARY_FILE_TYPE_FV :
2014-01-27 06:23:15 +01:00
for ElementRegionData in ElementRegion . RegionDataList :
2018-03-26 22:25:43 +02:00
if ElementRegionData is not None and ElementRegionData . upper ( ) == FvObj . UiFvName :
2014-01-27 06:23:15 +01:00
if FvObj . BlockSizeList != [ ] :
return FvObj . BlockSizeList [ 0 ] [ 0 ]
else :
return ElementRegion . BlockSizeOfRegion ( ElementFd . BlockSizeList )
return DefaultBlockSize
## DisplayFvSpaceInfo()
#
# @param FvObj Whose block size to get
# @retval None
#
def DisplayFvSpaceInfo ( FdfParser ) :
FvSpaceInfoList = [ ]
MaxFvNameLength = 0
for FvName in FdfParser . Profile . FvDict :
if len ( FvName ) > MaxFvNameLength :
MaxFvNameLength = len ( FvName )
FvSpaceInfoFileName = os . path . join ( GenFdsGlobalVariable . FvDir , FvName . upper ( ) + ' .Fv.map ' )
if os . path . exists ( FvSpaceInfoFileName ) :
FileLinesList = linecache . getlines ( FvSpaceInfoFileName )
TotalFound = False
Total = ' '
UsedFound = False
Used = ' '
FreeFound = False
Free = ' '
for Line in FileLinesList :
NameValue = Line . split ( ' = ' )
if len ( NameValue ) == 2 :
if NameValue [ 0 ] . strip ( ) == ' EFI_FV_TOTAL_SIZE ' :
TotalFound = True
Total = NameValue [ 1 ] . strip ( )
if NameValue [ 0 ] . strip ( ) == ' EFI_FV_TAKEN_SIZE ' :
UsedFound = True
Used = NameValue [ 1 ] . strip ( )
if NameValue [ 0 ] . strip ( ) == ' EFI_FV_SPACE_SIZE ' :
FreeFound = True
Free = NameValue [ 1 ] . strip ( )
if TotalFound and UsedFound and FreeFound :
FvSpaceInfoList . append ( ( FvName , Total , Used , Free ) )
GenFdsGlobalVariable . InfLogger ( ' \n FV Space Information ' )
for FvSpaceInfo in FvSpaceInfoList :
Name = FvSpaceInfo [ 0 ]
TotalSizeValue = long ( FvSpaceInfo [ 1 ] , 0 )
UsedSizeValue = long ( FvSpaceInfo [ 2 ] , 0 )
FreeSizeValue = long ( FvSpaceInfo [ 3 ] , 0 )
if UsedSizeValue == TotalSizeValue :
Percentage = ' 100 '
else :
2015-12-01 05:22:16 +01:00
Percentage = str ( ( UsedSizeValue + 0.0 ) / TotalSizeValue ) [ 0 : 4 ] . lstrip ( ' 0. ' )
2014-01-27 06:23:15 +01:00
GenFdsGlobalVariable . InfLogger ( Name + ' ' + ' [ ' + Percentage + ' %F ull] ' + str ( TotalSizeValue ) + ' total, ' + str ( UsedSizeValue ) + ' used, ' + str ( FreeSizeValue ) + ' free ' )
## PreprocessImage()
#
# @param BuildDb Database from build meta data files
# @param DscFile modules from dsc file will be preprocessed
# @retval None
#
def PreprocessImage ( BuildDb , DscFile ) :
2018-04-16 15:52:13 +02:00
PcdDict = BuildDb . BuildObject [ DscFile , TAB_COMMON , GenFdsGlobalVariable . TargetName , GenFdsGlobalVariable . ToolChainTag ] . Pcds
2014-01-27 06:23:15 +01:00
PcdValue = ' '
for Key in PcdDict :
PcdObj = PcdDict [ Key ]
if PcdObj . TokenCName == ' PcdBsBaseAddress ' :
PcdValue = PcdObj . DefaultValue
break
if PcdValue == ' ' :
return
Int64PcdValue = long ( PcdValue , 0 )
if Int64PcdValue == 0 or Int64PcdValue < - 1 :
return
TopAddress = 0
if Int64PcdValue > 0 :
TopAddress = Int64PcdValue
2018-04-16 15:52:13 +02:00
ModuleDict = BuildDb . BuildObject [ DscFile , TAB_COMMON , GenFdsGlobalVariable . TargetName , GenFdsGlobalVariable . ToolChainTag ] . Modules
2014-01-27 06:23:15 +01:00
for Key in ModuleDict :
2018-04-16 15:52:13 +02:00
ModuleObj = BuildDb . BuildObject [ Key , TAB_COMMON , GenFdsGlobalVariable . TargetName , GenFdsGlobalVariable . ToolChainTag ]
2014-01-27 06:23:15 +01:00
print ModuleObj . BaseName + ' ' + ModuleObj . ModuleType
2017-11-15 17:06:45 +01:00
def GenerateGuidXRefFile ( BuildDb , ArchList , FdfParserObj ) :
2014-01-27 06:23:15 +01:00
GuidXRefFileName = os . path . join ( GenFdsGlobalVariable . FvDir , " Guid.xref " )
GuidXRefFile = StringIO . StringIO ( ' ' )
2014-07-01 09:10:10 +02:00
GuidDict = { }
2017-11-15 17:06:45 +01:00
ModuleList = [ ]
FileGuidList = [ ]
2014-01-27 06:23:15 +01:00
for Arch in ArchList :
PlatformDataBase = BuildDb . BuildObject [ GenFdsGlobalVariable . ActivePlatform , Arch , GenFdsGlobalVariable . TargetName , GenFdsGlobalVariable . ToolChainTag ]
for ModuleFile in PlatformDataBase . Modules :
Module = BuildDb . BuildObject [ ModuleFile , Arch , GenFdsGlobalVariable . TargetName , GenFdsGlobalVariable . ToolChainTag ]
2017-11-15 17:06:45 +01:00
if Module in ModuleList :
continue
else :
ModuleList . append ( Module )
2014-01-27 06:23:15 +01:00
GuidXRefFile . write ( " %s %s \n " % ( Module . Guid , Module . BaseName ) )
2014-07-01 09:10:10 +02:00
for key , item in Module . Protocols . items ( ) :
GuidDict [ key ] = item
for key , item in Module . Guids . items ( ) :
GuidDict [ key ] = item
for key , item in Module . Ppis . items ( ) :
GuidDict [ key ] = item
2017-11-15 17:06:45 +01:00
for FvName in FdfParserObj . Profile . FvDict :
for FfsObj in FdfParserObj . Profile . FvDict [ FvName ] . FfsList :
if not isinstance ( FfsObj , FfsFileStatement . FileStatement ) :
InfPath = PathClass ( NormPath ( mws . join ( GenFdsGlobalVariable . WorkSpaceDir , FfsObj . InfFileName ) ) )
FdfModule = BuildDb . BuildObject [ InfPath , Arch , GenFdsGlobalVariable . TargetName , GenFdsGlobalVariable . ToolChainTag ]
if FdfModule in ModuleList :
continue
else :
ModuleList . append ( FdfModule )
GuidXRefFile . write ( " %s %s \n " % ( FdfModule . Guid , FdfModule . BaseName ) )
for key , item in FdfModule . Protocols . items ( ) :
GuidDict [ key ] = item
for key , item in FdfModule . Guids . items ( ) :
GuidDict [ key ] = item
for key , item in FdfModule . Ppis . items ( ) :
GuidDict [ key ] = item
else :
FileStatementGuid = FfsObj . NameGuid
if FileStatementGuid in FileGuidList :
continue
else :
FileGuidList . append ( FileStatementGuid )
Name = [ ]
FfsPath = os . path . join ( GenFdsGlobalVariable . FvDir , ' Ffs ' )
FfsPath = glob . glob ( os . path . join ( FfsPath , FileStatementGuid ) + ' * ' )
if not FfsPath :
continue
if not os . path . exists ( FfsPath [ 0 ] ) :
continue
MatchDict = { }
ReFileEnds = re . compile ( ' \ S+(.ui)$| \ S+(fv.sec.txt)$| \ S+(.pe32.txt)$| \ S+(.te.txt)$| \ S+(.pic.txt)$| \ S+(.raw.txt)$| \ S+(.ffs.txt)$ ' )
FileList = os . listdir ( FfsPath [ 0 ] )
for File in FileList :
Match = ReFileEnds . search ( File )
if Match :
for Index in range ( 1 , 8 ) :
if Match . group ( Index ) and Match . group ( Index ) in MatchDict :
MatchDict [ Match . group ( Index ) ] . append ( File )
elif Match . group ( Index ) :
MatchDict [ Match . group ( Index ) ] = [ File ]
if not MatchDict :
continue
if ' .ui ' in MatchDict :
for File in MatchDict [ ' .ui ' ] :
with open ( os . path . join ( FfsPath [ 0 ] , File ) , ' rb ' ) as F :
F . read ( )
length = F . tell ( )
F . seek ( 4 )
TmpStr = unpack ( ' %d h ' % ( ( length - 4 ) / 2 ) , F . read ( ) )
Name = ' ' . join ( [ chr ( c ) for c in TmpStr [ : - 1 ] ] )
else :
FileList = [ ]
if ' fv.sec.txt ' in MatchDict :
FileList = MatchDict [ ' fv.sec.txt ' ]
elif ' .pe32.txt ' in MatchDict :
FileList = MatchDict [ ' .pe32.txt ' ]
elif ' .te.txt ' in MatchDict :
FileList = MatchDict [ ' .te.txt ' ]
elif ' .pic.txt ' in MatchDict :
FileList = MatchDict [ ' .pic.txt ' ]
elif ' .raw.txt ' in MatchDict :
FileList = MatchDict [ ' .raw.txt ' ]
elif ' .ffs.txt ' in MatchDict :
FileList = MatchDict [ ' .ffs.txt ' ]
else :
pass
for File in FileList :
with open ( os . path . join ( FfsPath [ 0 ] , File ) , ' r ' ) as F :
Name . append ( ( F . read ( ) . split ( ) [ - 1 ] ) )
if not Name :
continue
Name = ' ' . join ( Name ) if type ( Name ) == type ( [ ] ) else Name
GuidXRefFile . write ( " %s %s \n " % ( FileStatementGuid , Name ) )
2014-07-01 09:10:10 +02:00
# Append GUIDs, Protocols, and PPIs to the Xref file
GuidXRefFile . write ( " \n " )
for key , item in GuidDict . items ( ) :
GuidXRefFile . write ( " %s %s \n " % ( GuidStructureStringToGuidString ( item ) . upper ( ) , key ) )
2014-01-27 06:23:15 +01:00
if GuidXRefFile . getvalue ( ) :
SaveFileOnChange ( GuidXRefFileName , GuidXRefFile . getvalue ( ) , False )
GenFdsGlobalVariable . InfLogger ( " \n GUID cross reference file can be found at %s " % GuidXRefFileName )
elif os . path . exists ( GuidXRefFileName ) :
os . remove ( GuidXRefFileName )
GuidXRefFile . close ( )
##Define GenFd as static function
GenFd = staticmethod ( GenFd )
GetFvBlockSize = staticmethod ( GetFvBlockSize )
DisplayFvSpaceInfo = staticmethod ( DisplayFvSpaceInfo )
PreprocessImage = staticmethod ( PreprocessImage )
GenerateGuidXRefFile = staticmethod ( GenerateGuidXRefFile )
if __name__ == ' __main__ ' :
r = main ( )
## 0-127 is a safe return range, and 1 is a standard default error
if r < 0 or r > 127 : r = 1
sys . exit ( r )