2009-07-17 11:10:31 +02:00
|
|
|
## @file
|
|
|
|
# generate capsule
|
|
|
|
#
|
2018-04-17 16:40:15 +02:00
|
|
|
# Copyright (c) 2007-2018, Intel Corporation. All rights reserved.<BR>
|
2009-07-17 11:10:31 +02:00
|
|
|
#
|
2019-04-04 01:03:11 +02:00
|
|
|
# SPDX-License-Identifier: BSD-2-Clause-Patent
|
2009-07-17 11:10:31 +02:00
|
|
|
#
|
|
|
|
|
|
|
|
##
|
|
|
|
# Import Modules
|
|
|
|
#
|
2018-10-15 02:27:53 +02:00
|
|
|
from __future__ import absolute_import
|
2018-07-13 12:18:33 +02:00
|
|
|
from .GenFdsGlobalVariable import GenFdsGlobalVariable
|
2018-06-25 12:31:36 +02:00
|
|
|
from io import BytesIO
|
2015-06-23 08:46:01 +02:00
|
|
|
from struct import pack
|
|
|
|
import os
|
|
|
|
from Common.Misc import SaveFileOnChange
|
2016-08-29 09:44:59 +02:00
|
|
|
import uuid
|
2009-07-17 11:10:31 +02:00
|
|
|
|
|
|
|
## base class for capsule data
|
|
|
|
#
|
|
|
|
#
|
|
|
|
class CapsuleData:
|
|
|
|
## The constructor
|
|
|
|
#
|
|
|
|
# @param self The object pointer
|
|
|
|
def __init__(self):
|
|
|
|
pass
|
2018-07-05 11:40:04 +02:00
|
|
|
|
2009-07-17 11:10:31 +02:00
|
|
|
## generate capsule data
|
|
|
|
#
|
|
|
|
# @param self The object pointer
|
|
|
|
def GenCapsuleSubItem(self):
|
|
|
|
pass
|
2018-07-05 11:40:04 +02:00
|
|
|
|
2009-07-17 11:10:31 +02:00
|
|
|
## FFS class for capsule data
|
|
|
|
#
|
|
|
|
#
|
|
|
|
class CapsuleFfs (CapsuleData):
|
|
|
|
## The constructor
|
|
|
|
#
|
|
|
|
# @param self The object pointer
|
|
|
|
#
|
2011-09-18 14:17:25 +02:00
|
|
|
def __init__(self) :
|
2009-07-17 11:10:31 +02:00
|
|
|
self.Ffs = None
|
2009-09-11 05:14:43 +02:00
|
|
|
self.FvName = None
|
2009-07-17 11:10:31 +02:00
|
|
|
|
|
|
|
## generate FFS capsule data
|
|
|
|
#
|
|
|
|
# @param self The object pointer
|
|
|
|
# @retval string Generated file name
|
|
|
|
#
|
|
|
|
def GenCapsuleSubItem(self):
|
|
|
|
FfsFile = self.Ffs.GenFfs()
|
|
|
|
return FfsFile
|
|
|
|
|
|
|
|
## FV class for capsule data
|
|
|
|
#
|
|
|
|
#
|
|
|
|
class CapsuleFv (CapsuleData):
|
|
|
|
## The constructor
|
|
|
|
#
|
|
|
|
# @param self The object pointer
|
|
|
|
#
|
|
|
|
def __init__(self) :
|
2009-09-11 05:14:43 +02:00
|
|
|
self.Ffs = None
|
2009-07-17 11:10:31 +02:00
|
|
|
self.FvName = None
|
2009-09-11 05:14:43 +02:00
|
|
|
self.CapsuleName = None
|
2009-07-17 11:10:31 +02:00
|
|
|
|
|
|
|
## generate FV capsule data
|
|
|
|
#
|
|
|
|
# @param self The object pointer
|
|
|
|
# @retval string Generated file name
|
|
|
|
#
|
|
|
|
def GenCapsuleSubItem(self):
|
|
|
|
if self.FvName.find('.fv') == -1:
|
2018-04-17 16:40:15 +02:00
|
|
|
if self.FvName.upper() in GenFdsGlobalVariable.FdfParser.Profile.FvDict:
|
|
|
|
FvObj = GenFdsGlobalVariable.FdfParser.Profile.FvDict[self.FvName.upper()]
|
2019-01-23 03:16:00 +01:00
|
|
|
FdBuffer = BytesIO()
|
2009-09-11 05:14:43 +02:00
|
|
|
FvObj.CapsuleName = self.CapsuleName
|
2009-07-17 11:10:31 +02:00
|
|
|
FvFile = FvObj.AddToBuffer(FdBuffer)
|
2009-09-11 05:14:43 +02:00
|
|
|
FvObj.CapsuleName = None
|
|
|
|
FdBuffer.close()
|
2009-07-17 11:10:31 +02:00
|
|
|
return FvFile
|
|
|
|
else:
|
|
|
|
FvFile = GenFdsGlobalVariable.ReplaceWorkspaceMacro(self.FvName)
|
|
|
|
return FvFile
|
2011-09-18 14:17:25 +02:00
|
|
|
|
|
|
|
## FD class for capsule data
|
|
|
|
#
|
|
|
|
#
|
|
|
|
class CapsuleFd (CapsuleData):
|
|
|
|
## The constructor
|
|
|
|
#
|
|
|
|
# @param self The object pointer
|
|
|
|
#
|
|
|
|
def __init__(self) :
|
|
|
|
self.Ffs = None
|
|
|
|
self.FdName = None
|
|
|
|
self.CapsuleName = None
|
|
|
|
|
|
|
|
## generate FD capsule data
|
|
|
|
#
|
|
|
|
# @param self The object pointer
|
|
|
|
# @retval string Generated file name
|
|
|
|
#
|
|
|
|
def GenCapsuleSubItem(self):
|
|
|
|
if self.FdName.find('.fd') == -1:
|
2018-04-17 16:40:15 +02:00
|
|
|
if self.FdName.upper() in GenFdsGlobalVariable.FdfParser.Profile.FdDict:
|
|
|
|
FdObj = GenFdsGlobalVariable.FdfParser.Profile.FdDict[self.FdName.upper()]
|
2011-09-18 14:17:25 +02:00
|
|
|
FdFile = FdObj.GenFd()
|
|
|
|
return FdFile
|
|
|
|
else:
|
|
|
|
FdFile = GenFdsGlobalVariable.ReplaceWorkspaceMacro(self.FdName)
|
|
|
|
return FdFile
|
2018-07-05 11:40:04 +02:00
|
|
|
|
2011-09-18 14:17:25 +02:00
|
|
|
## AnyFile class for capsule data
|
|
|
|
#
|
|
|
|
#
|
|
|
|
class CapsuleAnyFile (CapsuleData):
|
|
|
|
## The constructor
|
|
|
|
#
|
|
|
|
# @param self The object pointer
|
|
|
|
#
|
|
|
|
def __init__(self) :
|
|
|
|
self.Ffs = None
|
|
|
|
self.FileName = None
|
|
|
|
|
|
|
|
## generate AnyFile capsule data
|
|
|
|
#
|
|
|
|
# @param self The object pointer
|
|
|
|
# @retval string Generated file name
|
|
|
|
#
|
2014-01-10 06:25:50 +01:00
|
|
|
def GenCapsuleSubItem(self):
|
|
|
|
return self.FileName
|
2018-07-05 11:40:04 +02:00
|
|
|
|
2014-01-10 06:25:50 +01:00
|
|
|
## Afile class for capsule data
|
|
|
|
#
|
|
|
|
#
|
|
|
|
class CapsuleAfile (CapsuleData):
|
|
|
|
## The constructor
|
|
|
|
#
|
|
|
|
# @param self The object pointer
|
|
|
|
#
|
|
|
|
def __init__(self) :
|
|
|
|
self.Ffs = None
|
|
|
|
self.FileName = None
|
|
|
|
|
|
|
|
## generate Afile capsule data
|
|
|
|
#
|
|
|
|
# @param self The object pointer
|
|
|
|
# @retval string Generated file name
|
|
|
|
#
|
2011-09-18 14:17:25 +02:00
|
|
|
def GenCapsuleSubItem(self):
|
2015-06-23 08:46:01 +02:00
|
|
|
return self.FileName
|
|
|
|
|
|
|
|
class CapsulePayload(CapsuleData):
|
|
|
|
'''Generate payload file, the header is defined below:
|
|
|
|
#pragma pack(1)
|
|
|
|
typedef struct {
|
|
|
|
UINT32 Version;
|
|
|
|
EFI_GUID UpdateImageTypeId;
|
|
|
|
UINT8 UpdateImageIndex;
|
|
|
|
UINT8 reserved_bytes[3];
|
|
|
|
UINT32 UpdateImageSize;
|
|
|
|
UINT32 UpdateVendorCodeSize;
|
|
|
|
UINT64 UpdateHardwareInstance; //Introduced in v2
|
|
|
|
} EFI_FIRMWARE_MANAGEMENT_CAPSULE_IMAGE_HEADER;
|
|
|
|
'''
|
|
|
|
def __init__(self):
|
|
|
|
self.UiName = None
|
|
|
|
self.Version = None
|
|
|
|
self.ImageTypeId = None
|
|
|
|
self.ImageIndex = None
|
|
|
|
self.HardwareInstance = None
|
2016-10-09 03:30:06 +02:00
|
|
|
self.ImageFile = []
|
|
|
|
self.VendorCodeFile = []
|
2016-08-15 07:52:12 +02:00
|
|
|
self.Certificate_Guid = None
|
|
|
|
self.MonotonicCount = None
|
2017-06-06 07:28:07 +02:00
|
|
|
self.Existed = False
|
|
|
|
self.Buffer = None
|
2015-06-23 08:46:01 +02:00
|
|
|
|
2016-08-29 09:44:59 +02:00
|
|
|
def GenCapsuleSubItem(self, AuthData=[]):
|
2015-06-23 08:46:01 +02:00
|
|
|
if not self.Version:
|
2017-01-04 03:40:54 +01:00
|
|
|
self.Version = '0x00000002'
|
|
|
|
if not self.ImageIndex:
|
|
|
|
self.ImageIndex = '0x1'
|
|
|
|
if not self.HardwareInstance:
|
|
|
|
self.HardwareInstance = '0x0'
|
2015-06-23 08:46:01 +02:00
|
|
|
ImageFileSize = os.path.getsize(self.ImageFile)
|
2016-08-29 09:44:59 +02:00
|
|
|
if AuthData:
|
|
|
|
# the ImageFileSize need include the full authenticated info size. From first bytes of MonotonicCount to last bytes of certificate.
|
|
|
|
# the 32 bit is the MonotonicCount, dwLength, wRevision, wCertificateType and CertType
|
|
|
|
ImageFileSize += 32
|
2015-06-23 08:46:01 +02:00
|
|
|
VendorFileSize = 0
|
|
|
|
if self.VendorCodeFile:
|
|
|
|
VendorFileSize = os.path.getsize(self.VendorCodeFile)
|
|
|
|
|
|
|
|
#
|
|
|
|
# Fill structure
|
|
|
|
#
|
|
|
|
Guid = self.ImageTypeId.split('-')
|
|
|
|
Buffer = pack('=ILHHBBBBBBBBBBBBIIQ',
|
2018-06-25 12:31:33 +02:00
|
|
|
int(self.Version, 16),
|
2018-07-05 11:40:04 +02:00
|
|
|
int(Guid[0], 16),
|
|
|
|
int(Guid[1], 16),
|
|
|
|
int(Guid[2], 16),
|
|
|
|
int(Guid[3][-4:-2], 16),
|
|
|
|
int(Guid[3][-2:], 16),
|
2015-06-23 08:46:01 +02:00
|
|
|
int(Guid[4][-12:-10], 16),
|
|
|
|
int(Guid[4][-10:-8], 16),
|
|
|
|
int(Guid[4][-8:-6], 16),
|
|
|
|
int(Guid[4][-6:-4], 16),
|
|
|
|
int(Guid[4][-4:-2], 16),
|
|
|
|
int(Guid[4][-2:], 16),
|
|
|
|
int(self.ImageIndex, 16),
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
0,
|
|
|
|
ImageFileSize,
|
|
|
|
VendorFileSize,
|
|
|
|
int(self.HardwareInstance, 16)
|
|
|
|
)
|
2016-08-29 09:44:59 +02:00
|
|
|
if AuthData:
|
|
|
|
Buffer += pack('QIHH', AuthData[0], AuthData[1], AuthData[2], AuthData[3])
|
2018-11-28 04:12:37 +01:00
|
|
|
Buffer += uuid.UUID(AuthData[4]).bytes_le
|
2016-08-29 09:44:59 +02:00
|
|
|
|
|
|
|
#
|
|
|
|
# Append file content to the structure
|
|
|
|
#
|
|
|
|
ImageFile = open(self.ImageFile, 'rb')
|
|
|
|
Buffer += ImageFile.read()
|
|
|
|
ImageFile.close()
|
|
|
|
if self.VendorCodeFile:
|
|
|
|
VendorFile = open(self.VendorCodeFile, 'rb')
|
|
|
|
Buffer += VendorFile.read()
|
|
|
|
VendorFile.close()
|
2017-06-06 07:28:07 +02:00
|
|
|
self.Existed = True
|
2015-06-23 08:46:01 +02:00
|
|
|
return Buffer
|