blob: 3922241be005c234230d850c4c0f6ce5d52e3dd2 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
gaurav ranaf79323c2015-03-10 14:08:50 +05302/*
3 * Copyright 2015 Freescale Semiconductor, Inc.
gaurav ranaf79323c2015-03-10 14:08:50 +05304 */
5
Aneesh Bansal43104702016-01-22 16:37:24 +05306#ifndef __CONFIG_FSL_CHAIN_TRUST_H
7#define __CONFIG_FSL_CHAIN_TRUST_H
gaurav ranaf79323c2015-03-10 14:08:50 +05308
Simon Glassfb64e362020-05-10 11:40:09 -06009#include <linux/stringify.h>
10
Aneesh Bansal43104702016-01-22 16:37:24 +053011#ifdef CONFIG_CHAIN_OF_TRUST
12
gaurav ranaf79323c2015-03-10 14:08:50 +053013#ifndef CONFIG_EXTRA_ENV
14#define CONFIG_EXTRA_ENV ""
15#endif
16
17/*
18 * Control should not reach back to uboot after validation of images
19 * for secure boot flow and therefore bootscript should have
20 * the bootm command. If control reaches back to uboot anyhow
21 * after validating images, core should just spin.
22 */
23
24/*
25 * Define the key hash for boot script here if public/private key pair used to
26 * sign bootscript are different from the SRK hash put in the fuse
27 * Example of defining KEY_HASH is
28 * #define CONFIG_BOOTSCRIPT_KEY_HASH \
29 * "41066b564c6ffcef40ccbc1e0a5d0d519604000c785d97bbefd25e4d288d1c8b"
30 */
31
Sam Protsenkobd7bffe2017-08-14 20:22:17 +030032#ifdef CONFIG_USE_BOOTARGS
Saksham Jain25484692016-03-23 16:24:43 +053033#define CONFIG_SET_BOOTARGS "setenv bootargs \'" CONFIG_BOOTARGS" \';"
34#else
35#define CONFIG_SET_BOOTARGS "setenv bootargs \'root=/dev/ram " \
36 "rw console=ttyS0,115200 ramdisk_size=600000\';"
37#endif
38
39
gaurav ranaf79323c2015-03-10 14:08:50 +053040#ifdef CONFIG_BOOTSCRIPT_KEY_HASH
41#define CONFIG_SECBOOT \
42 "setenv bs_hdraddr " __stringify(CONFIG_BOOTSCRIPT_HDR_ADDR)";" \
Saksham Jain25484692016-03-23 16:24:43 +053043 CONFIG_SET_BOOTARGS \
gaurav ranaf79323c2015-03-10 14:08:50 +053044 CONFIG_EXTRA_ENV \
45 "esbc_validate $bs_hdraddr " \
46 __stringify(CONFIG_BOOTSCRIPT_KEY_HASH)";" \
47 "source $img_addr;" \
48 "esbc_halt\0"
49#else
50#define CONFIG_SECBOOT \
51 "setenv bs_hdraddr " __stringify(CONFIG_BOOTSCRIPT_HDR_ADDR)";" \
Saksham Jain25484692016-03-23 16:24:43 +053052 CONFIG_SET_BOOTARGS \
gaurav ranaf79323c2015-03-10 14:08:50 +053053 CONFIG_EXTRA_ENV \
54 "esbc_validate $bs_hdraddr;" \
55 "source $img_addr;" \
56 "esbc_halt\0"
57#endif
58
Aneesh Bansalb69061d2015-06-16 10:36:43 +053059#ifdef CONFIG_BOOTSCRIPT_COPY_RAM
60#define CONFIG_BS_COPY_ENV \
61 "setenv bs_hdr_ram " __stringify(CONFIG_BS_HDR_ADDR_RAM)";" \
Sumit Garg45642832016-06-14 13:52:39 -040062 "setenv bs_hdr_device " __stringify(CONFIG_BS_HDR_ADDR_DEVICE)";" \
Aneesh Bansalb69061d2015-06-16 10:36:43 +053063 "setenv bs_hdr_size " __stringify(CONFIG_BS_HDR_SIZE)";" \
64 "setenv bs_ram " __stringify(CONFIG_BS_ADDR_RAM)";" \
Sumit Garg45642832016-06-14 13:52:39 -040065 "setenv bs_device " __stringify(CONFIG_BS_ADDR_DEVICE)";" \
Aneesh Bansalb69061d2015-06-16 10:36:43 +053066 "setenv bs_size " __stringify(CONFIG_BS_SIZE)";"
67
Saksham Jain503eab92016-03-23 16:24:37 +053068/* For secure boot flow, default environment used will be used */
Ruchika Guptaba688752017-04-17 18:07:18 +053069#if defined(CONFIG_SYS_RAMBOOT) || defined(CONFIG_NAND_BOOT) || \
70 defined(CONFIG_SD_BOOT)
71#if defined(CONFIG_RAMBOOT_NAND) || defined(CONFIG_NAND_BOOT)
Aneesh Bansalb69061d2015-06-16 10:36:43 +053072#define CONFIG_BS_COPY_CMD \
Sumit Garg45642832016-06-14 13:52:39 -040073 "nand read $bs_hdr_ram $bs_hdr_device $bs_hdr_size ;" \
74 "nand read $bs_ram $bs_device $bs_size ;"
Sumit Garg45642832016-06-14 13:52:39 -040075#elif defined(CONFIG_SD_BOOT)
76#define CONFIG_BS_COPY_CMD \
77 "mmc read $bs_hdr_ram $bs_hdr_device $bs_hdr_size ;" \
78 "mmc read $bs_ram $bs_device $bs_size ;"
Ruchika Guptaba688752017-04-17 18:07:18 +053079#endif
80#else
Saksham Jain503eab92016-03-23 16:24:37 +053081#define CONFIG_BS_COPY_CMD \
Sumit Garg45642832016-06-14 13:52:39 -040082 "cp.b $bs_hdr_device $bs_hdr_ram $bs_hdr_size ;" \
83 "cp.b $bs_device $bs_ram $bs_size ;"
gaurav ranaf79323c2015-03-10 14:08:50 +053084#endif
Saksham Jain503eab92016-03-23 16:24:37 +053085#endif /* CONFIG_BOOTSCRIPT_COPY_RAM */
gaurav ranaf79323c2015-03-10 14:08:50 +053086
Aneesh Bansalb69061d2015-06-16 10:36:43 +053087#ifndef CONFIG_BS_COPY_ENV
88#define CONFIG_BS_COPY_ENV
89#endif
90
91#ifndef CONFIG_BS_COPY_CMD
92#define CONFIG_BS_COPY_CMD
93#endif
94
Aneesh Bansal43104702016-01-22 16:37:24 +053095#define CONFIG_CHAIN_BOOT_CMD CONFIG_BS_COPY_ENV \
Aneesh Bansalb69061d2015-06-16 10:36:43 +053096 CONFIG_BS_COPY_CMD \
97 CONFIG_SECBOOT
gaurav ranaf79323c2015-03-10 14:08:50 +053098
99#endif
100#endif