Tom Rini | 6546112 | 2022-06-17 16:24:31 -0400 | [diff] [blame] | 1 | config NXP_ESBC |
| 2 | bool "NXP ESBC (secure boot) functionality" |
| 3 | help |
| 4 | Enable Freescale Secure Boot feature. Normally selected by defconfig. |
| 5 | If unsure, do not change. |
| 6 | |
| 7 | menu "Chain of trust / secure boot options" |
Udit Agarwal | 22ec238 | 2019-11-07 16:11:32 +0000 | [diff] [blame] | 8 | depends on !FIT_SIGNATURE && NXP_ESBC |
Tom Rini | 6546112 | 2022-06-17 16:24:31 -0400 | [diff] [blame] | 9 | |
| 10 | config CHAIN_OF_TRUST |
Tom Rini | a5c4d40 | 2017-03-01 16:51:58 -0500 | [diff] [blame] | 11 | select FSL_CAAM |
Gaurav Jain | bd50fd1 | 2022-06-09 16:32:15 +0530 | [diff] [blame] | 12 | select ARCH_MISC_INIT |
Tom Rini | 0b58c2e | 2022-06-16 14:04:39 -0400 | [diff] [blame] | 13 | select FSL_SEC_MON |
Ley Foon Tan | 48fcc4a | 2017-05-03 17:13:32 +0800 | [diff] [blame] | 14 | select SPL_BOARD_INIT if (ARM && SPL) |
Alexandru Gagniuc | 97464ff | 2021-09-02 19:54:19 -0500 | [diff] [blame] | 15 | select SPL_HASH if (ARM && SPL) |
Tom Rini | 5bdd919 | 2017-05-15 12:17:49 -0400 | [diff] [blame] | 16 | select SHA_HW_ACCEL |
| 17 | select SHA_PROG_HW_ACCEL |
Simon Glass | 73c18b4 | 2017-07-23 21:19:39 -0600 | [diff] [blame] | 18 | select ENV_IS_NOWHERE |
Sumit Garg | 13ad290 | 2018-01-09 01:27:46 +0530 | [diff] [blame] | 19 | select CMD_EXT4 if ARM |
| 20 | select CMD_EXT4_WRITE if ARM |
Tom Rini | 6546112 | 2022-06-17 16:24:31 -0400 | [diff] [blame] | 21 | imply CMD_BLOB |
| 22 | imply CMD_HASH if ARM |
| 23 | def_bool y |
Simon Glass | a6a9ea4 | 2017-05-17 03:25:16 -0600 | [diff] [blame] | 24 | |
| 25 | config CMD_ESBC_VALIDATE |
| 26 | bool "Enable the 'esbc_validate' and 'esbc_halt' commands" |
Tom Rini | aac187d | 2022-06-16 14:04:35 -0400 | [diff] [blame] | 27 | default y |
Simon Glass | a6a9ea4 | 2017-05-17 03:25:16 -0600 | [diff] [blame] | 28 | help |
| 29 | This option enables two commands used for secure booting: |
| 30 | |
| 31 | esbc_validate - validate signature using RSA verification |
| 32 | esbc_halt - put the core in spin loop (Secure Boot Only) |
Rajesh Bhagat | 241a3cc | 2018-01-17 16:13:04 +0530 | [diff] [blame] | 33 | |
Tom Rini | eb56a39 | 2022-06-16 14:04:37 -0400 | [diff] [blame] | 34 | config ESBC_HDR_LS |
| 35 | bool |
| 36 | |
| 37 | config ESBC_ADDR_64BIT |
| 38 | def_bool y |
| 39 | depends on ESBC_HDR_LS && FSL_LAYERSCAPE |
| 40 | help |
| 41 | For Layerscape based platforms, ESBC image Address in Header is 64bit. |
| 42 | |
Tom Rini | a166399 | 2022-06-16 14:04:40 -0400 | [diff] [blame] | 43 | config SYS_FSL_SFP_BE |
| 44 | def_bool y |
Tom Rini | 6546112 | 2022-06-17 16:24:31 -0400 | [diff] [blame] | 45 | depends on PPC || FSL_LSCH2 || ARCH_LS1021A |
Tom Rini | a166399 | 2022-06-16 14:04:40 -0400 | [diff] [blame] | 46 | |
| 47 | config SYS_FSL_SFP_LE |
| 48 | def_bool y |
Tom Rini | 6546112 | 2022-06-17 16:24:31 -0400 | [diff] [blame] | 49 | depends on !SYS_FSL_SFP_BE |
Tom Rini | a166399 | 2022-06-16 14:04:40 -0400 | [diff] [blame] | 50 | |
| 51 | choice |
| 52 | prompt "SFP IP revision" |
Tom Rini | a166399 | 2022-06-16 14:04:40 -0400 | [diff] [blame] | 53 | default SYS_FSL_SFP_VER_3_0 if PPC |
| 54 | default SYS_FSL_SFP_VER_3_4 |
| 55 | |
| 56 | config SYS_FSL_SFP_VER_3_0 |
| 57 | bool "SFP version 3.0" |
| 58 | |
| 59 | config SYS_FSL_SFP_VER_3_2 |
| 60 | bool "SFP version 3.2" |
| 61 | |
| 62 | config SYS_FSL_SFP_VER_3_4 |
| 63 | bool "SFP version 3.4" |
| 64 | |
| 65 | endchoice |
| 66 | |
Tom Rini | 27fcd31 | 2022-06-17 16:24:32 -0400 | [diff] [blame] | 67 | config SPL_UBOOT_KEY_HASH |
| 68 | string "Non-SRK key hash for U-Boot public/private key pair" |
| 69 | depends on SPL |
| 70 | default "" |
| 71 | help |
| 72 | Set the key hash for U-Boot here if public/private key pair used to |
| 73 | sign U-boot are different from the SRK hash put in the fuse. Example |
| 74 | of a key hash is |
| 75 | 41066b564c6ffcef40ccbc1e0a5d0d519604000c785d97bbefd25e4d288d1c8b. |
| 76 | Otherwise leave this empty. |
| 77 | |
Tom Rini | bf1dfd8 | 2022-06-17 16:24:34 -0400 | [diff] [blame] | 78 | if PPC |
| 79 | |
| 80 | config BOOTSCRIPT_COPY_RAM |
| 81 | bool "Secure boot copies boot script to RAM" |
| 82 | help |
| 83 | On systems that support chain of trust booting, a number of addresses |
| 84 | are required to set variables that are used in the copying and then |
| 85 | verification of different parts of the system. If enabled, the subsequent |
| 86 | options are for what location to use in each step. |
| 87 | |
| 88 | config BS_ADDR_DEVICE |
| 89 | hex "Address in RAM for bs_device" |
| 90 | depends on BOOTSCRIPT_COPY_RAM |
| 91 | |
| 92 | config BS_SIZE |
| 93 | hex "The size of bs_size which is the amount read from bs_device" |
| 94 | depends on BOOTSCRIPT_COPY_RAM |
| 95 | |
| 96 | config BS_ADDR_RAM |
| 97 | hex "Address in RAM for bs_ram" |
| 98 | depends on BOOTSCRIPT_COPY_RAM |
| 99 | |
| 100 | config BS_HDR_ADDR_DEVICE |
| 101 | hex "Address in RAM for bs_hdr_device" |
| 102 | depends on BOOTSCRIPT_COPY_RAM |
| 103 | |
| 104 | config BS_HDR_SIZE |
| 105 | hex "The size of bs_hdr_size which is the amount read from bs_hdr_device" |
| 106 | depends on BOOTSCRIPT_COPY_RAM |
| 107 | |
| 108 | config BS_HDR_ADDR_RAM |
| 109 | hex "Address in RAM for bs_hdr_ram" |
| 110 | depends on BOOTSCRIPT_COPY_RAM |
| 111 | |
| 112 | config BOOTSCRIPT_HDR_ADDR |
| 113 | hex "CONFIG_BOOTSCRIPT_HDR_ADDR" |
| 114 | default BS_ADDR_RAM if BOOTSCRIPT_COPY_RAM |
| 115 | |
| 116 | endif |
| 117 | |
Tom Rini | a166399 | 2022-06-16 14:04:40 -0400 | [diff] [blame] | 118 | config SYS_FSL_SRK_LE |
| 119 | def_bool y |
Tom Rini | 6546112 | 2022-06-17 16:24:31 -0400 | [diff] [blame] | 120 | depends on ARM |
Tom Rini | a166399 | 2022-06-16 14:04:40 -0400 | [diff] [blame] | 121 | |
| 122 | config KEY_REVOCATION |
| 123 | def_bool y |
Tom Rini | 6546112 | 2022-06-17 16:24:31 -0400 | [diff] [blame] | 124 | |
| 125 | endmenu |
| 126 | |
| 127 | comment "Other functionality shared between NXP SoCs" |
Tom Rini | a166399 | 2022-06-16 14:04:40 -0400 | [diff] [blame] | 128 | |
Tom Rini | b643ebd | 2022-03-24 17:17:58 -0400 | [diff] [blame] | 129 | config DEEP_SLEEP |
| 130 | bool "Enable SoC deep sleep feature" |
Tom Rini | aac187d | 2022-06-16 14:04:35 -0400 | [diff] [blame] | 131 | depends on ARCH_T1024 || ARCH_T1040 || ARCH_T1042 || ARCH_LS1021A |
| 132 | default y |
Tom Rini | b643ebd | 2022-03-24 17:17:58 -0400 | [diff] [blame] | 133 | help |
| 134 | Indicates this SoC supports deep sleep feature. If deep sleep is |
| 135 | supported, core will start to execute uboot when wakes up. |
| 136 | |
Tom Rini | 9d291f4 | 2022-06-20 08:07:44 -0400 | [diff] [blame] | 137 | config LAYERSCAPE_NS_ACCESS |
| 138 | bool "Layerscape non-secure access support" |
| 139 | depends on ARCH_LS1021A || FSL_LSCH2 |
| 140 | |
Tom Rini | 7485ebf6 | 2022-06-20 08:07:45 -0400 | [diff] [blame] | 141 | config PCIE1 |
| 142 | bool "PCIe controller #1" |
| 143 | depends on LAYERSCAPE_NS_ACCESS || PPC |
| 144 | |
| 145 | config PCIE2 |
| 146 | bool "PCIe controller #2" |
| 147 | depends on LAYERSCAPE_NS_ACCESS || PPC |
| 148 | |
| 149 | config PCIE3 |
| 150 | bool "PCIe controller #3" |
| 151 | depends on LAYERSCAPE_NS_ACCESS || PPC |
| 152 | |
| 153 | config PCIE4 |
| 154 | bool "PCIe controller #4" |
| 155 | depends on LAYERSCAPE_NS_ACCESS || PPC |
| 156 | |
Stephen Carlson | e36d49c | 2021-06-22 16:35:20 -0700 | [diff] [blame] | 157 | config FSL_USE_PCA9547_MUX |
| 158 | bool "Enable PCA9547 I2C Mux on Freescale boards" |
Tom Rini | aac187d | 2022-06-16 14:04:35 -0400 | [diff] [blame] | 159 | depends on PPC || ARCH_LS1021A || FSL_LSCH2 || FSL_LSCH3 |
Stephen Carlson | e36d49c | 2021-06-22 16:35:20 -0700 | [diff] [blame] | 160 | help |
| 161 | This option enables the PCA9547 I2C mux on Freescale boards. |
| 162 | |
Stephen Carlson | c3301a2 | 2021-02-08 11:11:29 +0100 | [diff] [blame] | 163 | config VID |
Stephen Carlson | c3301a2 | 2021-02-08 11:11:29 +0100 | [diff] [blame] | 164 | bool "Enable Freescale VID" |
Tom Rini | aac187d | 2022-06-16 14:04:35 -0400 | [diff] [blame] | 165 | depends on (PPC || ARCH_LS1021A || FSL_LSCH2 || FSL_LSCH3) && (I2C || DM_I2C) |
Stephen Carlson | c3301a2 | 2021-02-08 11:11:29 +0100 | [diff] [blame] | 166 | help |
| 167 | This option enables setting core voltage based on individual |
| 168 | values saved in SoC fuses. |
| 169 | |
Tom Rini | 89cdcab | 2021-12-12 22:12:31 -0500 | [diff] [blame] | 170 | config SPL_VID |
| 171 | bool "Enable Freescale VID in SPL" |
Tom Rini | aac187d | 2022-06-16 14:04:35 -0400 | [diff] [blame] | 172 | depends on (PPC || ARCH_LS1021A || FSL_LSCH2 || FSL_LSCH3) && (SPL_I2C || DM_SPL_I2C) |
Tom Rini | 89cdcab | 2021-12-12 22:12:31 -0500 | [diff] [blame] | 173 | help |
| 174 | This option enables setting core voltage based on individual |
| 175 | values saved in SoC fuses, in SPL. |
| 176 | |
| 177 | if VID || SPL_VID |
| 178 | |
| 179 | config VID_FLS_ENV |
| 180 | string "Environment variable for overriding VDD" |
| 181 | help |
| 182 | This option allows for specifying the environment variable |
| 183 | to check to override VDD information. |
| 184 | |
| 185 | config VOL_MONITOR_INA220 |
| 186 | bool "Enable the INA220 voltage monitor read" |
| 187 | help |
| 188 | This option enables INA220 voltage monitor read |
| 189 | functionality. It is used by the common VID driver. |
| 190 | |
| 191 | config VOL_MONITOR_IR36021_READ |
| 192 | bool "Enable the IR36021 voltage monitor read" |
| 193 | help |
| 194 | This option enables IR36021 voltage monitor read |
| 195 | functionality. It is used by the common VID driver. |
| 196 | |
| 197 | config VOL_MONITOR_IR36021_SET |
| 198 | bool "Enable the IR36021 voltage monitor set" |
| 199 | help |
| 200 | This option enables IR36021 voltage monitor set |
| 201 | functionality. It is used by the common VID driver. |
| 202 | |
Rajesh Bhagat | 241a3cc | 2018-01-17 16:13:04 +0530 | [diff] [blame] | 203 | config VOL_MONITOR_LTC3882_READ |
Rajesh Bhagat | 241a3cc | 2018-01-17 16:13:04 +0530 | [diff] [blame] | 204 | bool "Enable the LTC3882 voltage monitor read" |
Rajesh Bhagat | 241a3cc | 2018-01-17 16:13:04 +0530 | [diff] [blame] | 205 | help |
| 206 | This option enables LTC3882 voltage monitor read |
Stephen Carlson | c3301a2 | 2021-02-08 11:11:29 +0100 | [diff] [blame] | 207 | functionality. It is used by the common VID driver. |
Rajesh Bhagat | 241a3cc | 2018-01-17 16:13:04 +0530 | [diff] [blame] | 208 | |
| 209 | config VOL_MONITOR_LTC3882_SET |
Rajesh Bhagat | 241a3cc | 2018-01-17 16:13:04 +0530 | [diff] [blame] | 210 | bool "Enable the LTC3882 voltage monitor set" |
Rajesh Bhagat | 241a3cc | 2018-01-17 16:13:04 +0530 | [diff] [blame] | 211 | help |
| 212 | This option enables LTC3882 voltage monitor set |
Stephen Carlson | c3301a2 | 2021-02-08 11:11:29 +0100 | [diff] [blame] | 213 | functionality. It is used by the common VID driver. |
| 214 | |
| 215 | config VOL_MONITOR_ISL68233_READ |
Stephen Carlson | c3301a2 | 2021-02-08 11:11:29 +0100 | [diff] [blame] | 216 | bool "Enable the ISL68233 voltage monitor read" |
| 217 | help |
| 218 | This option enables ISL68233 voltage monitor read |
| 219 | functionality. It is used by the common VID driver. |
| 220 | |
| 221 | config VOL_MONITOR_ISL68233_SET |
Stephen Carlson | c3301a2 | 2021-02-08 11:11:29 +0100 | [diff] [blame] | 222 | bool "Enable the ISL68233 voltage monitor set" |
| 223 | help |
| 224 | This option enables ISL68233 voltage monitor set |
| 225 | functionality. It is used by the common VID driver. |
Tom Rini | 89cdcab | 2021-12-12 22:12:31 -0500 | [diff] [blame] | 226 | |
| 227 | endif |
Tom Rini | e24547a | 2022-03-30 18:07:32 -0400 | [diff] [blame] | 228 | |
| 229 | config FSL_QIXIS |
| 230 | bool "Enable QIXIS support" |
Tom Rini | aac187d | 2022-06-16 14:04:35 -0400 | [diff] [blame] | 231 | depends on PPC || ARCH_LS1021A || FSL_LSCH2 || FSL_LSCH3 |
Tom Rini | e24547a | 2022-03-30 18:07:32 -0400 | [diff] [blame] | 232 | |
| 233 | config QIXIS_I2C_ACCESS |
| 234 | bool "Access to QIXIS is over i2c" |
| 235 | depends on FSL_QIXIS |
| 236 | default y |
Tom Rini | 4171301 | 2022-06-08 08:24:28 -0400 | [diff] [blame] | 237 | |
| 238 | config HAS_FSL_DR_USB |
| 239 | def_bool y |
| 240 | depends on USB_EHCI_HCD && PPC |