blob: 787f983ffd460318c7754d7a3f4aeeb5bde55fe6 [file] [log] [blame]
Masahiro Yamadad3ae6782014-07-30 14:08:14 +09001menu "ARM architecture"
2 depends on ARM
3
4config SYS_ARCH
Masahiro Yamadad3ae6782014-07-30 14:08:14 +09005 default "arm"
6
Masahiro Yamada0d46c342014-09-14 03:01:51 +09007config ARM64
8 bool
Dan Carpenter391b84e2024-03-04 10:04:29 +03009 select 64BIT
Masahiro Yamada653e9fe2016-07-25 19:56:03 +090010 select PHYS_64BIT
Tom Rini84f9b612016-08-22 08:22:17 -040011 select SYS_CACHE_SHIFT_6
Sean Anderson13871e12022-04-12 10:59:04 -040012 imply SPL_SEPARATE_BSS
Masahiro Yamada0d46c342014-09-14 03:01:51 +090013
Marek Vasut355405c2021-08-30 15:05:23 +020014config ARM64_CRC32
15 bool "Enable support for CRC32 instruction"
Tom Rini83b60bd2023-04-05 19:48:51 -040016 depends on ARM64 && CC_IS_GCC
Marek Vasut355405c2021-08-30 15:05:23 +020017 default y
18 help
19 ARMv8 implements dedicated crc32 instruction for crc32 calculation.
20 This is faster than software crc32 calculation. This instruction may
21 not be present on all ARMv8.0, but is always present on ARMv8.1 and
22 newer.
23
Peng Fan8541b9f2022-04-13 17:47:18 +080024config COUNTER_FREQUENCY
25 int "Timer clock frequency"
26 depends on ARM64 || CPU_V7A
Peng Fan30c80dd2022-04-13 17:47:19 +080027 default 8000000 if IMX8 || MX7 || MX6UL || MX6ULL
28 default 24000000 if ARCH_SUNXI || ARCH_EXYNOS || ROCKCHIP_RK3128 || \
29 ROCKCHIP_RK3288 || ROCKCHIP_RK322X || ROCKCHIP_RK3036
30 default 25000000 if ARCH_LX2160A || ARCH_LX2162A || ARCH_LS1088A
31 default 100000000 if ARCH_ZYNQMP
Jit Loon Lim977071e2024-03-12 22:01:03 +080032 default 200000000 if ARCH_SOCFPGA && ARM64 && TARGET_SOCFPGA_AGILEX5
Peng Fan8541b9f2022-04-13 17:47:18 +080033 default 0
34 help
35 For platforms with ARMv8-A and ARMv7-A which features a system
36 counter, those platforms needs software to program the counter
37 frequency. Setup time clock frequency for certain platform.
38 0 means no need to configure the system counter frequency.
39 For platforms needs the frequency set in U-Boot with a
40 pre-defined value, should have the macro defined as a non-zero value.
41
Stephen Warren81c21372017-11-02 18:11:27 -060042config POSITION_INDEPENDENT
43 bool "Generate position-independent pre-relocation code"
Chia-Wei Wangbbd3c612021-08-03 10:50:10 +080044 depends on ARM64 || CPU_V7A
Stephen Warren81c21372017-11-02 18:11:27 -060045 help
46 U-Boot expects to be linked to a specific hard-coded address, and to
47 be loaded to and run from that address. This option lifts that
Edgar E. Iglesias63d73362020-09-09 19:07:24 +020048 restriction, thus allowing the code to be loaded to and executed from
49 almost any 4K aligned address. This logic relies on the relocation
Robert P. J. Day3a8d4e12019-12-25 06:34:07 -050050 information that is embedded in the binary to support U-Boot
Stephen Warren81c21372017-11-02 18:11:27 -060051 relocating itself to the top-of-RAM later during execution.
Stephen Warrenb80fe6d2017-12-19 18:30:36 -070052
Masahiro Yamadabf4645c2019-06-26 13:51:46 +090053config INIT_SP_RELATIVE
54 bool "Specify the early stack pointer relative to the .bss section"
Chia-Wei Wang88103202021-08-03 10:50:09 +080055 depends on ARM64
Andre Przywara4d711892020-09-30 17:39:18 +010056 default n if ARCH_QEMU
Andre Przywaraa834b772020-09-30 17:39:15 +010057 default y if POSITION_INDEPENDENT
Stephen Warrenb80fe6d2017-12-19 18:30:36 -070058 help
59 U-Boot typically uses a hard-coded value for the stack pointer
Masahiro Yamadabf4645c2019-06-26 13:51:46 +090060 before relocation. Enable this option to instead calculate the
Stephen Warrenb80fe6d2017-12-19 18:30:36 -070061 initial SP at run-time. This is useful to avoid hard-coding addresses
Robert P. J. Day3a8d4e12019-12-25 06:34:07 -050062 into U-Boot, so that it can be loaded and executed at arbitrary
Masahiro Yamadabf4645c2019-06-26 13:51:46 +090063 addresses and thus avoid using arbitrary addresses at runtime.
64
65 If this option is enabled, the early stack pointer is set to
66 &_bss_start with a offset value added. The offset is specified by
67 SYS_INIT_SP_BSS_OFFSET.
68
69config SYS_INIT_SP_BSS_OFFSET
70 int "Early stack offset from the .bss base address"
Chia-Wei Wang88103202021-08-03 10:50:09 +080071 depends on ARM64
Masahiro Yamadabf4645c2019-06-26 13:51:46 +090072 depends on INIT_SP_RELATIVE
73 default 524288
74 help
75 This option's value is the offset added to &_bss_start in order to
Stephen Warrenb80fe6d2017-12-19 18:30:36 -070076 calculate the stack pointer. This offset should be large enough so
77 that the early malloc region, global data (gd), and early stack usage
78 do not overlap any appended DTB.
Stephen Warren80a93652018-01-03 14:31:51 -070079
Pali Rohára4d6e0f2022-04-06 16:20:18 +020080config SPL_SYS_NO_VECTOR_TABLE
81 depends on SPL
82 bool
83
Csókás Bence2c6e70b2023-12-19 14:33:18 +010084config SPL_USE_SEPARATE_FAULT_HANDLERS
85 bool "Use separate fault handlers instead of a single common one"
86 depends on !SPL_SYS_NO_VECTOR_TABLE && !ARM64 && !CPU_V7M
87 help
88 Instead of a common fault handler, generate a separate one for
89 undefined_instruction, software_interrupt, prefetch_abort etc.
90 This is for debugging purposes, when you want to set breakpoints
91 on them separately.
92
Stephen Warren80a93652018-01-03 14:31:51 -070093config LINUX_KERNEL_IMAGE_HEADER
Chia-Wei Wang88103202021-08-03 10:50:09 +080094 depends on ARM64
Stephen Warren80a93652018-01-03 14:31:51 -070095 bool
96 help
97 Place a Linux kernel image header at the start of the U-Boot binary.
98 The format of the header is described in the Linux kernel source at
99 Documentation/arm64/booting.txt. This feature is useful since the
100 image header reports the amount of memory (BSS and similar) that
101 U-Boot needs to use, but which isn't part of the binary.
102
Stephen Warren80a93652018-01-03 14:31:51 -0700103config LNX_KRNL_IMG_TEXT_OFFSET_BASE
Chia-Wei Wang88103202021-08-03 10:50:09 +0800104 depends on LINUX_KERNEL_IMAGE_HEADER
Stephen Warren80a93652018-01-03 14:31:51 -0700105 hex
106 help
Simon Glass72cc5382022-10-20 18:22:39 -0600107 The value subtracted from CONFIG_TEXT_BASE to calculate the
Robert P. J. Day3a8d4e12019-12-25 06:34:07 -0500108 TEXT_OFFSET value written to the Linux kernel image header.
Stephen Warren81c21372017-11-02 18:11:27 -0600109
Tom Rini249f11f2021-08-19 14:19:39 -0400110config GICV2
111 bool
112
113config GICV3
114 bool
115
Patrick Rudolph7cda00a2024-10-23 15:20:04 +0200116config DRIVER_GICV2
117 bool "ARM GICV2 driver"
118 select IRQ
119 help
120 ARM GICV2 driver.
121 Basic support for parsing the GICV2 node and generate ACPI tables.
122
Bharat Kumar Reddy Gooty436efc02019-12-16 09:09:43 -0800123config GIC_V3_ITS
124 bool "ARM GICV3 ITS"
Wasim Khan339539c2021-03-08 16:48:14 +0100125 select IRQ
Bharat Kumar Reddy Gooty436efc02019-12-16 09:09:43 -0800126 help
127 ARM GICV3 Interrupt translation service (ITS).
128 Basic support for programming locality specific peripheral
129 interrupts (LPI) configuration tables and enable LPI tables.
130 LPI configuration table can be used by u-boot or Linux.
131 ARM GICV3 has limitation, once the LPI table is enabled, LPI
132 configuration table can not be re-programmed, unless GICV3 reset.
133
Venkatesh Yadav Abbarapuda023da2024-03-06 16:54:41 +0530134config GICV3_SUPPORT_GIC600
135 bool "ARM GICV3 GIC600 SUPPORT"
136 help
137 ARM GIC-600 IP complies with ARM GICv3 architecture, but among others,
138 implements a power control register in the Redistributor frame.This
139 register must be programmed to mark the frame as powered on, before
140 accessing other registers in the frame. Rest of initialization sequence
141 remains the same.
142
Stephen Warren81c21372017-11-02 18:11:27 -0600143config STATIC_RELA
144 bool
Andre Przywaraf7582ee2020-09-30 17:39:13 +0100145 default y if ARM64
Stephen Warren81c21372017-11-02 18:11:27 -0600146
Lokesh Vutlaf94277d2016-03-24 16:02:00 +0530147config DMA_ADDR_T_64BIT
148 bool
149 default y if ARM64
150
Georges Savoundararadj3bae15f2014-10-28 23:16:09 +0100151config HAS_VBAR
Tom Rinibca01962016-08-22 08:22:18 -0400152 bool
Georges Savoundararadj3bae15f2014-10-28 23:16:09 +0100153
Albert ARIBAUDa3823222015-10-23 18:06:40 +0200154config HAS_THUMB2
Tom Rinibca01962016-08-22 08:22:18 -0400155 bool
Albert ARIBAUDa3823222015-10-23 18:06:40 +0200156
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900157config GPIO_EXTRA_HEADER
158 bool
159
Phil Edworthy3b8f16a2017-06-01 07:33:28 +0100160# Used for compatibility with asm files copied from the kernel
161config ARM_ASM_UNIFIED
162 bool
163 default y
164
165# Used for compatibility with asm files copied from the kernel
166config THUMB2_KERNEL
167 bool
168
Trevor Woernerba64b8b2019-05-03 09:40:59 -0400169config SYS_ICACHE_OFF
170 bool "Do not enable icache"
Trevor Woernerba64b8b2019-05-03 09:40:59 -0400171 help
172 Do not enable instruction cache in U-Boot.
173
Trevor Woerner43ec7e02019-05-03 09:41:00 -0400174config SPL_SYS_ICACHE_OFF
175 bool "Do not enable icache in SPL"
176 depends on SPL
177 default SYS_ICACHE_OFF
178 help
179 Do not enable instruction cache in SPL.
180
Trevor Woernerba64b8b2019-05-03 09:40:59 -0400181config SYS_DCACHE_OFF
182 bool "Do not enable dcache"
Trevor Woernerba64b8b2019-05-03 09:40:59 -0400183 help
184 Do not enable data cache in U-Boot.
185
Trevor Woerner43ec7e02019-05-03 09:41:00 -0400186config SPL_SYS_DCACHE_OFF
187 bool "Do not enable dcache in SPL"
188 depends on SPL
189 default SYS_DCACHE_OFF
190 help
191 Do not enable data cache in SPL.
192
Lokesh Vutla5a5bb6c2018-04-26 18:21:28 +0530193config SYS_ARM_CACHE_CP15
194 bool "CP15 based cache enabling support"
195 help
196 Select this if your processor suports enabling caches by using
197 CP15 registers.
198
Lokesh Vutlab2d00d62018-04-26 18:21:27 +0530199config SYS_ARM_MMU
200 bool "MMU-based Paged Memory Management Support"
Lokesh Vutla5a5bb6c2018-04-26 18:21:28 +0530201 select SYS_ARM_CACHE_CP15
Lokesh Vutlab2d00d62018-04-26 18:21:27 +0530202 help
203 Select if you want MMU-based virtualised addressing space
Robert P. J. Day3a8d4e12019-12-25 06:34:07 -0500204 support via paged memory management.
Lokesh Vutlab2d00d62018-04-26 18:21:27 +0530205
Lokesh Vutla076ee452018-04-26 18:21:30 +0530206config SYS_ARM_MPU
207 bool 'Use the ARM v7 PMSA Compliant MPU'
208 help
209 Some ARM systems without an MMU have instead a Memory Protection
210 Unit (MPU) that defines the type and permissions for regions of
211 memory.
212 If your CPU has an MPU then you should choose 'y' here unless you
213 know that you do not want to use the MPU.
214
Tom Rinibacb52c2017-03-07 07:13:42 -0500215# If set, the workarounds for these ARM errata are applied early during U-Boot
216# startup. Note that in general these options force the workarounds to be
217# applied; no CPU-type/version detection exists, unlike the similar options in
218# the Linux kernel. Do not set these options unless they apply! Also note that
Robert P. J. Day3a8d4e12019-12-25 06:34:07 -0500219# the following can be machine-specific errata. These do have ability to
220# provide rudimentary version and machine-specific checks, but expect no
Tom Rinibacb52c2017-03-07 07:13:42 -0500221# product checks:
222# CONFIG_ARM_ERRATA_430973
223# CONFIG_ARM_ERRATA_454179
224# CONFIG_ARM_ERRATA_621766
225# CONFIG_ARM_ERRATA_798870
226# CONFIG_ARM_ERRATA_801819
Nishanth Menon85515bf2018-06-12 15:24:08 -0500227# CONFIG_ARM_CORTEX_A8_CVE_2017_5715
Nishanth Menon6ffdeaa2018-06-12 15:24:09 -0500228# CONFIG_ARM_CORTEX_A15_CVE_2017_5715
Nishanth Menon85515bf2018-06-12 15:24:08 -0500229
Tom Rinibacb52c2017-03-07 07:13:42 -0500230config ARM_ERRATA_430973
231 bool
232
233config ARM_ERRATA_454179
234 bool
235
236config ARM_ERRATA_621766
237 bool
238
239config ARM_ERRATA_716044
240 bool
241
Siarhei Siamashkafe038a72017-03-06 03:16:53 +0200242config ARM_ERRATA_725233
243 bool
244
Tom Rinibacb52c2017-03-07 07:13:42 -0500245config ARM_ERRATA_742230
246 bool
247
248config ARM_ERRATA_743622
249 bool
250
251config ARM_ERRATA_751472
252 bool
253
254config ARM_ERRATA_761320
255 bool
256
257config ARM_ERRATA_773022
258 bool
259
260config ARM_ERRATA_774769
261 bool
262
263config ARM_ERRATA_794072
264 bool
265
266config ARM_ERRATA_798870
267 bool
268
269config ARM_ERRATA_801819
270 bool
271
272config ARM_ERRATA_826974
273 bool
274
275config ARM_ERRATA_828024
276 bool
277
278config ARM_ERRATA_829520
279 bool
280
281config ARM_ERRATA_833069
282 bool
283
284config ARM_ERRATA_833471
285 bool
286
Peng Fan5ac341f2017-08-08 13:34:52 +0800287config ARM_ERRATA_845369
Michal Simekf751ff52018-07-23 15:55:12 +0200288 bool
Peng Fan5ac341f2017-08-08 13:34:52 +0800289
Nisal Menukafaa993a2017-04-26 16:18:01 -0500290config ARM_ERRATA_852421
291 bool
292
293config ARM_ERRATA_852423
294 bool
295
Alison Wangc1293872017-12-28 13:00:55 +0800296config ARM_ERRATA_855873
297 bool
298
Nishanth Menon85515bf2018-06-12 15:24:08 -0500299config ARM_CORTEX_A8_CVE_2017_5715
300 bool
301
Nishanth Menon6ffdeaa2018-06-12 15:24:09 -0500302config ARM_CORTEX_A15_CVE_2017_5715
303 bool
304
Georges Savoundararadj3bae15f2014-10-28 23:16:09 +0100305config CPU_ARM720T
Tom Rinibca01962016-08-22 08:22:18 -0400306 bool
Tom Rini84f9b612016-08-22 08:22:17 -0400307 select SYS_CACHE_SHIFT_5
Lokesh Vutlab2d00d62018-04-26 18:21:27 +0530308 imply SYS_ARM_MMU
Georges Savoundararadj3bae15f2014-10-28 23:16:09 +0100309
310config CPU_ARM920T
Tom Rinibca01962016-08-22 08:22:18 -0400311 bool
Tom Rini84f9b612016-08-22 08:22:17 -0400312 select SYS_CACHE_SHIFT_5
Lokesh Vutlab2d00d62018-04-26 18:21:27 +0530313 imply SYS_ARM_MMU
Georges Savoundararadj3bae15f2014-10-28 23:16:09 +0100314
315config CPU_ARM926EJS
Tom Rinibca01962016-08-22 08:22:18 -0400316 bool
Tom Rini84f9b612016-08-22 08:22:17 -0400317 select SYS_CACHE_SHIFT_5
Lokesh Vutlab2d00d62018-04-26 18:21:27 +0530318 imply SYS_ARM_MMU
Sean Anderson13871e12022-04-12 10:59:04 -0400319 imply SPL_SEPARATE_BSS
Georges Savoundararadj3bae15f2014-10-28 23:16:09 +0100320
321config CPU_ARM946ES
Tom Rinibca01962016-08-22 08:22:18 -0400322 bool
Tom Rini84f9b612016-08-22 08:22:17 -0400323 select SYS_CACHE_SHIFT_5
Lokesh Vutlab2d00d62018-04-26 18:21:27 +0530324 imply SYS_ARM_MMU
Georges Savoundararadj3bae15f2014-10-28 23:16:09 +0100325
326config CPU_ARM1136
Tom Rinibca01962016-08-22 08:22:18 -0400327 bool
Tom Rini84f9b612016-08-22 08:22:17 -0400328 select SYS_CACHE_SHIFT_5
Lokesh Vutlab2d00d62018-04-26 18:21:27 +0530329 imply SYS_ARM_MMU
Sean Anderson13871e12022-04-12 10:59:04 -0400330 imply SPL_SEPARATE_BSS
Georges Savoundararadj3bae15f2014-10-28 23:16:09 +0100331
332config CPU_ARM1176
Tom Rinibca01962016-08-22 08:22:18 -0400333 bool
334 select HAS_VBAR
Tom Rini84f9b612016-08-22 08:22:17 -0400335 select SYS_CACHE_SHIFT_5
Lokesh Vutlab2d00d62018-04-26 18:21:27 +0530336 imply SYS_ARM_MMU
Georges Savoundararadj3bae15f2014-10-28 23:16:09 +0100337
Lokesh Vutla81b1a672018-04-26 18:21:26 +0530338config CPU_V7A
Tom Rinibca01962016-08-22 08:22:18 -0400339 bool
Tom Rinibca01962016-08-22 08:22:18 -0400340 select HAS_THUMB2
Michal Simek84f3dec2018-07-23 15:55:13 +0200341 select HAS_VBAR
Tom Rini84f9b612016-08-22 08:22:17 -0400342 select SYS_CACHE_SHIFT_6
Lokesh Vutlab2d00d62018-04-26 18:21:27 +0530343 imply SYS_ARM_MMU
Georges Savoundararadj3bae15f2014-10-28 23:16:09 +0100344
rev13@wp.plb3b57e82015-03-01 12:44:39 +0100345config CPU_V7M
346 bool
Tom Rinibca01962016-08-22 08:22:18 -0400347 select HAS_THUMB2
Lokesh Vutla076ee452018-04-26 18:21:30 +0530348 select SYS_ARM_MPU
Michal Simek84f3dec2018-07-23 15:55:13 +0200349 select SYS_CACHE_SHIFT_5
Tom Rini19bdef62018-05-07 20:46:52 -0400350 select SYS_THUMB_BUILD
Michal Simek84f3dec2018-07-23 15:55:13 +0200351 select THUMB2_KERNEL
rev13@wp.plb3b57e82015-03-01 12:44:39 +0100352
Michal Simekf4359382018-04-26 18:21:29 +0530353config CPU_V7R
354 bool
355 select HAS_THUMB2
Lokesh Vutla076ee452018-04-26 18:21:30 +0530356 select SYS_ARM_CACHE_CP15
Michal Simek84f3dec2018-07-23 15:55:13 +0200357 select SYS_ARM_MPU
358 select SYS_CACHE_SHIFT_6
Michal Simekf4359382018-04-26 18:21:29 +0530359
Georges Savoundararadj3bae15f2014-10-28 23:16:09 +0100360config SYS_CPU
Tom Rinibca01962016-08-22 08:22:18 -0400361 default "arm720t" if CPU_ARM720T
362 default "arm920t" if CPU_ARM920T
363 default "arm926ejs" if CPU_ARM926EJS
364 default "arm946es" if CPU_ARM946ES
365 default "arm1136" if CPU_ARM1136
366 default "arm1176" if CPU_ARM1176
Lokesh Vutla81b1a672018-04-26 18:21:26 +0530367 default "armv7" if CPU_V7A
Michal Simekf4359382018-04-26 18:21:29 +0530368 default "armv7" if CPU_V7R
Tom Rinibca01962016-08-22 08:22:18 -0400369 default "armv7m" if CPU_V7M
Masahiro Yamadadade3b02014-11-06 11:39:27 +0900370 default "armv8" if ARM64
Georges Savoundararadj3bae15f2014-10-28 23:16:09 +0100371
Marek Vasutb06c9542016-05-26 18:01:36 +0200372config SYS_ARM_ARCH
373 int
374 default 4 if CPU_ARM720T
375 default 4 if CPU_ARM920T
376 default 5 if CPU_ARM926EJS
377 default 5 if CPU_ARM946ES
378 default 6 if CPU_ARM1136
379 default 6 if CPU_ARM1176
Lokesh Vutla81b1a672018-04-26 18:21:26 +0530380 default 7 if CPU_V7A
Marek Vasutb06c9542016-05-26 18:01:36 +0200381 default 7 if CPU_V7M
Michal Simekf4359382018-04-26 18:21:29 +0530382 default 7 if CPU_V7R
Marek Vasutb06c9542016-05-26 18:01:36 +0200383 default 8 if ARM64
384
Patrick Delaunayafc69a92020-04-10 16:02:02 +0200385choice
386 prompt "Select the ARM data write cache policy"
Tom Rini6b0eeb72023-07-18 19:33:28 -0400387 default SYS_ARM_CACHE_WRITETHROUGH if TARGET_BCMNS || RZA1
Patrick Delaunayafc69a92020-04-10 16:02:02 +0200388 default SYS_ARM_CACHE_WRITEBACK
389
390config SYS_ARM_CACHE_WRITEBACK
391 bool "Write-back (WB)"
392 help
393 A write updates the cache only and marks the cache line as dirty.
394 External memory is updated only when the line is evicted or explicitly
395 cleaned.
396
397config SYS_ARM_CACHE_WRITETHROUGH
398 bool "Write-through (WT)"
399 help
400 A write updates both the cache and the external memory system.
401 This does not mark the cache line as dirty.
402
403config SYS_ARM_CACHE_WRITEALLOC
404 bool "Write allocation (WA)"
405 help
406 A cache line is allocated on a write miss. This means that executing a
407 store instruction on the processor might cause a burst read to occur.
408 There is a linefill to obtain the data for the cache line, before the
409 write is performed.
410endchoice
411
Pali Rohár3588a412022-05-06 11:05:13 +0200412config ARCH_VERY_EARLY_INIT
413 bool
414
415config SPL_ARCH_VERY_EARLY_INIT
416 bool
417
Adam Fordd36b1022019-08-14 08:29:25 -0500418config ARCH_CPU_INIT
419 bool "Enable ARCH_CPU_INIT"
420 help
Robert P. J. Day3a8d4e12019-12-25 06:34:07 -0500421 Some architectures require a call to arch_cpu_init().
Adam Fordd36b1022019-08-14 08:29:25 -0500422 Say Y here to enable it
423
Andre Przywara7b169252018-04-12 04:24:46 +0300424config SYS_ARCH_TIMER
425 bool "ARM Generic Timer support"
Lokesh Vutla81b1a672018-04-26 18:21:26 +0530426 depends on CPU_V7A || ARM64
Andre Przywara7b169252018-04-12 04:24:46 +0300427 default y if ARM64
428 help
429 The ARM Generic Timer (aka arch-timer) provides an architected
430 interface to a timer source on an SoC.
Robert P. J. Day3a8d4e12019-12-25 06:34:07 -0500431 It is mandatory for ARMv8 implementation and widely available
Andre Przywara7b169252018-04-12 04:24:46 +0300432 on ARMv7 systems.
433
Masahiro Yamadae8ead732017-04-14 11:10:23 +0900434config ARM_SMCCC
435 bool "Support for ARM SMC Calling Convention (SMCCC)"
Lokesh Vutla81b1a672018-04-26 18:21:26 +0530436 depends on CPU_V7A || ARM64
Masahiro Yamada836c55d2017-04-14 11:10:24 +0900437 select ARM_PSCI_FW
Masahiro Yamadae8ead732017-04-14 11:10:23 +0900438 help
439 Say Y here if you want to enable ARM SMC Calling Convention.
440 This should be enabled if U-Boot needs to communicate with system
441 firmware (for example, PSCI) according to SMCCC.
442
Tom Rini1c640a62017-03-18 09:01:44 -0400443config SYS_THUMB_BUILD
444 bool "Build U-Boot using the Thumb instruction set"
445 depends on !ARM64
446 help
447 Use this flag to build U-Boot using the Thumb instruction set for
448 ARM architectures. Thumb instruction set provides better code
449 density. For ARM architectures that support Thumb2 this flag will
450 result in Thumb2 code generated by GCC.
451
452config SPL_SYS_THUMB_BUILD
453 bool "Build SPL using the Thumb instruction set"
454 default y if SYS_THUMB_BUILD
Adam Ford43a1e2d2019-08-13 14:32:30 -0500455 depends on !ARM64 && SPL
Tom Rini1c640a62017-03-18 09:01:44 -0400456 help
457 Use this flag to build SPL using the Thumb instruction set for
458 ARM architectures. Thumb instruction set provides better code
459 density. For ARM architectures that support Thumb2 this flag will
460 result in Thumb2 code generated by GCC.
461
Kever Yang55688602019-04-02 20:41:20 +0800462config TPL_SYS_THUMB_BUILD
463 bool "Build TPL using the Thumb instruction set"
464 default y if SYS_THUMB_BUILD
465 depends on TPL && !ARM64
466 help
Robert P. J. Day3a8d4e12019-12-25 06:34:07 -0500467 Use this flag to build TPL using the Thumb instruction set for
Kever Yang55688602019-04-02 20:41:20 +0800468 ARM architectures. Thumb instruction set provides better code
469 density. For ARM architectures that support Thumb2 this flag will
470 result in Thumb2 code generated by GCC.
471
Philip Oberfichtner5833e1b2022-08-17 15:07:12 +0200472config SYS_L2_PL310
473 bool "ARM PL310 L2 cache controller"
474 help
475 Enable support for ARM PL310 L2 cache controller in U-Boot
Kever Yang55688602019-04-02 20:41:20 +0800476
Philip Oberfichtnerc55a2522022-08-17 15:07:13 +0200477config SPL_SYS_L2_PL310
478 bool "ARM PL310 L2 cache controller in SPL"
479 help
480 Enable support for ARM PL310 L2 cache controller in SPL
481
Peng Fan10ddab42015-08-19 15:48:57 +0800482config SYS_L2CACHE_OFF
483 bool "L2cache off"
484 help
Robert P. J. Day3a8d4e12019-12-25 06:34:07 -0500485 If SoC does not support L2CACHE or one does not want to enable
Peng Fan10ddab42015-08-19 15:48:57 +0800486 L2CACHE, choose this option.
487
Andre Przywara48321ba2016-05-31 10:45:06 -0700488config ENABLE_ARM_SOC_BOOT0_HOOK
489 bool "prepare BOOT0 header"
490 help
491 If the SoC's BOOT0 requires a header area filled with (magic)
Simon Goldschmidt387218a2018-02-13 13:18:00 +0100492 values, then choose this option, and create a file included as
493 <asm/arch/boot0.h> which contains the required assembler code.
Andre Przywara48321ba2016-05-31 10:45:06 -0700494
Fabio Estevam988f5052016-12-15 19:30:40 -0200495config USE_ARCH_MEMCPY
496 bool "Use an assembly optimized implementation of memcpy"
Stefan Roese330807f2021-09-02 17:00:19 +0200497 default y if !ARM64
498 depends on !ARM64 || (ARM64 && (GCC_VERSION >= 90400))
Fabio Estevam988f5052016-12-15 19:30:40 -0200499 help
500 Enable the generation of an optimized version of memcpy.
Robert P. J. Day3a8d4e12019-12-25 06:34:07 -0500501 Such an implementation may be faster under some conditions
Fabio Estevam988f5052016-12-15 19:30:40 -0200502 but may increase the binary size.
503
Tom Rini443b5162017-01-12 13:16:02 -0500504config SPL_USE_ARCH_MEMCPY
Andy Yan524f3ce2017-06-28 16:27:37 +0800505 bool "Use an assembly optimized implementation of memcpy for SPL"
Tom Rini443b5162017-01-12 13:16:02 -0500506 default y if USE_ARCH_MEMCPY
Stefan Roese330807f2021-09-02 17:00:19 +0200507 depends on SPL
Tom Rini443b5162017-01-12 13:16:02 -0500508 help
509 Enable the generation of an optimized version of memcpy.
Robert P. J. Day3a8d4e12019-12-25 06:34:07 -0500510 Such an implementation may be faster under some conditions
Tom Rini443b5162017-01-12 13:16:02 -0500511 but may increase the binary size.
512
Kever Yang55688602019-04-02 20:41:20 +0800513config TPL_USE_ARCH_MEMCPY
514 bool "Use an assembly optimized implementation of memcpy for TPL"
515 default y if USE_ARCH_MEMCPY
Stefan Roese330807f2021-09-02 17:00:19 +0200516 depends on TPL
Kever Yang55688602019-04-02 20:41:20 +0800517 help
518 Enable the generation of an optimized version of memcpy.
Robert P. J. Day3a8d4e12019-12-25 06:34:07 -0500519 Such an implementation may be faster under some conditions
Kever Yang55688602019-04-02 20:41:20 +0800520 but may increase the binary size.
521
Stefan Roese330807f2021-09-02 17:00:19 +0200522config USE_ARCH_MEMMOVE
523 bool "Use an assembly optimized implementation of memmove" if !ARM64
524 default USE_ARCH_MEMCPY if ARM64
525 depends on ARM64
526 help
527 Enable the generation of an optimized version of memmove.
528 Such an implementation may be faster under some conditions
529 but may increase the binary size.
530
531config SPL_USE_ARCH_MEMMOVE
532 bool "Use an assembly optimized implementation of memmove for SPL" if !ARM64
533 default SPL_USE_ARCH_MEMCPY if ARM64
534 depends on SPL && ARM64
535 help
536 Enable the generation of an optimized version of memmove.
537 Such an implementation may be faster under some conditions
538 but may increase the binary size.
539
540config TPL_USE_ARCH_MEMMOVE
541 bool "Use an assembly optimized implementation of memmove for TPL" if !ARM64
542 default TPL_USE_ARCH_MEMCPY if ARM64
543 depends on TPL && ARM64
544 help
545 Enable the generation of an optimized version of memmove.
546 Such an implementation may be faster under some conditions
547 but may increase the binary size.
548
Fabio Estevam988f5052016-12-15 19:30:40 -0200549config USE_ARCH_MEMSET
550 bool "Use an assembly optimized implementation of memset"
Stefan Roese330807f2021-09-02 17:00:19 +0200551 default y if !ARM64
552 depends on !ARM64 || (ARM64 && (GCC_VERSION >= 90400))
Tom Rini443b5162017-01-12 13:16:02 -0500553 help
554 Enable the generation of an optimized version of memset.
Robert P. J. Day3a8d4e12019-12-25 06:34:07 -0500555 Such an implementation may be faster under some conditions
Tom Rini443b5162017-01-12 13:16:02 -0500556 but may increase the binary size.
557
558config SPL_USE_ARCH_MEMSET
Andy Yan524f3ce2017-06-28 16:27:37 +0800559 bool "Use an assembly optimized implementation of memset for SPL"
Tom Rini443b5162017-01-12 13:16:02 -0500560 default y if USE_ARCH_MEMSET
Stefan Roese330807f2021-09-02 17:00:19 +0200561 depends on SPL
Fabio Estevam988f5052016-12-15 19:30:40 -0200562 help
563 Enable the generation of an optimized version of memset.
Robert P. J. Day3a8d4e12019-12-25 06:34:07 -0500564 Such an implementation may be faster under some conditions
Fabio Estevam988f5052016-12-15 19:30:40 -0200565 but may increase the binary size.
566
Kever Yang55688602019-04-02 20:41:20 +0800567config TPL_USE_ARCH_MEMSET
568 bool "Use an assembly optimized implementation of memset for TPL"
569 default y if USE_ARCH_MEMSET
Stefan Roese330807f2021-09-02 17:00:19 +0200570 depends on TPL
Kever Yang55688602019-04-02 20:41:20 +0800571 help
572 Enable the generation of an optimized version of memset.
Robert P. J. Day3a8d4e12019-12-25 06:34:07 -0500573 Such an implementation may be faster under some conditions
Kever Yang55688602019-04-02 20:41:20 +0800574 but may increase the binary size.
575
Alison Wang73818d52016-11-10 10:49:03 +0800576config ARM64_SUPPORT_AARCH32
577 bool "ARM64 system support AArch32 execution state"
Adam Ford43a1e2d2019-08-13 14:32:30 -0500578 depends on ARM64
579 default y if !TARGET_THUNDERX_88XX
Alison Wang73818d52016-11-10 10:49:03 +0800580 help
581 This ARM64 system supports AArch32 execution state.
582
Tom Rinia0d59a12022-12-04 10:14:12 -0500583config IPROC
584 bool
585
Tom Rini893cd412022-06-10 22:59:33 -0400586config S5P
587 def_bool y if ARCH_EXYNOS || ARCH_S5PC1XX
588
Masahiro Yamadad3ae6782014-07-30 14:08:14 +0900589choice
590 prompt "Target select"
Simon Glassdfd904a2015-08-30 19:19:30 -0600591 default TARGET_HIKEY
Masahiro Yamadad3ae6782014-07-30 14:08:14 +0900592
Masahiro Yamadaaf908ee2015-02-20 17:04:01 +0900593config ARCH_AT91
594 bool "Atmel AT91"
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900595 select GPIO_EXTRA_HEADER
Tom Rini4a2b61b2018-05-10 07:15:52 -0400596 select SPL_BOARD_INIT if SPL && !TARGET_SMARTWEB
Gregory CLEMENT21cbec72020-06-05 10:43:36 +0200597 select SPL_SEPARATE_BSS if SPL
Sean Anderson97c0aaf2023-11-04 22:27:42 -0400598 imply SYS_THUMB_BUILD
Masahiro Yamadad3ae6782014-07-30 14:08:14 +0900599
Masahiro Yamadae604ef92014-08-31 07:11:01 +0900600config ARCH_DAVINCI
601 bool "TI DaVinci"
Georges Savoundararadj3bae15f2014-10-28 23:16:09 +0100602 select CPU_ARM926EJS
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900603 select GPIO_EXTRA_HEADER
Lukasz Majewski76f442982020-06-04 23:11:53 +0800604 select SPL_DM_SPI if SPL
Simon Glassd09f3772017-08-04 16:34:43 -0600605 imply CMD_SAVES
Masahiro Yamadae604ef92014-08-31 07:11:01 +0900606 help
607 Support for TI's DaVinci platform.
Masahiro Yamadad3ae6782014-07-30 14:08:14 +0900608
Yang Xiwendb1d1f42023-04-01 19:17:33 +0800609config ARCH_HISTB
610 bool "Hisilicon HiSTB SoCs"
611 select DM
612 select DM_SERIAL
613 select OF_CONTROL
614 select PL01X_SERIAL
615 imply CMD_DM
616 help
617 Support for HiSTB SoCs.
618
Trevor Woernerbb7ab072020-05-06 08:02:40 -0400619config ARCH_KIRKWOOD
Masahiro Yamadad7570852014-08-31 07:10:59 +0900620 bool "Marvell Kirkwood"
Simon Glass95d31412017-01-23 13:31:21 -0700621 select ARCH_MISC_INIT
Michal Simek84f3dec2018-07-23 15:55:13 +0200622 select BOARD_EARLY_INIT_F
623 select CPU_ARM926EJS
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900624 select GPIO_EXTRA_HEADER
Stefan Roese5ae022f2022-09-15 16:20:39 +0200625 select TIMER
Masahiro Yamadad3ae6782014-07-30 14:08:14 +0900626
Stefan Roese383e0c12015-08-25 13:18:38 +0200627config ARCH_MVEBU
Stefan Roesecb410332016-05-25 08:13:45 +0200628 bool "Marvell MVEBU family (Armada XP/375/38x/3700/7K/8K)"
Tom Rini208bba22023-02-15 22:36:48 -0500629 select ARCH_EARLY_INIT_R if ARM64
Stefan Roese096de4f2015-09-01 11:27:52 +0200630 select DM
Stefan Roese7f9f8e32015-09-02 08:41:41 +0200631 select DM_SERIAL
Stefan Roese49e7d772015-11-20 13:51:57 +0100632 select DM_SPI
633 select DM_SPI_FLASH
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900634 select GPIO_EXTRA_HEADER
Tom Riniddb1ec12024-01-10 13:46:10 -0500635 select MTD
Lukasz Majewski76f442982020-06-04 23:11:53 +0800636 select SPL_DM_SPI if SPL
637 select SPL_DM_SPI_FLASH if SPL
Stefan Roese5ae022f2022-09-15 16:20:39 +0200638 select SPL_TIMER if SPL
Chris Packhambe529152022-11-05 17:23:55 +1300639 select TIMER if !ARM64
Michal Simek84f3dec2018-07-23 15:55:13 +0200640 select OF_CONTROL
641 select OF_SEPARATE
Adam Ford4e96ff82018-04-15 13:51:26 -0400642 select SPI
Michal Simek2e7c8192018-07-23 15:55:14 +0200643 imply CMD_DM
Stefan Roese9b1e2312014-10-22 12:13:19 +0200644
Trevor Woernerf9953752020-05-06 08:02:38 -0400645config ARCH_ORION5X
Masahiro Yamada04ffbc12014-08-31 07:11:06 +0900646 bool "Marvell Orion"
Georges Savoundararadj3bae15f2014-10-28 23:16:09 +0100647 select CPU_ARM926EJS
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900648 select GPIO_EXTRA_HEADER
Sean Anderson13871e12022-04-12 10:59:04 -0400649 select SPL_SEPARATE_BSS if SPL
Stefan Roese5ae022f2022-09-15 16:20:39 +0200650 select TIMER
Masahiro Yamadad3ae6782014-07-30 14:08:14 +0900651
Masahiro Yamadaed22cc72015-03-19 19:42:56 +0900652config ARCH_BCM283X
653 bool "Broadcom BCM283X family"
Patrick Rudolph2e978922024-10-23 15:20:16 +0200654 select CPU
Masahiro Yamada5ef5ccc2015-03-31 12:47:53 +0900655 select DM
Masahiro Yamada5ef5ccc2015-03-31 12:47:53 +0900656 select DM_GPIO
Michal Simek84f3dec2018-07-23 15:55:13 +0200657 select DM_SERIAL
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900658 select GPIO_EXTRA_HEADER
Fabian Vogtf9e3ed52016-09-26 14:26:51 +0200659 select OF_CONTROL
Alexander Graf633ef892018-01-25 12:05:52 +0100660 select PL01X_SERIAL
Alexander Grafc8bda542018-01-29 13:57:20 +0100661 select SERIAL_SEARCH_ALL
Michal Simek2e7c8192018-07-23 15:55:14 +0200662 imply CMD_DM
Tom Rinid8532af2017-06-02 11:03:50 -0400663 imply FAT_WRITE
Tom Rinib92f23f2021-12-24 11:57:04 -0500664 imply OF_HAS_PRIOR_STAGE
Stephen Warrendc7ea682015-02-16 12:16:15 -0700665
Thomas Fitzsimmons919646d2018-06-08 17:59:45 -0400666config ARCH_BCMSTB
667 bool "Broadcom BCM7XXX family"
668 select CPU_V7A
669 select DM
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900670 select GPIO_EXTRA_HEADER
Thomas Fitzsimmons919646d2018-06-08 17:59:45 -0400671 select OF_CONTROL
Michal Simek2e7c8192018-07-23 15:55:14 +0200672 imply CMD_DM
Simon Glass94886db2021-12-16 20:59:36 -0700673 imply OF_HAS_PRIOR_STAGE
Thomas Fitzsimmons919646d2018-06-08 17:59:45 -0400674 help
675 This enables support for Broadcom ARM-based set-top box
676 chipsets, including the 7445 family of chips.
677
William Zhangd7cdf302022-05-09 09:28:02 -0700678config ARCH_BCMBCA
679 bool "Broadcom broadband chip family"
680 select DM
681 select OF_CONTROL
William Zhang2abed602022-08-22 11:19:45 -0700682 imply CMD_DM
William Zhangd7cdf302022-05-09 09:28:02 -0700683
Kristian Amlie8f8a2992021-09-07 08:37:51 +0200684config TARGET_VEXPRESS_CA9X4
685 bool "Support vexpress_ca9x4"
686 select CPU_V7A
Ole P. Orhagene60fee72024-01-26 13:47:50 +0100687 select PL01X_SERIAL
Kristian Amlie8f8a2992021-09-07 08:37:51 +0200688
Linus Walleijaa5676f2023-04-24 09:38:29 +0200689config TARGET_BCMNS
690 bool "Support Broadcom Northstar"
691 select CPU_V7A
692 select DM
693 select DM_GPIO
694 select DM_SERIAL
695 select OF_CONTROL
696 select TIMER
697 select SYS_NS16550
698 select ARM_GLOBAL_TIMER
699 imply SYS_THUMB_BUILD
700 imply MTD_RAW_NAND
701 imply NAND_BRCMNAND
702 imply NAND_BRCMNAND_IPROC
703 help
704 Support for Broadcom Northstar SoCs. NS is a dual-core 32-bit
705 ARMv7 Cortex-A9 SoC family including BCM4708, BCM47094,
706 BCM5301x etc.
707
Rayagonda Kokatanur1d8fa362020-07-15 22:48:55 +0530708config TARGET_BCMNS3
709 bool "Support Broadcom NS3"
710 select ARM64
711 select BOARD_LATE_INIT
712 help
713 Support for Broadcom Northstar 3 SoCs. NS3 is a octo-core 64-bit
714 ARMv8 Cortex-A72 processors targeting a broad range of networking
715 applications.
716
Masahiro Yamadac54550b2014-08-31 07:11:00 +0900717config ARCH_EXYNOS
718 bool "Samsung EXYNOS"
Masahiro Yamada5ef5ccc2015-03-31 12:47:53 +0900719 select DM
Michal Simek84f3dec2018-07-23 15:55:13 +0200720 select DM_GPIO
Simon Glass7bbb7d92016-11-23 06:34:40 -0700721 select DM_I2C
Michal Simek84f3dec2018-07-23 15:55:13 +0200722 select DM_KEYBOARD
Masahiro Yamada5ef5ccc2015-03-31 12:47:53 +0900723 select DM_SERIAL
724 select DM_SPI
Michal Simek84f3dec2018-07-23 15:55:13 +0200725 select DM_SPI_FLASH
Tom Riniddb1ec12024-01-10 13:46:10 -0500726 select MTD
Adam Ford4e96ff82018-04-15 13:51:26 -0400727 select SPI
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900728 select GPIO_EXTRA_HEADER
Guillaume GARDETf5357322018-11-20 14:15:13 +0100729 imply SYS_THUMB_BUILD
Michal Simek2e7c8192018-07-23 15:55:14 +0200730 imply CMD_DM
Tom Rinid8532af2017-06-02 11:03:50 -0400731 imply FAT_WRITE
Masahiro Yamadad3ae6782014-07-30 14:08:14 +0900732
Simon Glass96aa0722014-10-07 22:01:50 -0600733config ARCH_S5PC1XX
734 bool "Samsung S5PC1XX"
Lokesh Vutla81b1a672018-04-26 18:21:26 +0530735 select CPU_V7A
Masahiro Yamada5ef5ccc2015-03-31 12:47:53 +0900736 select DM
Masahiro Yamada5ef5ccc2015-03-31 12:47:53 +0900737 select DM_GPIO
Simon Glassc6aa9702016-11-23 06:34:41 -0700738 select DM_I2C
Michal Simek84f3dec2018-07-23 15:55:13 +0200739 select DM_SERIAL
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900740 select GPIO_EXTRA_HEADER
Michal Simek2e7c8192018-07-23 15:55:14 +0200741 imply CMD_DM
Simon Glass96aa0722014-10-07 22:01:50 -0600742
Masahiro Yamada52ece9c2014-08-31 07:11:07 +0900743config ARCH_HIGHBANK
744 bool "Calxeda Highbank"
Lokesh Vutla81b1a672018-04-26 18:21:26 +0530745 select CPU_V7A
Andre Przywara8d1069f2021-04-12 01:04:51 +0100746 select PL01X_SERIAL
747 select DM
748 select DM_SERIAL
749 select OF_CONTROL
Andre Przywara8d1069f2021-04-12 01:04:51 +0100750 select CLK
751 select CLK_CCF
752 select AHCI
Andre Przywara126d9a62021-04-12 01:04:54 +0100753 select PHYS_64BIT
Andre Przywarac875d882022-10-20 23:10:25 +0100754 select TIMER
755 select SP804_TIMER
Simon Glass94886db2021-12-16 20:59:36 -0700756 imply OF_HAS_PRIOR_STAGE
Masahiro Yamadad3ae6782014-07-30 14:08:14 +0900757
Masahiro Yamadacad44162015-04-21 21:59:36 +0900758config ARCH_INTEGRATOR
759 bool "ARM Ltd. Integrator family"
Linus Walleij616d9a02015-07-27 11:22:48 +0200760 select DM
761 select DM_SERIAL
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900762 select GPIO_EXTRA_HEADER
Alexander Graf633ef892018-01-25 12:05:52 +0100763 select PL01X_SERIAL
Michal Simek2e7c8192018-07-23 15:55:14 +0200764 imply CMD_DM
Masahiro Yamadacad44162015-04-21 21:59:36 +0900765
Robert Markoe7a34f12020-07-06 10:37:54 +0200766config ARCH_IPQ40XX
767 bool "Qualcomm IPQ40xx SoCs"
768 select CPU_V7A
769 select DM
770 select DM_GPIO
771 select DM_SERIAL
Robert Marko42c5ee82020-09-10 16:00:03 +0200772 select DM_RESET
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900773 select GPIO_EXTRA_HEADER
Robert Markoe7a34f12020-07-06 10:37:54 +0200774 select PINCTRL
775 select CLK
776 select OF_CONTROL
Caleb Connolly90c44642023-11-07 12:41:00 +0000777 select CLK_QCOM_IPQ4019
Caleb Connollycdc0d082023-11-14 12:55:41 +0000778 select PINCTRL_QCOM_IPQ4019
Robert Markoe7a34f12020-07-06 10:37:54 +0200779 imply CMD_DM
Robert Markoef065df2024-05-14 12:17:51 +0200780 imply OF_UPSTREAM
Robert Markoe7a34f12020-07-06 10:37:54 +0200781
Masahiro Yamada32013fb2014-08-31 07:11:05 +0900782config ARCH_KEYSTONE
783 bool "TI Keystone"
Andrew Davis01939572023-07-25 10:54:16 -0500784 select CMD_DDR3
Michal Simek84f3dec2018-07-23 15:55:13 +0200785 select CMD_POWEROFF
Lokesh Vutla81b1a672018-04-26 18:21:26 +0530786 select CPU_V7A
Tom Rinife2cea62021-08-21 13:50:16 -0400787 select DDR_SPD
Andrew Davis01939572023-07-25 10:54:16 -0500788 select SPL_BOARD_INIT if SPL
Masahiro Yamada6e0971b2014-10-20 17:45:56 +0900789 select SUPPORT_SPL
Andre Przywara7b169252018-04-12 04:24:46 +0300790 select SYS_ARCH_TIMER
Michal Simek84f3dec2018-07-23 15:55:13 +0200791 select SYS_THUMB_BUILD
Tom Rinic20bb732017-07-22 18:36:16 -0400792 imply CMD_MTDPARTS
Andrew Davis2aefcb62023-07-25 10:54:15 -0500793 imply CMD_NFS
Simon Glassd09f3772017-08-04 16:34:43 -0600794 imply CMD_SAVES
Andrew Davis01939572023-07-25 10:54:16 -0500795 imply DM_I2C
Michal Simek84f3dec2018-07-23 15:55:13 +0200796 imply FIT
Andrew Davis01939572023-07-25 10:54:16 -0500797 imply SOC_TI
798 imply TI_KEYSTONE_SERDES
Masahiro Yamadad3ae6782014-07-30 14:08:14 +0900799
Lokesh Vutla9bdec002018-08-27 15:57:08 +0530800config ARCH_K3
801 bool "Texas Instruments' K3 Architecture"
802 select SPL
803 select SUPPORT_SPL
804 select FIT
Andrew Davis86a01cf2023-07-14 11:22:33 +0530805 select REGEX
Manorit Chawdhryf65cdf72023-07-14 11:22:40 +0530806 select FIT_SIGNATURE if ARM64
Andrew Davis8bd8a232023-08-03 09:54:41 -0500807 imply TI_SECURE_DEVICE
Lokesh Vutla9bdec002018-08-27 15:57:08 +0530808
Masahiro Yamada6e1288c2017-04-25 13:10:11 +0900809config ARCH_OMAP2PLUS
810 bool "TI OMAP2+"
Lokesh Vutla81b1a672018-04-26 18:21:26 +0530811 select CPU_V7A
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900812 select GPIO_EXTRA_HEADER
Paul Kocialkowski8cf5fb92024-07-29 22:44:37 +0200813 select SPL_SOC_INIT if SPL
Tom Rinic37e0cf2017-09-17 11:44:49 -0400814 select SPL_STACK_R if SPL
Masahiro Yamada6e1288c2017-04-25 13:10:11 +0900815 select SUPPORT_SPL
Dario Binacchid1cb3f62020-12-30 00:06:29 +0100816 imply TI_SYSC if DM && OF_CONTROL
Masahiro Yamada6e1288c2017-04-25 13:10:11 +0900817 imply FIT
Sean Anderson13871e12022-04-12 10:59:04 -0400818 imply SPL_SEPARATE_BSS
Masahiro Yamada6e1288c2017-04-25 13:10:11 +0900819
Beniamino Galvanid1037e42016-05-08 08:30:16 +0200820config ARCH_MESON
821 bool "Amlogic Meson"
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900822 select GPIO_EXTRA_HEADER
Masahiro Yamada9afc6c52018-04-25 18:47:52 +0900823 imply DISTRO_DEFAULTS
Heinrich Schuchardt966caaf2020-04-05 12:20:23 +0200824 imply DM_RNG
Beniamino Galvanid1037e42016-05-08 08:30:16 +0200825 help
826 Support for the Meson SoC family developed by Amlogic Inc.,
827 targeted at media players and tablet computers. We currently
828 support the S905 (GXBaby) 64-bit SoC.
829
developerf4a079c2018-11-15 10:07:52 +0800830config ARCH_MEDIATEK
831 bool "MediaTek SoCs"
developerf4a079c2018-11-15 10:07:52 +0800832 select DM
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900833 select GPIO_EXTRA_HEADER
developerf4a079c2018-11-15 10:07:52 +0800834 select OF_CONTROL
835 select SPL_DM if SPL
836 select SPL_LIBCOMMON_SUPPORT if SPL
837 select SPL_LIBGENERIC_SUPPORT if SPL
838 select SPL_OF_CONTROL if SPL
839 select SUPPORT_SPL
840 help
841 Support for the MediaTek SoCs family developed by MediaTek Inc.
842 Please refer to doc/README.mediatek for more information.
843
Vladimir Zapolskiy31d0e962018-09-17 21:43:03 +0300844config ARCH_LPC32XX
845 bool "NXP LPC32xx platform"
846 select CPU_ARM926EJS
847 select DM
848 select DM_GPIO
849 select DM_SERIAL
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900850 select GPIO_EXTRA_HEADER
Vladimir Zapolskiy31d0e962018-09-17 21:43:03 +0300851 select SPL_DM if SPL
852 select SUPPORT_SPL
853 imply CMD_DM
854
Peng Fan6bae1c72018-10-18 14:28:08 +0200855config ARCH_IMX8
856 bool "NXP i.MX8 platform"
857 select ARM64
Gaurav Jaindb4dd6a2022-03-24 11:50:33 +0530858 select SYS_FSL_HAS_SEC
859 select SYS_FSL_SEC_COMPAT_4
860 select SYS_FSL_SEC_LE
Peng Fan6bae1c72018-10-18 14:28:08 +0200861 select DM
Tom Rini7d3684a2023-01-16 15:46:49 -0500862 select DM_EVENT
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900863 select GPIO_EXTRA_HEADER
Tom Rini8086a822021-08-24 20:40:59 -0400864 select MACH_IMX
Peng Fan6bae1c72018-10-18 14:28:08 +0200865 select OF_CONTROL
Ye Li97b41652019-07-12 09:33:52 +0000866 select ENABLE_ARM_SOC_BOOT0_HOOK
Peng Fan6bae1c72018-10-18 14:28:08 +0200867
Peng Fan39945c12018-11-20 10:19:25 +0000868config ARCH_IMX8M
Peng Fan66294882018-01-10 13:20:19 +0800869 bool "NXP i.MX8M platform"
870 select ARM64
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900871 select GPIO_EXTRA_HEADER
Tom Rini8086a822021-08-24 20:40:59 -0400872 select MACH_IMX
Gaurav Jain81113a02022-03-24 11:50:27 +0530873 select SYS_FSL_HAS_SEC
Aymen Sghaier4da25692021-03-25 17:30:25 +0800874 select SYS_FSL_SEC_COMPAT_4
875 select SYS_FSL_SEC_LE
Tom Rini1a195882021-08-18 23:12:33 -0400876 select SYS_I2C_MXC
Peng Fan66294882018-01-10 13:20:19 +0800877 select DM
Tom Rini7d3684a2023-01-16 15:46:49 -0500878 select DM_EVENT if CLK
Peng Fan66294882018-01-10 13:20:19 +0800879 select SUPPORT_SPL
Michal Simek2e7c8192018-07-23 15:55:14 +0200880 imply CMD_DM
Peng Fan66294882018-01-10 13:20:19 +0800881
Peng Fan570dc4f2021-08-07 16:00:30 +0800882config ARCH_IMX8ULP
883 bool "NXP i.MX8ULP platform"
884 select ARM64
885 select DM
Tom Rini7d3684a2023-01-16 15:46:49 -0500886 select DM_EVENT
Tom Rini8086a822021-08-24 20:40:59 -0400887 select MACH_IMX
Peng Fan570dc4f2021-08-07 16:00:30 +0800888 select OF_CONTROL
889 select SUPPORT_SPL
890 select GPIO_EXTRA_HEADER
Ye Lic408ed32022-07-26 16:40:49 +0800891 select MISC
Peng Fand5c31832023-06-15 18:09:05 +0800892 select IMX_ELE
Peng Fan570dc4f2021-08-07 16:00:30 +0800893 imply CMD_DM
894
Peng Fanbbcd2c42022-07-26 16:40:39 +0800895config ARCH_IMX9
896 bool "NXP i.MX9 platform"
897 select ARM64
898 select DM
Tom Rini7d3684a2023-01-16 15:46:49 -0500899 select DM_EVENT
Peng Fanbbcd2c42022-07-26 16:40:39 +0800900 select MACH_IMX
901 select SUPPORT_SPL
Ye Lifa105572022-07-26 16:41:01 +0800902 select GPIO_EXTRA_HEADER
Ye Lic408ed32022-07-26 16:40:49 +0800903 select MISC
Peng Fand5c31832023-06-15 18:09:05 +0800904 select IMX_ELE
Peng Fanbbcd2c42022-07-26 16:40:39 +0800905 imply CMD_DM
Peng Fanbbcd2c42022-07-26 16:40:39 +0800906
Giulio Benetti9dba2622020-01-10 15:51:47 +0100907config ARCH_IMXRT
908 bool "NXP i.MXRT platform"
909 select CPU_V7M
910 select DM
911 select DM_SERIAL
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900912 select GPIO_EXTRA_HEADER
Tom Rini8086a822021-08-24 20:40:59 -0400913 select MACH_IMX
Giulio Benetti9dba2622020-01-10 15:51:47 +0100914 select SUPPORT_SPL
915 imply CMD_DM
916
Stefan Agner081ea1f2018-02-06 09:44:34 +0100917config ARCH_MX23
918 bool "NXP i.MX23 family"
919 select CPU_ARM926EJS
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900920 select GPIO_EXTRA_HEADER
Tom Rini8086a822021-08-24 20:40:59 -0400921 select MACH_IMX
Stefan Agner081ea1f2018-02-06 09:44:34 +0100922 select SUPPORT_SPL
923
Stefan Agner663a3232018-02-06 09:44:35 +0100924config ARCH_MX28
925 bool "NXP i.MX28 family"
926 select CPU_ARM926EJS
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900927 select GPIO_EXTRA_HEADER
Tom Rini8086a822021-08-24 20:40:59 -0400928 select MACH_IMX
Stefan Agner663a3232018-02-06 09:44:35 +0100929 select SUPPORT_SPL
930
Magnus Liljac74f70f2018-05-11 14:06:54 +0200931config ARCH_MX31
932 bool "NXP i.MX31 family"
933 select CPU_ARM1136
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900934 select GPIO_EXTRA_HEADER
Tom Rini8086a822021-08-24 20:40:59 -0400935 select MACH_IMX
Magnus Liljac74f70f2018-05-11 14:06:54 +0200936
Peng Fan2c7b1702017-02-22 16:21:39 +0800937config ARCH_MX7ULP
Michal Simekf751ff52018-07-23 15:55:12 +0200938 bool "NXP MX7ULP"
Tom Rinid02971e2022-02-25 11:19:47 -0500939 select BOARD_POSTCLK_INIT
Lokesh Vutla81b1a672018-04-26 18:21:26 +0530940 select CPU_V7A
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900941 select GPIO_EXTRA_HEADER
Tom Rini8086a822021-08-24 20:40:59 -0400942 select MACH_IMX
Gaurav Jain714e7e32022-03-24 11:50:31 +0530943 select SYS_FSL_HAS_SEC
Franck LENORMAND4fde0a12021-03-25 17:30:23 +0800944 select SYS_FSL_SEC_COMPAT_4
945 select SYS_FSL_SEC_LE
Peng Fan2c7b1702017-02-22 16:21:39 +0800946 select ROM_UNIFIED_SECTIONS
Adam Fordb413c452018-02-04 09:32:43 -0600947 imply MXC_GPIO
Tom Rini4f834a42019-12-03 09:28:03 -0500948 imply SYS_THUMB_BUILD
Peng Fan2c7b1702017-02-22 16:21:39 +0800949
Adrian Alonso98810772015-09-03 11:49:28 -0500950config ARCH_MX7
951 bool "Freescale MX7"
Michal Simek84f3dec2018-07-23 15:55:13 +0200952 select ARCH_MISC_INIT
Lokesh Vutla81b1a672018-04-26 18:21:26 +0530953 select CPU_V7A
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900954 select GPIO_EXTRA_HEADER
Tom Rini8086a822021-08-24 20:40:59 -0400955 select MACH_IMX
Tom Rini599b11b2022-12-02 16:42:18 -0500956 select MXC_GPT_HCLK
Gaurav Jaine389ac92022-03-24 11:50:30 +0530957 select SYS_FSL_HAS_SEC
York Sun92c36e22016-12-28 08:43:30 -0800958 select SYS_FSL_SEC_COMPAT_4
York Sunfa4199422016-12-28 08:43:31 -0800959 select SYS_FSL_SEC_LE
Marek Vasut42b24b42020-05-22 01:13:00 +0200960 imply BOARD_EARLY_INIT_F
Adam Fordb413c452018-02-04 09:32:43 -0600961 imply MXC_GPIO
Tom Rini4f834a42019-12-03 09:28:03 -0500962 imply SYS_THUMB_BUILD
Adrian Alonso98810772015-09-03 11:49:28 -0500963
Boris BREZILLON51e82662015-03-04 13:13:03 +0100964config ARCH_MX6
965 bool "Freescale MX6"
Tom Rinid02971e2022-02-25 11:19:47 -0500966 select BOARD_POSTCLK_INIT
Lokesh Vutla81b1a672018-04-26 18:21:26 +0530967 select CPU_V7A
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900968 select GPIO_EXTRA_HEADER
Tom Rini8086a822021-08-24 20:40:59 -0400969 select MACH_IMX
Tom Rini599b11b2022-12-02 16:42:18 -0500970 select MXC_GPT_HCLK
Heinrich Schuchardtcdd0c852020-06-26 19:57:55 +0200971 select SYS_FSL_HAS_SEC
York Sun92c36e22016-12-28 08:43:30 -0800972 select SYS_FSL_SEC_COMPAT_4
York Sunfa4199422016-12-28 08:43:31 -0800973 select SYS_FSL_SEC_LE
Philip Oberfichtner5833e1b2022-08-17 15:07:12 +0200974 select SYS_L2_PL310 if !SYS_L2CACHE_OFF
Adam Fordb413c452018-02-04 09:32:43 -0600975 imply MXC_GPIO
Tom Rini4f834a42019-12-03 09:28:03 -0500976 imply SYS_THUMB_BUILD
Sean Anderson13871e12022-04-12 10:59:04 -0400977 imply SPL_SEPARATE_BSS
Boris BREZILLON51e82662015-03-04 13:13:03 +0100978
Andrej Rosano1ac4bca2015-04-08 18:56:29 +0200979config ARCH_MX5
980 bool "Freescale MX5"
Simon Glass7a99a872017-01-23 13:31:20 -0700981 select BOARD_EARLY_INIT_F
Michal Simek84f3dec2018-07-23 15:55:13 +0200982 select CPU_V7A
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900983 select GPIO_EXTRA_HEADER
Tom Rini8086a822021-08-24 20:40:59 -0400984 select MACH_IMX
Adam Fordb413c452018-02-04 09:32:43 -0600985 imply MXC_GPIO
Andrej Rosano1ac4bca2015-04-08 18:56:29 +0200986
Stefan Bosch6563ea22020-07-10 19:07:26 +0200987config ARCH_NEXELL
988 bool "Nexell S5P4418/S5P6818 SoC"
989 select ENABLE_ARM_SOC_BOOT0_HOOK
990 select DM
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +0900991 select GPIO_EXTRA_HEADER
Stefan Bosch6563ea22020-07-10 19:07:26 +0200992
Jim Liu4359b332022-04-19 13:32:19 +0800993config ARCH_NPCM
994 bool "Support Nuvoton SoCs"
995 select DM
996 select OF_CONTROL
997 imply CMD_DM
998
Mark Kettenis58d51272021-10-23 16:58:03 +0200999config ARCH_APPLE
1000 bool "Apple SoCs"
1001 select ARM64
Mark Kettenis835cb5d2021-10-23 16:58:04 +02001002 select CLK
Mark Kettenis59b09ba2023-01-21 20:27:58 +01001003 select CMD_PCI
Mark Kettenis58d51272021-10-23 16:58:03 +02001004 select CMD_USB
1005 select DM
Mark Kettenisc9329762021-11-02 18:21:57 +01001006 select DM_GPIO
Mark Kettenis58d51272021-10-23 16:58:03 +02001007 select DM_KEYBOARD
Mark Kettenisf3efb3b2022-01-22 20:38:12 +01001008 select DM_MAILBOX
Mark Kettenis9e8c4832022-01-22 20:38:17 +01001009 select DM_RESET
Mark Kettenis58d51272021-10-23 16:58:03 +02001010 select DM_SERIAL
Mark Kettenis0c3e9242022-01-23 16:48:12 +01001011 select DM_SPI
Mark Kettenis58d51272021-10-23 16:58:03 +02001012 select DM_USB
Simon Glass52cb5042022-10-18 07:46:31 -06001013 select VIDEO
Mark Kettenis357a2562021-10-23 16:58:05 +02001014 select IOMMU
Mark Kettenis58d51272021-10-23 16:58:03 +02001015 select LINUX_KERNEL_IMAGE_HEADER
Tom Riniddb1ec12024-01-10 13:46:10 -05001016 select MTD
Mark Kettenisdfacafb2022-04-19 21:20:31 +02001017 select OF_BOARD_SETUP
Mark Kettenis58d51272021-10-23 16:58:03 +02001018 select OF_CONTROL
Mark Kettenis59b09ba2023-01-21 20:27:58 +01001019 select PCI
Mark Kettenis23d98982023-07-14 22:21:42 +02001020 select PHY
Mark Kettenisc9329762021-11-02 18:21:57 +01001021 select PINCTRL
Mark Kettenis58d51272021-10-23 16:58:03 +02001022 select POSITION_INDEPENDENT
Mark Kettenis2fc94052022-01-10 20:58:44 +01001023 select POWER_DOMAIN
1024 select REGMAP
Mark Kettenis0c3e9242022-01-23 16:48:12 +01001025 select SPI
Mark Kettenis2fc94052022-01-10 20:58:44 +01001026 select SYSCON
Mark Kettenise19700f2022-01-12 19:55:17 +01001027 select SYSRESET
1028 select SYSRESET_WATCHDOG
1029 select SYSRESET_WATCHDOG_AUTO
Mark Kettenis58d51272021-10-23 16:58:03 +02001030 select USB
1031 imply CMD_DM
1032 imply CMD_GPT
Janne Grunau8bf7b592024-04-18 21:00:28 +02001033 imply BOOTSTD_FULL
Simon Glass94886db2021-12-16 20:59:36 -07001034 imply OF_HAS_PRIOR_STAGE
Mark Kettenis58d51272021-10-23 16:58:03 +02001035
Manivannan Sadhasivam474a5df2018-06-14 23:38:31 +05301036config ARCH_OWL
1037 bool "Actions Semi OWL SoCs"
Manivannan Sadhasivam474a5df2018-06-14 23:38:31 +05301038 select DM
1039 select DM_SERIAL
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001040 select GPIO_EXTRA_HEADER
Amit Singh Tomarcae81932020-04-19 19:28:25 +05301041 select OWL_SERIAL
Amit Singh Tomar8821be42020-04-19 19:28:30 +05301042 select CLK
1043 select CLK_OWL
Manivannan Sadhasivam474a5df2018-06-14 23:38:31 +05301044 select OF_CONTROL
Tom Rinia38d0ac2020-05-01 10:52:11 -04001045 select SYS_RELOC_GD_ENV_ADDR
Michal Simek2e7c8192018-07-23 15:55:14 +02001046 imply CMD_DM
Manivannan Sadhasivam474a5df2018-06-14 23:38:31 +05301047
Tuomas Tynkkynen28cac522017-09-19 23:18:07 +03001048config ARCH_QEMU
1049 bool "QEMU Virtual Platform"
Tuomas Tynkkynen28cac522017-09-19 23:18:07 +03001050 select DM
1051 select DM_SERIAL
1052 select OF_CONTROL
Alexander Graf633ef892018-01-25 12:05:52 +01001053 select PL01X_SERIAL
Michal Simek2e7c8192018-07-23 15:55:14 +02001054 imply CMD_DM
Heinrich Schuchardt2ebc22c2020-09-19 07:55:35 +02001055 imply DM_RNG
AKASHI Takahiro501cc842018-09-14 17:06:54 +09001056 imply DM_RTC
1057 imply RTC_PL031
Patrick Rudolphcb42bc82024-10-23 15:20:08 +02001058 imply OF_HAS_PRIOR_STAGE if !TARGET_QEMU_ARM_SBSA
Alper Nebi Yasak79f469a2023-08-14 20:39:41 +03001059 imply VIDEO
1060 imply VIDEO_BOCHS
1061 imply SYS_WHITE_ON_BLACK
1062 imply SYS_CONSOLE_IS_IN_ENV
Alper Nebi Yasakbd522b52023-08-14 20:39:42 +03001063 imply PRE_CONSOLE_BUFFER
Alper Nebi Yasak211639d2023-08-14 20:39:43 +03001064 imply USB
1065 imply USB_XHCI_HCD
1066 imply USB_XHCI_PCI
1067 imply USB_KEYBOARD
1068 imply CMD_USB
Tuomas Tynkkynen28cac522017-09-19 23:18:07 +03001069
Marek Vasut6468c4c2024-02-27 17:05:55 +01001070config ARCH_RENESAS
Masahiro Yamadac9c54e22014-08-31 07:10:57 +09001071 bool "Renesas ARM SoCs"
Nobuhiro Iwamatsu7c112732015-10-10 05:58:28 +09001072 select DM
1073 select DM_SERIAL
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001074 select GPIO_EXTRA_HEADER
Marek Vasutcc0d09e2024-02-11 18:34:30 +01001075 select LTO
Biju Das055763a2020-09-22 13:06:49 +01001076 imply BOARD_EARLY_INIT_F
Michal Simek2e7c8192018-07-23 15:55:14 +02001077 imply CMD_DM
Tom Rinid8532af2017-06-02 11:03:50 -04001078 imply FAT_WRITE
Marek Vasutd258ab42024-03-25 09:17:54 +01001079 imply OF_UPSTREAM
Tom Rini1c640a62017-03-18 09:01:44 -04001080 imply SYS_THUMB_BUILD
Marek Vasutb90dc692018-12-03 13:28:25 +01001081 imply ARCH_MISC_INIT if DISPLAY_CPUINFO
Nikita Kiryanovf5cab0f2014-09-07 18:59:29 +03001082
Mateusz Kulikowski2507d822016-03-31 23:12:32 +02001083config ARCH_SNAPDRAGON
1084 bool "Qualcomm Snapdragon SoCs"
1085 select ARM64
1086 select DM
1087 select DM_GPIO
1088 select DM_SERIAL
Konrad Dybcio6c0b8442023-11-07 12:41:01 +00001089 select DM_RESET
Volodymyr Babchukaae46492024-03-11 21:33:45 +00001090 select POWER_DOMAIN
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001091 select GPIO_EXTRA_HEADER
Michal Simek84f3dec2018-07-23 15:55:13 +02001092 select MSM_SMEM
Mateusz Kulikowski2507d822016-03-31 23:12:32 +02001093 select OF_CONTROL
1094 select OF_SEPARATE
Ramon Fried4b4bd492018-07-02 02:57:56 +03001095 select SMEM
Michal Simek84f3dec2018-07-23 15:55:13 +02001096 select SPMI
Caleb Connolly31385662024-02-26 17:26:25 +00001097 select BOARD_LATE_INIT
Caleb Connollyfe1694c2024-02-26 17:26:24 +00001098 select OF_BOARD
1099 select SAVE_PREV_BL_FDT_ADDR
Sumit Garg4a40f732024-04-12 15:24:32 +05301100 select LINUX_KERNEL_IMAGE_HEADER if !ENABLE_ARM_SOC_BOOT0_HOOK
Caleb Connollycb265ef2024-04-18 18:24:09 +01001101 imply OF_UPSTREAM
Michal Simek2e7c8192018-07-23 15:55:14 +02001102 imply CMD_DM
Mateusz Kulikowski2507d822016-03-31 23:12:32 +02001103
Masahiro Yamada144a3e02015-04-21 20:38:20 +09001104config ARCH_SOCFPGA
1105 bool "Altera SOCFPGA family"
Marek Vasut014f0ab2018-05-11 22:25:59 +02001106 select ARCH_EARLY_INIT_R
Marek Vasut04c8f4f2018-08-13 20:06:46 +02001107 select ARCH_MISC_INIT if !TARGET_SOCFPGA_ARRIA10
Siew Chin Lim8a714162021-03-01 20:04:10 +08001108 select ARM64 if TARGET_SOCFPGA_SOC64
Ley Foon Tan9c407b52018-05-24 00:17:32 +08001109 select CPU_V7A if TARGET_SOCFPGA_GEN5 || TARGET_SOCFPGA_ARRIA10
Masahiro Yamadae2005542015-03-31 12:47:59 +09001110 select DM
Marek Vasut57f03d22018-05-11 22:26:35 +02001111 select DM_SERIAL
Tom Rini249f11f2021-08-19 14:19:39 -04001112 select GICV2
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001113 select GPIO_EXTRA_HEADER
Ley Foon Tan9c407b52018-05-24 00:17:32 +08001114 select ENABLE_ARM_SOC_BOOT0_HOOK if TARGET_SOCFPGA_GEN5 || TARGET_SOCFPGA_ARRIA10
Marek Vasut014f0ab2018-05-11 22:25:59 +02001115 select OF_CONTROL
Ley Foon Tan9ae7b0a2018-07-13 13:40:23 +08001116 select SPL_DM_RESET if DM_RESET
Michal Simek84f3dec2018-07-23 15:55:13 +02001117 select SPL_DM_SERIAL
Marek Vasut014f0ab2018-05-11 22:25:59 +02001118 select SPL_LIBCOMMON_SUPPORT
Marek Vasut014f0ab2018-05-11 22:25:59 +02001119 select SPL_LIBGENERIC_SUPPORT
Marek Vasut014f0ab2018-05-11 22:25:59 +02001120 select SPL_OF_CONTROL
Siew Chin Lim8a714162021-03-01 20:04:10 +08001121 select SPL_SEPARATE_BSS if TARGET_SOCFPGA_SOC64
Wan Yee Laue249d542024-02-05 11:47:16 +08001122 select SPL_DRIVERS_MISC if TARGET_SOCFPGA_SOC64
1123 select SPL_SOCFPGA_DT_REG if TARGET_SOCFPGA_SOC64
Simon Glassf4d60392021-08-08 12:20:12 -06001124 select SPL_SERIAL
Simon Goldschmidtfc824662019-07-15 21:47:55 +02001125 select SPL_SYSRESET
Simon Glass1ba1d4e2021-07-10 21:14:28 -06001126 select SPL_WATCHDOG
Marek Vasut014f0ab2018-05-11 22:25:59 +02001127 select SUPPORT_SPL
Marek Vasut57f03d22018-05-11 22:26:35 +02001128 select SYS_NS16550
Ley Foon Tan9c407b52018-05-24 00:17:32 +08001129 select SYS_THUMB_BUILD if TARGET_SOCFPGA_GEN5 || TARGET_SOCFPGA_ARRIA10
Simon Goldschmidtfc824662019-07-15 21:47:55 +02001130 select SYSRESET
1131 select SYSRESET_SOCFPGA if TARGET_SOCFPGA_GEN5 || TARGET_SOCFPGA_ARRIA10
Jit Loon Lim977071e2024-03-12 22:01:03 +08001132 select SYSRESET_SOCFPGA_SOC64 if !TARGET_SOCFPGA_AGILEX5 && \
1133 TARGET_SOCFPGA_SOC64
Michal Simek2e7c8192018-07-23 15:55:14 +02001134 imply CMD_DM
Tom Rinic20bb732017-07-22 18:36:16 -04001135 imply CMD_MTDPARTS
Daniel Thompsona9e2c672017-05-19 17:26:58 +01001136 imply CRC32_VERIFY
Simon Goldschmidta4347302018-02-13 06:34:14 +01001137 imply DM_SPI
1138 imply DM_SPI_FLASH
Tom Rinid8532af2017-06-02 11:03:50 -04001139 imply FAT_WRITE
Tom Riniddb1ec12024-01-10 13:46:10 -05001140 imply MTD
Simon Goldschmidtb1c42692019-04-09 21:02:05 +02001141 imply SPL
1142 imply SPL_DM
Lukasz Majewski76f442982020-06-04 23:11:53 +08001143 imply SPL_DM_SPI
1144 imply SPL_DM_SPI_FLASH
Simon Goldschmidtc26195d2018-11-29 21:17:08 +01001145 imply SPL_LIBDISK_SUPPORT
Simon Glassb58bfe02021-08-08 12:20:09 -06001146 imply SPL_MMC
Simon Goldschmidta4347302018-02-13 06:34:14 +01001147 imply SYS_MMCSD_RAW_MODE_U_BOOT_USE_PARTITION
Simon Goldschmidt3b551bc2018-10-30 20:21:49 +01001148 imply SYS_MMCSD_RAW_MODE_U_BOOT_USE_PARTITION_TYPE
Simon Goldschmidtc26195d2018-11-29 21:17:08 +01001149 imply SPL_SPI_FLASH_SUPPORT
Simon Glassa5820472021-08-08 12:20:14 -06001150 imply SPL_SPI
Dinh Nguyen41e32962019-04-23 16:55:06 -05001151 imply L2X0_CACHE
Marek Vasut69295472014-12-30 18:16:08 +01001152
Ian Campbelld8e69e02014-10-24 21:20:44 +01001153config ARCH_SUNXI
1154 bool "Support sunxi (Allwinner) SoCs"
Masahiro Yamada87247af2017-10-17 13:42:44 +09001155 select BINMAN
Hans de Goedec9511672016-04-03 09:41:44 +02001156 select CMD_GPIO
Hans de Goede2c526402016-05-15 13:51:58 +02001157 select CMD_MMC if MMC
Tom Rini5b9e6162021-07-09 10:11:56 -04001158 select CMD_USB if DISTRO_DEFAULTS && USB_HOST
Jagan Teki80d261b2019-01-11 16:40:20 +05301159 select CLK
Hans de Goede03914882015-04-15 20:46:48 +02001160 select DM
Hans de Goedec8d43472015-12-21 20:22:00 +01001161 select DM_GPIO
Samuel Holland468f23b2021-10-08 00:17:25 -05001162 select DM_I2C if I2C
Andre Przywara06435db2022-01-11 12:46:02 +00001163 select DM_SPI if SPI
Tom Riniddb1ec12024-01-10 13:46:10 -05001164 select DM_SPI_FLASH if SPI && MTD
Hans de Goedec8d43472015-12-21 20:22:00 +01001165 select DM_KEYBOARD
Jagan Tekic4981542019-04-12 16:48:25 +05301166 select DM_MMC if MMC
Tom Rini10e87172015-06-30 16:51:15 -04001167 select DM_SERIAL
Hans de Goede48a234a2016-03-22 22:51:52 +01001168 select OF_BOARD_SETUP
Hans de Goede03914882015-04-15 20:46:48 +02001169 select OF_CONTROL
1170 select OF_SEPARATE
Samuel Hollande3095022021-08-12 20:09:43 -05001171 select PINCTRL
Tom Rinie69ba982018-03-06 19:02:27 -05001172 select SPECIFY_CONSOLE_INDEX
Samuel Hollandd30ac692021-08-22 13:23:53 -05001173 select SPL_SEPARATE_BSS if SPL
Tom Rinidac518f2017-06-21 07:54:46 -04001174 select SPL_STACK_R if SPL
1175 select SPL_SYS_MALLOC_SIMPLE if SPL
Andre Przywara9d874962024-01-03 00:12:27 +00001176 select SPL_SYS_THUMB_BUILD if SPL && !ARM64
Andre Przywara9d3bab92019-06-23 15:09:46 +01001177 select SUNXI_GPIO
Michal Simek84f3dec2018-07-23 15:55:13 +02001178 select SYS_NS16550
Maxime Ripard2ba0f212017-10-19 11:49:29 +02001179 select SYS_THUMB_BUILD if !ARM64
Yann E. MORINe28217d2016-10-31 22:33:40 +01001180 select USB if DISTRO_DEFAULTS
Tom Rini5b9e6162021-07-09 10:11:56 -04001181 select USB_KEYBOARD if DISTRO_DEFAULTS && USB_HOST
1182 select USB_STORAGE if DISTRO_DEFAULTS && USB_HOST
Andre Przywara9d874962024-01-03 00:12:27 +00001183 select SPL_USE_TINY_PRINTF if SPL
Andre Przywara3130df52020-02-20 17:51:14 +00001184 select USE_PREBOOT
1185 select SYS_RELOC_GD_ENV_ADDR
Andy Shevchenko1facc0f2020-12-08 17:45:31 +02001186 imply BOARD_LATE_INIT
Michal Simek2e7c8192018-07-23 15:55:14 +02001187 imply CMD_DM
Maxime Ripardbc7db012017-08-24 11:54:03 +02001188 imply CMD_GPT
Miquel Raynald0935362019-10-03 19:50:03 +02001189 imply CMD_UBI if MTD_RAW_NAND
Masahiro Yamada9afc6c52018-04-25 18:47:52 +09001190 imply DISTRO_DEFAULTS
Andre Przywara8ee04092022-07-15 16:52:14 +01001191 imply DM_REGULATOR
1192 imply DM_REGULATOR_FIXED
Tom Rinid8532af2017-06-02 11:03:50 -04001193 imply FAT_WRITE
Marek Vasut88e3a842018-10-10 18:27:35 +02001194 imply FIT
Andre Heider11790742018-01-16 09:44:22 +01001195 imply OF_LIBFDT_OVERLAY
Masahiro Yamada8e5e1ea2017-04-28 19:42:19 +09001196 imply PRE_CONSOLE_BUFFER
Simon Glass035939e2021-07-10 21:14:30 -06001197 imply SPL_GPIO
Masahiro Yamada8e5e1ea2017-04-28 19:42:19 +09001198 imply SPL_LIBCOMMON_SUPPORT
Masahiro Yamada8e5e1ea2017-04-28 19:42:19 +09001199 imply SPL_LIBGENERIC_SUPPORT
Simon Glassb58bfe02021-08-08 12:20:09 -06001200 imply SPL_MMC if MMC
Simon Glasse91ac4c2021-07-10 21:14:24 -06001201 imply SPL_POWER
Simon Glassf4d60392021-08-08 12:20:12 -06001202 imply SPL_SERIAL
Samuel Hollandf97d6762021-11-03 22:55:16 -05001203 imply SYSRESET
1204 imply SYSRESET_WATCHDOG
1205 imply SYSRESET_WATCHDOG_AUTO
Maxime Ripardabb17b42017-09-07 10:46:24 +02001206 imply USB_GADGET
Samuel Holland576ccd62021-08-22 13:53:28 -05001207 imply WDT
Chen-Yu Tsai848c2632014-10-22 16:47:44 +08001208
Stephan Gerhold4f1170f2020-01-04 18:45:17 +01001209config ARCH_U8500
1210 bool "ST-Ericsson U8500 Series"
1211 select CPU_V7A
1212 select DM
1213 select DM_GPIO
1214 select DM_MMC if MMC
1215 select DM_SERIAL
Stephan Gerholdca0a82b2021-08-07 15:07:19 +02001216 select DM_USB_GADGET if DM_USB
Stephan Gerhold4f1170f2020-01-04 18:45:17 +01001217 select OF_CONTROL
1218 select SYSRESET
1219 select TIMER
Stephan Gerholdca0a82b2021-08-07 15:07:19 +02001220 imply AB8500_USB_PHY
Stephan Gerhold4f1170f2020-01-04 18:45:17 +01001221 imply ARM_PL180_MMCI
Stephan Gerholdca0a82b2021-08-07 15:07:19 +02001222 imply CLK
1223 imply DM_PMIC
Stephan Gerhold4f1170f2020-01-04 18:45:17 +01001224 imply DM_RTC
Stephan Gerholdca0a82b2021-08-07 15:07:19 +02001225 imply NOMADIK_GPIO
Stephan Gerhold4f1170f2020-01-04 18:45:17 +01001226 imply NOMADIK_MTU_TIMER
Stephan Gerholdca0a82b2021-08-07 15:07:19 +02001227 imply PHY
Stephan Gerhold4f1170f2020-01-04 18:45:17 +01001228 imply PL01X_SERIAL
Stephan Gerholdca0a82b2021-08-07 15:07:19 +02001229 imply PMIC_AB8500
Stephan Gerhold4f1170f2020-01-04 18:45:17 +01001230 imply RTC_PL031
Stephan Gerholdd7720452021-08-07 15:07:24 +02001231 imply SYS_THUMB_BUILD
Stephan Gerhold4f1170f2020-01-04 18:45:17 +01001232 imply SYSRESET_SYSCON
1233
Michal Simek4b066a12018-08-22 14:55:27 +02001234config ARCH_VERSAL
1235 bool "Support Xilinx Versal Platform"
1236 select ARM64
1237 select CLK
1238 select DM
Michal Simek0609abd2019-01-15 08:52:46 +01001239 select DM_MMC if MMC
Michal Simek4b066a12018-08-22 14:55:27 +02001240 select DM_SERIAL
Tom Rini249f11f2021-08-19 14:19:39 -04001241 select GICV3
Michal Simek4b066a12018-08-22 14:55:27 +02001242 select OF_CONTROL
T Karthik Reddycb8485b2021-08-10 06:50:19 -06001243 select SOC_DEVICE
Siva Durga Prasad Paladugu37c2ff82019-01-31 17:28:14 +05301244 imply BOARD_LATE_INIT
Michal Simekbab07b62020-07-28 12:45:47 +02001245 imply ENV_VARS_UBOOT_RUNTIME_CONFIG
Michal Simek4b066a12018-08-22 14:55:27 +02001246
Michal Simekd903ce42024-05-29 16:47:58 +02001247config ARCH_VERSAL2
1248 bool "Support AMD Versal Gen 2 Platform"
1249 select ARM64
1250 select CLK
1251 select DM
1252 select DM_MMC if MMC
1253 select DM_SERIAL
1254 select OF_CONTROL
1255 imply BOARD_LATE_INIT
1256 imply ENV_VARS_UBOOT_RUNTIME_CONFIG
1257 imply ZYNQMP_FIRMWARE
1258
Michal Simek2e53eb22022-09-19 14:21:02 +02001259config ARCH_VERSAL_NET
Michal Simek30a73db2022-11-05 18:21:27 -07001260 bool "Support Xilinx Versal NET Platform"
Michal Simek2e53eb22022-09-19 14:21:02 +02001261 select ARM64
1262 select CLK
1263 select DM
Michal Simek2e53eb22022-09-19 14:21:02 +02001264 select DM_MMC if MMC
1265 select DM_SERIAL
1266 select OF_CONTROL
1267 imply BOARD_LATE_INIT
1268 imply ENV_VARS_UBOOT_RUNTIME_CONFIG
1269
Stefan Agnerd53c0a42017-03-13 18:41:36 -07001270config ARCH_VF610
1271 bool "Freescale Vybrid"
Lokesh Vutla81b1a672018-04-26 18:21:26 +05301272 select CPU_V7A
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001273 select GPIO_EXTRA_HEADER
Tom Rini945a6682022-11-19 18:45:22 -05001274 select IOMUX_SHARE_CONF_REG
Tom Rini8086a822021-08-24 20:40:59 -04001275 select MACH_IMX
York Sun097e3602016-12-28 08:43:42 -08001276 select SYS_FSL_ERRATUM_ESDHC111
Tom Rinic20bb732017-07-22 18:36:16 -04001277 imply CMD_MTDPARTS
Miquel Raynald0935362019-10-03 19:50:03 +02001278 imply MTD_RAW_NAND
Sanchayan Maitycc4d78f2015-04-15 16:24:26 +05301279
Masahiro Yamada8204bd12015-03-16 16:43:24 +09001280config ARCH_ZYNQ
Michal Simek8caedde2017-11-23 08:25:41 +01001281 bool "Xilinx Zynq based platform"
Stefan Herbrechtsmeier10ff2882022-08-05 08:16:28 +02001282 select ARM_TWD_TIMER
Tom Rini57bef812023-02-15 22:36:49 -05001283 select ARCH_EARLY_INIT_R if FPGA || (SPL && SPL_FPGA)
Michal Simek84f3dec2018-07-23 15:55:13 +02001284 select CLK
1285 select CLK_ZYNQ
Lokesh Vutla81b1a672018-04-26 18:21:26 +05301286 select CPU_V7A
Michal Simek7659fe42022-02-17 14:28:41 +01001287 select DEBUG_UART_BOARD_INIT if SPL && DEBUG_UART
Masahiro Yamada2df07d42015-03-31 12:47:55 +09001288 select DM
Michal Simek6d35f3f2018-01-09 14:49:28 +01001289 select DM_MMC if MMC
Simon Glass23d9b622015-10-17 19:41:27 -06001290 select DM_SERIAL
Michal Simek84f3dec2018-07-23 15:55:13 +02001291 select DM_SPI
Jagan Teki0bd03a52015-06-27 00:51:32 +05301292 select DM_SPI_FLASH
Michal Simek84f3dec2018-07-23 15:55:13 +02001293 select OF_CONTROL
Tom Riniddb1ec12024-01-10 13:46:10 -05001294 select MTD
Adam Ford4e96ff82018-04-15 13:51:26 -04001295 select SPI
Lukas Funkebae556542024-03-27 13:11:53 +01001296 select SPL_SOC_INIT if SPL
Michal Simek84f3dec2018-07-23 15:55:13 +02001297 select SPL_CLK if SPL
1298 select SPL_DM if SPL
Lukasz Majewski76f442982020-06-04 23:11:53 +08001299 select SPL_DM_SPI if SPL
1300 select SPL_DM_SPI_FLASH if SPL
Michal Simek84f3dec2018-07-23 15:55:13 +02001301 select SPL_OF_CONTROL if SPL
1302 select SPL_SEPARATE_BSS if SPL
Stefan Herbrechtsmeier10ff2882022-08-05 08:16:28 +02001303 select SPL_TIMER if SPL
Michal Simek84f3dec2018-07-23 15:55:13 +02001304 select SUPPORT_SPL
Stefan Herbrechtsmeier10ff2882022-08-05 08:16:28 +02001305 select TIMER
Michal Simek37ad2702018-08-20 08:24:14 +02001306 imply BOARD_LATE_INIT
Simon Glass04ac6f12017-04-26 22:28:02 -06001307 imply CMD_CLK
Michal Simek2e7c8192018-07-23 15:55:14 +02001308 imply CMD_DM
Simon Glassc6567fa2017-08-04 16:34:48 -06001309 imply CMD_SPL
Michal Simekbab07b62020-07-28 12:45:47 +02001310 imply ENV_VARS_UBOOT_RUNTIME_CONFIG
Michal Simek84f3dec2018-07-23 15:55:13 +02001311 imply FAT_WRITE
Masahiro Yamadad3ae6782014-07-30 14:08:14 +09001312
Michal Simekb513bcd2018-04-12 17:39:46 +02001313config ARCH_ZYNQMP_R5
1314 bool "Xilinx ZynqMP R5 based platform"
Michal Simek84f3dec2018-07-23 15:55:13 +02001315 select CLK
Michal Simekb513bcd2018-04-12 17:39:46 +02001316 select CPU_V7R
Michal Simekb513bcd2018-04-12 17:39:46 +02001317 select DM
Michal Simek5f3c3382019-01-15 09:06:46 +01001318 select DM_MMC if MMC
Michal Simekb513bcd2018-04-12 17:39:46 +02001319 select DM_SERIAL
Michal Simek84f3dec2018-07-23 15:55:13 +02001320 select OF_CONTROL
Michal Simek2e7c8192018-07-23 15:55:14 +02001321 imply CMD_DM
Jean-Jacques Hiblot44aaec72018-11-29 10:52:42 +01001322 imply DM_USB_GADGET
Michal Simekb513bcd2018-04-12 17:39:46 +02001323
Siva Durga Prasad Paladugu650fb402015-06-10 15:50:57 +05301324config ARCH_ZYNQMP
Michal Simek8caedde2017-11-23 08:25:41 +01001325 bool "Xilinx ZynqMP based platform"
Michal Simek04b7e622015-01-15 10:01:51 +01001326 select ARM64
Michal Simek84f3dec2018-07-23 15:55:13 +02001327 select CLK
Michal Simek25b83712015-10-17 19:41:25 -06001328 select DM
Michal Simeke5710e32022-02-17 14:28:42 +01001329 select DEBUG_UART_BOARD_INIT if SPL && DEBUG_UART
Michal Simek875a1352022-11-29 16:09:42 +01001330 imply DM_MAILBOX
Michal Simek73f2d0f2019-01-15 08:52:51 +01001331 select DM_MMC if MMC
Michal Simek25b83712015-10-17 19:41:25 -06001332 select DM_SERIAL
Tom Riniddb1ec12024-01-10 13:46:10 -05001333 select MTD
Michal Simek968388d2019-01-15 10:50:39 +01001334 select DM_SPI if SPI
1335 select DM_SPI_FLASH if DM_SPI
Michal Simek85593af2022-01-14 13:08:42 +01001336 imply FIRMWARE
Tom Rini249f11f2021-08-19 14:19:39 -04001337 select GICV2
Michal Simek84f3dec2018-07-23 15:55:13 +02001338 select OF_CONTROL
Lukas Funkebae556542024-03-27 13:11:53 +01001339 select SPL_SOC_INIT if SPL
Michal Simekfd1d7662017-12-01 15:13:36 +01001340 select SPL_CLK if SPL
Michal Simek40280f12020-08-19 10:30:39 +02001341 select SPL_DM if SPL
1342 select SPL_DM_SPI if SPI && SPL_DM
Lukasz Majewski76f442982020-06-04 23:11:53 +08001343 select SPL_DM_SPI_FLASH if SPL_DM_SPI
Ibai Erkiaga2d9b95b2019-09-27 11:37:04 +01001344 select SPL_DM_MAILBOX if SPL
Michal Simek85593af2022-01-14 13:08:42 +01001345 imply SPL_FIRMWARE if SPL
Michal Simek1bae5ec2024-03-12 16:51:21 +01001346 imply SPL_FS_FAT if SPL
1347 imply SPL_LIBCOMMON_SUPPORT if SPL
1348 imply SPL_LIBDISK_SUPPORT if SPL
1349 imply SPL_LIBGENERIC_SUPPORT if SPL
1350 imply SPL_MMC if SPL && MMC_SDHCI_ZYNQ
1351 imply SPL_SERIAL if SPL
1352 imply SPL_SPI if SPL && ZYNQ_QSPI
1353 imply SPL_SPI_FLASH_SUPPORT if SPL && ZYNQ_QSPI
Michal Simek88674da2018-11-23 09:01:44 +01001354 select SPL_SEPARATE_BSS if SPL
Michal Simek84f3dec2018-07-23 15:55:13 +02001355 select SUPPORT_SPL
Michal Simek875a1352022-11-29 16:09:42 +01001356 imply ZYNQMP_IPI if DM_MAILBOX
T Karthik Reddy501c2062021-08-10 06:50:18 -06001357 select SOC_DEVICE
Michal Simek37ad2702018-08-20 08:24:14 +02001358 imply BOARD_LATE_INIT
Michal Simek2e7c8192018-07-23 15:55:14 +02001359 imply CMD_DM
Michal Simekbab07b62020-07-28 12:45:47 +02001360 imply ENV_VARS_UBOOT_RUNTIME_CONFIG
Tom Rinid8532af2017-06-02 11:03:50 -04001361 imply FAT_WRITE
Michal Simeka8ddd6a2018-10-04 14:26:13 +02001362 imply MP
Jean-Jacques Hiblot44aaec72018-11-29 10:52:42 +01001363 imply DM_USB_GADGET
T Karthik Reddy01719722021-10-29 13:11:43 +02001364 imply ZYNQMP_GPIO_MODEPIN if DM_GPIO && USB
Michal Simek04b7e622015-01-15 10:01:51 +01001365
Trevor Woerner513f6402020-05-06 08:02:41 -04001366config ARCH_TEGRA
Masahiro Yamada73a5b1a2014-08-31 07:10:56 +09001367 bool "NVIDIA Tegra"
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001368 select GPIO_EXTRA_HEADER
Svyatoslav Ryhelb822b3f2024-01-06 22:33:59 +02001369 imply BOOTSTD_DEFAULTS
Tom Rinid8532af2017-06-02 11:03:50 -04001370 imply FAT_WRITE
Svyatoslav Ryhel79a7e412023-02-01 10:53:03 +02001371 imply SPL_TIMER if SPL
Masahiro Yamadad3ae6782014-07-30 14:08:14 +09001372
Andre Przywarab33739f2022-03-04 16:30:09 +00001373config ARCH_VEXPRESS64
1374 bool "Support ARMv8 Arm Ltd. VExpress based boards and models"
Masahiro Yamada0d46c342014-09-14 03:01:51 +09001375 select ARM64
Andre Przywara94504f42020-04-27 19:18:01 +01001376 select DM
Andre Przywara94504f42020-04-27 19:18:01 +01001377 select DM_SERIAL
Andre Przywarab33739f2022-03-04 16:30:09 +00001378 select PL01X_SERIAL
Andre Przywara395e9a92022-03-04 16:30:11 +00001379 select OF_CONTROL
1380 select CLK
Andre Przywara9fd5ec52022-03-04 16:30:13 +00001381 select BLK
1382 select MTD_NOR_FLASH if MTD
1383 select FLASH_CFI_DRIVER if MTD
1384 select ENV_IS_IN_FLASH if MTD
Andre Przywara019753a2022-03-04 16:30:14 +00001385 imply DISTRO_DEFAULTS
Linus Walleijc5822502015-01-23 14:41:10 +01001386
Rui Miguel Silvaee0fec72022-05-11 10:55:41 +01001387config TARGET_CORSTONE1000
1388 bool "Support Corstone1000 Platform"
1389 select ARM64
1390 select PL01X_SERIAL
1391 select DM
1392
Usama Arif9218a112020-08-12 16:12:53 +01001393config TARGET_TOTAL_COMPUTE
1394 bool "Support Total Compute Platform"
1395 select ARM64
1396 select PL01X_SERIAL
1397 select DM
1398 select DM_SERIAL
1399 select DM_MMC
1400 select DM_GPIO
1401
Prabhakar Kushwaha122bcfd2015-11-09 16:42:07 +05301402config TARGET_LS2080A_EMU
1403 bool "Support ls2080a_emu"
York Sun4dd8c612016-10-04 14:31:48 -07001404 select ARCH_LS2080A
Masahiro Yamada0d46c342014-09-14 03:01:51 +09001405 select ARM64
Linus Walleij74771392015-03-09 10:53:21 +01001406 select ARMV8_MULTIENTRY
Rajesh Bhagatba2414f2019-02-01 05:22:01 +00001407 select FSL_DDR_SYNC_REFRESH
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001408 select GPIO_EXTRA_HEADER
Prabhakar Kushwaha122bcfd2015-11-09 16:42:07 +05301409 help
Robert P. J. Day3a8d4e12019-12-25 06:34:07 -05001410 Support for Freescale LS2080A_EMU platform.
1411 The LS2080A Development System (EMULATOR) is a pre-silicon
Prabhakar Kushwaha122bcfd2015-11-09 16:42:07 +05301412 development platform that supports the QorIQ LS2080A
1413 Layerscape Architecture processor.
Masahiro Yamadad3ae6782014-07-30 14:08:14 +09001414
Ashish Kumar1ef4c772017-08-31 16:12:55 +05301415config TARGET_LS1088AQDS
1416 bool "Support ls1088aqds"
1417 select ARCH_LS1088A
1418 select ARM64
1419 select ARMV8_MULTIENTRY
AKASHI Takahirofb83f752019-07-03 10:44:39 +09001420 select ARCH_SUPPORT_TFABOOT
Ashish Kumar1ef4c772017-08-31 16:12:55 +05301421 select BOARD_LATE_INIT
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001422 select GPIO_EXTRA_HEADER
Ashish Kumar4feb83b2017-11-06 13:18:44 +05301423 select SUPPORT_SPL
Rajesh Bhagatba2414f2019-02-01 05:22:01 +00001424 select FSL_DDR_INTERACTIVE if !SD_BOOT
Ashish Kumar1ef4c772017-08-31 16:12:55 +05301425 help
Robert P. J. Day3a8d4e12019-12-25 06:34:07 -05001426 Support for NXP LS1088AQDS platform.
Ashish Kumar1ef4c772017-08-31 16:12:55 +05301427 The LS1088A Development System (QDS) is a high-performance
1428 development platform that supports the QorIQ LS1088A
1429 Layerscape Architecture processor.
1430
Prabhakar Kushwaha122bcfd2015-11-09 16:42:07 +05301431config TARGET_LS2080AQDS
1432 bool "Support ls2080aqds"
York Sun4dd8c612016-10-04 14:31:48 -07001433 select ARCH_LS2080A
York Sun03017032015-03-20 19:28:23 -07001434 select ARM64
1435 select ARMV8_MULTIENTRY
AKASHI Takahirofb83f752019-07-03 10:44:39 +09001436 select ARCH_SUPPORT_TFABOOT
Tom Rini22d567e2017-01-22 19:43:11 -05001437 select BOARD_LATE_INIT
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001438 select GPIO_EXTRA_HEADER
Scott Wood8e728cd2015-03-24 13:25:02 -07001439 select SUPPORT_SPL
Simon Glass0e5faf02017-06-14 21:28:21 -06001440 imply SCSI
Tuomas Tynkkynenedf9f622017-12-08 15:36:19 +02001441 imply SCSI_AHCI
Rajesh Bhagatba2414f2019-02-01 05:22:01 +00001442 select FSL_DDR_BIST
1443 select FSL_DDR_INTERACTIVE if !SPL
York Sun03017032015-03-20 19:28:23 -07001444 help
Robert P. J. Day3a8d4e12019-12-25 06:34:07 -05001445 Support for Freescale LS2080AQDS platform.
Prabhakar Kushwaha122bcfd2015-11-09 16:42:07 +05301446 The LS2080A Development System (QDS) is a high-performance
1447 development platform that supports the QorIQ LS2080A
York Sun03017032015-03-20 19:28:23 -07001448 Layerscape Architecture processor.
1449
Prabhakar Kushwaha122bcfd2015-11-09 16:42:07 +05301450config TARGET_LS2080ARDB
1451 bool "Support ls2080ardb"
York Sun4dd8c612016-10-04 14:31:48 -07001452 select ARCH_LS2080A
York Sune12abcb2015-03-20 19:28:24 -07001453 select ARM64
1454 select ARMV8_MULTIENTRY
AKASHI Takahirofb83f752019-07-03 10:44:39 +09001455 select ARCH_SUPPORT_TFABOOT
Tom Rini22d567e2017-01-22 19:43:11 -05001456 select BOARD_LATE_INIT
Scott Wood212b8d82015-03-24 13:25:03 -07001457 select SUPPORT_SPL
Rajesh Bhagatba2414f2019-02-01 05:22:01 +00001458 select FSL_DDR_BIST
1459 select FSL_DDR_INTERACTIVE if !SPL
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001460 select GPIO_EXTRA_HEADER
Simon Glass0e5faf02017-06-14 21:28:21 -06001461 imply SCSI
Tuomas Tynkkynenedf9f622017-12-08 15:36:19 +02001462 imply SCSI_AHCI
York Sune12abcb2015-03-20 19:28:24 -07001463 help
Prabhakar Kushwaha122bcfd2015-11-09 16:42:07 +05301464 Support for Freescale LS2080ARDB platform.
1465 The LS2080A Reference design board (RDB) is a high-performance
1466 development platform that supports the QorIQ LS2080A
York Sune12abcb2015-03-20 19:28:24 -07001467 Layerscape Architecture processor.
1468
Priyanka Jain75cd67f2017-04-27 15:08:07 +05301469config TARGET_LS2081ARDB
1470 bool "Support ls2081ardb"
1471 select ARCH_LS2080A
1472 select ARM64
1473 select ARMV8_MULTIENTRY
1474 select BOARD_LATE_INIT
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001475 select GPIO_EXTRA_HEADER
Priyanka Jain75cd67f2017-04-27 15:08:07 +05301476 select SUPPORT_SPL
Priyanka Jain75cd67f2017-04-27 15:08:07 +05301477 help
1478 Support for Freescale LS2081ARDB platform.
1479 The LS2081A Reference design board (RDB) is a high-performance
1480 development platform that supports the QorIQ LS2081A/LS2041A
1481 Layerscape Architecture processor.
1482
Priyanka Jainfd45ca02018-11-28 13:04:27 +00001483config TARGET_LX2160ARDB
1484 bool "Support lx2160ardb"
1485 select ARCH_LX2160A
Priyanka Jainfd45ca02018-11-28 13:04:27 +00001486 select ARM64
1487 select ARMV8_MULTIENTRY
AKASHI Takahirofb83f752019-07-03 10:44:39 +09001488 select ARCH_SUPPORT_TFABOOT
Priyanka Jainfd45ca02018-11-28 13:04:27 +00001489 select BOARD_LATE_INIT
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001490 select GPIO_EXTRA_HEADER
Priyanka Jainfd45ca02018-11-28 13:04:27 +00001491 help
1492 Support for NXP LX2160ARDB platform.
1493 The lx2160ardb (LX2160A Reference design board (RDB)
1494 is a high-performance development platform that supports the
1495 QorIQ LX2160A/LX2120A/LX2080A Layerscape Architecture processor.
1496
Pankaj Bansal338baa32019-02-08 10:29:58 +00001497config TARGET_LX2160AQDS
1498 bool "Support lx2160aqds"
1499 select ARCH_LX2160A
Pankaj Bansal338baa32019-02-08 10:29:58 +00001500 select ARM64
1501 select ARMV8_MULTIENTRY
AKASHI Takahirofb83f752019-07-03 10:44:39 +09001502 select ARCH_SUPPORT_TFABOOT
Pankaj Bansal338baa32019-02-08 10:29:58 +00001503 select BOARD_LATE_INIT
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001504 select GPIO_EXTRA_HEADER
Pankaj Bansal338baa32019-02-08 10:29:58 +00001505 help
1506 Support for NXP LX2160AQDS platform.
1507 The lx2160aqds (LX2160A QorIQ Development System (QDS)
1508 is a high-performance development platform that supports the
1509 QorIQ LX2160A/LX2120A/LX2080A Layerscape Architecture processor.
1510
Meenakshi Aggarwal8a03b0d2020-12-04 20:17:28 +05301511config TARGET_LX2162AQDS
1512 bool "Support lx2162aqds"
1513 select ARCH_LX2162A
1514 select ARCH_MISC_INIT
1515 select ARM64
1516 select ARMV8_MULTIENTRY
1517 select ARCH_SUPPORT_TFABOOT
1518 select BOARD_LATE_INIT
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001519 select GPIO_EXTRA_HEADER
Meenakshi Aggarwal8a03b0d2020-12-04 20:17:28 +05301520 help
1521 Support for NXP LX2162AQDS platform.
1522 The lx2162aqds support is based on LX2160A Layerscape Architecture processor.
1523
Peter Griffin31f327e2015-07-30 18:55:23 +01001524config TARGET_HIKEY
1525 bool "Support HiKey 96boards Consumer Edition Platform"
1526 select ARM64
Peter Griffinff9302f2015-09-10 21:55:16 +01001527 select DM
1528 select DM_GPIO
Peter Griffin0382c642015-09-10 21:55:17 +01001529 select DM_SERIAL
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001530 select GPIO_EXTRA_HEADER
Peter Griffinc97c37a2016-04-20 17:13:59 +01001531 select OF_CONTROL
Alexander Graf633ef892018-01-25 12:05:52 +01001532 select PL01X_SERIAL
Tom Rinie69ba982018-03-06 19:02:27 -05001533 select SPECIFY_CONSOLE_INDEX
Michal Simek2e7c8192018-07-23 15:55:14 +02001534 imply CMD_DM
Peter Griffin31f327e2015-07-30 18:55:23 +01001535 help
1536 Support for HiKey 96boards platform. It features a HI6220
1537 SoC, with 8xA53 CPU, mali450 gpu, and 1GB RAM.
1538
Manivannan Sadhasivamcf33f922019-08-02 20:40:09 +05301539config TARGET_HIKEY960
1540 bool "Support HiKey960 96boards Consumer Edition Platform"
1541 select ARM64
1542 select DM
1543 select DM_SERIAL
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001544 select GPIO_EXTRA_HEADER
Manivannan Sadhasivamcf33f922019-08-02 20:40:09 +05301545 select OF_CONTROL
1546 select PL01X_SERIAL
1547 imply CMD_DM
1548 help
1549 Support for HiKey960 96boards platform. It features a HI3660
1550 SoC, with 4xA73 CPU, 4xA53 CPU, MALI-G71 GPU, and 3GB RAM.
1551
Jorge Ramirez-Ortizf5b38422017-06-26 15:52:49 +02001552config TARGET_POPLAR
1553 bool "Support Poplar 96boards Enterprise Edition Platform"
1554 select ARM64
1555 select DM
Jorge Ramirez-Ortizf5b38422017-06-26 15:52:49 +02001556 select DM_SERIAL
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001557 select GPIO_EXTRA_HEADER
Michal Simek84f3dec2018-07-23 15:55:13 +02001558 select OF_CONTROL
Alexander Graf633ef892018-01-25 12:05:52 +01001559 select PL01X_SERIAL
Michal Simek2e7c8192018-07-23 15:55:14 +02001560 imply CMD_DM
Jorge Ramirez-Ortizf5b38422017-06-26 15:52:49 +02001561 help
1562 Support for Poplar 96boards EE platform. It features a HI3798cv200
1563 SoC, with 4xA53 CPU, 1GB RAM and the high performance Mali T720 GPU
1564 making it capable of running any commercial set-top solution based on
1565 Linux or Android.
1566
Prabhakar Kushwaha55432502016-06-03 18:41:34 +05301567config TARGET_LS1012AQDS
1568 bool "Support ls1012aqds"
York Sunb3d71642016-09-26 08:09:26 -07001569 select ARCH_LS1012A
Prabhakar Kushwaha55432502016-06-03 18:41:34 +05301570 select ARM64
AKASHI Takahirofb83f752019-07-03 10:44:39 +09001571 select ARCH_SUPPORT_TFABOOT
Tom Rini22d567e2017-01-22 19:43:11 -05001572 select BOARD_LATE_INIT
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001573 select GPIO_EXTRA_HEADER
Prabhakar Kushwaha55432502016-06-03 18:41:34 +05301574 help
1575 Support for Freescale LS1012AQDS platform.
1576 The LS1012A Development System (QDS) is a high-performance
1577 development platform that supports the QorIQ LS1012A
1578 Layerscape Architecture processor.
1579
Prabhakar Kushwahaa315c662016-06-03 18:41:35 +05301580config TARGET_LS1012ARDB
1581 bool "Support ls1012ardb"
York Sunb3d71642016-09-26 08:09:26 -07001582 select ARCH_LS1012A
Prabhakar Kushwahaa315c662016-06-03 18:41:35 +05301583 select ARM64
AKASHI Takahirofb83f752019-07-03 10:44:39 +09001584 select ARCH_SUPPORT_TFABOOT
Tom Rini22d567e2017-01-22 19:43:11 -05001585 select BOARD_LATE_INIT
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001586 select GPIO_EXTRA_HEADER
Simon Glass0e5faf02017-06-14 21:28:21 -06001587 imply SCSI
Tuomas Tynkkynenedf9f622017-12-08 15:36:19 +02001588 imply SCSI_AHCI
Prabhakar Kushwahaa315c662016-06-03 18:41:35 +05301589 help
1590 Support for Freescale LS1012ARDB platform.
1591 The LS1012A Reference design board (RDB) is a high-performance
1592 development platform that supports the QorIQ LS1012A
1593 Layerscape Architecture processor.
1594
Bhaskar Upadhaya7fff22a2018-01-11 20:03:31 +05301595config TARGET_LS1012A2G5RDB
1596 bool "Support ls1012a2g5rdb"
1597 select ARCH_LS1012A
1598 select ARM64
AKASHI Takahirofb83f752019-07-03 10:44:39 +09001599 select ARCH_SUPPORT_TFABOOT
Bhaskar Upadhaya7fff22a2018-01-11 20:03:31 +05301600 select BOARD_LATE_INIT
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001601 select GPIO_EXTRA_HEADER
Bhaskar Upadhaya7fff22a2018-01-11 20:03:31 +05301602 imply SCSI
1603 help
1604 Support for Freescale LS1012A2G5RDB platform.
1605 The LS1012A 2G5 Reference design board (RDB) is a high-performance
1606 development platform that supports the QorIQ LS1012A
1607 Layerscape Architecture processor.
1608
Bhaskar Upadhaya5e6f5982018-05-23 11:03:30 +05301609config TARGET_LS1012AFRWY
1610 bool "Support ls1012afrwy"
1611 select ARCH_LS1012A
1612 select ARM64
AKASHI Takahirofb83f752019-07-03 10:44:39 +09001613 select ARCH_SUPPORT_TFABOOT
Michal Simek84f3dec2018-07-23 15:55:13 +02001614 select BOARD_LATE_INIT
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001615 select GPIO_EXTRA_HEADER
Bhaskar Upadhaya5e6f5982018-05-23 11:03:30 +05301616 imply SCSI
1617 imply SCSI_AHCI
1618 help
1619 Support for Freescale LS1012AFRWY platform.
1620 The LS1012A FRWY board (FRWY) is a high-performance
1621 development platform that supports the QorIQ LS1012A
1622 Layerscape Architecture processor.
1623
Prabhakar Kushwaha9e7ee7b2016-06-03 18:41:36 +05301624config TARGET_LS1012AFRDM
1625 bool "Support ls1012afrdm"
York Sunb3d71642016-09-26 08:09:26 -07001626 select ARCH_LS1012A
Prabhakar Kushwaha9e7ee7b2016-06-03 18:41:36 +05301627 select ARM64
AKASHI Takahirofb83f752019-07-03 10:44:39 +09001628 select ARCH_SUPPORT_TFABOOT
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001629 select GPIO_EXTRA_HEADER
Prabhakar Kushwaha9e7ee7b2016-06-03 18:41:36 +05301630 help
1631 Support for Freescale LS1012AFRDM platform.
1632 The LS1012A Freedom board (FRDM) is a high-performance
1633 development platform that supports the QorIQ LS1012A
1634 Layerscape Architecture processor.
1635
Yuantian Tang473bbc42019-04-10 16:43:35 +08001636config TARGET_LS1028AQDS
1637 bool "Support ls1028aqds"
1638 select ARCH_LS1028A
1639 select ARM64
1640 select ARMV8_MULTIENTRY
AKASHI Takahirofb83f752019-07-03 10:44:39 +09001641 select ARCH_SUPPORT_TFABOOT
Yuantian Tangafa86692019-07-02 16:16:22 +08001642 select BOARD_LATE_INIT
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001643 select GPIO_EXTRA_HEADER
Yuantian Tang473bbc42019-04-10 16:43:35 +08001644 help
1645 Support for Freescale LS1028AQDS platform
1646 The LS1028A Development System (QDS) is a high-performance
1647 development platform that supports the QorIQ LS1028A
1648 Layerscape Architecture processor.
1649
Yuantian Tang92f18ff2019-04-10 16:43:34 +08001650config TARGET_LS1028ARDB
1651 bool "Support ls1028ardb"
1652 select ARCH_LS1028A
1653 select ARM64
1654 select ARMV8_MULTIENTRY
AKASHI Takahirofb83f752019-07-03 10:44:39 +09001655 select ARCH_SUPPORT_TFABOOT
Yuantian Tang31c98902020-03-09 14:10:07 +08001656 select BOARD_LATE_INIT
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001657 select GPIO_EXTRA_HEADER
Yuantian Tang92f18ff2019-04-10 16:43:34 +08001658 help
1659 Support for Freescale LS1028ARDB platform
1660 The LS1028A Development System (RDB) is a high-performance
1661 development platform that supports the QorIQ LS1028A
1662 Layerscape Architecture processor.
1663
Ashish Kumar227b4bc2017-08-31 16:12:54 +05301664config TARGET_LS1088ARDB
1665 bool "Support ls1088ardb"
1666 select ARCH_LS1088A
1667 select ARM64
1668 select ARMV8_MULTIENTRY
AKASHI Takahirofb83f752019-07-03 10:44:39 +09001669 select ARCH_SUPPORT_TFABOOT
Ashish Kumar227b4bc2017-08-31 16:12:54 +05301670 select BOARD_LATE_INIT
Ashish Kumar5676ceb2017-11-06 13:18:43 +05301671 select SUPPORT_SPL
Rajesh Bhagatba2414f2019-02-01 05:22:01 +00001672 select FSL_DDR_INTERACTIVE if !SD_BOOT
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001673 select GPIO_EXTRA_HEADER
Ashish Kumar227b4bc2017-08-31 16:12:54 +05301674 help
1675 Support for NXP LS1088ARDB platform.
1676 The LS1088A Reference design board (RDB) is a high-performance
1677 development platform that supports the QorIQ LS1088A
1678 Layerscape Architecture processor.
1679
Wang Huanf0ce7d62014-09-05 13:52:44 +08001680config TARGET_LS1021AQDS
Alison Wang6ea8ad42014-12-03 16:18:09 +08001681 bool "Support ls1021aqds"
Michal Simek84f3dec2018-07-23 15:55:13 +02001682 select ARCH_LS1021A
1683 select ARCH_SUPPORT_PSCI
1684 select BOARD_EARLY_INIT_F
Tom Rini22d567e2017-01-22 19:43:11 -05001685 select BOARD_LATE_INIT
Lokesh Vutla81b1a672018-04-26 18:21:26 +05301686 select CPU_V7A
Hongbo Zhange80fccf2016-09-21 18:31:04 +08001687 select CPU_V7_HAS_NONSEC
1688 select CPU_V7_HAS_VIRT
York Sun4de7e932016-09-26 08:09:29 -07001689 select LS1_DEEP_SLEEP
Tom Rinid7b177e2022-12-02 16:42:40 -05001690 select PEN_ADDR_BIG_ENDIAN
Michal Simek84f3dec2018-07-23 15:55:13 +02001691 select SUPPORT_SPL
York Sund297d392016-12-28 08:43:40 -08001692 select SYS_FSL_DDR
Rajesh Bhagatba2414f2019-02-01 05:22:01 +00001693 select FSL_DDR_INTERACTIVE
Lukasz Majewski23aa8342020-06-04 23:11:52 +08001694 select DM_SPI_FLASH if FSL_DSPI || FSL_QSPI
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001695 select GPIO_EXTRA_HEADER
Lukasz Majewski23aa8342020-06-04 23:11:52 +08001696 select SPI_FLASH_DATAFLASH if FSL_DSPI || FSL_QSPI
Simon Glass0e5faf02017-06-14 21:28:21 -06001697 imply SCSI
Masahiro Yamadad5415b22016-08-30 16:22:22 +09001698
Wang Huanddf89f92014-09-05 13:52:45 +08001699config TARGET_LS1021ATWR
Alison Wang6ea8ad42014-12-03 16:18:09 +08001700 bool "Support ls1021atwr"
Michal Simek84f3dec2018-07-23 15:55:13 +02001701 select ARCH_LS1021A
1702 select ARCH_SUPPORT_PSCI
1703 select BOARD_EARLY_INIT_F
Tom Rini22d567e2017-01-22 19:43:11 -05001704 select BOARD_LATE_INIT
Lokesh Vutla81b1a672018-04-26 18:21:26 +05301705 select CPU_V7A
Hongbo Zhange80fccf2016-09-21 18:31:04 +08001706 select CPU_V7_HAS_NONSEC
1707 select CPU_V7_HAS_VIRT
York Sun4de7e932016-09-26 08:09:29 -07001708 select LS1_DEEP_SLEEP
Tom Rinid7b177e2022-12-02 16:42:40 -05001709 select PEN_ADDR_BIG_ENDIAN
Michal Simek84f3dec2018-07-23 15:55:13 +02001710 select SUPPORT_SPL
Lukasz Majewski23aa8342020-06-04 23:11:52 +08001711 select DM_SPI_FLASH if FSL_DSPI || FSL_QSPI
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001712 select GPIO_EXTRA_HEADER
Simon Glass0e5faf02017-06-14 21:28:21 -06001713 imply SCSI
Wang Huanddf89f92014-09-05 13:52:45 +08001714
Aleksandar Gerasimovski032bdbc2021-02-22 18:18:11 +00001715config TARGET_PG_WCOM_SELI8
1716 bool "Support Hitachi-Powergrids SELI8 service unit card"
1717 select ARCH_LS1021A
1718 select ARCH_SUPPORT_PSCI
1719 select BOARD_EARLY_INIT_F
1720 select BOARD_LATE_INIT
1721 select CPU_V7A
1722 select CPU_V7_HAS_NONSEC
1723 select CPU_V7_HAS_VIRT
1724 select SYS_FSL_DDR
1725 select FSL_DDR_INTERACTIVE
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001726 select GPIO_EXTRA_HEADER
Aleksandar Gerasimovski032bdbc2021-02-22 18:18:11 +00001727 select VENDOR_KM
1728 imply SCSI
1729 help
1730 Support for Hitachi-Powergrids SELI8 service unit card.
1731 SELI8 is a QorIQ LS1021a based service unit card used
1732 in XMC20 and FOX615 product families.
1733
Aleksandar Gerasimovski3b24bbd2021-06-08 14:16:28 +00001734config TARGET_PG_WCOM_EXPU1
1735 bool "Support Hitachi-Powergrids EXPU1 service unit card"
1736 select ARCH_LS1021A
1737 select ARCH_SUPPORT_PSCI
1738 select BOARD_EARLY_INIT_F
1739 select BOARD_LATE_INIT
1740 select CPU_V7A
1741 select CPU_V7_HAS_NONSEC
1742 select CPU_V7_HAS_VIRT
1743 select SYS_FSL_DDR
1744 select FSL_DDR_INTERACTIVE
1745 select VENDOR_KM
1746 imply SCSI
1747 help
1748 Support for Hitachi-Powergrids EXPU1 service unit card.
1749 EXPU1 is a QorIQ LS1021a based service unit card used
1750 in XMC20 and FOX615 product families.
1751
Jianchao Wange5332ba2019-07-19 00:30:01 +03001752config TARGET_LS1021ATSN
1753 bool "Support ls1021atsn"
1754 select ARCH_LS1021A
1755 select ARCH_SUPPORT_PSCI
1756 select BOARD_EARLY_INIT_F
1757 select BOARD_LATE_INIT
1758 select CPU_V7A
1759 select CPU_V7_HAS_NONSEC
1760 select CPU_V7_HAS_VIRT
1761 select LS1_DEEP_SLEEP
1762 select SUPPORT_SPL
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001763 select GPIO_EXTRA_HEADER
Jianchao Wange5332ba2019-07-19 00:30:01 +03001764 imply SCSI
1765
Feng Li39e112d2016-11-03 14:15:17 +08001766config TARGET_LS1021AIOT
1767 bool "Support ls1021aiot"
Michal Simek84f3dec2018-07-23 15:55:13 +02001768 select ARCH_LS1021A
1769 select ARCH_SUPPORT_PSCI
Tom Rini22d567e2017-01-22 19:43:11 -05001770 select BOARD_LATE_INIT
Lokesh Vutla81b1a672018-04-26 18:21:26 +05301771 select CPU_V7A
Feng Li39e112d2016-11-03 14:15:17 +08001772 select CPU_V7_HAS_NONSEC
1773 select CPU_V7_HAS_VIRT
Tom Rinid7b177e2022-12-02 16:42:40 -05001774 select PEN_ADDR_BIG_ENDIAN
Feng Li39e112d2016-11-03 14:15:17 +08001775 select SUPPORT_SPL
Lukasz Majewski23aa8342020-06-04 23:11:52 +08001776 select DM_SPI_FLASH if FSL_DSPI || FSL_QSPI
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001777 select GPIO_EXTRA_HEADER
Simon Glass0e5faf02017-06-14 21:28:21 -06001778 imply SCSI
Feng Li39e112d2016-11-03 14:15:17 +08001779 help
1780 Support for Freescale LS1021AIOT platform.
1781 The LS1021A Freescale board (IOT) is a high-performance
1782 development platform that supports the QorIQ LS1021A
1783 Layerscape Architecture processor.
1784
Shaohui Xiedd335672015-11-11 17:58:37 +08001785config TARGET_LS1043AQDS
1786 bool "Support ls1043aqds"
York Sun149eb332016-09-26 08:09:27 -07001787 select ARCH_LS1043A
Shaohui Xiedd335672015-11-11 17:58:37 +08001788 select ARM64
1789 select ARMV8_MULTIENTRY
AKASHI Takahirofb83f752019-07-03 10:44:39 +09001790 select ARCH_SUPPORT_TFABOOT
Michal Simek84f3dec2018-07-23 15:55:13 +02001791 select BOARD_EARLY_INIT_F
Tom Rini22d567e2017-01-22 19:43:11 -05001792 select BOARD_LATE_INIT
Shaohui Xiedd335672015-11-11 17:58:37 +08001793 select SUPPORT_SPL
Rajesh Bhagatba2414f2019-02-01 05:22:01 +00001794 select FSL_DDR_INTERACTIVE if !SPL
Lukasz Majewski9cb0cc12020-06-04 23:11:51 +08001795 select FSL_DSPI if !SPL_NO_DSPI
1796 select DM_SPI_FLASH if FSL_DSPI
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001797 select GPIO_EXTRA_HEADER
Simon Glass0e5faf02017-06-14 21:28:21 -06001798 imply SCSI
Peng Maa550eb62019-01-30 19:11:49 +08001799 imply SCSI_AHCI
Shaohui Xiedd335672015-11-11 17:58:37 +08001800 help
1801 Support for Freescale LS1043AQDS platform.
1802
Mingkai Hueee86ff2015-10-26 19:47:52 +08001803config TARGET_LS1043ARDB
1804 bool "Support ls1043ardb"
York Sun149eb332016-09-26 08:09:27 -07001805 select ARCH_LS1043A
Mingkai Hueee86ff2015-10-26 19:47:52 +08001806 select ARM64
Hou Zhiqiangc7098fa2015-10-26 19:47:57 +08001807 select ARMV8_MULTIENTRY
AKASHI Takahirofb83f752019-07-03 10:44:39 +09001808 select ARCH_SUPPORT_TFABOOT
Michal Simek84f3dec2018-07-23 15:55:13 +02001809 select BOARD_EARLY_INIT_F
Tom Rini22d567e2017-01-22 19:43:11 -05001810 select BOARD_LATE_INIT
Gong Qianyu8168a0f2015-10-26 19:47:53 +08001811 select SUPPORT_SPL
Lukasz Majewski9cb0cc12020-06-04 23:11:51 +08001812 select FSL_DSPI if !SPL_NO_DSPI
1813 select DM_SPI_FLASH if FSL_DSPI
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001814 select GPIO_EXTRA_HEADER
Mingkai Hueee86ff2015-10-26 19:47:52 +08001815 help
1816 Support for Freescale LS1043ARDB platform.
1817
Shaohui Xie085ac1c2016-09-07 17:56:14 +08001818config TARGET_LS1046AQDS
1819 bool "Support ls1046aqds"
York Sunbad49842016-09-26 08:09:24 -07001820 select ARCH_LS1046A
Shaohui Xie085ac1c2016-09-07 17:56:14 +08001821 select ARM64
1822 select ARMV8_MULTIENTRY
AKASHI Takahirofb83f752019-07-03 10:44:39 +09001823 select ARCH_SUPPORT_TFABOOT
Michal Simek84f3dec2018-07-23 15:55:13 +02001824 select BOARD_EARLY_INIT_F
Tom Rini22d567e2017-01-22 19:43:11 -05001825 select BOARD_LATE_INIT
Shaohui Xie085ac1c2016-09-07 17:56:14 +08001826 select DM_SPI_FLASH if DM_SPI
Michal Simek84f3dec2018-07-23 15:55:13 +02001827 select SUPPORT_SPL
Rajesh Bhagatba2414f2019-02-01 05:22:01 +00001828 select FSL_DDR_BIST if !SPL
1829 select FSL_DDR_INTERACTIVE if !SPL
1830 select FSL_DDR_INTERACTIVE if !SPL
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001831 select GPIO_EXTRA_HEADER
Simon Glass0e5faf02017-06-14 21:28:21 -06001832 imply SCSI
Shaohui Xie085ac1c2016-09-07 17:56:14 +08001833 help
1834 Support for Freescale LS1046AQDS platform.
1835 The LS1046A Development System (QDS) is a high-performance
1836 development platform that supports the QorIQ LS1046A
1837 Layerscape Architecture processor.
1838
Mingkai Hud2396512016-09-07 18:47:28 +08001839config TARGET_LS1046ARDB
1840 bool "Support ls1046ardb"
York Sunbad49842016-09-26 08:09:24 -07001841 select ARCH_LS1046A
Mingkai Hud2396512016-09-07 18:47:28 +08001842 select ARM64
1843 select ARMV8_MULTIENTRY
AKASHI Takahirofb83f752019-07-03 10:44:39 +09001844 select ARCH_SUPPORT_TFABOOT
Michal Simek84f3dec2018-07-23 15:55:13 +02001845 select BOARD_EARLY_INIT_F
Tom Rini22d567e2017-01-22 19:43:11 -05001846 select BOARD_LATE_INIT
Mingkai Hud2396512016-09-07 18:47:28 +08001847 select DM_SPI_FLASH if DM_SPI
Hou Zhiqiang67b6d0a2016-12-09 16:09:01 +08001848 select POWER_MC34VR500
Michal Simek84f3dec2018-07-23 15:55:13 +02001849 select SUPPORT_SPL
Rajesh Bhagatba2414f2019-02-01 05:22:01 +00001850 select FSL_DDR_BIST
1851 select FSL_DDR_INTERACTIVE if !SPL
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001852 select GPIO_EXTRA_HEADER
Simon Glass0e5faf02017-06-14 21:28:21 -06001853 imply SCSI
Mingkai Hud2396512016-09-07 18:47:28 +08001854 help
1855 Support for Freescale LS1046ARDB platform.
1856 The LS1046A Reference Design Board (RDB) is a high-performance
1857 development platform that supports the QorIQ LS1046A
1858 Layerscape Architecture processor.
1859
Vabhav Sharma51641912019-06-06 12:35:28 +00001860config TARGET_LS1046AFRWY
1861 bool "Support ls1046afrwy"
1862 select ARCH_LS1046A
1863 select ARM64
1864 select ARMV8_MULTIENTRY
AKASHI Takahirofb83f752019-07-03 10:44:39 +09001865 select ARCH_SUPPORT_TFABOOT
Vabhav Sharma51641912019-06-06 12:35:28 +00001866 select BOARD_EARLY_INIT_F
1867 select BOARD_LATE_INIT
1868 select DM_SPI_FLASH if DM_SPI
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001869 select GPIO_EXTRA_HEADER
Vabhav Sharma51641912019-06-06 12:35:28 +00001870 imply SCSI
1871 help
1872 Support for Freescale LS1046AFRWY platform.
1873 The LS1046A Freeway Board (FRWY) is a high-performance
1874 development platform that supports the QorIQ LS1046A
1875 Layerscape Architecture processor.
Masahiro Yamadad3ae6782014-07-30 14:08:14 +09001876
Tom Rinidec7ea02024-05-20 13:35:03 -06001877config ARCH_SC5XX
1878 bool "Analog Devices SC5XX-processor family"
Oliver Gaskell3fe227b2024-09-12 16:50:53 +01001879 select ADI_SC5XX_TIMER
1880 select DM
1881 select DM_SERIAL
Oliver Gaskelld4f7cb52024-09-12 16:50:54 +01001882 select HAS_CUSTOM_SYS_INIT_SP_ADDR
Oliver Gaskell3fe227b2024-09-12 16:50:53 +01001883 select PANIC_HANG
1884 select SPL
Oliver Gaskelld4f7cb52024-09-12 16:50:54 +01001885 select SPL_BOOTROM_SUPPORT
Oliver Gaskell3fe227b2024-09-12 16:50:53 +01001886 select SPL_DM
Oliver Gaskelld4f7cb52024-09-12 16:50:54 +01001887 select SPL_DM_SEQ_ALIAS
1888 select SPL_LIBGENERIC_SUPPORT
1889 select SPL_LIBCOMMON_SUPPORT
1890 select SPL_SKIP_LOWLEVEL_INIT
Oliver Gaskell3fe227b2024-09-12 16:50:53 +01001891 select SUPPORT_SPL
1892 select TIMER
Tom Rinidec7ea02024-05-20 13:35:03 -06001893
Michael Walle36ba7642020-10-15 23:08:57 +02001894config TARGET_SL28
1895 bool "Support sl28"
1896 select ARCH_LS1028A
1897 select ARM64
1898 select ARMV8_MULTIENTRY
1899 select SUPPORT_SPL
1900 select BINMAN
Michael Walleb53a4f32021-03-26 19:40:57 +01001901 select DM
1902 select DM_GPIO
1903 select DM_I2C
1904 select DM_MMC
Tom Riniddb1ec12024-01-10 13:46:10 -05001905 select MTD
Michael Walleb53a4f32021-03-26 19:40:57 +01001906 select DM_SPI_FLASH
Michael Walleb53a4f32021-03-26 19:40:57 +01001907 select DM_MDIO
Simon Glass3933d292021-08-01 18:54:44 -06001908 select PCI
Michael Walleb53a4f32021-03-26 19:40:57 +01001909 select DM_RNG
1910 select DM_RTC
Tom Rini15a2ab52023-10-27 20:59:51 -04001911 select SCSI
Michael Walle7a66ef02021-03-26 19:40:58 +01001912 select DM_SERIAL
Michael Walleb53a4f32021-03-26 19:40:57 +01001913 select DM_SPI
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09001914 select GPIO_EXTRA_HEADER
Michael Walleb53a4f32021-03-26 19:40:57 +01001915 select SPL_DM if SPL
1916 select SPL_DM_SPI if SPL
1917 select SPL_DM_SPI_FLASH if SPL
1918 select SPL_DM_I2C if SPL
1919 select SPL_DM_MMC if SPL
1920 select SPL_DM_SERIAL if SPL
Michael Walle36ba7642020-10-15 23:08:57 +02001921 help
1922 Support for Kontron SMARC-sAL28 board.
1923
Mathew McBridee605fb12022-01-31 18:34:43 +05301924config TARGET_TEN64
1925 bool "Support ten64"
1926 select ARCH_LS1088A
1927 select ARCH_MISC_INIT
1928 select ARM64
1929 select ARMV8_MULTIENTRY
1930 select ARCH_SUPPORT_TFABOOT
1931 select BOARD_LATE_INIT
1932 select SUPPORT_SPL
1933 select FSL_DDR_INTERACTIVE if !SD_BOOT
1934 select GPIO_EXTRA_HEADER
1935 help
1936 Support for Traverse Technologies Ten64 board, based
1937 on NXP LS1088A.
1938
Masahiro Yamada82069432014-10-03 19:21:07 +09001939config ARCH_UNIPHIER
Masahiro Yamada563ee4c2015-05-29 17:30:01 +09001940 bool "Socionext UniPhier SoCs"
Tom Rini22d567e2017-01-22 19:43:11 -05001941 select BOARD_LATE_INIT
Masahiro Yamada85eb8262015-03-31 12:47:54 +09001942 select DM
Masahiro Yamada5f128922016-02-16 17:03:50 +09001943 select DM_GPIO
Masahiro Yamada85eb8262015-03-31 12:47:54 +09001944 select DM_I2C
Masahiro Yamada867453e2016-02-18 19:52:49 +09001945 select DM_MMC
Masahiro Yamada8fc53822020-01-30 22:07:59 +09001946 select DM_MTD
Masahiro Yamada2aa4b5b2016-10-08 13:25:31 +09001947 select DM_RESET
Masahiro Yamada694adf12016-09-14 01:05:59 +09001948 select DM_SERIAL
Masahiro Yamadae0a6fa82018-07-19 16:28:25 +09001949 select OF_BOARD_SETUP
Masahiro Yamada694adf12016-09-14 01:05:59 +09001950 select OF_CONTROL
1951 select OF_LIBFDT
Masahiro Yamada0c977252016-09-17 03:33:01 +09001952 select PINCTRL
Ley Foon Tan48fcc4a2017-05-03 17:13:32 +08001953 select SPL_BOARD_INIT if SPL
Masahiro Yamadadabee242017-01-21 18:05:22 +09001954 select SPL_DM if SPL
1955 select SPL_LIBCOMMON_SUPPORT if SPL
1956 select SPL_LIBGENERIC_SUPPORT if SPL
1957 select SPL_OF_CONTROL if SPL
1958 select SPL_PINCTRL if SPL
Masahiro Yamada694adf12016-09-14 01:05:59 +09001959 select SUPPORT_SPL
Michal Simek2e7c8192018-07-23 15:55:14 +02001960 imply CMD_DM
Masahiro Yamada577242b2018-07-20 21:47:18 +09001961 imply DISTRO_DEFAULTS
Tom Rinid8532af2017-06-02 11:03:50 -04001962 imply FAT_WRITE
Masahiro Yamada563ee4c2015-05-29 17:30:01 +09001963 help
1964 Support for UniPhier SoC family developed by Socionext Inc.
1965 (formerly, System LSI Business Division of Panasonic Corporation)
Masahiro Yamada82069432014-10-03 19:21:07 +09001966
Masami Hiramatsu7c741272021-06-04 18:45:10 +09001967config ARCH_SYNQUACER
1968 bool "Socionext SynQuacer SoCs"
1969 select ARM64
1970 select DM
1971 select GIC_V3
1972 select PSCI_RESET
1973 select SYSRESET
1974 select SYSRESET_PSCI
1975 select OF_CONTROL
1976 help
1977 Support for SynQuacer SoC family developed by Socionext Inc.
1978 This SoC is used on 96boards EE DeveloperBox.
1979
Trevor Woerner2bcc1ed2020-05-06 08:02:42 -04001980config ARCH_STM32
Patrick Delaunay85b53972018-03-12 10:46:10 +01001981 bool "Support STMicroelectronics STM32 MCU with cortex M"
rev13@wp.pl6b5e5a92015-03-01 12:44:42 +01001982 select CPU_V7M
Kamil Lulko75d48a62015-12-01 09:08:19 +01001983 select DM
1984 select DM_SERIAL
Michal Simek2e7c8192018-07-23 15:55:14 +02001985 imply CMD_DM
rev13@wp.pl6b5e5a92015-03-01 12:44:42 +01001986
Patrice Chotard5b428242017-02-21 13:37:04 +01001987config ARCH_STI
Patrick Delaunaya6b185e2022-05-20 18:38:10 +02001988 bool "Support STMicroelectronics SoCs"
Michal Simek84f3dec2018-07-23 15:55:13 +02001989 select BLK
Lokesh Vutla81b1a672018-04-26 18:21:26 +05301990 select CPU_V7A
Patrice Chotard42d742b2017-02-21 13:37:07 +01001991 select DM
Patrice Chotard2eea7d82017-02-21 13:37:09 +01001992 select DM_MMC
Patrice Chotard1235aa02017-03-22 10:54:03 +01001993 select DM_RESET
Michal Simek84f3dec2018-07-23 15:55:13 +02001994 select DM_SERIAL
Michal Simek2e7c8192018-07-23 15:55:14 +02001995 imply CMD_DM
Patrice Chotard5b428242017-02-21 13:37:04 +01001996 help
1997 Support for STMicroelectronics STiH407/10 SoC family.
1998 This SoC is used on Linaro 96Board STiH410-B2260
1999
Patrick Delaunay85b53972018-03-12 10:46:10 +01002000config ARCH_STM32MP
2001 bool "Support STMicroelectronics STM32MP Socs with cortex A"
Patrick Delaunayc5d15652018-03-20 10:54:53 +01002002 select ARCH_MISC_INIT
Patrick Delaunayf8fe21d2020-04-01 09:07:33 +02002003 select ARCH_SUPPORT_TFABOOT
Patrick Delaunay85b53972018-03-12 10:46:10 +01002004 select BOARD_LATE_INIT
2005 select CLK
2006 select DM
2007 select DM_GPIO
2008 select DM_RESET
2009 select DM_SERIAL
Michal Simek84f3dec2018-07-23 15:55:13 +02002010 select MISC
Patrick Delaunay85b53972018-03-12 10:46:10 +01002011 select OF_CONTROL
2012 select OF_LIBFDT
Patrick Delaunaya6f03912019-07-05 17:20:14 +02002013 select OF_SYSTEM_SETUP
Patrick Delaunay85b53972018-03-12 10:46:10 +01002014 select PINCTRL
2015 select REGMAP
Patrick Delaunay85b53972018-03-12 10:46:10 +01002016 select SYSCON
Patrick Delaunay32ddd262018-03-20 14:15:06 +01002017 select SYSRESET
Patrice Chotardd29531c2023-10-27 16:43:04 +02002018 select SYS_THUMB_BUILD if !ARM64
Kever Yang525ea472019-04-02 20:41:25 +08002019 imply SPL_SYSRESET
Michal Simek2e7c8192018-07-23 15:55:14 +02002020 imply CMD_DM
Patrick Delaunay4e8dbe22019-04-12 11:55:46 +02002021 imply CMD_POWEROFF
Patrick Delaunay03552502019-07-30 19:16:28 +02002022 imply OF_LIBFDT_OVERLAY
Patrick Delaunayd70e3f82019-02-27 17:01:11 +01002023 imply ENV_VARS_UBOOT_RUNTIME_CONFIG
Patrick Delaunay64e02e92019-04-18 17:32:38 +02002024 imply USE_PREBOOT
Simon Glass65831d92021-12-18 11:27:50 -07002025 imply TIMESTAMP
Patrick Delaunay85b53972018-03-12 10:46:10 +01002026 help
2027 Support for STM32MP SoC family developed by STMicroelectronics,
2028 MPUs based on ARM cortex A core
Patrick Delaunay5d061412019-02-12 11:44:39 +01002029 U-BOOT is running in DDR, loaded by the First Stage BootLoader (FSBL).
2030 FSBL can be TF-A: Trusted Firmware for Cortex A, for trusted boot
2031 chain.
2032 SPL is the unsecure FSBL for the basic boot chain.
Patrick Delaunay85b53972018-03-12 10:46:10 +01002033
Simon Glass2cffe662015-08-30 16:55:38 -06002034config ARCH_ROCKCHIP
2035 bool "Support Rockchip SoCs"
Simon Glass94106272016-06-12 23:30:14 -06002036 select BLK
Quentin Schulzd9ffa5e2022-09-02 15:10:52 +02002037 select BINMAN if SPL_OPTEE || SPL
Simon Glass2cffe662015-08-30 16:55:38 -06002038 select DM
Simon Glass94106272016-06-12 23:30:14 -06002039 select DM_GPIO
2040 select DM_I2C
2041 select DM_MMC
Michal Simek84f3dec2018-07-23 15:55:13 +02002042 select DM_PWM
2043 select DM_REGULATOR
Simon Glass94106272016-06-12 23:30:14 -06002044 select DM_SERIAL
2045 select DM_SPI
2046 select DM_SPI_FLASH
Jonas Karlman08293182023-11-12 17:48:58 +00002047 select DM_USB_GADGET if USB_DWC3_GADGET
Philipp Tomsichb6f395c2017-10-10 16:21:03 +02002048 select ENABLE_ARM_SOC_BOOT0_HOOK
Michal Simek84f3dec2018-07-23 15:55:13 +02002049 select OF_CONTROL
Tom Riniddb1ec12024-01-10 13:46:10 -05002050 select MTD
Adam Ford4e96ff82018-04-15 13:51:26 -04002051 select SPI
Michal Simek84f3dec2018-07-23 15:55:13 +02002052 select SPL_DM if SPL
Lukasz Majewski76f442982020-06-04 23:11:53 +08002053 select SPL_DM_SPI if SPL
2054 select SPL_DM_SPI_FLASH if SPL
Michal Simek84f3dec2018-07-23 15:55:13 +02002055 select SYS_MALLOC_F
2056 select SYS_THUMB_BUILD if !ARM64
2057 imply ADC
Michal Simek2e7c8192018-07-23 15:55:14 +02002058 imply CMD_DM
Kever Yang2563ee82019-03-29 09:08:58 +08002059 imply DEBUG_UART_BOARD_INIT
Simon Glassf27e9d52023-04-24 13:49:51 +12002060 imply BOOTSTD_DEFAULTS
Tom Rinid8532af2017-06-02 11:03:50 -04002061 imply FAT_WRITE
Philipp Tomsich2fa7b7e2017-09-20 13:50:13 +02002062 imply SARADC_ROCKCHIP
Michal Simek84f3dec2018-07-23 15:55:13 +02002063 imply SPL_SYSRESET
Thomas Hebb1bda4322019-11-15 08:48:57 -08002064 imply SPL_SYS_MALLOC_SIMPLE
Kever Yang4a3448c2018-04-19 11:37:09 +08002065 imply SYS_NS16550
Michal Simek84f3dec2018-07-23 15:55:13 +02002066 imply TPL_SYSRESET
2067 imply USB_FUNCTION_FASTBOOT
Simon Glass2cffe662015-08-30 16:55:38 -06002068
Suneel Garapatiaddfabc2019-10-19 18:37:55 -07002069config ARCH_OCTEONTX
2070 bool "Support OcteonTX SoCs"
Stefan Roesefbd18652020-09-23 11:01:30 +02002071 select CLK
Suneel Garapatiaddfabc2019-10-19 18:37:55 -07002072 select DM
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09002073 select GPIO_EXTRA_HEADER
Suneel Garapatiaddfabc2019-10-19 18:37:55 -07002074 select ARM64
2075 select OF_CONTROL
2076 select OF_LIVE
2077 select BOARD_LATE_INIT
2078 select SYS_CACHE_SHIFT_7
Tom Rini50e6f1b2021-12-12 22:12:32 -05002079 select SYS_PCI_64BIT if PCI
Simon Glass94886db2021-12-16 20:59:36 -07002080 imply OF_HAS_PRIOR_STAGE
Suneel Garapatid9e72462019-10-19 18:47:37 -07002081
2082config ARCH_OCTEONTX2
2083 bool "Support OcteonTX2 SoCs"
Stefan Roesefbd18652020-09-23 11:01:30 +02002084 select CLK
Suneel Garapatid9e72462019-10-19 18:47:37 -07002085 select DM
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09002086 select GPIO_EXTRA_HEADER
Suneel Garapatid9e72462019-10-19 18:47:37 -07002087 select ARM64
2088 select OF_CONTROL
2089 select OF_LIVE
2090 select BOARD_LATE_INIT
2091 select SYS_CACHE_SHIFT_7
Tom Rini50e6f1b2021-12-12 22:12:32 -05002092 select SYS_PCI_64BIT if PCI
Simon Glass94886db2021-12-16 20:59:36 -07002093 imply OF_HAS_PRIOR_STAGE
Suneel Garapatid9e72462019-10-19 18:47:37 -07002094
Sergey Temerkhanov69f7a032015-10-14 09:55:50 -07002095config TARGET_THUNDERX_88XX
2096 bool "Support ThunderX 88xx"
Marek Vasut09ab8ad2016-06-01 02:33:53 +02002097 select ARM64
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09002098 select GPIO_EXTRA_HEADER
Sergey Temerkhanov69f7a032015-10-14 09:55:50 -07002099 select OF_CONTROL
Alexander Graf633ef892018-01-25 12:05:52 +01002100 select PL01X_SERIAL
Michal Simek84f3dec2018-07-23 15:55:13 +02002101 select SYS_CACHE_SHIFT_7
Sergey Temerkhanov69f7a032015-10-14 09:55:50 -07002102
maxims@google.comf57bd002017-01-18 13:44:55 -08002103config ARCH_ASPEED
2104 bool "Support Aspeed SoCs"
maxims@google.comf57bd002017-01-18 13:44:55 -08002105 select DM
Michal Simek84f3dec2018-07-23 15:55:13 +02002106 select OF_CONTROL
Michal Simek2e7c8192018-07-23 15:55:14 +02002107 imply CMD_DM
maxims@google.comf57bd002017-01-18 13:44:55 -08002108
liu hao1c4a2c42019-10-31 07:51:08 +00002109config TARGET_DURIAN
2110 bool "Support Phytium Durian Platform"
2111 select ARM64
Masami Hiramatsucc32c0b2021-06-04 18:43:55 +09002112 select GPIO_EXTRA_HEADER
liu hao1c4a2c42019-10-31 07:51:08 +00002113 help
2114 Support for durian platform.
2115 It has 2GB Sdram, uart and pcie.
2116
weichangzheng74b45192022-03-02 15:09:05 +08002117config TARGET_POMELO
2118 bool "Support Phytium Pomelo Platform"
2119 select ARM64
2120 select DM
2121 select AHCI
2122 select SCSI_AHCI
2123 select AHCI_PCI
2124 select BLK
2125 select PCI
2126 select DM_PCI
2127 select SCSI
weichangzheng74b45192022-03-02 15:09:05 +08002128 select DM_SERIAL
weichangzheng74b45192022-03-02 15:09:05 +08002129 imply CMD_PCI
2130 help
2131 Support for pomelo platform.
2132 It has 8GB Sdram, uart and pcie.
2133
TracyMg_Li734d5772023-12-25 11:21:34 +08002134config TARGET_PE2201
2135 bool "Support Phytium PE2201 Platform"
2136 select ARM64
2137 help
2138 Support for pe2201 platform.It has 2GB Sdram, uart and pcie.
2139
Alex Nemirovsky1ecad072020-01-30 12:34:59 -08002140config TARGET_PRESIDIO_ASIC
2141 bool "Support Cortina Presidio ASIC Platform"
2142 select ARM64
Tom Rini249f11f2021-08-19 14:19:39 -04002143 select GICV2
Alex Nemirovsky1ecad072020-01-30 12:34:59 -08002144
Andrii Anisov355d1e42020-08-06 12:42:47 +03002145config TARGET_XENGUEST_ARM64
2146 bool "Xen guest ARM64"
2147 select ARM64
2148 select XEN
2149 select OF_CONTROL
2150 select LINUX_KERNEL_IMAGE_HEADER
Peng Fan8162f8f2020-08-06 12:42:50 +03002151 select XEN_SERIAL
Simon Glass94886db2021-12-16 20:59:36 -07002152 imply OF_HAS_PRIOR_STAGE
2153
Nick Hawkins0998a752022-06-08 16:21:34 -05002154config ARCH_GXP
2155 bool "Support HPE GXP SoCs"
2156 select DM
2157 select OF_CONTROL
2158 imply CMD_DM
2159
Masahiro Yamadad3ae6782014-07-30 14:08:14 +09002160endchoice
2161
Tom Rini4cc38852021-08-30 09:16:30 -04002162config SUPPORT_PASSING_ATAGS
2163 bool "Support pre-devicetree ATAG-based booting"
2164 depends on !ARM64
2165 imply SETUP_MEMORY_TAGS
2166 help
2167 Support for booting older Linux kernels, using ATAGs rather than
2168 passing a devicetree. This is option is rarely used, and the
2169 semantics are defined at
2170 https://www.kernel.org/doc/Documentation/arm/Booting at section 4a.
2171
2172config SETUP_MEMORY_TAGS
2173 bool "Pass memory size information via ATAG"
2174 depends on SUPPORT_PASSING_ATAGS
2175
2176config CMDLINE_TAG
2177 bool "Pass Linux kernel cmdline via ATAG"
2178 depends on SUPPORT_PASSING_ATAGS
2179
2180config INITRD_TAG
2181 bool "Pass initrd starting point and size via ATAG"
2182 depends on SUPPORT_PASSING_ATAGS
2183
2184config REVISION_TAG
2185 bool "Pass system revision via ATAG"
2186 depends on SUPPORT_PASSING_ATAGS
2187
2188config SERIAL_TAG
2189 bool "Pass system serial number via ATAG"
2190 depends on SUPPORT_PASSING_ATAGS
2191
Tom Riniea1e52b2021-08-30 09:16:31 -04002192config STATIC_MACH_TYPE
2193 bool "Statically define the Machine ID number"
Tom Rinia4bdec22023-09-04 21:12:28 -04002194 default y if TARGET_DS109 || TARGET_DS414 || DEFAULT_DEVICE_TREE = "sun7i-a20-icnova-swac"
Tom Riniea1e52b2021-08-30 09:16:31 -04002195 help
2196 When booting via ATAGs, enable this option if we know the correct
2197 machine ID number to use at compile time. Some systems will be
2198 passed the number dynamically by whatever loads U-Boot.
2199
2200config MACH_TYPE
2201 int "Machine ID number"
2202 depends on STATIC_MACH_TYPE
Pali Rohár4cf1b942022-08-11 22:29:03 +02002203 default 527 if TARGET_DS109
Pali Rohár4cf1b942022-08-11 22:29:03 +02002204 default 3036 if TARGET_DS414
2205 default 4283 if DEFAULT_DEVICE_TREE = "sun7i-a20-icnova-swac"
Tom Riniea1e52b2021-08-30 09:16:31 -04002206 help
2207 When booting via ATAGs, the machine type must be passed as a number.
2208 For the full list see https://www.arm.linux.org.uk/developer/machines
2209
AKASHI Takahirofb83f752019-07-03 10:44:39 +09002210config ARCH_SUPPORT_TFABOOT
2211 bool
2212
2213config TFABOOT
2214 bool "Support for booting from TF-A"
2215 depends on ARCH_SUPPORT_TFABOOT
AKASHI Takahirofb83f752019-07-03 10:44:39 +09002216 help
Andre Przywara41087af2020-09-30 15:45:07 +01002217 Some platforms support the setup of secure registers (for instance
2218 for CPU errata handling) or provide secure services like PSCI.
2219 Those services could also be provided by other firmware parts
2220 like TF-A (Trusted Firmware for Cortex-A), in which case U-Boot
2221 does not need to (and cannot) execute this code.
2222 Enabling this option will make a U-Boot binary that is relying
2223 on other firmware layers to provide secure functionality.
AKASHI Takahirofb83f752019-07-03 10:44:39 +09002224
Andrew F. Davisd3fe9172018-02-14 11:53:37 -06002225config TI_SECURE_DEVICE
2226 bool "HS Device Type Support"
Andrew F. Davis2ed41072019-04-12 12:54:45 -04002227 depends on ARCH_KEYSTONE || ARCH_OMAP2PLUS || ARCH_K3
Andrew F. Davisd3fe9172018-02-14 11:53:37 -06002228 help
2229 If a high secure (HS) device type is being used, this config
2230 must be set. This option impacts various aspects of the
2231 build system (to create signed boot images that can be
2232 authenticated) and the code. See the doc/README.ti-secure
2233 file for further details.
2234
Tom Rini43b9c292021-12-17 18:08:45 -05002235config SYS_KWD_CONFIG
2236 string "kwbimage config file path"
2237 depends on ARCH_KIRKWOOD || ARCH_MVEBU
2238 default "arch/arm/mach-mvebu/kwbimage.cfg"
2239 help
2240 Path within the source directory to the kwbimage.cfg file to use
2241 when packaging the U-Boot image for use.
2242
Mark Kettenis58d51272021-10-23 16:58:03 +02002243source "arch/arm/mach-apple/Kconfig"
2244
maxims@google.comf57bd002017-01-18 13:44:55 -08002245source "arch/arm/mach-aspeed/Kconfig"
2246
Masahiro Yamadaaf908ee2015-02-20 17:04:01 +09002247source "arch/arm/mach-at91/Kconfig"
2248
Masahiro Yamadaed22cc72015-03-19 19:42:56 +09002249source "arch/arm/mach-bcm283x/Kconfig"
Masahiro Yamadae604ef92014-08-31 07:11:01 +09002250
William Zhangd7cdf302022-05-09 09:28:02 -07002251source "arch/arm/mach-bcmbca/Kconfig"
2252
Thomas Fitzsimmons919646d2018-06-08 17:59:45 -04002253source "arch/arm/mach-bcmstb/Kconfig"
2254
Masahiro Yamadaed22cc72015-03-19 19:42:56 +09002255source "arch/arm/mach-davinci/Kconfig"
Simon Glass13fc6a22015-02-05 21:41:39 -07002256
Thomas Abraham74f84862015-08-03 17:58:00 +05302257source "arch/arm/mach-exynos/Kconfig"
Masahiro Yamadac54550b2014-08-31 07:11:00 +09002258
Nick Hawkins0998a752022-06-08 16:21:34 -05002259source "arch/arm/mach-hpe/gxp/Kconfig"
2260
Masahiro Yamada95ec48b2015-02-20 17:04:08 +09002261source "arch/arm/mach-highbank/Kconfig"
Masahiro Yamada52ece9c2014-08-31 07:11:07 +09002262
Yang Xiwendb1d1f42023-04-01 19:17:33 +08002263source "arch/arm/mach-histb/Kconfig"
2264
Masahiro Yamadacad44162015-04-21 21:59:36 +09002265source "arch/arm/mach-integrator/Kconfig"
2266
Robert Markoe7a34f12020-07-06 10:37:54 +02002267source "arch/arm/mach-ipq40xx/Kconfig"
2268
Lokesh Vutla9bdec002018-08-27 15:57:08 +05302269source "arch/arm/mach-k3/Kconfig"
2270
Masahiro Yamadaf058b792015-02-20 17:04:11 +09002271source "arch/arm/mach-keystone/Kconfig"
Masahiro Yamada32013fb2014-08-31 07:11:05 +09002272
Masahiro Yamada5e5e23a2015-02-20 17:04:06 +09002273source "arch/arm/mach-kirkwood/Kconfig"
Masahiro Yamadad7570852014-08-31 07:10:59 +09002274
Trevor Woerner28d261f2020-05-06 08:02:36 -04002275source "arch/arm/mach-lpc32xx/Kconfig"
Vladimir Zapolskiy31d0e962018-09-17 21:43:03 +03002276
Stefan Roese383e0c12015-08-25 13:18:38 +02002277source "arch/arm/mach-mvebu/Kconfig"
2278
Suneel Garapatiaddfabc2019-10-19 18:37:55 -07002279source "arch/arm/mach-octeontx/Kconfig"
Suneel Garapatid9e72462019-10-19 18:47:37 -07002280
2281source "arch/arm/mach-octeontx2/Kconfig"
2282
York Sun149eb332016-09-26 08:09:27 -07002283source "arch/arm/cpu/armv7/ls102xa/Kconfig"
2284
Magnus Liljac74f70f2018-05-11 14:06:54 +02002285source "arch/arm/mach-imx/mx3/Kconfig"
2286
Peng Fan66294882018-01-10 13:20:19 +08002287source "arch/arm/mach-imx/mx5/Kconfig"
2288
2289source "arch/arm/mach-imx/mx6/Kconfig"
Peng Fan2c7b1702017-02-22 16:21:39 +08002290
Stefano Babic33731bc2017-06-29 10:16:06 +02002291source "arch/arm/mach-imx/mx7/Kconfig"
Adrian Alonso98810772015-09-03 11:49:28 -05002292
Peng Fan66294882018-01-10 13:20:19 +08002293source "arch/arm/mach-imx/mx7ulp/Kconfig"
Boris BREZILLON51e82662015-03-04 13:13:03 +01002294
Peng Fan6bae1c72018-10-18 14:28:08 +02002295source "arch/arm/mach-imx/imx8/Kconfig"
2296
Peng Fan39945c12018-11-20 10:19:25 +00002297source "arch/arm/mach-imx/imx8m/Kconfig"
Andrej Rosano1ac4bca2015-04-08 18:56:29 +02002298
Peng Fan570dc4f2021-08-07 16:00:30 +08002299source "arch/arm/mach-imx/imx8ulp/Kconfig"
2300
Peng Fanbbcd2c42022-07-26 16:40:39 +08002301source "arch/arm/mach-imx/imx9/Kconfig"
2302
Giulio Benetti9dba2622020-01-10 15:51:47 +01002303source "arch/arm/mach-imx/imxrt/Kconfig"
2304
Stefan Agner081ea1f2018-02-06 09:44:34 +01002305source "arch/arm/mach-imx/mxs/Kconfig"
2306
Tom Rini28eec372016-11-07 21:34:54 -05002307source "arch/arm/mach-omap2/Kconfig"
Madan Srinivaseba13cd2016-05-19 19:10:43 -05002308
York Sunbad49842016-09-26 08:09:24 -07002309source "arch/arm/cpu/armv8/fsl-layerscape/Kconfig"
2310
Masahiro Yamada22537642015-02-20 17:04:09 +09002311source "arch/arm/mach-orion5x/Kconfig"
Masahiro Yamada04ffbc12014-08-31 07:11:06 +09002312
Manivannan Sadhasivam474a5df2018-06-14 23:38:31 +05302313source "arch/arm/mach-owl/Kconfig"
2314
Marek Vasute3f84ec2024-02-27 17:05:56 +01002315source "arch/arm/mach-renesas/Kconfig"
Masahiro Yamadac9c54e22014-08-31 07:10:57 +09002316
Beniamino Galvanid1037e42016-05-08 08:30:16 +02002317source "arch/arm/mach-meson/Kconfig"
2318
developerf4a079c2018-11-15 10:07:52 +08002319source "arch/arm/mach-mediatek/Kconfig"
2320
Tuomas Tynkkynen28cac522017-09-19 23:18:07 +03002321source "arch/arm/mach-qemu/Kconfig"
2322
Simon Glass2cffe662015-08-30 16:55:38 -06002323source "arch/arm/mach-rockchip/Kconfig"
2324
Minkyu Kang56b820a2015-11-20 15:24:57 +09002325source "arch/arm/mach-s5pc1xx/Kconfig"
Simon Glass96aa0722014-10-07 22:01:50 -06002326
Tom Rinidec7ea02024-05-20 13:35:03 -06002327source "arch/arm/mach-sc5xx/Kconfig"
2328
Mateusz Kulikowski2507d822016-03-31 23:12:32 +02002329source "arch/arm/mach-snapdragon/Kconfig"
2330
Masahiro Yamada144a3e02015-04-21 20:38:20 +09002331source "arch/arm/mach-socfpga/Kconfig"
2332
Patrice Chotard5b428242017-02-21 13:37:04 +01002333source "arch/arm/mach-sti/Kconfig"
2334
Vikas Manocha95c89192016-01-15 17:49:06 -08002335source "arch/arm/mach-stm32/Kconfig"
2336
Patrick Delaunay85b53972018-03-12 10:46:10 +01002337source "arch/arm/mach-stm32mp/Kconfig"
2338
Masahiro Yamada4976a222017-04-28 19:42:18 +09002339source "arch/arm/mach-sunxi/Kconfig"
2340
Masahiro Yamadaed1632a2015-02-20 17:04:04 +09002341source "arch/arm/mach-tegra/Kconfig"
Masahiro Yamada73a5b1a2014-08-31 07:10:56 +09002342
Stephan Gerhold4f1170f2020-01-04 18:45:17 +01002343source "arch/arm/mach-u8500/Kconfig"
2344
Masahiro Yamadaf8563982015-02-27 02:26:42 +09002345source "arch/arm/mach-uniphier/Kconfig"
Masahiro Yamada82069432014-10-03 19:21:07 +09002346
Stefan Agnerd53c0a42017-03-13 18:41:36 -07002347source "arch/arm/cpu/armv7/vf610/Kconfig"
2348
Masahiro Yamada43246cc2015-03-16 16:43:22 +09002349source "arch/arm/mach-zynq/Kconfig"
Masahiro Yamada73a5b1a2014-08-31 07:10:56 +09002350
Michal Simek7f60b232019-01-17 08:22:43 +01002351source "arch/arm/mach-zynqmp/Kconfig"
2352
Michal Simek4b066a12018-08-22 14:55:27 +02002353source "arch/arm/mach-versal/Kconfig"
2354
Michal Simekd903ce42024-05-29 16:47:58 +02002355source "arch/arm/mach-versal2/Kconfig"
2356
Michal Simek2e53eb22022-09-19 14:21:02 +02002357source "arch/arm/mach-versal-net/Kconfig"
2358
Michal Simekb513bcd2018-04-12 17:39:46 +02002359source "arch/arm/mach-zynqmp-r5/Kconfig"
2360
Hans de Goede85437352014-11-14 09:34:30 +01002361source "arch/arm/cpu/armv7/Kconfig"
2362
Linus Walleij74771392015-03-09 10:53:21 +01002363source "arch/arm/cpu/armv8/Kconfig"
2364
Stefano Babic33731bc2017-06-29 10:16:06 +02002365source "arch/arm/mach-imx/Kconfig"
Boris BREZILLON6b9b9a02015-03-04 13:13:04 +01002366
Stefan Bosch6563ea22020-07-10 19:07:26 +02002367source "arch/arm/mach-nexell/Kconfig"
2368
Jim Liu4359b332022-04-19 13:32:19 +08002369source "arch/arm/mach-npcm/Kconfig"
2370
Usama Arif9218a112020-08-12 16:12:53 +01002371source "board/armltd/total_compute/Kconfig"
Rui Miguel Silvaee0fec72022-05-11 10:55:41 +01002372source "board/armltd/corstone1000/Kconfig"
Heiko Schocherf1163962016-06-07 08:31:25 +02002373source "board/bosch/shc/Kconfig"
Sjoerd Simonsf93564c2019-02-25 15:33:00 +00002374source "board/bosch/guardian/Kconfig"
Suneel Garapatiaddfabc2019-10-19 18:37:55 -07002375source "board/Marvell/octeontx/Kconfig"
Suneel Garapatid9e72462019-10-19 18:47:37 -07002376source "board/Marvell/octeontx2/Kconfig"
Kristian Amlie8f8a2992021-09-07 08:37:51 +02002377source "board/armltd/vexpress/Kconfig"
Masahiro Yamadad3ae6782014-07-30 14:08:14 +09002378source "board/armltd/vexpress64/Kconfig"
Alex Nemirovsky1ecad072020-01-30 12:34:59 -08002379source "board/cortina/presidio-asic/Kconfig"
Linus Walleijaaa9e3d2023-04-24 09:38:30 +02002380source "board/broadcom/bcmns/Kconfig"
Rayagonda Kokatanur1d8fa362020-07-15 22:48:55 +05302381source "board/broadcom/bcmns3/Kconfig"
Sergey Temerkhanov69f7a032015-10-14 09:55:50 -07002382source "board/cavium/thunderx/Kconfig"
Felix Brack1ba8c9e2018-01-23 18:27:22 +01002383source "board/eets/pdu001/Kconfig"
Bin Meng53290422018-10-15 02:21:18 -07002384source "board/emulation/qemu-arm/Kconfig"
Patrick Rudolphcb42bc82024-10-23 15:20:08 +02002385source "board/emulation/qemu-sbsa/Kconfig"
Prabhakar Kushwaha122bcfd2015-11-09 16:42:07 +05302386source "board/freescale/ls2080aqds/Kconfig"
2387source "board/freescale/ls2080ardb/Kconfig"
Ashish Kumar227b4bc2017-08-31 16:12:54 +05302388source "board/freescale/ls1088a/Kconfig"
Yuantian Tang92f18ff2019-04-10 16:43:34 +08002389source "board/freescale/ls1028a/Kconfig"
Wang Huanf0ce7d62014-09-05 13:52:44 +08002390source "board/freescale/ls1021aqds/Kconfig"
Shaohui Xiedd335672015-11-11 17:58:37 +08002391source "board/freescale/ls1043aqds/Kconfig"
Wang Huanddf89f92014-09-05 13:52:45 +08002392source "board/freescale/ls1021atwr/Kconfig"
Jianchao Wange5332ba2019-07-19 00:30:01 +03002393source "board/freescale/ls1021atsn/Kconfig"
Feng Li39e112d2016-11-03 14:15:17 +08002394source "board/freescale/ls1021aiot/Kconfig"
Shaohui Xie085ac1c2016-09-07 17:56:14 +08002395source "board/freescale/ls1046aqds/Kconfig"
Mingkai Hueee86ff2015-10-26 19:47:52 +08002396source "board/freescale/ls1043ardb/Kconfig"
Mingkai Hud2396512016-09-07 18:47:28 +08002397source "board/freescale/ls1046ardb/Kconfig"
Vabhav Sharma51641912019-06-06 12:35:28 +00002398source "board/freescale/ls1046afrwy/Kconfig"
Prabhakar Kushwaha55432502016-06-03 18:41:34 +05302399source "board/freescale/ls1012aqds/Kconfig"
Prabhakar Kushwahaa315c662016-06-03 18:41:35 +05302400source "board/freescale/ls1012ardb/Kconfig"
Prabhakar Kushwaha9e7ee7b2016-06-03 18:41:36 +05302401source "board/freescale/ls1012afrdm/Kconfig"
Priyanka Jainfd45ca02018-11-28 13:04:27 +00002402source "board/freescale/lx2160a/Kconfig"
Marcin Niestroj20315d22017-01-25 09:53:08 +01002403source "board/grinn/chiliboard/Kconfig"
Tom Rinibdf4f182015-09-02 15:32:20 -04002404source "board/hisilicon/hikey/Kconfig"
Manivannan Sadhasivamcf33f922019-08-02 20:40:09 +05302405source "board/hisilicon/hikey960/Kconfig"
Jorge Ramirez-Ortizf5b38422017-06-26 15:52:49 +02002406source "board/hisilicon/poplar/Kconfig"
Ladislav Michl10bdc712017-04-01 17:17:16 +02002407source "board/isee/igep003x/Kconfig"
Michael Walle36ba7642020-10-15 23:08:57 +02002408source "board/kontron/sl28/Kconfig"
Parthiban Nallathambi8214fd92020-07-27 16:48:41 +02002409source "board/myir/mys_6ulx/Kconfig"
Tom Rinib5207bb2022-11-19 18:45:26 -05002410source "board/samsung/common/Kconfig"
Tom Rini29e05952022-06-10 22:59:35 -04002411source "board/siemens/common/Kconfig"
Navin Sankar Velliangiri3b2cc732021-05-18 09:03:20 +05302412source "board/seeed/npi_imx6ull/Kconfig"
Masami Hiramatsu7c741272021-06-04 18:45:10 +09002413source "board/socionext/developerbox/Kconfig"
Enric Balletbò i Serra9d89b082015-09-07 07:43:20 +02002414source "board/tcl/sl50/Kconfig"
Mathew McBridee605fb12022-01-31 18:34:43 +05302415source "board/traverse/ten64/Kconfig"
Parthiban Nallathambi5e9147d2019-04-18 00:04:09 +02002416source "board/variscite/dart_6ul/Kconfig"
Yegor Yefremovfa8b71b2015-05-29 19:27:29 +02002417source "board/vscom/baltos/Kconfig"
liu hao1c4a2c42019-10-31 07:51:08 +00002418source "board/phytium/durian/Kconfig"
weichangzheng74b45192022-03-02 15:09:05 +08002419source "board/phytium/pomelo/Kconfig"
TracyMg_Li734d5772023-12-25 11:21:34 +08002420source "board/phytium/pe2201/Kconfig"
Andrii Anisov355d1e42020-08-06 12:42:47 +03002421source "board/xen/xenguest_arm64/Kconfig"
Masahiro Yamadad3ae6782014-07-30 14:08:14 +09002422
Masahiro Yamadadf00e522014-09-01 11:06:34 +09002423source "arch/arm/Kconfig.debug"
2424
Masahiro Yamadad3ae6782014-07-30 14:08:14 +09002425endmenu