mirror of
https://github.com/brain-hackers/u-boot-brain
synced 2024-09-19 03:03:22 +09:00
4f44304b0b
Add entries to support some standard U-Boot binaries, such as u-boot.bin, u-boot.dtb, etc. Also add some tests for these. Signed-off-by: Simon Glass <sjg@chromium.org> Tested-by: Bin Meng <bmeng.cn@gmail.com>
38 lines
1.3 KiB
Python
38 lines
1.3 KiB
Python
# Copyright (c) 2016 Google, Inc
|
|
# Written by Simon Glass <sjg@chromium.org>
|
|
#
|
|
# SPDX-License-Identifier: GPL-2.0+
|
|
#
|
|
# Entry-type module for blobs, which are binary objects read from files
|
|
#
|
|
|
|
from entry import Entry
|
|
import fdt_util
|
|
import tools
|
|
|
|
class Entry_blob(Entry):
|
|
def __init__(self, image, etype, node):
|
|
Entry.__init__(self, image, etype, node)
|
|
self._filename = fdt_util.GetString(self._node, "filename", self.etype)
|
|
|
|
def ObtainContents(self):
|
|
self._filename = self.GetDefaultFilename()
|
|
self._pathname = tools.GetInputFilename(self._filename)
|
|
self.ReadContents()
|
|
return True
|
|
|
|
def ReadContents(self):
|
|
with open(self._pathname) as fd:
|
|
# We assume the data is small enough to fit into memory. If this
|
|
# is used for large filesystem image that might not be true.
|
|
# In that case, Image.BuildImage() could be adjusted to use a
|
|
# new Entry method which can read in chunks. Then we could copy
|
|
# the data in chunks and avoid reading it all at once. For now
|
|
# this seems like an unnecessary complication.
|
|
self.data = fd.read()
|
|
self.contents_size = len(self.data)
|
|
return True
|
|
|
|
def GetDefaultFilename(self):
|
|
return self._filename
|