blob: 5c7f4bf964afc133cbf7af4b288314d5ef453032 [file] [log] [blame]
Stefan Roese383e0c12015-08-25 13:18:38 +02001if ARCH_MVEBU
2
Mario Six10d14492017-01-11 16:01:00 +01003config HAVE_MVEBU_EFUSE
4 bool
Mario Six10d14492017-01-11 16:01:00 +01005
Stefan Roese05b17652016-05-17 15:00:30 +02006config ARMADA_32BIT
7 bool
Michal Simek7e7ba3b2018-07-23 15:55:15 +02008 select BOARD_EARLY_INIT_F
Lokesh Vutla81b1a672018-04-26 18:21:26 +05309 select CPU_V7A
Stefan Roese1f1b3e92019-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 Rinib7cc2fe2021-10-15 10:54:41 -040013 select SPL_SKIP_LOWLEVEL_INIT if SPL
Stefan Roese1f1b3e92019-04-11 08:58:32 +020014 select SPL_SIMPLE_BUS if SPL
Michal Simek7e7ba3b2018-07-23 15:55:15 +020015 select SUPPORT_SPL
Philip Oberfichtner5833e1b2022-08-17 15:07:12 +020016 select SYS_L2_PL310 if !SYS_L2CACHE_OFF
Stefan Roese85bddff2019-04-12 16:42:28 +020017 select TRANSLATION_OFFSET
Pali Rohárc5c28df2022-04-06 16:20:20 +020018 select SPL_SYS_NO_VECTOR_TABLE if SPL
Pali Roháraaed3282022-05-06 11:05:14 +020019 select ARCH_VERY_EARLY_INIT
Stefan Roese05b17652016-05-17 15:00:30 +020020
Stefan Roese05b17652016-05-17 15:00:30 +020021# ARMv7 SoCs...
Stefan Roese9106ed02016-01-29 09:14:54 +010022config ARMADA_375
23 bool
Stefan Roese05b17652016-05-17 15:00:30 +020024 select ARMADA_32BIT
Stefan Roese9106ed02016-01-29 09:14:54 +010025
Stefan Roeseeb083e52015-12-21 13:56:33 +010026config ARMADA_38X
27 bool
Stefan Roese05b17652016-05-17 15:00:30 +020028 select ARMADA_32BIT
Mario Six10d14492017-01-11 16:01:00 +010029 select HAVE_MVEBU_EFUSE
Stefan Roeseeb083e52015-12-21 13:56:33 +010030
Joshua Scott4ba8e992020-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 Roeseeb083e52015-12-21 13:56:33 +010037config ARMADA_XP
38 bool
Stefan Roese05b17652016-05-17 15:00:30 +020039 select ARMADA_32BIT
40
41# ARMv8 SoCs...
42config ARMADA_3700
43 bool
44 select ARM64
Pali Rohár70d9bee2022-02-23 14:15:45 +010045 select HAVE_MVEBU_EFUSE
Stefan Roeseeb083e52015-12-21 13:56:33 +010046
Stefan Roesecb410332016-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 Packhameaab4612022-11-05 17:23:59 +130052config ALLEYCAT_5
53 bool
54 select ARM64
55
Chris Packham1d496682016-10-26 14:08:30 +130056# Armada PLL frequency (used for NAND clock generation)
57config SYS_MVEBU_PLL_CLOCK
58 int
Chris Packhama8f845e2019-04-11 22:22:50 +120059 default "2000000000" if ARMADA_XP || ARMADA_3700 || ARMADA_8K || ARMADA_MSYS
Chris Packham1d496682016-10-26 14:08:30 +130060 default "1000000000" if ARMADA_38X || ARMADA_375
61
Stefan Roese05b17652016-05-17 15:00:30 +020062# Armada XP/38x SoC types...
Phil Suttera7f94ad2015-12-25 14:41:22 +010063config MV78230
64 bool
65 select ARMADA_XP
66
67config MV78260
68 bool
69 select ARMADA_XP
Simon Glass203b3ab2017-06-14 21:28:24 -060070 imply CMD_SATA
Phil Suttera7f94ad2015-12-25 14:41:22 +010071
72config MV78460
73 bool
74 select ARMADA_XP
75
Chris Packhama8f845e2019-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 Packhamf5fc25b2016-09-22 12:56:13 +120092config 88F6820
Phil Suttera7f94ad2015-12-25 14:41:22 +010093 bool
94 select ARMADA_38X
95
Tom Rini40a325f2022-03-30 18:07:24 -040096config CUSTOMER_BOARD_SUPPORT
97 bool
98
Tony Dinh63eba132023-02-01 15:13:05 -080099config DDR4
100 bool "Support Marvell DDR4 Training driver"
101
Stefan Roese383e0c12015-08-25 13:18:38 +0200102choice
Chris Packham67b7d502022-11-05 17:24:00 +1300103 prompt "Armada XP/375/38x/3700/7K/8K/Alleycat-5 board select"
Stefan Roese383e0c12015-08-25 13:18:38 +0200104 optional
105
Stefan Roese73606402015-10-20 15:14:47 +0200106config TARGET_CLEARFOG
107 bool "Support ClearFog"
Chris Packhamf5fc25b2016-09-22 12:56:13 +1200108 select 88F6820
Baruch Siach1c5e95d2020-01-20 14:20:13 +0200109 select BOARD_LATE_INIT
Martin Rowe7eceb672023-03-27 21:24:09 +1000110 select OF_BOARD_SETUP
Stefan Roese73606402015-10-20 15:14:47 +0200111
Dennis Gilmore77c39402018-06-11 19:39:53 -0500112config TARGET_HELIOS4
113 bool "Support Helios4"
114 select 88F6820
115
Konstantin Porotchkin7f8dfea2017-02-16 13:52:22 +0200116config TARGET_MVEBU_ARMADA_37XX
117 bool "Support Armada 37xx platforms"
Stefan Roese6edf27e2016-05-17 15:04:16 +0200118 select ARMADA_3700
Simon Glass0e5faf02017-06-14 21:28:21 -0600119 imply SCSI
Stefan Roese6edf27e2016-05-17 15:04:16 +0200120
Stefan Roese9106ed02016-01-29 09:14:54 +0100121config TARGET_DB_88F6720
122 bool "Support DB-88F6720 Armada 375"
123 select ARMADA_375
124
Stefan Roese383e0c12015-08-25 13:18:38 +0200125config TARGET_DB_88F6820_GP
126 bool "Support DB-88F6820-GP"
Chris Packhamf5fc25b2016-09-22 12:56:13 +1200127 select 88F6820
Stefan Roese383e0c12015-08-25 13:18:38 +0200128
Chris Packhama90dd4c2016-09-22 12:56:14 +1200129config TARGET_DB_88F6820_AMC
130 bool "Support DB-88F6820-AMC"
131 select 88F6820
132
Marek Behún09e16b82017-06-09 19:28:45 +0200133config TARGET_TURRIS_OMNIA
134 bool "Support Turris Omnia"
135 select 88F6820
Marek Behún0f2e66a2019-05-02 16:53:37 +0200136 select BOARD_LATE_INIT
Marek Behún1e4cbb92019-05-02 16:53:28 +0200137 select DM_I2C
138 select I2C_MUX
139 select I2C_MUX_PCA954x
Marek Behún4c3abea2021-10-09 19:33:46 +0200140 select SPL_DRIVERS_MISC
Marek Behún1e4cbb92019-05-02 16:53:28 +0200141 select SPL_I2C_MUX
Marek Behúnca6095b2021-10-09 19:33:45 +0200142 select SPL_SYS_MALLOC_SIMPLE
Marek Behún1e4cbb92019-05-02 16:53:28 +0200143 select SYS_I2C_MVTWSI
Marek Behún5e92efe2019-05-02 16:53:32 +0200144 select ATSHA204A
Marek Behún09e16b82017-06-09 19:28:45 +0200145
Marek Behúnf835bed2018-04-24 17:21:31 +0200146config TARGET_TURRIS_MOX
147 bool "Support Turris Mox"
148 select ARMADA_3700
149
Stefan Roese5c806f12016-10-25 10:56:19 +0200150config TARGET_MVEBU_ARMADA_8K
151 bool "Support Armada 7k/8k platforms"
Stefan Roese7be1b9b2016-05-25 08:21:21 +0200152 select ARMADA_8K
Tom Rini22d567e2017-01-22 19:43:11 -0500153 select BOARD_LATE_INIT
Simon Glass0e5faf02017-06-14 21:28:21 -0600154 imply SCSI
Stefan Roese7be1b9b2016-05-25 08:21:21 +0200155
Chris Packham67b7d502022-11-05 17:24:00 +1300156config TARGET_MVEBU_ALLEYCAT5
157 bool "Support AlleyCat 5 platforms"
158 select ALLEYCAT_5
159
Konstantin Porotchkin1d6ff1f2021-03-16 17:20:57 +0100160config TARGET_OCTEONTX2_CN913x
161 bool "Support CN913x platforms"
162 select ARMADA_8K
163 imply BOARD_EARLY_INIT_R
164 select BOARD_LATE_INIT
165 imply SCSI
166
Stefan Roese383e0c12015-08-25 13:18:38 +0200167config TARGET_DB_MV784MP_GP
168 bool "Support db-mv784mp-gp"
Tom Rini9a04d7d2022-02-25 11:19:46 -0500169 select BOARD_ECC_SUPPORT
Phil Suttera7f94ad2015-12-25 14:41:22 +0100170 select MV78460
Stefan Roese383e0c12015-08-25 13:18:38 +0200171
Tony Dinh6aebc1a2023-02-09 14:00:03 -0800172config TARGET_DS116
173 bool "Support Synology DS116"
174 select 88F6820
175
Phil Sutterd76eba62015-12-25 14:41:25 +0100176config TARGET_DS414
177 bool "Support Synology DS414"
178 select MV78230
179
Stefan Roese383e0c12015-08-25 13:18:38 +0200180config TARGET_MAXBCM
181 bool "Support maxbcm"
Tom Rini9a04d7d2022-02-25 11:19:46 -0500182 select BOARD_ECC_SUPPORT
Phil Suttera7f94ad2015-12-25 14:41:22 +0100183 select MV78460
Stefan Roese383e0c12015-08-25 13:18:38 +0200184
Tony Dinh63eba132023-02-01 15:13:05 -0800185config TARGET_N2350
186 bool "Support Thecus N2350"
187 select 88F6820
188 select DDR4
189
Stefan Roese459e0642016-01-20 08:13:29 +0100190config TARGET_THEADORABLE
191 bool "Support theadorable Armada XP"
Tom Rini22d567e2017-01-22 19:43:11 -0500192 select BOARD_LATE_INIT if USB
Stefan Roese459e0642016-01-20 08:13:29 +0100193 select MV78260
Simon Glass203b3ab2017-06-14 21:28:24 -0600194 imply CMD_SATA
Stefan Roese459e0642016-01-20 08:13:29 +0100195
Dirk Eibachfb605942017-02-22 16:07:23 +0100196config TARGET_CONTROLCENTERDC
197 bool "Support CONTROLCENTERDC"
198 select 88F6820
Tom Rini40a325f2022-03-30 18:07:24 -0400199 select CUSTOMER_BOARD_SUPPORT
Dirk Eibachfb605942017-02-22 16:07:23 +0100200
Chris Packhamb55b2c92019-01-10 21:01:00 +1300201config TARGET_X530
202 bool "Support Allied Telesis x530"
203 select 88F6820
204
Chris Packham7325f1f2023-07-10 10:47:36 +1200205config TARGET_X240
206 bool "Support Allied Telesis x240"
207 select ALLEYCAT_5
208
Chris Packham199e3182019-04-11 22:22:53 +1200209config TARGET_DB_XC3_24G4XG
210 bool "Support DB-XC3-24G4XG"
211 select 98DX3336
212
Luka Kovacic25acb8b2020-05-26 20:17:50 +0200213config TARGET_CRS3XX_98DX3236
214 bool "Support CRS3XX-98DX3236"
Luka Kovacicb686e222019-05-07 19:35:55 +0200215 select 98DX3236
216
Stefan Roese383e0c12015-08-25 13:18:38 +0200217endchoice
218
Tom Rini59180392021-08-21 13:50:13 -0400219choice
220 prompt "DDR bus width"
221 default DDR_64BIT
222 depends on ARMADA_XP
223
224config DDR_64BIT
225 bool "64bit bus width"
226
227config DDR_32BIT
228 bool "32bit bus width"
229
230endchoice
231
Tom Rini592bcd02021-08-21 13:50:15 -0400232config DDR_LOG_LEVEL
233 int "DDR training code log level"
234 depends on ARMADA_XP
235 default 0
236 range 0 3
237 help
238 Amount of information provided on error while running the DDR
239 training code. At level 0, provides an error code in a case of
240 failure, RL, WL errors and other algorithm failure. At level 1,
241 provides the D-Unit setup (SPD/Static configuration). At level 2,
242 provides the windows margin as a results of DQS centeralization.
243 At level 3, rovides the windows margin of each DQ as a results of
244 DQS centeralization.
245
Marek Behún90555af2022-02-17 13:54:42 +0100246config DDR_RESET_ON_TRAINING_FAILURE
247 bool "Reset the board on DDR training failure instead of hanging"
248 depends on ARMADA_38X || ARMADA_XP
249 help
250 If DDR training fails in SPL, reset the board instead of hanging.
251 Some boards are known to fail DDR training occasionally and an
252 immediate reset may be preferable to waiting until the board is
253 reset by watchdog (if there even is one).
254
255 Note that if booting via UART and the DDR training fails, the
256 device will still hang - it doesn't make sense to reset the board
257 in such a case.
258
Tom Rini9a04d7d2022-02-25 11:19:46 -0500259config BOARD_ECC_SUPPORT
260 bool
261
Stefan Roeseb9f41bf2015-12-21 13:40:37 +0100262config SYS_BOARD
263 default "clearfog" if TARGET_CLEARFOG
Dennis Gilmore77c39402018-06-11 19:39:53 -0500264 default "helios4" if TARGET_HELIOS4
Konstantin Porotchkin7f8dfea2017-02-16 13:52:22 +0200265 default "mvebu_armada-37xx" if TARGET_MVEBU_ARMADA_37XX
Stefan Roese9106ed02016-01-29 09:14:54 +0100266 default "db-88f6720" if TARGET_DB_88F6720
Stefan Roeseb9f41bf2015-12-21 13:40:37 +0100267 default "db-88f6820-gp" if TARGET_DB_88F6820_GP
Chris Packhama90dd4c2016-09-22 12:56:14 +1200268 default "db-88f6820-amc" if TARGET_DB_88F6820_AMC
Marek Behún09e16b82017-06-09 19:28:45 +0200269 default "turris_omnia" if TARGET_TURRIS_OMNIA
Marek Behúnf835bed2018-04-24 17:21:31 +0200270 default "turris_mox" if TARGET_TURRIS_MOX
Stefan Roese5c806f12016-10-25 10:56:19 +0200271 default "mvebu_armada-8k" if TARGET_MVEBU_ARMADA_8K
Konstantin Porotchkin1d6ff1f2021-03-16 17:20:57 +0100272 default "octeontx2_cn913x" if TARGET_OCTEONTX2_CN913x
Stefan Roeseb9f41bf2015-12-21 13:40:37 +0100273 default "db-mv784mp-gp" if TARGET_DB_MV784MP_GP
Tony Dinh6aebc1a2023-02-09 14:00:03 -0800274 default "ds116" if TARGET_DS116
Phil Sutterd76eba62015-12-25 14:41:25 +0100275 default "ds414" if TARGET_DS414
Stefan Roeseb9f41bf2015-12-21 13:40:37 +0100276 default "maxbcm" if TARGET_MAXBCM
Tony Dinh63eba132023-02-01 15:13:05 -0800277 default "n2350" if TARGET_N2350
Stefan Roese459e0642016-01-20 08:13:29 +0100278 default "theadorable" if TARGET_THEADORABLE
Baruch Siachdaa6f082018-06-18 21:56:23 +0300279 default "a38x" if TARGET_CONTROLCENTERDC
Chris Packhamb55b2c92019-01-10 21:01:00 +1300280 default "x530" if TARGET_X530
Chris Packham7325f1f2023-07-10 10:47:36 +1200281 default "x240" if TARGET_X240
Chris Packham199e3182019-04-11 22:22:53 +1200282 default "db-xc3-24g4xg" if TARGET_DB_XC3_24G4XG
Luka Kovacic25acb8b2020-05-26 20:17:50 +0200283 default "crs3xx-98dx3236" if TARGET_CRS3XX_98DX3236
Chris Packham67b7d502022-11-05 17:24:00 +1300284 default "mvebu_alleycat-5" if TARGET_MVEBU_ALLEYCAT5
Stefan Roeseb9f41bf2015-12-21 13:40:37 +0100285
286config SYS_CONFIG_NAME
287 default "clearfog" if TARGET_CLEARFOG
Dennis Gilmore77c39402018-06-11 19:39:53 -0500288 default "helios4" if TARGET_HELIOS4
Konstantin Porotchkin7f8dfea2017-02-16 13:52:22 +0200289 default "mvebu_armada-37xx" if TARGET_MVEBU_ARMADA_37XX
Stefan Roese9106ed02016-01-29 09:14:54 +0100290 default "db-88f6720" if TARGET_DB_88F6720
Stefan Roeseb9f41bf2015-12-21 13:40:37 +0100291 default "db-88f6820-gp" if TARGET_DB_88F6820_GP
Chris Packhama90dd4c2016-09-22 12:56:14 +1200292 default "db-88f6820-amc" if TARGET_DB_88F6820_AMC
Stefan Roese5c806f12016-10-25 10:56:19 +0200293 default "mvebu_armada-8k" if TARGET_MVEBU_ARMADA_8K
Konstantin Porotchkin1d6ff1f2021-03-16 17:20:57 +0100294 default "mvebu_armada-8k" if TARGET_OCTEONTX2_CN913x
Stefan Roeseb9f41bf2015-12-21 13:40:37 +0100295 default "db-mv784mp-gp" if TARGET_DB_MV784MP_GP
Tony Dinh6aebc1a2023-02-09 14:00:03 -0800296 default "ds116" if TARGET_DS116
Phil Sutterd76eba62015-12-25 14:41:25 +0100297 default "ds414" if TARGET_DS414
Stefan Roeseb9f41bf2015-12-21 13:40:37 +0100298 default "maxbcm" if TARGET_MAXBCM
Tony Dinh63eba132023-02-01 15:13:05 -0800299 default "n2350" if TARGET_N2350
Stefan Roese459e0642016-01-20 08:13:29 +0100300 default "theadorable" if TARGET_THEADORABLE
Marek Behún09e16b82017-06-09 19:28:45 +0200301 default "turris_omnia" if TARGET_TURRIS_OMNIA
Marek Behúnf835bed2018-04-24 17:21:31 +0200302 default "turris_mox" if TARGET_TURRIS_MOX
Baruch Siachdaa6f082018-06-18 21:56:23 +0300303 default "controlcenterdc" if TARGET_CONTROLCENTERDC
Chris Packhamb55b2c92019-01-10 21:01:00 +1300304 default "x530" if TARGET_X530
Chris Packham7325f1f2023-07-10 10:47:36 +1200305 default "x240" if TARGET_X240
Chris Packham199e3182019-04-11 22:22:53 +1200306 default "db-xc3-24g4xg" if TARGET_DB_XC3_24G4XG
Luka Kovacic25acb8b2020-05-26 20:17:50 +0200307 default "crs3xx-98dx3236" if TARGET_CRS3XX_98DX3236
Chris Packham67b7d502022-11-05 17:24:00 +1300308 default "mvebu_alleycat-5" if TARGET_MVEBU_ALLEYCAT5
Stefan Roeseb9f41bf2015-12-21 13:40:37 +0100309
310config SYS_VENDOR
311 default "Marvell" if TARGET_DB_MV784MP_GP
Konstantin Porotchkin7f8dfea2017-02-16 13:52:22 +0200312 default "Marvell" if TARGET_MVEBU_ARMADA_37XX
Stefan Roese9106ed02016-01-29 09:14:54 +0100313 default "Marvell" if TARGET_DB_88F6720
Stefan Roeseb9f41bf2015-12-21 13:40:37 +0100314 default "Marvell" if TARGET_DB_88F6820_GP
Chris Packhama90dd4c2016-09-22 12:56:14 +1200315 default "Marvell" if TARGET_DB_88F6820_AMC
Stefan Roese5c806f12016-10-25 10:56:19 +0200316 default "Marvell" if TARGET_MVEBU_ARMADA_8K
Konstantin Porotchkin1d6ff1f2021-03-16 17:20:57 +0100317 default "Marvell" if TARGET_OCTEONTX2_CN913x
Chris Packham199e3182019-04-11 22:22:53 +1200318 default "Marvell" if TARGET_DB_XC3_24G4XG
319 default "Marvell" if TARGET_MVEBU_DB_88F7040
Stefan Roeseb9f41bf2015-12-21 13:40:37 +0100320 default "solidrun" if TARGET_CLEARFOG
Dennis Gilmore77c39402018-06-11 19:39:53 -0500321 default "kobol" if TARGET_HELIOS4
Tony Dinh6aebc1a2023-02-09 14:00:03 -0800322 default "Synology" if TARGET_DS116
Phil Sutterd76eba62015-12-25 14:41:25 +0100323 default "Synology" if TARGET_DS414
Tony Dinh63eba132023-02-01 15:13:05 -0800324 default "thecus" if TARGET_N2350
Marek Behún09e16b82017-06-09 19:28:45 +0200325 default "CZ.NIC" if TARGET_TURRIS_OMNIA
Marek Behúnf835bed2018-04-24 17:21:31 +0200326 default "CZ.NIC" if TARGET_TURRIS_MOX
Baruch Siachdaa6f082018-06-18 21:56:23 +0300327 default "gdsys" if TARGET_CONTROLCENTERDC
Chris Packhamb55b2c92019-01-10 21:01:00 +1300328 default "alliedtelesis" if TARGET_X530
Chris Packham7325f1f2023-07-10 10:47:36 +1200329 default "alliedtelesis" if TARGET_X240
Luka Kovacic25acb8b2020-05-26 20:17:50 +0200330 default "mikrotik" if TARGET_CRS3XX_98DX3236
Chris Packham67b7d502022-11-05 17:24:00 +1300331 default "Marvell" if TARGET_MVEBU_ALLEYCAT5
Stefan Roeseb9f41bf2015-12-21 13:40:37 +0100332
Stefan Roese383e0c12015-08-25 13:18:38 +0200333config SYS_SOC
334 default "mvebu"
335
Marek Behún09e16b82017-06-09 19:28:45 +0200336choice
Baruch Siach8d196a42018-06-18 21:56:24 +0300337 prompt "Boot method"
Joel Johnsona2018ab2020-04-17 01:19:05 -0600338 depends on SPL
Marek Behún09e16b82017-06-09 19:28:45 +0200339
Baruch Siach8d196a42018-06-18 21:56:24 +0300340config MVEBU_SPL_BOOT_DEVICE_SPI
Pali Rohár8d110322023-01-10 23:13:01 +0100341 bool "NOR flash (SPI or parallel)"
Joel Johnsona2018ab2020-04-17 01:19:05 -0600342 imply ENV_IS_IN_SPI_FLASH
Pali Rohárcf97b822021-07-23 11:14:29 +0200343 imply SPL_DM_SPI
344 imply SPL_SPI_FLASH_SUPPORT
345 imply SPL_SPI_LOAD
Simon Glassa5820472021-08-08 12:20:14 -0600346 imply SPL_SPI
Pali Rohára3a38e52021-07-23 11:14:25 +0200347 select SPL_BOOTROM_SUPPORT
Marek Behún09e16b82017-06-09 19:28:45 +0200348
Pali Rohár5c5cf602023-01-10 22:55:21 +0100349config MVEBU_SPL_BOOT_DEVICE_NAND
350 bool "NAND flash (SPI or parallel)"
351 select MTD_RAW_NAND
352 select SPL_BOOTROM_SUPPORT
353
Baruch Siach8d196a42018-06-18 21:56:24 +0300354config MVEBU_SPL_BOOT_DEVICE_MMC
Pali Rohár8d110322023-01-10 23:13:01 +0100355 bool "eMMC or SD card"
Joel Johnsona2018ab2020-04-17 01:19:05 -0600356 imply ENV_IS_IN_MMC
357 # GPIO needed for eMMC/SD card presence detection
Pali Rohárcf97b822021-07-23 11:14:29 +0200358 imply SPL_DM_GPIO
359 imply SPL_DM_MMC
360 imply SPL_GPIO
361 imply SPL_LIBDISK_SUPPORT
Simon Glassb58bfe02021-08-08 12:20:09 -0600362 imply SPL_MMC
Pali Rohárcefdc032023-01-08 13:31:41 +0100363 select SUPPORT_EMMC_BOOT if SPL_MMC
Pali Roháraa6244e2023-01-09 00:52:09 +0100364 select SYS_MMCSD_RAW_MODE_U_BOOT_USE_SECTOR if SPL_MMC
Pali Rohára3a38e52021-07-23 11:14:25 +0200365 select SPL_BOOTROM_SUPPORT
Marek Behún09e16b82017-06-09 19:28:45 +0200366
Baruch Siachb936a272019-05-16 13:03:58 +0300367config MVEBU_SPL_BOOT_DEVICE_SATA
368 bool "SATA"
Simon Glass081a45a2021-08-08 12:20:17 -0600369 imply SPL_SATA
Pali Rohárcf97b822021-07-23 11:14:29 +0200370 imply SPL_LIBDISK_SUPPORT
Pali Rohára3a38e52021-07-23 11:14:25 +0200371 select SPL_BOOTROM_SUPPORT
Baruch Siachb936a272019-05-16 13:03:58 +0300372
Pali Rohárea876902023-01-10 23:09:15 +0100373config MVEBU_SPL_BOOT_DEVICE_PEX
374 bool "PCI Express"
375 select SPL_BOOTROM_SUPPORT
376
Baruch Siachb35c4472018-06-18 21:56:26 +0300377config MVEBU_SPL_BOOT_DEVICE_UART
378 bool "UART"
Pali Rohára3a38e52021-07-23 11:14:25 +0200379 select SPL_BOOTROM_SUPPORT
Baruch Siachb35c4472018-06-18 21:56:26 +0300380
Marek Behún09e16b82017-06-09 19:28:45 +0200381endchoice
382
Pali Rohár5c5cf602023-01-10 22:55:21 +0100383config MVEBU_SPL_NAND_BADBLK_LOCATION
384 hex "NAND Bad block indicator location"
385 depends on MVEBU_SPL_BOOT_DEVICE_NAND
386 range 0x0 0x1
387 help
388 Value 0x0 = SLC flash = BBI at page 0 or page 1
389 Value 0x1 = MLC flash = BBI at last page in the block
390
Pali Rohár7085f822023-03-29 21:25:58 +0200391config MVEBU_SPL_SATA_BLKSZ
392 int "SATA block size"
393 depends on MVEBU_SPL_BOOT_DEVICE_SATA
394 range 512 32768
395 default 512
396 help
397 Block size of the SATA disk in bytes.
398 Typically 512 bytes for majority of disks
399 and 4096 bytes for 4K Native disks.
400
Mario Six10d14492017-01-11 16:01:00 +0100401config MVEBU_EFUSE
402 bool "Enable eFuse support"
Mario Six10d14492017-01-11 16:01:00 +0100403 depends on HAVE_MVEBU_EFUSE
404 help
405 Enable support for reading and writing eFuses on mvebu SoCs.
406
407config MVEBU_EFUSE_FAKE
408 bool "Fake eFuse access (dry run)"
Mario Six10d14492017-01-11 16:01:00 +0100409 depends on MVEBU_EFUSE
410 help
411 This enables a "dry run" mode where eFuses are not really programmed.
412 Instead the eFuse accesses are emulated by writing to and reading
413 from a memory block.
414 This is can be used for testing prog scripts.
415
Pali Rohár2662d2c2022-09-22 13:43:45 +0200416config MVEBU_EFUSE_VHV_GPIO
417 string "VHV_Enable GPIO name for eFuse programming"
418 depends on MVEBU_EFUSE && !ARMADA_3700
419 help
420 The eFuse programing (burning) phase requires supplying 1.8V to the
421 device on the VHV power pin, while for normal operation the VHV power
422 rail must be left unconnected. See Marvell AN-389: ARMADA VHV Power
423 document (Doc. No. MV-S302545-00 Rev. C, August 2, 2016) for details.
424 .
425 This specify VHV_Enable GPIO name used in U-Boot for enabling VHV power.
426
427config MVEBU_EFUSE_VHV_GPIO_ACTIVE_LOW
428 bool "VHV_Enable GPIO is Active Low"
429 depends on MVEBU_EFUSE_VHV_GPIO != ""
430
Mario Six10d14492017-01-11 16:01:00 +0100431config SECURED_MODE_IMAGE
432 bool "Build image for trusted boot"
433 default false
434 depends on 88F6820
435 help
436 Build an image that employs the ARMADA SoC's trusted boot framework
437 for securely booting images.
438
439config SECURED_MODE_CSK_INDEX
440 int "Index of active CSK"
441 default 0
442 depends on SECURED_MODE_IMAGE
443
Tony Dinh89dc46d2023-03-02 19:27:29 -0800444config SF_DEFAULT_SPEED
445 int "Default speed for SPI flash in Hz"
446 default 10000000
447 depends on MVEBU_SPL_BOOT_DEVICE_SPI
448
449config SF_DEFAULT_MODE
450 hex "Default mode for SPI flash"
451 default 0x0
452 depends on MVEBU_SPL_BOOT_DEVICE_SPI
453
Joel Johnson28bf4ca2020-03-23 14:21:32 -0600454source "board/solidrun/clearfog/Kconfig"
Dennis Gilmore838e49b2020-12-08 21:07:36 -0600455source "board/kobol/helios4/Kconfig"
Joel Johnson28bf4ca2020-03-23 14:21:32 -0600456
Stefan Roese383e0c12015-08-25 13:18:38 +0200457endif