2018-05-07 06:58:06 +09:00
|
|
|
# SPDX-License-Identifier: GPL-2.0+
|
2016-11-26 12:15:53 +09:00
|
|
|
# Copyright (c) 2016 Google, Inc
|
|
|
|
# Written by Simon Glass <sjg@chromium.org>
|
|
|
|
#
|
|
|
|
# Entry-type module for 'u-boot'
|
|
|
|
#
|
|
|
|
|
|
|
|
import struct
|
|
|
|
|
|
|
|
from entry import Entry
|
|
|
|
from blob import Entry_blob
|
|
|
|
|
|
|
|
FD_SIGNATURE = struct.pack('<L', 0x0ff0a55a)
|
|
|
|
MAX_REGIONS = 5
|
|
|
|
|
|
|
|
(REGION_DESCRIPTOR, REGION_BIOS, REGION_ME, REGION_GBE,
|
|
|
|
REGION_PDATA) = range(5)
|
|
|
|
|
|
|
|
class Region:
|
|
|
|
def __init__(self, data, frba, region_num):
|
|
|
|
pos = frba + region_num * 4
|
|
|
|
val = struct.unpack('<L', data[pos:pos + 4])[0]
|
|
|
|
self.base = (val & 0xfff) << 12
|
|
|
|
self.limit = ((val & 0x0fff0000) >> 4) | 0xfff
|
|
|
|
self.size = self.limit - self.base + 1
|
|
|
|
|
|
|
|
class Entry_intel_descriptor(Entry_blob):
|
|
|
|
"""Intel flash descriptor block (4KB)
|
|
|
|
|
|
|
|
This is placed at the start of flash and provides information about
|
|
|
|
the SPI flash regions. In particular it provides the base address and
|
|
|
|
size of the ME region, allowing us to place the ME binary in the right
|
|
|
|
place.
|
|
|
|
"""
|
2018-06-02 00:38:14 +09:00
|
|
|
def __init__(self, section, etype, node):
|
|
|
|
Entry_blob.__init__(self, section, etype, node)
|
2016-11-26 12:15:53 +09:00
|
|
|
self._regions = []
|
|
|
|
|
|
|
|
def GetPositions(self):
|
|
|
|
pos = self.data.find(FD_SIGNATURE)
|
|
|
|
if pos == -1:
|
|
|
|
self.Raise('Cannot find FD signature')
|
|
|
|
flvalsig, flmap0, flmap1, flmap2 = struct.unpack('<LLLL',
|
|
|
|
self.data[pos:pos + 16])
|
|
|
|
frba = ((flmap0 >> 16) & 0xff) << 4
|
|
|
|
for i in range(MAX_REGIONS):
|
|
|
|
self._regions.append(Region(self.data, frba, i))
|
|
|
|
|
|
|
|
# Set the offset for ME only, for now, since the others are not used
|
|
|
|
return {'intel-me': [self._regions[REGION_ME].base,
|
|
|
|
self._regions[REGION_ME].size]}
|