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