blob: c80d8587b14935bfe6854122bdafcd382c0154d4 [file] [log] [blame]
Stefan Roesec3d89142015-08-25 13:18:38 +02001if ARCH_MVEBU
2
Mario Sixa1b6b0a2017-01-11 16:01:00 +01003config HAVE_MVEBU_EFUSE
4 bool
Mario Sixa1b6b0a2017-01-11 16:01:00 +01005
Stefan Roesef61aefc2016-05-17 15:00:30 +02006config ARMADA_32BIT
7 bool
Michal Simek58008cb2018-07-23 15:55:15 +02008 select BOARD_EARLY_INIT_F
Lokesh Vutlaacf15002018-04-26 18:21:26 +05309 select CPU_V7A
Stefan Roese237b6292019-04-11 08:58:32 +020010 select SPL_DM if SPL
11 select SPL_DM_SEQ_ALIAS if SPL
12 select SPL_OF_CONTROL if SPL
Tom Rini7609e022021-10-15 10:54:41 -040013 select SPL_SKIP_LOWLEVEL_INIT if SPL
Stefan Roese237b6292019-04-11 08:58:32 +020014 select SPL_SIMPLE_BUS if SPL
Michal Simek58008cb2018-07-23 15:55:15 +020015 select SUPPORT_SPL
Philip Oberfichtner11168882022-08-17 15:07:12 +020016 select SYS_L2_PL310 if !SYS_L2CACHE_OFF
Stefan Roesef2100f62019-04-12 16:42:28 +020017 select TRANSLATION_OFFSET
Pali Rohár2975bba2022-04-06 16:20:20 +020018 select SPL_SYS_NO_VECTOR_TABLE if SPL
Pali Rohár5bb2c552022-05-06 11:05:14 +020019 select ARCH_VERY_EARLY_INIT
Stefan Roesef61aefc2016-05-17 15:00:30 +020020
Stefan Roesef61aefc2016-05-17 15:00:30 +020021# ARMv7 SoCs...
Stefan Roese606576d2016-01-29 09:14:54 +010022config ARMADA_375
23 bool
Stefan Roesef61aefc2016-05-17 15:00:30 +020024 select ARMADA_32BIT
Stefan Roese606576d2016-01-29 09:14:54 +010025
Stefan Roese81e33f42015-12-21 13:56:33 +010026config ARMADA_38X
27 bool
Stefan Roesef61aefc2016-05-17 15:00:30 +020028 select ARMADA_32BIT
Mario Sixa1b6b0a2017-01-11 16:01:00 +010029 select HAVE_MVEBU_EFUSE
Stefan Roese81e33f42015-12-21 13:56:33 +010030
Joshua Scott28f0cbc2020-11-09 10:14:08 +130031config ARMADA_38X_HS_IMPEDANCE_THRESH
32 hex "Armada 38x USB 2.0 High-Speed Impedance Threshold (0x0 - 0x7)"
33 depends on ARMADA_38X
34 default 0x6
35 range 0x0 0x7
36
Stefan Roese81e33f42015-12-21 13:56:33 +010037config ARMADA_XP
38 bool
Stefan Roesef61aefc2016-05-17 15:00:30 +020039 select ARMADA_32BIT
Stefan Roese81e33f42015-12-21 13:56:33 +010040
Stefan Roesef61aefc2016-05-17 15:00:30 +020041# ARMv8 SoCs...
42config ARMADA_3700
43 bool
44 select ARM64
Pali Rohár10154b82022-02-23 14:15:45 +010045 select HAVE_MVEBU_EFUSE
Stefan Roesef61aefc2016-05-17 15:00:30 +020046
Stefan Roese21b29fc2016-05-25 08:13:45 +020047# Armada 7K and 8K are very similar - use only one Kconfig symbol for both
48config ARMADA_8K
49 bool
50 select ARM64
51
Chris Packham7d7bb992022-11-05 17:23:59 +130052config ALLEYCAT_5
53 bool
54 select ARM64
55
Chris Packhama53d97a2016-10-26 14:08:30 +130056# Armada PLL frequency (used for NAND clock generation)
57config SYS_MVEBU_PLL_CLOCK
58 int
Chris Packham0d0df462019-04-11 22:22:50 +120059 default "2000000000" if ARMADA_XP || ARMADA_3700 || ARMADA_8K || ARMADA_MSYS
Chris Packhama53d97a2016-10-26 14:08:30 +130060 default "1000000000" if ARMADA_38X || ARMADA_375
61
Stefan Roesef61aefc2016-05-17 15:00:30 +020062# Armada XP/38x SoC types...
Phil Sutter42902522015-12-25 14:41:22 +010063config MV78230
64 bool
65 select ARMADA_XP
66
67config MV78260
68 bool
69 select ARMADA_XP
Simon Glass3bf926c2017-06-14 21:28:24 -060070 imply CMD_SATA
Phil Sutter42902522015-12-25 14:41:22 +010071
72config MV78460
73 bool
74 select ARMADA_XP
75
Chris Packham0d0df462019-04-11 22:22:50 +120076config ARMADA_MSYS
77 bool
78 select ARMADA_32BIT
79
80config 98DX4251
81 bool
82 select ARMADA_MSYS
83
84config 98DX3336
85 bool
86 select ARMADA_MSYS
87
88config 98DX3236
89 bool
90 select ARMADA_MSYS
91
Chris Packham53d601f2016-09-22 12:56:13 +120092config 88F6820
Phil Sutter42902522015-12-25 14:41:22 +010093 bool
94 select ARMADA_38X
95
Tom Rini53dbf112022-03-30 18:07:24 -040096config CUSTOMER_BOARD_SUPPORT
97 bool
98
Tony Dinh3fdd09f2023-02-01 15:13:05 -080099config DDR4
100 bool "Support Marvell DDR4 Training driver"
101
Stefan Roesec3d89142015-08-25 13:18:38 +0200102choice
Chris Packham6cc8b5d2022-11-05 17:24:00 +1300103 prompt "Armada XP/375/38x/3700/7K/8K/Alleycat-5 board select"
Stefan Roesec3d89142015-08-25 13:18:38 +0200104 optional
105
Stefan Roese0299c902015-10-20 15:14:47 +0200106config TARGET_CLEARFOG
107 bool "Support ClearFog"
Chris Packham53d601f2016-09-22 12:56:13 +1200108 select 88F6820
Baruch Siach867572f2020-01-20 14:20:13 +0200109 select BOARD_LATE_INIT
Martin Rowec733fe92023-03-27 21:24:09 +1000110 select OF_BOARD_SETUP
Stefan Roese0299c902015-10-20 15:14:47 +0200111
Dennis Gilmoreae28a5f2018-06-11 19:39:53 -0500112config TARGET_HELIOS4
113 bool "Support Helios4"
114 select 88F6820
115
Konstantin Porotchkinc5330ae2017-02-16 13:52:22 +0200116config TARGET_MVEBU_ARMADA_37XX
117 bool "Support Armada 37xx platforms"
Stefan Roese01e62c72016-05-17 15:04:16 +0200118 select ARMADA_3700
Simon Glassfedb4282017-06-14 21:28:21 -0600119 imply SCSI
Stefan Roese01e62c72016-05-17 15:04:16 +0200120
Stefan Roese606576d2016-01-29 09:14:54 +0100121config TARGET_DB_88F6720
122 bool "Support DB-88F6720 Armada 375"
123 select ARMADA_375
124
Stefan Roesec3d89142015-08-25 13:18:38 +0200125config TARGET_DB_88F6820_GP
126 bool "Support DB-88F6820-GP"
Chris Packham53d601f2016-09-22 12:56:13 +1200127 select 88F6820
Stefan Roesec3d89142015-08-25 13:18:38 +0200128
Chris Packhamc0def242016-09-22 12:56:14 +1200129config TARGET_DB_88F6820_AMC
130 bool "Support DB-88F6820-AMC"
131 select 88F6820
132
Marek Behúnb6ee8602017-06-09 19:28:45 +0200133config TARGET_TURRIS_OMNIA
134 bool "Support Turris Omnia"
135 select 88F6820
Marek Behún539f0242019-05-02 16:53:37 +0200136 select BOARD_LATE_INIT
Marek Behún8420edc2019-05-02 16:53:28 +0200137 select DM_I2C
138 select I2C_MUX
139 select I2C_MUX_PCA954x
Marek Behún6d7bfb62021-10-09 19:33:46 +0200140 select SPL_DRIVERS_MISC
Marek Behún8420edc2019-05-02 16:53:28 +0200141 select SPL_I2C_MUX
Marek Behún2c8a4e42021-10-09 19:33:45 +0200142 select SPL_SYS_MALLOC_SIMPLE
Marek Behún8420edc2019-05-02 16:53:28 +0200143 select SYS_I2C_MVTWSI
Marek Behún6b26f3e2019-05-02 16:53:32 +0200144 select ATSHA204A
Marek Behúnb6ee8602017-06-09 19:28:45 +0200145
Marek Behún80af1a92018-04-24 17:21:31 +0200146config TARGET_TURRIS_MOX
Marek Behún94c0f0b2023-10-20 16:29:16 +0200147 bool "Support CZ.NIC's Turris Mox / RIPE Atlas Probe"
Marek Behún80af1a92018-04-24 17:21:31 +0200148 select ARMADA_3700
Marek Behún94c0f0b2023-10-20 16:29:16 +0200149 select BOARD_TYPES
150 select ENV_IS_IN_MMC
151 select ENV_IS_IN_SPI_FLASH
152 select MULTI_DTB_FIT
Marek Behún80af1a92018-04-24 17:21:31 +0200153
Stefan Roese633fa0e2016-10-25 10:56:19 +0200154config TARGET_MVEBU_ARMADA_8K
155 bool "Support Armada 7k/8k platforms"
Stefan Roese6f8c2d42016-05-25 08:21:21 +0200156 select ARMADA_8K
Tom Rinie5ec4812017-01-22 19:43:11 -0500157 select BOARD_LATE_INIT
Simon Glassfedb4282017-06-14 21:28:21 -0600158 imply SCSI
Stefan Roese6f8c2d42016-05-25 08:21:21 +0200159
Chris Packham6cc8b5d2022-11-05 17:24:00 +1300160config TARGET_MVEBU_ALLEYCAT5
161 bool "Support AlleyCat 5 platforms"
162 select ALLEYCAT_5
163
Konstantin Porotchkinc4052262021-03-16 17:20:57 +0100164config TARGET_OCTEONTX2_CN913x
165 bool "Support CN913x platforms"
166 select ARMADA_8K
167 imply BOARD_EARLY_INIT_R
168 select BOARD_LATE_INIT
169 imply SCSI
170
Stefan Roesec3d89142015-08-25 13:18:38 +0200171config TARGET_DB_MV784MP_GP
172 bool "Support db-mv784mp-gp"
Tom Rinida8592d2022-02-25 11:19:46 -0500173 select BOARD_ECC_SUPPORT
Phil Sutter42902522015-12-25 14:41:22 +0100174 select MV78460
Stefan Roesec3d89142015-08-25 13:18:38 +0200175
Tony Dinhb21f87a52023-02-09 14:00:03 -0800176config TARGET_DS116
177 bool "Support Synology DS116"
178 select 88F6820
179
Phil Sutteraefb8f42015-12-25 14:41:25 +0100180config TARGET_DS414
181 bool "Support Synology DS414"
182 select MV78230
183
Stefan Roesec3d89142015-08-25 13:18:38 +0200184config TARGET_MAXBCM
185 bool "Support maxbcm"
Tom Rinida8592d2022-02-25 11:19:46 -0500186 select BOARD_ECC_SUPPORT
Phil Sutter42902522015-12-25 14:41:22 +0100187 select MV78460
Stefan Roesec3d89142015-08-25 13:18:38 +0200188
Tony Dinh3fdd09f2023-02-01 15:13:05 -0800189config TARGET_N2350
190 bool "Support Thecus N2350"
191 select 88F6820
192 select DDR4
193
Stefan Roeseb20c38a2016-01-20 08:13:29 +0100194config TARGET_THEADORABLE
195 bool "Support theadorable Armada XP"
Tom Rinie5ec4812017-01-22 19:43:11 -0500196 select BOARD_LATE_INIT if USB
Stefan Roeseb20c38a2016-01-20 08:13:29 +0100197 select MV78260
Simon Glass3bf926c2017-06-14 21:28:24 -0600198 imply CMD_SATA
Stefan Roeseb20c38a2016-01-20 08:13:29 +0100199
Dirk Eibach60083262017-02-22 16:07:23 +0100200config TARGET_CONTROLCENTERDC
201 bool "Support CONTROLCENTERDC"
202 select 88F6820
Tom Rini53dbf112022-03-30 18:07:24 -0400203 select CUSTOMER_BOARD_SUPPORT
Dirk Eibach60083262017-02-22 16:07:23 +0100204
Chris Packham0e316662019-01-10 21:01:00 +1300205config TARGET_X530
206 bool "Support Allied Telesis x530"
207 select 88F6820
208
Chris Packham4c97c4b2023-07-10 10:47:36 +1200209config TARGET_X240
210 bool "Support Allied Telesis x240"
211 select ALLEYCAT_5
212
Chris Packham4db944a2019-04-11 22:22:53 +1200213config TARGET_DB_XC3_24G4XG
214 bool "Support DB-XC3-24G4XG"
215 select 98DX3336
216
Luka Kovacicdf9ebbe2020-05-26 20:17:50 +0200217config TARGET_CRS3XX_98DX3236
218 bool "Support CRS3XX-98DX3236"
Luka Kovacic22bb9132019-05-07 19:35:55 +0200219 select 98DX3236
220
Stefan Roesec3d89142015-08-25 13:18:38 +0200221endchoice
222
Tom Rini5b527c52021-08-21 13:50:13 -0400223choice
224 prompt "DDR bus width"
225 default DDR_64BIT
226 depends on ARMADA_XP
227
228config DDR_64BIT
229 bool "64bit bus width"
230
231config DDR_32BIT
232 bool "32bit bus width"
233
234endchoice
235
Tom Rinif66a3fd2021-08-21 13:50:15 -0400236config DDR_LOG_LEVEL
237 int "DDR training code log level"
238 depends on ARMADA_XP
239 default 0
240 range 0 3
241 help
242 Amount of information provided on error while running the DDR
243 training code. At level 0, provides an error code in a case of
244 failure, RL, WL errors and other algorithm failure. At level 1,
245 provides the D-Unit setup (SPD/Static configuration). At level 2,
246 provides the windows margin as a results of DQS centeralization.
247 At level 3, rovides the windows margin of each DQ as a results of
248 DQS centeralization.
249
Marek Behún871ee662022-02-17 13:54:42 +0100250config DDR_RESET_ON_TRAINING_FAILURE
251 bool "Reset the board on DDR training failure instead of hanging"
252 depends on ARMADA_38X || ARMADA_XP
253 help
254 If DDR training fails in SPL, reset the board instead of hanging.
255 Some boards are known to fail DDR training occasionally and an
256 immediate reset may be preferable to waiting until the board is
257 reset by watchdog (if there even is one).
258
259 Note that if booting via UART and the DDR training fails, the
260 device will still hang - it doesn't make sense to reset the board
261 in such a case.
262
Tom Rinida8592d2022-02-25 11:19:46 -0500263config BOARD_ECC_SUPPORT
264 bool
265
Stefan Roeseb322c832015-12-21 13:40:37 +0100266config SYS_BOARD
267 default "clearfog" if TARGET_CLEARFOG
Dennis Gilmoreae28a5f2018-06-11 19:39:53 -0500268 default "helios4" if TARGET_HELIOS4
Konstantin Porotchkinc5330ae2017-02-16 13:52:22 +0200269 default "mvebu_armada-37xx" if TARGET_MVEBU_ARMADA_37XX
Stefan Roese606576d2016-01-29 09:14:54 +0100270 default "db-88f6720" if TARGET_DB_88F6720
Stefan Roeseb322c832015-12-21 13:40:37 +0100271 default "db-88f6820-gp" if TARGET_DB_88F6820_GP
Chris Packhamc0def242016-09-22 12:56:14 +1200272 default "db-88f6820-amc" if TARGET_DB_88F6820_AMC
Marek Behúnb6ee8602017-06-09 19:28:45 +0200273 default "turris_omnia" if TARGET_TURRIS_OMNIA
Marek Behún80af1a92018-04-24 17:21:31 +0200274 default "turris_mox" if TARGET_TURRIS_MOX
Stefan Roese633fa0e2016-10-25 10:56:19 +0200275 default "mvebu_armada-8k" if TARGET_MVEBU_ARMADA_8K
Konstantin Porotchkinc4052262021-03-16 17:20:57 +0100276 default "octeontx2_cn913x" if TARGET_OCTEONTX2_CN913x
Stefan Roeseb322c832015-12-21 13:40:37 +0100277 default "db-mv784mp-gp" if TARGET_DB_MV784MP_GP
Tony Dinhb21f87a52023-02-09 14:00:03 -0800278 default "ds116" if TARGET_DS116
Phil Sutteraefb8f42015-12-25 14:41:25 +0100279 default "ds414" if TARGET_DS414
Stefan Roeseb322c832015-12-21 13:40:37 +0100280 default "maxbcm" if TARGET_MAXBCM
Tony Dinh3fdd09f2023-02-01 15:13:05 -0800281 default "n2350" if TARGET_N2350
Stefan Roeseb20c38a2016-01-20 08:13:29 +0100282 default "theadorable" if TARGET_THEADORABLE
Baruch Siachd38f04f2018-06-18 21:56:23 +0300283 default "a38x" if TARGET_CONTROLCENTERDC
Chris Packham0e316662019-01-10 21:01:00 +1300284 default "x530" if TARGET_X530
Chris Packham4c97c4b2023-07-10 10:47:36 +1200285 default "x240" if TARGET_X240
Chris Packham4db944a2019-04-11 22:22:53 +1200286 default "db-xc3-24g4xg" if TARGET_DB_XC3_24G4XG
Luka Kovacicdf9ebbe2020-05-26 20:17:50 +0200287 default "crs3xx-98dx3236" if TARGET_CRS3XX_98DX3236
Chris Packham6cc8b5d2022-11-05 17:24:00 +1300288 default "mvebu_alleycat-5" if TARGET_MVEBU_ALLEYCAT5
Stefan Roeseb322c832015-12-21 13:40:37 +0100289
290config SYS_CONFIG_NAME
291 default "clearfog" if TARGET_CLEARFOG
Dennis Gilmoreae28a5f2018-06-11 19:39:53 -0500292 default "helios4" if TARGET_HELIOS4
Konstantin Porotchkinc5330ae2017-02-16 13:52:22 +0200293 default "mvebu_armada-37xx" if TARGET_MVEBU_ARMADA_37XX
Stefan Roese606576d2016-01-29 09:14:54 +0100294 default "db-88f6720" if TARGET_DB_88F6720
Stefan Roeseb322c832015-12-21 13:40:37 +0100295 default "db-88f6820-gp" if TARGET_DB_88F6820_GP
Chris Packhamc0def242016-09-22 12:56:14 +1200296 default "db-88f6820-amc" if TARGET_DB_88F6820_AMC
Stefan Roese633fa0e2016-10-25 10:56:19 +0200297 default "mvebu_armada-8k" if TARGET_MVEBU_ARMADA_8K
Konstantin Porotchkinc4052262021-03-16 17:20:57 +0100298 default "mvebu_armada-8k" if TARGET_OCTEONTX2_CN913x
Stefan Roeseb322c832015-12-21 13:40:37 +0100299 default "db-mv784mp-gp" if TARGET_DB_MV784MP_GP
Tony Dinhb21f87a52023-02-09 14:00:03 -0800300 default "ds116" if TARGET_DS116
Phil Sutteraefb8f42015-12-25 14:41:25 +0100301 default "ds414" if TARGET_DS414
Stefan Roeseb322c832015-12-21 13:40:37 +0100302 default "maxbcm" if TARGET_MAXBCM
Tony Dinh3fdd09f2023-02-01 15:13:05 -0800303 default "n2350" if TARGET_N2350
Stefan Roeseb20c38a2016-01-20 08:13:29 +0100304 default "theadorable" if TARGET_THEADORABLE
Marek Behúnb6ee8602017-06-09 19:28:45 +0200305 default "turris_omnia" if TARGET_TURRIS_OMNIA
Marek Behún80af1a92018-04-24 17:21:31 +0200306 default "turris_mox" if TARGET_TURRIS_MOX
Baruch Siachd38f04f2018-06-18 21:56:23 +0300307 default "controlcenterdc" if TARGET_CONTROLCENTERDC
Chris Packham0e316662019-01-10 21:01:00 +1300308 default "x530" if TARGET_X530
Chris Packham4c97c4b2023-07-10 10:47:36 +1200309 default "x240" if TARGET_X240
Chris Packham4db944a2019-04-11 22:22:53 +1200310 default "db-xc3-24g4xg" if TARGET_DB_XC3_24G4XG
Luka Kovacicdf9ebbe2020-05-26 20:17:50 +0200311 default "crs3xx-98dx3236" if TARGET_CRS3XX_98DX3236
Chris Packham6cc8b5d2022-11-05 17:24:00 +1300312 default "mvebu_alleycat-5" if TARGET_MVEBU_ALLEYCAT5
Stefan Roeseb322c832015-12-21 13:40:37 +0100313
314config SYS_VENDOR
315 default "Marvell" if TARGET_DB_MV784MP_GP
Konstantin Porotchkinc5330ae2017-02-16 13:52:22 +0200316 default "Marvell" if TARGET_MVEBU_ARMADA_37XX
Stefan Roese606576d2016-01-29 09:14:54 +0100317 default "Marvell" if TARGET_DB_88F6720
Stefan Roeseb322c832015-12-21 13:40:37 +0100318 default "Marvell" if TARGET_DB_88F6820_GP
Chris Packhamc0def242016-09-22 12:56:14 +1200319 default "Marvell" if TARGET_DB_88F6820_AMC
Stefan Roese633fa0e2016-10-25 10:56:19 +0200320 default "Marvell" if TARGET_MVEBU_ARMADA_8K
Konstantin Porotchkinc4052262021-03-16 17:20:57 +0100321 default "Marvell" if TARGET_OCTEONTX2_CN913x
Chris Packham4db944a2019-04-11 22:22:53 +1200322 default "Marvell" if TARGET_DB_XC3_24G4XG
323 default "Marvell" if TARGET_MVEBU_DB_88F7040
Stefan Roeseb322c832015-12-21 13:40:37 +0100324 default "solidrun" if TARGET_CLEARFOG
Dennis Gilmoreae28a5f2018-06-11 19:39:53 -0500325 default "kobol" if TARGET_HELIOS4
Tony Dinhb21f87a52023-02-09 14:00:03 -0800326 default "Synology" if TARGET_DS116
Phil Sutteraefb8f42015-12-25 14:41:25 +0100327 default "Synology" if TARGET_DS414
Tony Dinh3fdd09f2023-02-01 15:13:05 -0800328 default "thecus" if TARGET_N2350
Marek Behúnb6ee8602017-06-09 19:28:45 +0200329 default "CZ.NIC" if TARGET_TURRIS_OMNIA
Marek Behún80af1a92018-04-24 17:21:31 +0200330 default "CZ.NIC" if TARGET_TURRIS_MOX
Baruch Siachd38f04f2018-06-18 21:56:23 +0300331 default "gdsys" if TARGET_CONTROLCENTERDC
Chris Packham0e316662019-01-10 21:01:00 +1300332 default "alliedtelesis" if TARGET_X530
Chris Packham4c97c4b2023-07-10 10:47:36 +1200333 default "alliedtelesis" if TARGET_X240
Luka Kovacicdf9ebbe2020-05-26 20:17:50 +0200334 default "mikrotik" if TARGET_CRS3XX_98DX3236
Chris Packham6cc8b5d2022-11-05 17:24:00 +1300335 default "Marvell" if TARGET_MVEBU_ALLEYCAT5
Stefan Roeseb322c832015-12-21 13:40:37 +0100336
Stefan Roesec3d89142015-08-25 13:18:38 +0200337config SYS_SOC
338 default "mvebu"
339
Marek Behúnb6ee8602017-06-09 19:28:45 +0200340choice
Baruch Siachad105f52018-06-18 21:56:24 +0300341 prompt "Boot method"
Joel Johnsonab2f7572020-04-17 01:19:05 -0600342 depends on SPL
Marek Behúnb6ee8602017-06-09 19:28:45 +0200343
Baruch Siachad105f52018-06-18 21:56:24 +0300344config MVEBU_SPL_BOOT_DEVICE_SPI
Pali Rohár41d52f32023-01-10 23:13:01 +0100345 bool "NOR flash (SPI or parallel)"
Joel Johnsonab2f7572020-04-17 01:19:05 -0600346 imply ENV_IS_IN_SPI_FLASH
Pali Rohár2226ca12021-07-23 11:14:29 +0200347 imply SPL_DM_SPI
348 imply SPL_SPI_FLASH_SUPPORT
349 imply SPL_SPI_LOAD
Simon Glassea2ca7e2021-08-08 12:20:14 -0600350 imply SPL_SPI
Pali Rohár9d0225b2021-07-23 11:14:25 +0200351 select SPL_BOOTROM_SUPPORT
Marek Behúnb6ee8602017-06-09 19:28:45 +0200352
Pali Rohár67bd6152023-01-10 22:55:21 +0100353config MVEBU_SPL_BOOT_DEVICE_NAND
354 bool "NAND flash (SPI or parallel)"
355 select MTD_RAW_NAND
356 select SPL_BOOTROM_SUPPORT
357
Baruch Siachad105f52018-06-18 21:56:24 +0300358config MVEBU_SPL_BOOT_DEVICE_MMC
Pali Rohár41d52f32023-01-10 23:13:01 +0100359 bool "eMMC or SD card"
Joel Johnsonab2f7572020-04-17 01:19:05 -0600360 imply ENV_IS_IN_MMC
361 # GPIO needed for eMMC/SD card presence detection
Pali Rohár2226ca12021-07-23 11:14:29 +0200362 imply SPL_DM_GPIO
363 imply SPL_DM_MMC
364 imply SPL_GPIO
365 imply SPL_LIBDISK_SUPPORT
Simon Glass103c5f12021-08-08 12:20:09 -0600366 imply SPL_MMC
Pali Rohár2f27db22023-01-08 13:31:41 +0100367 select SUPPORT_EMMC_BOOT if SPL_MMC
Pali Rohár913d7562023-01-09 00:52:09 +0100368 select SYS_MMCSD_RAW_MODE_U_BOOT_USE_SECTOR if SPL_MMC
Pali Rohár9d0225b2021-07-23 11:14:25 +0200369 select SPL_BOOTROM_SUPPORT
Marek Behúnb6ee8602017-06-09 19:28:45 +0200370
Baruch Siach22c65452019-05-16 13:03:58 +0300371config MVEBU_SPL_BOOT_DEVICE_SATA
372 bool "SATA"
Simon Glassf7560372021-08-08 12:20:17 -0600373 imply SPL_SATA
Pali Rohár2226ca12021-07-23 11:14:29 +0200374 imply SPL_LIBDISK_SUPPORT
Pali Rohár9d0225b2021-07-23 11:14:25 +0200375 select SPL_BOOTROM_SUPPORT
Baruch Siach22c65452019-05-16 13:03:58 +0300376
Pali Rohár50afad52023-01-10 23:09:15 +0100377config MVEBU_SPL_BOOT_DEVICE_PEX
378 bool "PCI Express"
379 select SPL_BOOTROM_SUPPORT
380
Baruch Siach72c4e672018-06-18 21:56:26 +0300381config MVEBU_SPL_BOOT_DEVICE_UART
382 bool "UART"
Pali Rohár9d0225b2021-07-23 11:14:25 +0200383 select SPL_BOOTROM_SUPPORT
Baruch Siach72c4e672018-06-18 21:56:26 +0300384
Marek Behúnb6ee8602017-06-09 19:28:45 +0200385endchoice
386
Pali Rohár67bd6152023-01-10 22:55:21 +0100387config MVEBU_SPL_NAND_BADBLK_LOCATION
388 hex "NAND Bad block indicator location"
389 depends on MVEBU_SPL_BOOT_DEVICE_NAND
390 range 0x0 0x1
391 help
392 Value 0x0 = SLC flash = BBI at page 0 or page 1
393 Value 0x1 = MLC flash = BBI at last page in the block
394
Pali Rohárc62af152023-03-29 21:25:58 +0200395config MVEBU_SPL_SATA_BLKSZ
396 int "SATA block size"
397 depends on MVEBU_SPL_BOOT_DEVICE_SATA
398 range 512 32768
399 default 512
400 help
401 Block size of the SATA disk in bytes.
402 Typically 512 bytes for majority of disks
403 and 4096 bytes for 4K Native disks.
404
Mario Sixa1b6b0a2017-01-11 16:01:00 +0100405config MVEBU_EFUSE
406 bool "Enable eFuse support"
Mario Sixa1b6b0a2017-01-11 16:01:00 +0100407 depends on HAVE_MVEBU_EFUSE
408 help
409 Enable support for reading and writing eFuses on mvebu SoCs.
410
411config MVEBU_EFUSE_FAKE
412 bool "Fake eFuse access (dry run)"
Mario Sixa1b6b0a2017-01-11 16:01:00 +0100413 depends on MVEBU_EFUSE
414 help
415 This enables a "dry run" mode where eFuses are not really programmed.
416 Instead the eFuse accesses are emulated by writing to and reading
417 from a memory block.
418 This is can be used for testing prog scripts.
419
Pali Rohár8092d1d2022-09-22 13:43:45 +0200420config MVEBU_EFUSE_VHV_GPIO
421 string "VHV_Enable GPIO name for eFuse programming"
422 depends on MVEBU_EFUSE && !ARMADA_3700
423 help
424 The eFuse programing (burning) phase requires supplying 1.8V to the
425 device on the VHV power pin, while for normal operation the VHV power
426 rail must be left unconnected. See Marvell AN-389: ARMADA VHV Power
427 document (Doc. No. MV-S302545-00 Rev. C, August 2, 2016) for details.
428 .
429 This specify VHV_Enable GPIO name used in U-Boot for enabling VHV power.
430
431config MVEBU_EFUSE_VHV_GPIO_ACTIVE_LOW
432 bool "VHV_Enable GPIO is Active Low"
433 depends on MVEBU_EFUSE_VHV_GPIO != ""
434
Mario Sixa1b6b0a2017-01-11 16:01:00 +0100435config SECURED_MODE_IMAGE
436 bool "Build image for trusted boot"
437 default false
438 depends on 88F6820
439 help
440 Build an image that employs the ARMADA SoC's trusted boot framework
441 for securely booting images.
442
443config SECURED_MODE_CSK_INDEX
444 int "Index of active CSK"
445 default 0
446 depends on SECURED_MODE_IMAGE
447
Tony Dinh21f62272023-03-02 19:27:29 -0800448config SF_DEFAULT_SPEED
449 int "Default speed for SPI flash in Hz"
450 default 10000000
451 depends on MVEBU_SPL_BOOT_DEVICE_SPI
452
453config SF_DEFAULT_MODE
454 hex "Default mode for SPI flash"
455 default 0x0
456 depends on MVEBU_SPL_BOOT_DEVICE_SPI
457
Joel Johnson9f205d62020-03-23 14:21:32 -0600458source "board/solidrun/clearfog/Kconfig"
Dennis Gilmore5a3db5d2020-12-08 21:07:36 -0600459source "board/kobol/helios4/Kconfig"
Joel Johnson9f205d62020-03-23 14:21:32 -0600460
Stefan Roesec3d89142015-08-25 13:18:38 +0200461endif