GENERIC64 revision 1.60
1#
2#	$NetBSD: GENERIC64,v 1.60 2018/10/26 23:34:05 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?
103acpibut*	at acpi?
104acpiged*	at acpi?
105acpilid*	at acpi?
106
107# CPUs
108cpus*		at fdt? pass 0
109cpu*		at fdt? pass 0
110cpu*		at acpi?
111
112# Performance monitors
113armpmu*		at fdt?
114pseudo-device	tprof
115
116# CPU frequency scaling
117cpufreqdt*	at cpu?
118
119# Power State Coordination Interface (PSCI)
120psci*		at fdt?
121
122fclock*		at fdt? pass 1
123ffclock*	at fdt? pass 1
124fregulator*	at fdt? pass 4
125gregulator*	at fdt? pass 4
126gpiokeys*	at fdt?
127wskbd*		at gpiokeys? console ? mux 1
128gpioleds*	at fdt?
129
130# System Controller
131syscon*		at fdt? pass 1		# Generic System Controller
132
133# Timer
134gtmr*		at fdt? pass 1		# ARM Generic Timer
135gtmr*		at acpi?
136armgtmr0	at gtmr?
137tegratimer*	at fdt?			# Timers
138
139# Watchdog
140sbsawdt*	at acpi?		# ARM SBSA-compliant watchdog
141sunxiwdt*	at fdt?			# Allwinner watchdog
142watchdog*	at fdt?			# Broadcom BCM283x watchdog
143
144# Interrupt controller
145bcmicu*		at fdt? pass 1		# Broadcom BCM283x ICU
146tegralic*	at fdt? pass 1		# NVIDIA Tegra LIC
147gic*		at fdt? pass 1		# ARM GICv2
148gic*		at acpi?
149armgic0		at gic?
150gicvthree*	at fdt? pass 1		# ARM GICv3
151gicvthree*	at acpi?
152sunxinmi*	at fdt? pass 2		# Allwinner NMI / R_INTC
153
154# Memory controller
155tegramc*	at fdt?	pass 4		# NVIDIA Tegra MC
156
157# Firmware devices
158bcmmbox*	at fdt?			# Broadcom VideoCore IV mailbox
159vcmbox*		at bcmmbox?
160qemufwcfg*	at fdt?			# QEMU Firmware Configuration device
161qemufwcfg*	at acpi?
162
163# DMA controller
164bcmdmac*	at fdt?			# Broadcom BCM283x DMA controller
165sun6idma*	at fdt?			# Allwinner DMA controller (sun6i)
166tegraapbdma*	at fdt? pass 4		# NVIDIA Tegra APB DMA
167
168# FUSE controller
169sunxisid*	at fdt? pass 4		# Allwinner SID
170tegrafuse*	at fdt? pass 4		# NVIDIA Tegra FUSE
171
172# Power management controller
173tegrapmc*	at fdt? pass 4		# NVIDIA Tegra PMC
174
175# Clock and Reset controller
176bcmcprman*	at fdt? pass 1		# Broadcom BCM283x Clock Manager
177bcmaux*		at fdt? pass 1		# Broadcom BCM283x Aux Periph Clocks
178rkcru*		at fdt? pass 2		# Rockchip RK3328 CRU
179sun8ih3ccu*	at fdt? pass 2		# Allwinner H3/H5 CCU
180sun8ih3rccu*	at fdt? pass 2		# Allwinner H3/H5 CCU (PRCM)
181sun50ia64ccu*	at fdt? pass 2		# Allwinner A64 CCU
182sun50ia64rccu*	at fdt? pass 2		# Allwinner A64 CCU (PRCM)
183sun50ih6ccu*	at fdt? pass 2		# Allwinner H6 CCU
184sun50ih6rccu*	at fdt? pass 2		# Allwinner H6 CCU (PRCM)
185sunxiresets*	at fdt? pass 1		# Allwinner misc. resets
186sunxigates*	at fdt? pass 1		# Allwinner misc. gates
187sunxigmacclk*	at fdt? pass 2		# Allwinner GMAC MII/RGMII clock mux
188tegra210car*	at fdt? pass 3		# NVIDIA Tegra CAR (T210)
189
190# GPIO controller
191bcmgpio*	at fdt?			# Broadcom BCM283x GPIO
192plgpio*		at fdt?			# ARM PrimeCell PL061 GPIO
193plgpio*		at acpi?
194sunxigpio*	at fdt? pass 3		# Allwinner GPIO
195tegragpio*	at fdt? pass 2		# NVIDIA Tegra GPIO
196rkgpio*		at rkiomux?		# Rockchip GPIO
197gpio*		at gpiobus?
198
199# PWM controller
200sunxipwm*	at fdt? pass 3		# Allwinner PWM
201
202# MPIO / Pinmux
203rkiomux*	at fdt?	pass 3		# Rockchip IOMUX
204tegrapinmux*	at fdt?			# NVIDIA Tegra MPIO
205
206# XUSB PADCTL
207tegra210xpad*	at fdt?			# NVIDIA Tegra XUSB PADCTL (T210)
208tegra210xphy*	at tegra210xpad?
209
210# PCIE
211pcihost*	at fdt?			# Generic PCI host controller
212acpipchb*	at acpi?		# ACPI PCIe host bridge
213tegrapcie0	at fdt?			# NVIDIA Tegra PCIE
214pci*		at pcibus? 
215ppb*		at pci? dev ? function ?
216pci*		at ppb?
217
218# Ethernet
219awge*		at fdt?				# DesignWare Gigabit Ethernet
220emac*		at fdt?				# Allwinner Gigabit Ethernet (EMAC)
221mskc*		at pci? dev ? function ?	# Marvell Yukon 2 Gigabit Ethernet
222msk*		at mskc?
223re*		at pci? dev ? function ?	# Realtek RTL8111GS
224
225# MII/PHY support
226exphy* 		at mii? phy ?		# 3Com internal PHYs
227gentbi* 	at mii? phy ?		# Generic Ten-Bit 1000BASE-[CLS]X PHYs
228glxtphy*	at mii? phy ?		# Level One LXT-1000 PHYs
229gphyter* 	at mii? phy ?		# NS83861 Gig-E PHY
230icsphy*		at mii? phy ?		# Integrated Circuit Systems ICS189x
231igphy*		at mii? phy ?		# Intel IGP01E1000
232ihphy*		at mii? phy ?		# Intel 82577 PHYs
233ikphy*		at mii? phy ?		# Intel 82563 PHYs
234inphy*		at mii? phy ?		# Intel 82555 PHYs
235iophy*		at mii? phy ?		# Intel 82553 PHYs
236lxtphy*		at mii? phy ?		# Level One LXT-970 PHYs
237makphy*		at mii? phy ?		# Marvell Semiconductor 88E1000 PHYs
238nsphy*		at mii? phy ?		# NS83840 PHYs
239nsphyter*	at mii? phy ? 		# NS83843 PHYs
240pnaphy*		at mii? phy ?		# generic HomePNA PHYs
241qsphy*		at mii? phy ?		# Quality Semiconductor QS6612 PHYs
242rdcphy*		at mii? phy ?		# RDC R6040 10/100 PHY
243rgephy*		at mii? phy ?		# Realtek 8169S/8110S internal PHYs
244rlphy*		at mii? phy ?		# Realtek 8139/8201L PHYs
245sqphy*		at mii? phy ?		# Seeq 80220/80221/80223 PHYs
246tlphy*		at mii? phy ?		# ThunderLAN PHYs
247tqphy*		at mii? phy ?		# TDK Semiconductor PHYs
248urlphy*		at mii? phy ?		# Realtek RTL8150L internal PHYs
249ukphy*		at mii? phy ?		# generic unknown PHYs
250
251# Mini-PCIe Wireless
252#options 	ATHHAL_AR5212,ATHHAL_RF2425	# AR5BHB63
253#ath*		at pci? dev ? function ?	# Atheros IEEE 802.11
254#athn*		at pci? dev ? function ?	# Atheros IEEE 802.11
255
256# UART
257com*		at fdt?	pass 4		# UART
258plcom*		at fdt?	pass 4		# ARM PL011 UART
259plcom*		at acpi?
260
261# I2C controllers
262bsciic*		at fdt?			# Broadcom BCM283x Serial Control
263dwiic*		at fdt?			# Designware I2C
264dwiic*		at acpi?
265rkiic*		at fdt?			# Rockchip I2C
266sunxirsb*	at fdt?			# Allwinner RSB
267sunxitwi*	at fdt?			# Allwinner TWI
268tegrai2c*	at fdt? pass 4		# NVIDIA Tegra I2C
269iic*		at i2cbus?
270
271# I2C devices
272titemp*		at iic?
273seeprom*	at iic?
274spdmem*		at iic?			# memory module SPD EEPROM decoder
275as3722pmic*	at iic?
276as3722reg*	at as3722pmic?
277axppmic*	at iic?			# X-Powers AXP Power Management IC
278axpreg*		at axppmic?
279fan53555reg*	at iic?			# FAN53555 / SY82x regulator
280max77620pmic*	at iic?
281pcf8563rtc*	at iic?			# PCF8563 RTC
282rkpmic*		at iic?			# Rockchip Power Management IC
283rkreg*		at rkpmic?
284tcagpio*	at iic?
285
286# Random number generators
287bcmrng*		at fdt?			# Broadcom BCM283x RNG
288amdccp*		at fdt?			# AMD Cryptograhic Coprocessor RNG
289amdccp*		at acpi?
290
291# RTC
292plrtc*		at fdt?			# ARM PrimeCell RTC
293sunxirtc*	at fdt?			# Allwinner RTC
294tegrartc*	at fdt?			# NVIDIA Tegra RTC
295
296# SDMMC
297dwcmmc*		at fdt?			# Designware SD/MMC
298mmcpwrseq*	at fdt?			# Simple MMC power sequence provider
299sdhc*		at fdt?			# SD Host Controller Interface
300sdhost*		at fdt?			# Broadcom BCM283x SD Host Interface
301sunximmc*	at fdt?			# Allwinner SD/MMC
302sdmmc*		at sdmmcbus?
303ld0		at sdmmc0
304ld1		at sdmmc1
305ld2		at sdmmc2
306ld3		at sdmmc3
307ld*		at sdmmc?
308
309# SATA
310ahcisata*	at fdt?			# AHCI SATA
311ahcisata*	at acpi?
312atabus*		at ata?
313atapibus*	at atapi?
314wd*		at atabus? drive ?
315cd*		at atapibus? drive ?
316
317# SPI controllers
318bcmspi*		at fdt?			# Broadcom BCM283x SPI
319spi*		at spibus?
320
321# Audio support
322hdaudio*	at fdt?			# Intel HDA
323hdafg*		at hdaudiobus?
324options 	HDAUDIOVERBOSE
325options 	HDAUDIO_32BIT_ACCESS
326options 	HDAUDIO_ENABLE_HDMI
327options 	HDAUDIO_ENABLE_DISPLAYPORT
328ausoc*		at fdt?			# Simple SoC audio card
329sunxicodec*	at fdt?			# Allwinner audio codec
330sun8icodec*	at fdt?			# Allwinner audio codec (sun8i/sun50i)
331h3codec*	at fdt?			# Allwinner H3 audio codec (analog part)
332a64acodec*	at fdt?			# Allwinner A64 audio codec (analog part)
333sunxii2s*	at fdt?			# Allwinner I2S/PCM
334audio*		at audiobus?
335
336spkr*		at audio?		# PC speaker (synthesized)
337
338# HDMI CEC
339tegracec0	at fdt?			# NVIDIA Tegra HDMI CEC
340hdmicec*	at hdmicecbus?
341
342# Display
343#tegradrm*	at fdt?			# NVIDIA Tegra Display
344#tegrafb*	at tegrafbbus?
345genfb*		at fdt?			# Simple Framebuffer
346wsdisplay*	at wsemuldisplaydev?
347options 	VCONS_DRAW_INTR
348options 	WSEMUL_VT100
349options 	WS_DEFAULT_FG=WSCOL_WHITE
350options 	WS_DEFAULT_BG=WSCOL_BLACK
351options 	WS_KERNEL_FG=WSCOL_GREEN
352options 	WS_KERNEL_BG=WSCOL_BLACK
353options 	WSDISPLAY_COMPAT_PCVT
354options 	WSDISPLAY_COMPAT_SYSCONS
355options 	WSDISPLAY_COMPAT_USL
356options 	WSDISPLAY_COMPAT_RAWKBD
357options 	WSDISPLAY_DEFAULTSCREENS=4
358options 	WSDISPLAY_MULTICONS
359pseudo-device	wsmux
360pseudo-device	wsfont
361
362# GPU
363#nouveau*	at fdt?			# NVIDIA GPU
364
365# Backlight
366pwmbacklight*	at fdt?			# PWM Backlight controls
367
368# Thermal throttling controller
369sunxithermal*	at fdt?			# Allwinner thermal sensor controller
370tegrasoctherm*	at fdt?			# NVIDIA Tegra SOC_THERM
371
372# USB
373rkusb*		at fdt? pass 9		# Rockchip USB PHY
374rkusbphy*	at rkusb?
375sunxiusbphy*	at fdt? pass 9		# Allwinner USB PHY
376sunxiusb3phy*	at fdt? pass 9		# Allwinner USB3 PHY
377tegrausbphy*	at fdt?			# NVIDIA Tegra USB PHY
378dwctwo*		at fdt?			# Designware USB DRD
379ehci*		at fdt?			# EHCI
380ehci*		at pci?			# EHCI
381ehci*		at acpi?		# EHCI
382motg*		at fdt?			# Mentor Graphics USB OTG
383ohci*		at fdt?			# OHCI
384ohci*		at pci?			# OHCI
385xhci*		at fdt?			# XHCI
386xhci*		at pci?			# XHCI
387xhci*		at acpi?		# XHCI
388usb*		at usbus?
389
390include "dev/usb/usbdevices.config"
391midi*		at midibus?
392
393# Virtio devices
394virtio*		at fdt?			# Virtio MMIO device
395virtio*		at acpi?
396#viomb*		at virtio?		# Virtio memory balloon device
397ld*		at virtio?		# Virtio disk device
398vioif*		at virtio?		# Virtio network device
399viornd*		at virtio?		# Virtio entropy device
400vioscsi*	at virtio?		# Virtio SCSI device
401
402cinclude "arch/evbarm/conf/GENERIC64.local"
403