sandbox: Add an image for VPL
Use binman to build an image which includes all the U-Boot phases so that a full VBE boot can take place with just that image.bin file. Attach the image file to mmc2 so it can be loaded. VBE is used to load images in two phases: - In VPL, VBE decides which SPL image to load - In SPL, VBE decides which U-Boot image to load The latter should really be determined by VPL, since it does the full signature verification on the selected configuration. However, we have separate configurations for SPL and U-Boot proper, so for now we keep it simple and have SPL do its own verification. This will need to be tidied up later. Signed-off-by: Simon Glass <sjg@chromium.org>
This commit is contained in:
parent
a56f663f07
commit
8de9896aa6
@ -21,6 +21,9 @@
|
||||
spi0 = &spi;
|
||||
};
|
||||
|
||||
binman: binman {
|
||||
};
|
||||
|
||||
memory {
|
||||
reg = <0 CONFIG_SYS_SDRAM_SIZE>;
|
||||
};
|
||||
@ -103,3 +106,7 @@
|
||||
#include "sandbox.dtsi"
|
||||
#include "cros-ec-keyboard.dtsi"
|
||||
#include "sandbox_pmic.dtsi"
|
||||
|
||||
#ifdef CONFIG_SANDBOX_VPL
|
||||
#include "sandbox_vpl.dtsi"
|
||||
#endif
|
||||
|
84
arch/sandbox/dts/sandbox_vpl.dtsi
Normal file
84
arch/sandbox/dts/sandbox_vpl.dtsi
Normal file
@ -0,0 +1,84 @@
|
||||
// SPDX-License-Identifier: GPL-2.0+
|
||||
/*
|
||||
* Devicetree file for VPL (Verifying Program Loader)
|
||||
*/
|
||||
|
||||
&binman {
|
||||
u-boot-tpl-elf {
|
||||
no-expanded;
|
||||
};
|
||||
u-boot-vpl-elf {
|
||||
no-expanded;
|
||||
};
|
||||
fw-update {
|
||||
type = "section";
|
||||
|
||||
/*
|
||||
* provide plenty of space for ELF files with debug info so that
|
||||
* gdb can be used
|
||||
*/
|
||||
offset = <0x400000>;
|
||||
size = <0xdffc00>;
|
||||
|
||||
fit {
|
||||
fit,external-offset = <0>;
|
||||
description = "AP firmware";
|
||||
images {
|
||||
spl {
|
||||
description = "U-Boot SPL";
|
||||
type = "firmware";
|
||||
phase = "spl";
|
||||
arch = "sandbox";
|
||||
os = "u-boot";
|
||||
compression = "none";
|
||||
|
||||
hash-1 {
|
||||
algo = "sha256";
|
||||
};
|
||||
|
||||
u-boot-spl-elf {
|
||||
};
|
||||
};
|
||||
u-boot {
|
||||
description = "U-Boot";
|
||||
type = "firmware";
|
||||
phase = "u-boot";
|
||||
arch = "sandbox";
|
||||
os = "u-boot";
|
||||
compression = "none";
|
||||
|
||||
hash-1 {
|
||||
algo = "sha256";
|
||||
};
|
||||
|
||||
u-boot-elf {
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
configurations {
|
||||
conf-1 {
|
||||
compatible = "sandbox";
|
||||
description = "AP Firmware v1";
|
||||
firmware = "spl", "u-boot";
|
||||
signature {
|
||||
algo = "sha1,rsa2048";
|
||||
key-name-hint = "dev";
|
||||
sign-images = "firmware";
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
state {
|
||||
type = "fill";
|
||||
size = <0x200>;
|
||||
};
|
||||
version {
|
||||
type = "text";
|
||||
text = "1.2.3";
|
||||
size = <0x200>;
|
||||
};
|
||||
fdtmap {
|
||||
};
|
||||
};
|
@ -64,7 +64,7 @@
|
||||
osd0 = "/osd";
|
||||
};
|
||||
|
||||
binman {
|
||||
binman: binman {
|
||||
};
|
||||
|
||||
config {
|
||||
@ -1707,3 +1707,7 @@
|
||||
|
||||
#include "sandbox_pmic.dtsi"
|
||||
#include "cros-ec-keyboard.dtsi"
|
||||
|
||||
#ifdef CONFIG_SANDBOX_VPL
|
||||
#include "sandbox_vpl.dtsi"
|
||||
#endif
|
||||
|
Loading…
Reference in New Issue
Block a user