2009-07-17 11:10:31 +02:00
|
|
|
## @file
|
|
|
|
# process VTF generation
|
|
|
|
#
|
2014-08-15 05:06:48 +02:00
|
|
|
# Copyright (c) 2007 - 2014, Intel Corporation. All rights reserved.<BR>
|
2009-07-17 11:10:31 +02:00
|
|
|
#
|
2010-05-18 07:04:32 +02:00
|
|
|
# This program and the accompanying materials
|
2009-07-17 11:10:31 +02:00
|
|
|
# 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 GenFdsGlobalVariable import GenFdsGlobalVariable
|
2014-08-15 05:06:48 +02:00
|
|
|
import Common.LongFilePathOs as os
|
2009-07-17 11:10:31 +02:00
|
|
|
from CommonDataClass.FdfClass import VtfClassObject
|
2014-08-15 05:06:48 +02:00
|
|
|
from Common.LongFilePathSupport import OpenLongFilePath as open
|
2009-07-17 11:10:31 +02:00
|
|
|
T_CHAR_LF = '\n'
|
|
|
|
|
|
|
|
## generate VTF
|
|
|
|
#
|
|
|
|
#
|
|
|
|
class Vtf (VtfClassObject):
|
|
|
|
|
|
|
|
## The constructor
|
|
|
|
#
|
|
|
|
# @param self The object pointer
|
|
|
|
#
|
|
|
|
def __init__(self):
|
|
|
|
VtfClassObject.__init__(self)
|
|
|
|
|
|
|
|
## GenVtf() method
|
|
|
|
#
|
|
|
|
# Generate VTF
|
|
|
|
#
|
|
|
|
# @param self The object pointer
|
|
|
|
# @param FdAddressDict dictionary contains FV name and its base address
|
|
|
|
# @retval Dict FV and corresponding VTF file name
|
|
|
|
#
|
|
|
|
def GenVtf(self, FdAddressDict) :
|
|
|
|
self.GenBsfInf()
|
|
|
|
OutputFile = os.path.join(GenFdsGlobalVariable.FvDir, self.UiName + '.Vtf')
|
|
|
|
BaseAddArg = self.GetBaseAddressArg(FdAddressDict)
|
|
|
|
OutputArg, VtfRawDict = self.GenOutputArg()
|
|
|
|
|
|
|
|
Cmd = (
|
|
|
|
'GenVtf',
|
|
|
|
) + OutputArg + (
|
|
|
|
'-f', self.BsfInfName,
|
|
|
|
) + BaseAddArg
|
|
|
|
|
|
|
|
GenFdsGlobalVariable.CallExternalTool(Cmd, "GenFv -Vtf Failed!")
|
|
|
|
GenFdsGlobalVariable.SharpCounter = 0
|
|
|
|
|
|
|
|
return VtfRawDict
|
|
|
|
|
|
|
|
## GenBsfInf() method
|
|
|
|
#
|
|
|
|
# Generate inf used to generate VTF
|
|
|
|
#
|
|
|
|
# @param self The object pointer
|
|
|
|
#
|
|
|
|
def GenBsfInf (self):
|
|
|
|
FvList = self.GetFvList()
|
|
|
|
self.BsfInfName = os.path.join(GenFdsGlobalVariable.FvDir, self.UiName + '.inf')
|
2015-12-01 05:22:16 +01:00
|
|
|
BsfInf = open(self.BsfInfName, 'w+')
|
2010-07-28 05:07:30 +02:00
|
|
|
if self.ResetBin != None:
|
|
|
|
BsfInf.writelines ("[OPTIONS]" + T_CHAR_LF)
|
2015-12-01 05:22:16 +01:00
|
|
|
BsfInf.writelines ("IA32_RST_BIN" + \
|
|
|
|
" = " + \
|
2010-07-28 05:07:30 +02:00
|
|
|
GenFdsGlobalVariable.MacroExtend(GenFdsGlobalVariable.ReplaceWorkspaceMacro(self.ResetBin)) + \
|
2015-12-01 05:22:16 +01:00
|
|
|
T_CHAR_LF)
|
|
|
|
BsfInf.writelines (T_CHAR_LF)
|
|
|
|
|
2009-07-17 11:10:31 +02:00
|
|
|
BsfInf.writelines ("[COMPONENTS]" + T_CHAR_LF)
|
|
|
|
|
|
|
|
for ComponentObj in self.ComponentStatementList :
|
2015-12-01 05:22:16 +01:00
|
|
|
BsfInf.writelines ("COMP_NAME" + \
|
|
|
|
" = " + \
|
2009-07-17 11:10:31 +02:00
|
|
|
ComponentObj.CompName + \
|
2015-12-01 05:22:16 +01:00
|
|
|
T_CHAR_LF)
|
2009-07-17 11:10:31 +02:00
|
|
|
if ComponentObj.CompLoc.upper() == 'NONE':
|
2015-12-01 05:22:16 +01:00
|
|
|
BsfInf.writelines ("COMP_LOC" + \
|
|
|
|
" = " + \
|
|
|
|
'N' + \
|
|
|
|
T_CHAR_LF)
|
|
|
|
|
2009-07-17 11:10:31 +02:00
|
|
|
elif ComponentObj.FilePos != None:
|
2015-12-01 05:22:16 +01:00
|
|
|
BsfInf.writelines ("COMP_LOC" + \
|
|
|
|
" = " + \
|
2009-07-17 11:10:31 +02:00
|
|
|
ComponentObj.FilePos + \
|
2015-12-01 05:22:16 +01:00
|
|
|
T_CHAR_LF)
|
2009-07-17 11:10:31 +02:00
|
|
|
else:
|
|
|
|
Index = FvList.index(ComponentObj.CompLoc.upper())
|
|
|
|
if Index == 0:
|
2015-12-01 05:22:16 +01:00
|
|
|
BsfInf.writelines ("COMP_LOC" + \
|
|
|
|
" = " + \
|
|
|
|
'F' + \
|
|
|
|
T_CHAR_LF)
|
2009-07-17 11:10:31 +02:00
|
|
|
elif Index == 1:
|
2015-12-01 05:22:16 +01:00
|
|
|
BsfInf.writelines ("COMP_LOC" + \
|
|
|
|
" = " + \
|
|
|
|
'S' + \
|
|
|
|
T_CHAR_LF)
|
|
|
|
|
|
|
|
BsfInf.writelines ("COMP_TYPE" + \
|
|
|
|
" = " + \
|
2009-07-17 11:10:31 +02:00
|
|
|
ComponentObj.CompType + \
|
2015-12-01 05:22:16 +01:00
|
|
|
T_CHAR_LF)
|
|
|
|
BsfInf.writelines ("COMP_VER" + \
|
|
|
|
" = " + \
|
2009-07-17 11:10:31 +02:00
|
|
|
ComponentObj.CompVer + \
|
2015-12-01 05:22:16 +01:00
|
|
|
T_CHAR_LF)
|
|
|
|
BsfInf.writelines ("COMP_CS" + \
|
|
|
|
" = " + \
|
2009-07-17 11:10:31 +02:00
|
|
|
ComponentObj.CompCs + \
|
2015-12-01 05:22:16 +01:00
|
|
|
T_CHAR_LF)
|
|
|
|
|
2009-07-17 11:10:31 +02:00
|
|
|
BinPath = ComponentObj.CompBin
|
|
|
|
if BinPath != '-':
|
|
|
|
BinPath = GenFdsGlobalVariable.MacroExtend(GenFdsGlobalVariable.ReplaceWorkspaceMacro(BinPath))
|
2015-12-01 05:22:16 +01:00
|
|
|
BsfInf.writelines ("COMP_BIN" + \
|
|
|
|
" = " + \
|
2009-07-17 11:10:31 +02:00
|
|
|
BinPath + \
|
2015-12-01 05:22:16 +01:00
|
|
|
T_CHAR_LF)
|
|
|
|
|
2009-07-17 11:10:31 +02:00
|
|
|
SymPath = ComponentObj.CompSym
|
|
|
|
if SymPath != '-':
|
|
|
|
SymPath = GenFdsGlobalVariable.MacroExtend(GenFdsGlobalVariable.ReplaceWorkspaceMacro(SymPath))
|
2015-12-01 05:22:16 +01:00
|
|
|
BsfInf.writelines ("COMP_SYM" + \
|
|
|
|
" = " + \
|
2009-07-17 11:10:31 +02:00
|
|
|
SymPath + \
|
2015-12-01 05:22:16 +01:00
|
|
|
T_CHAR_LF)
|
|
|
|
BsfInf.writelines ("COMP_SIZE" + \
|
|
|
|
" = " + \
|
2009-07-17 11:10:31 +02:00
|
|
|
ComponentObj.CompSize + \
|
2015-12-01 05:22:16 +01:00
|
|
|
T_CHAR_LF)
|
|
|
|
BsfInf.writelines (T_CHAR_LF)
|
|
|
|
|
2009-07-17 11:10:31 +02:00
|
|
|
BsfInf.close()
|
|
|
|
|
|
|
|
## GenFvList() method
|
|
|
|
#
|
|
|
|
# Get FV list referenced by VTF components
|
|
|
|
#
|
|
|
|
# @param self The object pointer
|
|
|
|
#
|
|
|
|
def GetFvList(self):
|
|
|
|
FvList = []
|
|
|
|
for component in self.ComponentStatementList :
|
|
|
|
if component.CompLoc.upper() != 'NONE' and not (component.CompLoc.upper() in FvList):
|
|
|
|
FvList.append(component.CompLoc.upper())
|
|
|
|
|
|
|
|
return FvList
|
|
|
|
|
|
|
|
## GetBaseAddressArg() method
|
|
|
|
#
|
|
|
|
# Get base address arguments for GenVtf
|
|
|
|
#
|
|
|
|
# @param self The object pointer
|
|
|
|
#
|
|
|
|
def GetBaseAddressArg(self, FdAddressDict):
|
|
|
|
FvList = self.GetFvList()
|
|
|
|
CmdStr = tuple()
|
|
|
|
for i in FvList:
|
|
|
|
(BaseAddress, Size) = FdAddressDict.get(i)
|
|
|
|
CmdStr += (
|
|
|
|
'-r', '0x%x' % BaseAddress,
|
2015-12-01 05:22:16 +01:00
|
|
|
'-s', '0x%x' % Size,
|
2009-07-17 11:10:31 +02:00
|
|
|
)
|
|
|
|
return CmdStr
|
|
|
|
|
|
|
|
## GenOutputArg() method
|
|
|
|
#
|
|
|
|
# Get output arguments for GenVtf
|
|
|
|
#
|
|
|
|
# @param self The object pointer
|
|
|
|
#
|
|
|
|
def GenOutputArg(self):
|
|
|
|
FvVtfDict = {}
|
|
|
|
OutputFileName = ''
|
|
|
|
FvList = self.GetFvList()
|
|
|
|
Index = 0
|
|
|
|
Arg = tuple()
|
|
|
|
for FvObj in FvList:
|
|
|
|
Index = Index + 1
|
|
|
|
OutputFileName = 'Vtf%d.raw' % Index
|
|
|
|
OutputFileName = os.path.join(GenFdsGlobalVariable.FvDir, OutputFileName)
|
|
|
|
Arg += ('-o', OutputFileName)
|
|
|
|
FvVtfDict[FvObj.upper()] = OutputFileName
|
|
|
|
|
|
|
|
return Arg, FvVtfDict
|
|
|
|
|