xref: /openbmc/linux/arch/arm64/Kconfig.platforms (revision 827beb77)
1# SPDX-License-Identifier: GPL-2.0-only
2menu "Platform selection"
3
4config ARCH_ACTIONS
5	bool "Actions Semi Platforms"
6	select OWL_TIMER
7	select PINCTRL
8	help
9	  This enables support for the Actions Semiconductor S900 SoC family.
10
11config ARCH_SUNXI
12	bool "Allwinner sunxi 64-bit SoC Family"
13	select ARCH_HAS_RESET_CONTROLLER
14	select GENERIC_IRQ_CHIP
15	select IRQ_DOMAIN_HIERARCHY
16	select IRQ_FASTEOI_HIERARCHY_HANDLERS
17	select PINCTRL
18	select RESET_CONTROLLER
19	select SUN4I_TIMER
20	help
21	  This enables support for Allwinner sunxi based SoCs like the A64.
22
23config ARCH_ALPINE
24	bool "Annapurna Labs Alpine platform"
25	select ALPINE_MSI if PCI
26	help
27	  This enables support for the Annapurna Labs Alpine
28	  Soc family.
29
30config ARCH_APPLE
31	bool "Apple Silicon SoC family"
32	select APPLE_AIC
33	help
34	  This enables support for Apple's in-house ARM SoC family, starting
35	  with the Apple M1.
36
37config ARCH_BCM2835
38	bool "Broadcom BCM2835 family"
39	select TIMER_OF
40	select GPIOLIB
41	select MFD_CORE
42	select PINCTRL
43	select PINCTRL_BCM2835
44	select ARM_AMBA
45	select ARM_GIC
46	select ARM_TIMER_SP804
47	help
48	  This enables support for the Broadcom BCM2837 and BCM2711 SoC.
49	  These SoCs are used in the Raspberry Pi 3 and 4 devices.
50
51config ARCH_BCM4908
52	bool "Broadcom BCM4908 family"
53	select GPIOLIB
54	help
55	  This enables support for the Broadcom BCM4906, BCM4908 and
56	  BCM49408 SoCs. These SoCs use Brahma-B53 cores and can be
57	  found in home routers.
58
59config ARCH_BCM_IPROC
60	bool "Broadcom iProc SoC Family"
61	select COMMON_CLK_IPROC
62	select GPIOLIB
63	select PINCTRL
64	help
65	  This enables support for Broadcom iProc based SoCs
66
67config ARCH_BERLIN
68	bool "Marvell Berlin SoC Family"
69	select DW_APB_ICTL
70	select DW_APB_TIMER_OF
71	select GPIOLIB
72	select PINCTRL
73	help
74	  This enables support for Marvell Berlin SoC Family
75
76config ARCH_BITMAIN
77	bool "Bitmain SoC Platforms"
78	help
79	  This enables support for the Bitmain SoC Family.
80
81config ARCH_BRCMSTB
82	bool "Broadcom Set-Top-Box SoCs"
83	select ARCH_HAS_RESET_CONTROLLER
84	select GENERIC_IRQ_CHIP
85	select PINCTRL
86	help
87	  This enables support for Broadcom's ARMv8 Set Top Box SoCs
88
89config ARCH_EXYNOS
90	bool "ARMv8 based Samsung Exynos SoC family"
91	select COMMON_CLK_SAMSUNG
92	select EXYNOS_CHIPID
93	select EXYNOS_PM_DOMAINS if PM_GENERIC_DOMAINS
94	select EXYNOS_PMU
95	select HAVE_S3C_RTC if RTC_CLASS
96	select PINCTRL
97	select PINCTRL_EXYNOS
98	select PM_GENERIC_DOMAINS if PM
99	select SOC_SAMSUNG
100	help
101	  This enables support for ARMv8 based Samsung Exynos SoC family.
102
103config ARCH_SPARX5
104	bool "ARMv8 based Microchip Sparx5 SoC family"
105	select PINCTRL
106	select DW_APB_TIMER_OF
107	help
108	  This enables support for the Microchip Sparx5 ARMv8-based
109	  SoC family of TSN-capable gigabit switches.
110
111	  The SparX-5 Ethernet switch family provides a rich set of
112	  switching features such as advanced TCAM-based VLAN and QoS
113	  processing enabling delivery of differentiated services, and
114	  security through TCAM-based frame processing using versatile
115	  content aware processor (VCAP).
116
117config ARCH_K3
118	bool "Texas Instruments Inc. K3 multicore SoC architecture"
119	select PM_GENERIC_DOMAINS if PM
120	select MAILBOX
121	select SOC_TI
122	select TI_MESSAGE_MANAGER
123	select TI_SCI_PROTOCOL
124	select TI_SCI_INTR_IRQCHIP
125	select TI_SCI_INTA_IRQCHIP
126	select TI_K3_SOCINFO
127	help
128	  This enables support for Texas Instruments' K3 multicore SoC
129	  architecture.
130
131config ARCH_LAYERSCAPE
132	bool "ARMv8 based Freescale Layerscape SoC family"
133	select EDAC_SUPPORT
134	help
135	  This enables support for the Freescale Layerscape SoC family.
136
137config ARCH_LG1K
138	bool "LG Electronics LG1K SoC Family"
139	help
140	  This enables support for LG Electronics LG1K SoC Family
141
142config ARCH_HISI
143	bool "Hisilicon SoC Family"
144	select ARM_TIMER_SP804
145	select HISILICON_IRQ_MBIGEN if PCI
146	select PINCTRL
147	help
148	  This enables support for Hisilicon ARMv8 SoC family
149
150config ARCH_KEEMBAY
151	bool "Keem Bay SoC"
152	help
153	  This enables support for Intel Movidius SoC code-named Keem Bay.
154
155config ARCH_MEDIATEK
156	bool "MediaTek SoC Family"
157	select ARM_GIC
158	select PINCTRL
159	select MTK_TIMER
160	help
161	  This enables support for MediaTek MT27xx, MT65xx, MT76xx
162	  & MT81xx ARMv8 SoCs
163
164config ARCH_MESON
165	bool "Amlogic Platforms"
166	select COMMON_CLK
167	help
168	  This enables support for the arm64 based Amlogic SoCs
169	  such as the s905, S905X/D, S912, A113X/D or S905X/D2
170
171config ARCH_MVEBU
172	bool "Marvell EBU SoC Family"
173	select ARMADA_AP806_SYSCON
174	select ARMADA_CP110_SYSCON
175	select ARMADA_37XX_CLK
176	select GPIOLIB
177	select GPIOLIB_IRQCHIP
178	select MVEBU_GICP
179	select MVEBU_ICU
180	select MVEBU_ODMI
181	select MVEBU_PIC
182	select MVEBU_SEI
183	select OF_GPIO
184	select PINCTRL
185	select PINCTRL_ARMADA_37XX
186	select PINCTRL_ARMADA_AP806
187	select PINCTRL_ARMADA_CP110
188	help
189	  This enables support for Marvell EBU familly, including:
190	   - Armada 3700 SoC Family
191	   - Armada 7K SoC Family
192	   - Armada 8K SoC Family
193
194config ARCH_MXC
195	bool "ARMv8 based NXP i.MX SoC family"
196	select ARM64_ERRATUM_843419
197	select ARM64_ERRATUM_845719 if COMPAT
198	select IMX_GPCV2
199	select IMX_GPCV2_PM_DOMAINS
200	select PM
201	select PM_GENERIC_DOMAINS
202	select SOC_BUS
203	select TIMER_IMX_SYS_CTR
204	help
205	  This enables support for the ARMv8 based SoCs in the
206	  NXP i.MX family.
207
208config ARCH_QCOM
209	bool "Qualcomm Platforms"
210	select GPIOLIB
211	select PINCTRL
212	help
213	  This enables support for the ARMv8 based Qualcomm chipsets.
214
215config ARCH_REALTEK
216	bool "Realtek Platforms"
217	select RESET_CONTROLLER
218	help
219	  This enables support for the ARMv8 based Realtek chipsets,
220	  like the RTD1295.
221
222config ARCH_RENESAS
223	bool "Renesas SoC Platforms"
224	select GPIOLIB
225	select PINCTRL
226	select SOC_BUS
227	help
228	  This enables support for the ARMv8 based Renesas SoCs.
229
230config ARCH_ROCKCHIP
231	bool "Rockchip Platforms"
232	select ARCH_HAS_RESET_CONTROLLER
233	select PINCTRL
234	select PM
235	select ROCKCHIP_TIMER
236	help
237	  This enables support for the ARMv8 based Rockchip chipsets,
238	  like the RK3368.
239
240config ARCH_S32
241	bool "NXP S32 SoC Family"
242	help
243	  This enables support for the NXP S32 family of processors.
244
245config ARCH_SEATTLE
246	bool "AMD Seattle SoC Family"
247	help
248	  This enables support for AMD Seattle SOC Family
249
250config ARCH_INTEL_SOCFPGA
251	bool "Intel's SoCFPGA ARMv8 Families"
252	help
253	  This enables support for Intel's SoCFPGA ARMv8 families:
254	  Stratix 10 (ex. Altera), Agilex and eASIC N5X.
255
256config ARCH_SYNQUACER
257	bool "Socionext SynQuacer SoC Family"
258
259config ARCH_TEGRA
260	bool "NVIDIA Tegra SoC Family"
261	select ARCH_HAS_RESET_CONTROLLER
262	select ARM_GIC_PM
263	select CLKSRC_MMIO
264	select TIMER_OF
265	select GPIOLIB
266	select PINCTRL
267	select PM
268	select PM_GENERIC_DOMAINS
269	select RESET_CONTROLLER
270	help
271	  This enables support for the NVIDIA Tegra SoC family.
272
273config ARCH_SPRD
274	bool "Spreadtrum SoC platform"
275	help
276	  Support for Spreadtrum ARM based SoCs
277
278config ARCH_THUNDER
279	bool "Cavium Inc. Thunder SoC Family"
280	help
281	  This enables support for Cavium's Thunder Family of SoCs.
282
283config ARCH_THUNDER2
284	bool "Cavium ThunderX2 Server Processors"
285	select GPIOLIB
286	help
287	  This enables support for Cavium's ThunderX2 CN99XX family of
288	  server processors.
289
290config ARCH_UNIPHIER
291	bool "Socionext UniPhier SoC Family"
292	select ARCH_HAS_RESET_CONTROLLER
293	select PINCTRL
294	select RESET_CONTROLLER
295	help
296	  This enables support for Socionext UniPhier SoC family.
297
298config ARCH_VEXPRESS
299	bool "ARMv8 software model (Versatile Express)"
300	select GPIOLIB
301	select PM
302	select PM_GENERIC_DOMAINS
303	help
304	  This enables support for the ARMv8 software model (Versatile
305	  Express).
306
307config ARCH_VISCONTI
308	bool "Toshiba Visconti SoC Family"
309	select PINCTRL
310	select PINCTRL_VISCONTI
311	help
312	  This enables support for Toshiba Visconti SoCs Family.
313
314config ARCH_VULCAN
315	def_bool n
316
317config ARCH_XGENE
318	bool "AppliedMicro X-Gene SOC Family"
319	help
320	  This enables support for AppliedMicro X-Gene SOC Family
321
322config ARCH_ZYNQMP
323	bool "Xilinx ZynqMP Family"
324	help
325	  This enables support for Xilinx ZynqMP Family
326
327endmenu
328