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