part_efi: support padding between the GPT header and partition entries
authorPhilipp Tomsich <philipp.tomsich@theobroma-systems.com>
Wed, 1 Mar 2017 20:10:39 +0000 (21:10 +0100)
committerTom Rini <trini@konsulko.com>
Mon, 20 Mar 2017 22:04:18 +0000 (18:04 -0400)
commit02e43537b3223702e8e0289bc1c25208944865d0
tree5b930f5cf287f9b9aedb709df15ff5af1b4dda37
parentee6fdfadaafeb50a2e7d2a5a4f978332b5198000
part_efi: support padding between the GPT header and partition entries

Some architectures require their SPL loader at a fixed address within
the first 16KB of the disk. To avoid an overlap with the partition
entries of the EFI partition table, the first safe offset (in bytes,
from the start of the device) for the entries can be set through
CONFIG_EFI_PARTITION_ENTRIES_OFF (via Kconfig)

When formatting a device with an EFI partition table, we may need to
leave a gap between the GPT header (always in LBA 1) and the partition
entries. The GPT header already contains a field to specify the
on-disk location, which has so far always been set to LBA 2. With this
change, a configurable offset will be translated into a LBA address
indicating where to put the entries.

Now also allows an override via device-tree using a config-node (see
doc/device-tree-bindings/config.txt for documentation).

Tested (exporting an internal MMC formatted with this) against Linux,
MacOS X and Windows.

Signed-off-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com>
Reviewed-by: Simon Glass <sjg@chromium.org>
[trini: __maybe_unused on config_offset to avoid warning]
Signed-off-by: Tom Rini <trini@konsulko.com>
disk/Kconfig
disk/part_efi.c