arm64: ls1046ardb: Add distro secure boot support

Enable validation of boot.scr script prior to its execution dependent
on "secureboot" flag in environment. Disable fall back option to
qspi boot in case of secure boot. Also enable "secureboot=y" flag
in environment for ARM based platforms instead of bootcmd.

Signed-off-by: Sumit Garg <sumit.garg@nxp.com>
Tested-by: Vinitha Pillai <vinitha.pillai@nxp.com>
Reviewed-by: York Sun <york.sun@nxp.com>
This commit is contained in:
Sumit Garg 2017-06-06 20:50:29 +05:30 committed by York Sun
parent 76bbf1c634
commit f7b75f8b34
4 changed files with 22 additions and 1 deletions

View File

@ -36,3 +36,4 @@ CONFIG_FSL_QSPI=y
CONFIG_USB=y CONFIG_USB=y
CONFIG_DM_USB=y CONFIG_DM_USB=y
CONFIG_RSA=y CONFIG_RSA=y
CONFIG_DISTRO_DEFAULTS=y

View File

@ -44,3 +44,4 @@ CONFIG_USB=y
CONFIG_DM_USB=y CONFIG_DM_USB=y
CONFIG_RSA=y CONFIG_RSA=y
CONFIG_SPL_RSA=y CONFIG_SPL_RSA=y
CONFIG_DISTRO_DEFAULTS=y

View File

@ -220,9 +220,11 @@
"fdt_addr=0x64f00000\0" \ "fdt_addr=0x64f00000\0" \
"kernel_addr=0x65000000\0" \ "kernel_addr=0x65000000\0" \
"scriptaddr=0x80000000\0" \ "scriptaddr=0x80000000\0" \
"scripthdraddr=0x80080000\0" \
"fdtheader_addr_r=0x80100000\0" \ "fdtheader_addr_r=0x80100000\0" \
"kernelheader_addr_r=0x80200000\0" \ "kernelheader_addr_r=0x80200000\0" \
"load_addr=0xa0000000\0" \ "load_addr=0xa0000000\0" \
"kernel_addr_r=0x81000000\0" \
"fdt_addr_r=0x90000000\0" \ "fdt_addr_r=0x90000000\0" \
"ramdisk_addr_r=0xa0000000\0" \ "ramdisk_addr_r=0xa0000000\0" \
"kernel_start=0x1000000\0" \ "kernel_start=0x1000000\0" \
@ -232,6 +234,7 @@
MTDPARTS_DEFAULT "\0" \ MTDPARTS_DEFAULT "\0" \
BOOTENV \ BOOTENV \
"boot_scripts=ls1046ardb_boot.scr\0" \ "boot_scripts=ls1046ardb_boot.scr\0" \
"boot_script_hdr=hdr_ls1046ardb_bs.out\0" \
"scan_dev_for_boot_part=" \ "scan_dev_for_boot_part=" \
"part list ${devtype} ${devnum} devplist; " \ "part list ${devtype} ${devnum} devplist; " \
"env exists devplist || setenv devplist 1; " \ "env exists devplist || setenv devplist 1; " \
@ -242,6 +245,21 @@
"run scan_dev_for_boot; " \ "run scan_dev_for_boot; " \
"fi; " \ "fi; " \
"done\0" \ "done\0" \
"scan_dev_for_boot=" \
"echo Scanning ${devtype} " \
"${devnum}:${distro_bootpart}...; " \
"for prefix in ${boot_prefixes}; do " \
"run scan_dev_for_scripts; " \
"done;" \
"\0" \
"boot_a_script=" \
"load ${devtype} ${devnum}:${distro_bootpart} " \
"${scriptaddr} ${prefix}${script}; " \
"env exists secureboot && load ${devtype} " \
"${devnum}:${distro_bootpart} " \
"${scripthdraddr} ${prefix}${boot_script_hdr} " \
"&& esbc_validate ${scripthdraddr};" \
"source ${scriptaddr}\0" \
"installer=load mmc 0:2 $load_addr " \ "installer=load mmc 0:2 $load_addr " \
"/flex_installer_arm64.itb; " \ "/flex_installer_arm64.itb; " \
"bootm $load_addr#ls1046ardb\0" \ "bootm $load_addr#ls1046ardb\0" \

View File

@ -241,7 +241,8 @@
#ifndef SPL_NO_MISC #ifndef SPL_NO_MISC
#undef CONFIG_BOOTCOMMAND #undef CONFIG_BOOTCOMMAND
#define CONFIG_BOOTCOMMAND "run distro_bootcmd;run qspi_bootcmd" #define CONFIG_BOOTCOMMAND "run distro_bootcmd; env exists secureboot" \
"&& esbc_halt; run qspi_bootcmd;"
#define MTDPARTS_DEFAULT "mtdparts=1550000.quadspi:1m(rcw)," \ #define MTDPARTS_DEFAULT "mtdparts=1550000.quadspi:1m(rcw)," \
"15m(u-boot),48m(kernel.itb);" \ "15m(u-boot),48m(kernel.itb);" \
"7e800000.flash:16m(nand_uboot)," \ "7e800000.flash:16m(nand_uboot)," \