GENERIC64 revision 1.54
1#
2#	$NetBSD: GENERIC64,v 1.54 2018/10/21 12:26:59 jmcneill Exp $
3#
4#	GENERIC ARM (aarch64) kernel
5#
6
7include	"arch/evbarm/conf/std.generic64"
8include "arch/evbarm/conf/files.generic64"
9include	"arch/evbarm/conf/GENERIC.common"
10
11#
12# FDT files supported by this kernel - add to DTSSUBDIR and DTS as
13# appropriate
14#
15makeoptions 	DTSARCH="arm aarch64"
16makeoptions	DTSGNUARCH="arm arm64"
17makeoptions	DTSSUBDIR="allwinner broadcom nvidia rockchip"
18makeoptions	DTS="
19	bcm2837-rpi-3-b.dts
20	bcm2837-rpi-3-b-plus.dts
21
22	rk3328-evb.dts
23	rk3328-roc-cc.dts
24	rk3328-rock64.dts
25
26	rk3399-evb.dts
27	rk3399-firefly.dts
28	rk3399-gru-kevin.dts
29	rk3399-puma-haikou.dts
30	rk3399-rockpro64.dts
31	rk3399-sapphire-excavator.dts
32	rk3399-sapphire.dts
33
34	sun50i-a64-bananapi-m64.dts
35	sun50i-a64-nanopi-a64.dts
36	sun50i-a64-olinuxino.dts
37	sun50i-a64-orangepi-win.dts
38	sun50i-a64-pine64-plus.dts
39	sun50i-a64-pine64.dts
40	sun50i-a64-pinebook.dts
41	sun50i-a64-sopine-baseboard.dts
42	sun50i-a64-teres-i.dts
43
44	sun50i-h5-libretech-all-h3-cc.dts
45	sun50i-h5-nanopi-neo-plus2.dts
46	sun50i-h5-nanopi-neo2.dts
47	sun50i-h5-orangepi-pc2.dts
48	sun50i-h5-orangepi-prime.dts
49	sun50i-h5-orangepi-zero-plus.dts
50	sun50i-h5-orangepi-zero-plus2.dts
51
52	sun50i-h6-pine-h64.dts
53
54	tegra210-p2371-0000.dts
55	tegra210-p2371-2180.dts
56	tegra210-p2571.dts
57	tegra210-smaug.dts
58"
59options 	CPU_CORTEXA53
60options 	CPU_CORTEXA57
61options 	SOC_BCM2837
62options 	SOC_RK3328
63options 	SOC_RK3399
64options 	SOC_SUN50I_A64
65options 	SOC_SUN50I_H5
66options 	SOC_SUN50I_H6
67options 	SOC_TEGRA210
68#options 	SOC_THUNDERX
69options 	SOC_VIRT
70options 	MULTIPROCESSOR
71
72pseudo-device 	openfirm	# /dev/openfirm
73
74options 	DIAGNOSTIC	# internal consistency checks
75options 	DEBUG
76#options 	LOCKDEBUG
77#options 	PMAP_DEBUG	# Enable pmap_debug_level code
78options 	VERBOSE_INIT_ARM # verbose bootstrapping messages
79# EARLYCONS is required for early init messages from VERBOSE_INIT_ARM.
80#options 	EARLYCONS=bcm2837
81#options 	EARLYCONS=rk3328, CONSADDR=0xff130000
82#options 	EARLYCONS=rk3399, CONSADDR=0xff1a0000
83#options 	EARLYCONS=sunxi, CONSADDR=0x01c28000
84#options 	EARLYCONS=tegra, CONSADDR=0x70006000
85#options 	EARLYCONS=thunderx, CONSADDR=0x87e024000000
86#options 	EARLYCONS=virt
87
88makeoptions	DEBUG="-g"	# compile full symbol table
89makeoptions	COPY_SYMTAB=1
90
91config		netbsd		root on ? type ?
92
93options 	COMPAT_NETBSD32
94options 	EXEC_ELF32
95
96# Device tree support
97armfdt0		at root
98simplebus*	at fdt? pass 0
99
100# ACPI support
101acpifdt*	at fdt? pass 1
102acpi*		at acpifdt?
103
104# CPUs
105cpus*		at fdt? pass 0
106cpu*		at fdt? pass 0
107cpu*		at acpi?
108
109# Performance monitors
110armpmu*		at fdt?
111pseudo-device	tprof
112
113# CPU frequency scaling
114cpufreqdt*	at cpu?
115
116# Power State Coordination Interface (PSCI)
117psci*		at fdt?
118
119fclock*		at fdt? pass 1
120ffclock*	at fdt? pass 1
121fregulator*	at fdt? pass 4
122gregulator*	at fdt? pass 4
123gpiokeys*	at fdt?
124wskbd*		at gpiokeys? console ? mux 1
125gpioleds*	at fdt?
126
127# System Controller
128syscon*		at fdt? pass 1		# Generic System Controller
129
130# Timer
131gtmr*		at fdt? pass 1		# ARM Generic Timer
132gtmr*		at acpi?
133armgtmr0	at gtmr?
134tegratimer*	at fdt?			# Timers
135
136# Watchdog
137sunxiwdt*	at fdt?			# Allwinner watchdog
138watchdog*	at fdt?			# Broadcom BCM283x watchdog
139
140# Interrupt controller
141bcmicu*		at fdt? pass 1		# Broadcom BCM283x ICU
142tegralic*	at fdt? pass 1		# NVIDIA Tegra LIC
143gic*		at fdt? pass 1		# ARM GICv2
144gic*		at acpi?
145armgic0		at gic?
146gicvthree*	at fdt? pass 1		# ARM GICv3
147sunxinmi*	at fdt? pass 2		# Allwinner NMI / R_INTC
148
149# Memory controller
150tegramc*	at fdt?	pass 4		# NVIDIA Tegra MC
151
152# Firmware devices
153bcmmbox*	at fdt?			# Broadcom VideoCore IV mailbox
154vcmbox*		at bcmmbox?
155qemufwcfg*	at fdt?			# QEMU Firmware Configuration device
156qemufwcfg*	at acpi?
157
158# DMA controller
159bcmdmac*	at fdt?			# Broadcom BCM283x DMA controller
160sun6idma*	at fdt?			# Allwinner DMA controller (sun6i)
161tegraapbdma*	at fdt? pass 4		# NVIDIA Tegra APB DMA
162
163# FUSE controller
164sunxisid*	at fdt? pass 4		# Allwinner SID
165tegrafuse*	at fdt? pass 4		# NVIDIA Tegra FUSE
166
167# Power management controller
168tegrapmc*	at fdt? pass 4		# NVIDIA Tegra PMC
169
170# Clock and Reset controller
171bcmcprman*	at fdt? pass 1		# Broadcom BCM283x Clock Manager
172bcmaux*		at fdt? pass 1		# Broadcom BCM283x Aux Periph Clocks
173rkcru*		at fdt? pass 2		# Rockchip RK3328 CRU
174sun8ih3ccu*	at fdt? pass 2		# Allwinner H3/H5 CCU
175sun8ih3rccu*	at fdt? pass 2		# Allwinner H3/H5 CCU (PRCM)
176sun50ia64ccu*	at fdt? pass 2		# Allwinner A64 CCU
177sun50ia64rccu*	at fdt? pass 2		# Allwinner A64 CCU (PRCM)
178sun50ih6ccu*	at fdt? pass 2		# Allwinner H6 CCU
179sun50ih6rccu*	at fdt? pass 2		# Allwinner H6 CCU (PRCM)
180sunxiresets*	at fdt? pass 1		# Allwinner misc. resets
181sunxigates*	at fdt? pass 1		# Allwinner misc. gates
182sunxigmacclk*	at fdt? pass 2		# Allwinner GMAC MII/RGMII clock mux
183tegra210car*	at fdt? pass 3		# NVIDIA Tegra CAR (T210)
184
185# GPIO controller
186bcmgpio*	at fdt?			# Broadcom BCM283x GPIO
187plgpio*		at fdt?			# ARM PrimeCell PL061 GPIO
188plgpio*		at acpi?
189sunxigpio*	at fdt? pass 3		# Allwinner GPIO
190tegragpio*	at fdt? pass 2		# NVIDIA Tegra GPIO
191rkgpio*		at rkiomux?		# Rockchip GPIO
192gpio*		at gpiobus?
193
194# PWM controller
195sunxipwm*	at fdt? pass 3		# Allwinner PWM
196
197# MPIO / Pinmux
198rkiomux*	at fdt?	pass 3		# Rockchip IOMUX
199tegrapinmux*	at fdt?			# NVIDIA Tegra MPIO
200
201# XUSB PADCTL
202tegra210xpad*	at fdt?			# NVIDIA Tegra XUSB PADCTL (T210)
203tegra210xphy*	at tegra210xpad?
204
205# PCIE
206pcihost*	at fdt?			# Generic PCI host controller
207acpipchb*	at acpi?		# ACPI PCIe host bridge
208tegrapcie0	at fdt?			# NVIDIA Tegra PCIE
209pci*		at pcibus? 
210ppb*		at pci? dev ? function ?
211pci*		at ppb?
212
213# Ethernet
214awge*		at fdt?				# DesignWare Gigabit Ethernet
215emac*		at fdt?				# Allwinner Gigabit Ethernet (EMAC)
216mskc*		at pci? dev ? function ?	# Marvell Yukon 2 Gigabit Ethernet
217msk*		at mskc?
218re*		at pci? dev ? function ?	# Realtek RTL8111GS
219
220# MII/PHY support
221exphy* 		at mii? phy ?		# 3Com internal PHYs
222gentbi* 	at mii? phy ?		# Generic Ten-Bit 1000BASE-[CLS]X PHYs
223glxtphy*	at mii? phy ?		# Level One LXT-1000 PHYs
224gphyter* 	at mii? phy ?		# NS83861 Gig-E PHY
225icsphy*		at mii? phy ?		# Integrated Circuit Systems ICS189x
226igphy*		at mii? phy ?		# Intel IGP01E1000
227ihphy*		at mii? phy ?		# Intel 82577 PHYs
228ikphy*		at mii? phy ?		# Intel 82563 PHYs
229inphy*		at mii? phy ?		# Intel 82555 PHYs
230iophy*		at mii? phy ?		# Intel 82553 PHYs
231lxtphy*		at mii? phy ?		# Level One LXT-970 PHYs
232makphy*		at mii? phy ?		# Marvell Semiconductor 88E1000 PHYs
233nsphy*		at mii? phy ?		# NS83840 PHYs
234nsphyter*	at mii? phy ? 		# NS83843 PHYs
235pnaphy*		at mii? phy ?		# generic HomePNA PHYs
236qsphy*		at mii? phy ?		# Quality Semiconductor QS6612 PHYs
237rdcphy*		at mii? phy ?		# RDC R6040 10/100 PHY
238rgephy*		at mii? phy ?		# Realtek 8169S/8110S internal PHYs
239rlphy*		at mii? phy ?		# Realtek 8139/8201L PHYs
240sqphy*		at mii? phy ?		# Seeq 80220/80221/80223 PHYs
241tlphy*		at mii? phy ?		# ThunderLAN PHYs
242tqphy*		at mii? phy ?		# TDK Semiconductor PHYs
243urlphy*		at mii? phy ?		# Realtek RTL8150L internal PHYs
244ukphy*		at mii? phy ?		# generic unknown PHYs
245
246# Mini-PCIe Wireless
247#options 	ATHHAL_AR5212,ATHHAL_RF2425	# AR5BHB63
248#ath*		at pci? dev ? function ?	# Atheros IEEE 802.11
249#athn*		at pci? dev ? function ?	# Atheros IEEE 802.11
250
251# UART
252com*		at fdt?	pass 4		# UART
253plcom*		at fdt?	pass 4		# ARM PL011 UART
254plcom*		at acpi?
255
256# I2C controllers
257bsciic*		at fdt?			# Broadcom BCM283x Serial Control
258dwiic*		at fdt?			# Designware I2C
259dwiic*		at acpi?
260rkiic*		at fdt?			# Rockchip I2C
261sunxirsb*	at fdt?			# Allwinner RSB
262sunxitwi*	at fdt?			# Allwinner TWI
263tegrai2c*	at fdt? pass 4		# NVIDIA Tegra I2C
264iic*		at i2cbus?
265
266# I2C devices
267titemp*		at iic?
268seeprom*	at iic?
269spdmem*		at iic?			# memory module SPD EEPROM decoder
270as3722pmic*	at iic?
271as3722reg*	at as3722pmic?
272axppmic*	at iic?			# X-Powers AXP Power Management IC
273axpreg*		at axppmic?
274fan53555reg*	at iic?			# FAN53555 / SY82x regulator
275max77620pmic*	at iic?
276pcf8563rtc*	at iic?			# PCF8563 RTC
277rkpmic*		at iic?			# Rockchip Power Management IC
278rkreg*		at rkpmic?
279tcagpio*	at iic?
280
281# Random number generators
282bcmrng*		at fdt?			# Broadcom BCM283x RNG
283amdccp*		at fdt?			# AMD Cryptograhic Coprocessor RNG
284amdccp*		at acpi?
285
286# RTC
287plrtc*		at fdt?			# ARM PrimeCell RTC
288sunxirtc*	at fdt?			# Allwinner RTC
289tegrartc*	at fdt?			# NVIDIA Tegra RTC
290
291# SDMMC
292dwcmmc*		at fdt?			# Designware SD/MMC
293mmcpwrseq*	at fdt?			# Simple MMC power sequence provider
294sdhc*		at fdt?			# SD Host Controller Interface
295sdhost*		at fdt?			# Broadcom BCM283x SD Host Interface
296sunximmc*	at fdt?			# Allwinner SD/MMC
297sdmmc*		at sdmmcbus?
298ld0		at sdmmc0
299ld1		at sdmmc1
300ld2		at sdmmc2
301ld3		at sdmmc3
302ld*		at sdmmc?
303
304# SATA
305ahcisata*	at fdt?			# AHCI SATA
306ahcisata*	at acpi?
307atabus*		at ata?
308atapibus*	at atapi?
309wd*		at atabus? drive ?
310cd*		at atapibus? drive ?
311
312# SPI controllers
313bcmspi*		at fdt?			# Broadcom BCM283x SPI
314spi*		at spibus?
315
316# Audio support
317hdaudio*	at fdt?			# Intel HDA
318hdafg*		at hdaudiobus?
319options 	HDAUDIOVERBOSE
320options 	HDAUDIO_32BIT_ACCESS
321options 	HDAUDIO_ENABLE_HDMI
322options 	HDAUDIO_ENABLE_DISPLAYPORT
323ausoc*		at fdt?			# Simple SoC audio card
324sunxicodec*	at fdt?			# Allwinner audio codec
325sun8icodec*	at fdt?			# Allwinner audio codec (sun8i/sun50i)
326h3codec*	at fdt?			# Allwinner H3 audio codec (analog part)
327a64acodec*	at fdt?			# Allwinner A64 audio codec (analog part)
328sunxii2s*	at fdt?			# Allwinner I2S/PCM
329audio*		at audiobus?
330
331spkr*		at audio?		# PC speaker (synthesized)
332
333# HDMI CEC
334tegracec0	at fdt?			# NVIDIA Tegra HDMI CEC
335hdmicec*	at hdmicecbus?
336
337# Display
338#tegradrm*	at fdt?			# NVIDIA Tegra Display
339#tegrafb*	at tegrafbbus?
340genfb*		at fdt?			# Simple Framebuffer
341wsdisplay*	at wsemuldisplaydev?
342options 	VCONS_DRAW_INTR
343options 	WSEMUL_VT100
344options 	WS_DEFAULT_FG=WSCOL_WHITE
345options 	WS_DEFAULT_BG=WSCOL_BLACK
346options 	WS_KERNEL_FG=WSCOL_GREEN
347options 	WS_KERNEL_BG=WSCOL_BLACK
348options 	WSDISPLAY_COMPAT_PCVT
349options 	WSDISPLAY_COMPAT_SYSCONS
350options 	WSDISPLAY_COMPAT_USL
351options 	WSDISPLAY_COMPAT_RAWKBD
352options 	WSDISPLAY_DEFAULTSCREENS=4
353options 	WSDISPLAY_MULTICONS
354pseudo-device	wsmux
355pseudo-device	wsfont
356
357# GPU
358#nouveau*	at fdt?			# NVIDIA GPU
359
360# Backlight
361pwmbacklight*	at fdt?			# PWM Backlight controls
362
363# Thermal throttling controller
364sunxithermal*	at fdt?			# Allwinner thermal sensor controller
365tegrasoctherm*	at fdt?			# NVIDIA Tegra SOC_THERM
366
367# USB
368rkusb*		at fdt? pass 9		# Rockchip USB PHY
369rkusbphy*	at rkusb?
370sunxiusbphy*	at fdt? pass 9		# Allwinner USB PHY
371sunxiusb3phy*	at fdt? pass 9		# Allwinner USB3 PHY
372tegrausbphy*	at fdt?			# NVIDIA Tegra USB PHY
373dwctwo*		at fdt?			# Designware USB DRD
374ehci*		at fdt?			# EHCI
375ehci*		at pci?			# EHCI
376motg*		at fdt?			# Mentor Graphics USB OTG
377ohci*		at fdt?			# OHCI
378ohci*		at pci?			# OHCI
379xhci*		at fdt?			# XHCI
380xhci*		at pci?			# XHCI
381usb*		at usbus?
382
383include "dev/usb/usbdevices.config"
384midi*		at midibus?
385
386# Virtio devices
387virtio*		at fdt?			# Virtio MMIO device
388virtio*		at acpi?
389#viomb*		at virtio?		# Virtio memory balloon device
390ld*		at virtio?		# Virtio disk device
391vioif*		at virtio?		# Virtio network device
392viornd*		at virtio?		# Virtio entropy device
393vioscsi*	at virtio?		# Virtio SCSI device
394
395cinclude "arch/evbarm/conf/GENERIC64.local"
396