Patrick Delaunay | 85b5397 | 2018-03-12 10:46:10 +0100 | [diff] [blame] | 1 | if ARCH_STM32MP |
| 2 | |
| 3 | config SPL |
Patrick Delaunay | 4c5821d | 2020-07-24 11:13:31 +0200 | [diff] [blame] | 4 | select SPL_BOARD_INIT |
Patrick Delaunay | 85b5397 | 2018-03-12 10:46:10 +0100 | [diff] [blame] | 5 | select SPL_CLK |
| 6 | select SPL_DM |
| 7 | select SPL_DM_SEQ_ALIAS |
Simon Glass | 284cb9c | 2021-07-10 21:14:31 -0600 | [diff] [blame] | 8 | select SPL_DRIVERS_MISC |
Patrick Delaunay | 85b5397 | 2018-03-12 10:46:10 +0100 | [diff] [blame] | 9 | select SPL_FRAMEWORK |
Simon Glass | 035939e | 2021-07-10 21:14:30 -0600 | [diff] [blame] | 10 | select SPL_GPIO |
Patrick Delaunay | 85b5397 | 2018-03-12 10:46:10 +0100 | [diff] [blame] | 11 | select SPL_LIBCOMMON_SUPPORT |
| 12 | select SPL_LIBGENERIC_SUPPORT |
| 13 | select SPL_OF_CONTROL |
| 14 | select SPL_OF_TRANSLATE |
| 15 | select SPL_PINCTRL |
| 16 | select SPL_REGMAP |
Ley Foon Tan | 9caf712 | 2018-06-14 18:45:19 +0800 | [diff] [blame] | 17 | select SPL_DM_RESET |
Patrick Delaunay | 85b5397 | 2018-03-12 10:46:10 +0100 | [diff] [blame] | 18 | select SPL_SERIAL_SUPPORT |
| 19 | select SPL_SYSCON |
Simon Glass | 1ba1d4e | 2021-07-10 21:14:28 -0600 | [diff] [blame] | 20 | select SPL_WATCHDOG if WATCHDOG |
Patrick Delaunay | f860020 | 2019-04-18 17:32:47 +0200 | [diff] [blame] | 21 | imply BOOTSTAGE_STASH if SPL_BOOTSTAGE |
| 22 | imply SPL_BOOTSTAGE if BOOTSTAGE |
Patrick Delaunay | aa4e685 | 2019-02-27 17:01:14 +0100 | [diff] [blame] | 23 | imply SPL_DISPLAY_PRINT |
Patrick Delaunay | 85b5397 | 2018-03-12 10:46:10 +0100 | [diff] [blame] | 24 | imply SPL_LIBDISK_SUPPORT |
Jagan Teki | 7dccecd | 2021-03-16 21:52:02 +0530 | [diff] [blame] | 25 | imply SPL_SPI_LOAD if SPL_SPI_SUPPORT |
Patrick Delaunay | 85b5397 | 2018-03-12 10:46:10 +0100 | [diff] [blame] | 26 | |
| 27 | config SYS_SOC |
| 28 | default "stm32mp" |
| 29 | |
Patrick Delaunay | 7e517c6 | 2019-04-18 17:32:36 +0200 | [diff] [blame] | 30 | config SYS_MALLOC_LEN |
| 31 | default 0x2000000 |
| 32 | |
Patrick Delaunay | 088b676 | 2019-04-18 17:32:37 +0200 | [diff] [blame] | 33 | config ENV_SIZE |
Patrice Chotard | d83bba4 | 2019-05-07 18:40:47 +0200 | [diff] [blame] | 34 | default 0x2000 |
Patrick Delaunay | 088b676 | 2019-04-18 17:32:37 +0200 | [diff] [blame] | 35 | |
Patrick Delaunay | 310aa8a | 2020-01-13 15:17:42 +0100 | [diff] [blame] | 36 | config STM32MP15x |
| 37 | bool "Support STMicroelectronics STM32MP15x Soc" |
Patrick Delaunay | f8fe21d | 2020-04-01 09:07:33 +0200 | [diff] [blame] | 38 | select ARCH_SUPPORT_PSCI if !TFABOOT |
| 39 | select ARM_SMCCC if TFABOOT |
Lokesh Vutla | 81b1a67 | 2018-04-26 18:21:26 +0530 | [diff] [blame] | 40 | select CPU_V7A |
Patrick Delaunay | f8fe21d | 2020-04-01 09:07:33 +0200 | [diff] [blame] | 41 | select CPU_V7_HAS_NONSEC if !TFABOOT |
Patrick Delaunay | e020737 | 2018-04-16 10:13:24 +0200 | [diff] [blame] | 42 | select CPU_V7_HAS_VIRT |
Patrick Delaunay | de98cbf | 2019-07-02 13:26:07 +0200 | [diff] [blame] | 43 | select OF_BOARD_SETUP |
Patrick Delaunay | 85b5397 | 2018-03-12 10:46:10 +0100 | [diff] [blame] | 44 | select PINCTRL_STM32 |
Patrick Delaunay | b139a5b | 2018-07-09 15:17:20 +0200 | [diff] [blame] | 45 | select STM32_RCC |
Patrick Delaunay | 85b5397 | 2018-03-12 10:46:10 +0100 | [diff] [blame] | 46 | select STM32_RESET |
Patrick Delaunay | 4368e56 | 2019-07-30 19:16:25 +0200 | [diff] [blame] | 47 | select STM32_SERIAL |
Andre Przywara | 7b16925 | 2018-04-12 04:24:46 +0300 | [diff] [blame] | 48 | select SYS_ARCH_TIMER |
Patrick Delaunay | 59d0da1 | 2020-07-02 17:43:45 +0200 | [diff] [blame] | 49 | imply CMD_NVEDIT_INFO |
Patrick Delaunay | f8fe21d | 2020-04-01 09:07:33 +0200 | [diff] [blame] | 50 | imply SYSRESET_PSCI if TFABOOT |
| 51 | imply SYSRESET_SYSCON if !TFABOOT |
Patrick Delaunay | 310aa8a | 2020-01-13 15:17:42 +0100 | [diff] [blame] | 52 | help |
| 53 | support of STMicroelectronics SOC STM32MP15x family |
| 54 | STM32MP157, STM32MP153 or STM32MP151 |
| 55 | STMicroelectronics MPU with core ARMv7 |
| 56 | dual core A7 for STM32MP157/3, monocore for STM32MP151 |
| 57 | target all the STMicroelectronics board with SOC STM32MP1 family |
| 58 | |
| 59 | choice |
| 60 | prompt "STM32MP15x board select" |
| 61 | optional |
| 62 | |
| 63 | config TARGET_ST_STM32MP15x |
| 64 | bool "STMicroelectronics STM32MP15x boards" |
| 65 | select STM32MP15x |
Patrick Delaunay | 9c07f4a | 2019-04-18 17:32:45 +0200 | [diff] [blame] | 66 | imply BOOTCOUNT_LIMIT |
Patrick Delaunay | 66111eb | 2020-03-10 10:15:03 +0100 | [diff] [blame] | 67 | imply BOOTSTAGE |
Patrick Delaunay | 9c07f4a | 2019-04-18 17:32:45 +0200 | [diff] [blame] | 68 | imply CMD_BOOTCOUNT |
Patrick Delaunay | 66111eb | 2020-03-10 10:15:03 +0100 | [diff] [blame] | 69 | imply CMD_BOOTSTAGE |
Patrick Delaunay | f97beae | 2019-12-03 09:38:58 +0100 | [diff] [blame] | 70 | imply CMD_CLS if CMD_BMP |
Patrick Delaunay | 28a4609 | 2019-07-30 19:16:26 +0200 | [diff] [blame] | 71 | imply DISABLE_CONSOLE |
Patrick Delaunay | fcb4991 | 2019-07-30 19:16:23 +0200 | [diff] [blame] | 72 | imply PRE_CONSOLE_BUFFER |
Patrick Delaunay | 887d9e4 | 2019-07-30 19:16:22 +0200 | [diff] [blame] | 73 | imply SILENT_CONSOLE |
Patrick Delaunay | 85b5397 | 2018-03-12 10:46:10 +0100 | [diff] [blame] | 74 | help |
Patrick Delaunay | 310aa8a | 2020-01-13 15:17:42 +0100 | [diff] [blame] | 75 | target the STMicroelectronics board with SOC STM32MP15x |
| 76 | managed by board/st/stm32mp1: |
| 77 | Evalulation board (EV1) or Discovery board (DK1 and DK2). |
| 78 | The difference between board are managed with devicetree |
| 79 | |
Jagan Teki | 6cd3dc9 | 2021-03-16 21:52:06 +0530 | [diff] [blame] | 80 | config TARGET_MICROGEA_STM32MP1 |
| 81 | bool "Engicam MicroGEA STM32MP1 SOM" |
| 82 | select STM32MP15x |
| 83 | imply BOOTCOUNT_LIMIT |
| 84 | imply BOOTSTAGE |
| 85 | imply CMD_BOOTCOUNT |
| 86 | imply CMD_BOOTSTAGE |
| 87 | imply CMD_CLS if CMD_BMP |
| 88 | imply DISABLE_CONSOLE |
| 89 | imply PRE_CONSOLE_BUFFER |
| 90 | imply SILENT_CONSOLE |
| 91 | help |
| 92 | MicroGEA STM32MP1 is a STM32MP157A based Micro SOM. |
| 93 | |
| 94 | MicroGEA STM32MP1 MicroDev 2.0: |
| 95 | * MicroDev 2.0 is a general purpose miniature carrier board with CAN, |
| 96 | LTE and LVDS panel interfaces. |
| 97 | * MicroGEA STM32MP1 needs to mount on top of this MicroDev 2.0 board |
| 98 | for creating complete MicroGEA STM32MP1 MicroDev 2.0 Carrier board. |
| 99 | |
Jagan Teki | 46f44b5 | 2021-03-16 21:52:07 +0530 | [diff] [blame] | 100 | MicroGEA STM32MP1 MicroDev 2.0 7" OF: |
| 101 | * 7" OF is a capacitive touch 7" Open Frame panel solutions with LVDS |
| 102 | panel and toucscreen. |
| 103 | * MicroGEA STM32MP1 needs to mount on top of MicroDev 2.0 board with |
| 104 | pluged 7" OF for creating complete MicroGEA STM32MP1 MicroDev 2.0 7" |
| 105 | Open Frame Solution board. |
| 106 | |
Jagan Teki | c0f218b | 2021-03-16 21:52:03 +0530 | [diff] [blame] | 107 | config TARGET_ICORE_STM32MP1 |
| 108 | bool "Engicam i.Core STM32MP1 SOM" |
| 109 | select STM32MP15x |
| 110 | imply BOOTCOUNT_LIMIT |
| 111 | imply BOOTSTAGE |
| 112 | imply CMD_BOOTCOUNT |
| 113 | imply CMD_BOOTSTAGE |
| 114 | imply CMD_CLS if CMD_BMP |
| 115 | imply DISABLE_CONSOLE |
| 116 | imply PRE_CONSOLE_BUFFER |
| 117 | imply SILENT_CONSOLE |
| 118 | help |
| 119 | i.Core STM32MP1 is an EDIMM SOM based on STM32MP157A. |
| 120 | |
| 121 | i.Core STM32MP1 EDIMM2.2: |
| 122 | * EDIMM2.2 is a Form Factor Capacitive Evaluation Board. |
| 123 | * i.Core STM32MP1 needs to mount on top of EDIMM2.2 for |
| 124 | creating complete i.Core STM32MP1 EDIMM2.2 Starter Kit. |
| 125 | |
Jagan Teki | 4259785 | 2021-03-16 21:52:04 +0530 | [diff] [blame] | 126 | i.Core STM32MP1 C.TOUCH 2.0 |
| 127 | * C.TOUCH 2.0 is a general purpose Carrier board. |
| 128 | * i.Core STM32MP1 needs to mount on top of this Carrier board |
| 129 | for creating complete i.Core STM32MP1 C.TOUCH 2.0 board. |
| 130 | |
Marek Vasut | 5ff0529 | 2020-01-24 18:39:16 +0100 | [diff] [blame] | 131 | config TARGET_DH_STM32MP1_PDK2 |
| 132 | bool "DH STM32MP1 PDK2" |
| 133 | select STM32MP15x |
| 134 | imply BOOTCOUNT_LIMIT |
| 135 | imply CMD_BOOTCOUNT |
| 136 | help |
| 137 | Target the DH PDK2 development kit with STM32MP15x SoM. |
| 138 | |
Patrick Delaunay | 310aa8a | 2020-01-13 15:17:42 +0100 | [diff] [blame] | 139 | endchoice |
Patrick Delaunay | 85b5397 | 2018-03-12 10:46:10 +0100 | [diff] [blame] | 140 | |
| 141 | config SYS_TEXT_BASE |
Patrick Delaunay | 85b5397 | 2018-03-12 10:46:10 +0100 | [diff] [blame] | 142 | default 0xC0100000 |
Patrick Delaunay | 85b5397 | 2018-03-12 10:46:10 +0100 | [diff] [blame] | 143 | |
Patrick Delaunay | 6d3cbf3 | 2019-02-27 17:01:15 +0100 | [diff] [blame] | 144 | config NR_DRAM_BANKS |
| 145 | default 1 |
| 146 | |
Patrick Delaunay | ab7d644 | 2020-09-04 12:55:19 +0200 | [diff] [blame] | 147 | config DDR_CACHEABLE_SIZE |
| 148 | hex "Size of the DDR marked cacheable in pre-reloc stage" |
| 149 | default 0x10000000 if TFABOOT |
| 150 | default 0x40000000 |
| 151 | help |
| 152 | Define the size of the DDR marked as cacheable in U-Boot |
| 153 | pre-reloc stage. |
| 154 | This option can be useful to avoid speculatif access |
| 155 | to secured area of DDR used by TF-A or OP-TEE before U-Boot |
| 156 | initialization. |
| 157 | The areas marked "no-map" in device tree should be located |
| 158 | before this limit: STM32_DDR_BASE + DDR_CACHEABLE_SIZE. |
| 159 | |
Patrick Delaunay | fc69c68 | 2018-03-20 10:54:54 +0100 | [diff] [blame] | 160 | config SYS_MMCSD_RAW_MODE_U_BOOT_PARTITION_MMC2 |
| 161 | hex "Partition on MMC2 to use to load U-Boot from" |
| 162 | depends on SYS_MMCSD_RAW_MODE_U_BOOT_USE_PARTITION |
| 163 | default 1 |
| 164 | help |
| 165 | Partition on the second MMC to load U-Boot from when the MMC is being |
| 166 | used in raw mode |
| 167 | |
Patrick Delaunay | 43f214c | 2019-07-05 17:20:15 +0200 | [diff] [blame] | 168 | config STM32_ETZPC |
| 169 | bool "STM32 Extended TrustZone Protection" |
Patrick Delaunay | 3a6e387 | 2020-03-10 16:05:43 +0100 | [diff] [blame] | 170 | depends on STM32MP15x |
Patrick Delaunay | 43f214c | 2019-07-05 17:20:15 +0200 | [diff] [blame] | 171 | default y |
| 172 | help |
| 173 | Say y to enable STM32 Extended TrustZone Protection |
| 174 | |
Patrick Delaunay | 109d13f | 2019-07-05 17:20:17 +0200 | [diff] [blame] | 175 | config CMD_STM32KEY |
| 176 | bool "command stm32key to fuse public key hash" |
Patrick Delaunay | d6c098a | 2021-06-28 14:55:57 +0200 | [diff] [blame] | 177 | default n |
Patrick Delaunay | 109d13f | 2019-07-05 17:20:17 +0200 | [diff] [blame] | 178 | help |
| 179 | fuse public key hash in corresponding fuse used to authenticate |
| 180 | binary. |
Patrick Delaunay | d6c098a | 2021-06-28 14:55:57 +0200 | [diff] [blame] | 181 | This command is used to evaluate the secure boot on stm32mp SOC, |
| 182 | it is deactivated by default in real products. |
Patrick Delaunay | 109d13f | 2019-07-05 17:20:17 +0200 | [diff] [blame] | 183 | |
Patrick Delaunay | fcb4991 | 2019-07-30 19:16:23 +0200 | [diff] [blame] | 184 | config PRE_CON_BUF_ADDR |
| 185 | default 0xC02FF000 |
| 186 | |
| 187 | config PRE_CON_BUF_SZ |
| 188 | default 4096 |
| 189 | |
Patrick Delaunay | f860020 | 2019-04-18 17:32:47 +0200 | [diff] [blame] | 190 | config BOOTSTAGE_STASH_ADDR |
| 191 | default 0xC3000000 |
| 192 | |
Patrick Delaunay | 9c07f4a | 2019-04-18 17:32:45 +0200 | [diff] [blame] | 193 | if BOOTCOUNT_LIMIT |
| 194 | config SYS_BOOTCOUNT_SINGLEWORD |
| 195 | default y |
| 196 | |
| 197 | # TAMP_BOOTCOUNT = TAMP_BACKUP_REGISTER(21) |
| 198 | config SYS_BOOTCOUNT_ADDR |
| 199 | default 0x5C00A154 |
| 200 | endif |
| 201 | |
Patrick Delaunay | 82168e8 | 2018-05-17 14:50:46 +0200 | [diff] [blame] | 202 | if DEBUG_UART |
| 203 | |
| 204 | config DEBUG_UART_BOARD_INIT |
| 205 | default y |
| 206 | |
| 207 | # debug on UART4 by default |
| 208 | config DEBUG_UART_BASE |
| 209 | default 0x40010000 |
| 210 | |
| 211 | # clock source is HSI on reset |
| 212 | config DEBUG_UART_CLOCK |
| 213 | default 64000000 |
| 214 | endif |
| 215 | |
Patrick Delaunay | 0440d86 | 2021-02-25 13:37:00 +0100 | [diff] [blame] | 216 | source "arch/arm/mach-stm32mp/cmd_stm32prog/Kconfig" |
Marek Vasut | 5ff0529 | 2020-01-24 18:39:16 +0100 | [diff] [blame] | 217 | source "board/dhelectronics/dh_stm32mp1/Kconfig" |
Jagan Teki | c0f218b | 2021-03-16 21:52:03 +0530 | [diff] [blame] | 218 | source "board/engicam/stm32mp1/Kconfig" |
| 219 | source "board/st/stm32mp1/Kconfig" |
Patrick Delaunay | 6d3cbf3 | 2019-02-27 17:01:15 +0100 | [diff] [blame] | 220 | |
Patrick Delaunay | 85b5397 | 2018-03-12 10:46:10 +0100 | [diff] [blame] | 221 | endif |