1 # SPDX-License-Identifier: GPL-2.0+
2 # Copyright (c) 2018 Google, Inc
3 # Written by Simon Glass <sjg@chromium.org>
5 # Entry-type module for a Flash map, as used by the flashrom SPI flash tool
8 from binman.entry import Entry
9 from binman import fmap_util
11 from patman.tools import ToHexSize
15 class Entry_fmap(Entry):
16 """An entry which contains an Fmap section
18 Properties / Entry arguments:
21 FMAP is a simple format used by flashrom, an open-source utility for
22 reading and writing the SPI flash, typically on x86 CPUs. The format
23 provides flashrom with a list of areas, so it knows what it in the flash.
24 It can then read or write just a single area, instead of the whole flash.
26 The format is defined by the flashrom project, in the file lib/fmap.h -
27 see www.flashrom.org/Flashrom for more information.
29 When used, this entry will be populated with an FMAP which reflects the
30 entries in the current image. Note that any hierarchy is squashed, since
31 FMAP does not support this. Also, CBFS entries appear as a single entry -
32 the sub-entries are ignored.
34 def __init__(self, section, etype, node):
35 Entry.__init__(self, section, etype, node)
38 """Build an FMAP from the entries in the current image
43 def _AddEntries(areas, entry):
44 entries = entry.GetEntries()
45 tout.Debug("fmap: Add entry '%s' type '%s' (%s subentries)" %
46 (entry.GetPath(), entry.etype, ToHexSize(entries)))
47 if entries and entry.etype != 'cbfs':
48 for subentry in entries.values():
49 _AddEntries(areas, subentry)
53 pos -= entry.section.GetRootSkipAtStart()
54 areas.append(fmap_util.FmapArea(pos or 0, entry.size or 0,
55 tools.FromUnicode(entry.name), 0))
57 entries = self.GetImage().GetEntries()
59 for entry in entries.values():
60 _AddEntries(areas, entry)
61 return fmap_util.EncodeFmap(self.section.GetImageSize() or 0, self.name,
64 def ObtainContents(self):
65 """Obtain a placeholder for the fmap contents"""
66 self.SetContents(self._GetFmap())
69 def ProcessContents(self):
70 return self.ProcessContentsUpdate(self._GetFmap())