xref: /freebsd/sys/arm64/conf/NOTES (revision 35c87c070a2d04f06c56578b0a4b2e9c13f62be5)
1#
2# NOTES -- Lines that can be cut/pasted into kernel and hints configs.
3#
4# This file contains machine dependent kernel configuration notes.  For
5# machine independent notes, look in /sys/conf/NOTES.
6#
7# $FreeBSD$
8#
9
10#
11# We want LINT to cover profiling as well.
12# Except it's broken.
13#profile         2
14
15#
16# Enable the kernel DTrace hooks which are required to load the DTrace
17# kernel modules.
18#
19options 	KDTRACE_HOOKS
20
21#
22# Most of the following is copied from ARM64 GENERIC.
23cpu		ARM64
24
25makeoptions	DEBUG=-g		# Build kernel with gdb(1) debug symbols
26makeoptions	WITH_CTF=1		# Run ctfconvert(1) for DTrace support
27
28options 	PRINTF_BUFR_SIZE=128	# Prevent printf output being interspersed.
29options 	KDTRACE_FRAME		# Ensure frames are compiled in
30options 	VFP			# Floating-point support
31options 	RACCT_DEFAULT_TO_DISABLED # Set kern.racct.enable=0 by default
32
33# SoC support
34options 	SOC_ALLWINNER_A64
35options 	SOC_ALLWINNER_H5
36options 	SOC_CAVM_THUNDERX
37options 	SOC_HISI_HI6220
38options 	SOC_BRCM_BCM2837
39options 	SOC_BRCM_BCM2838
40options 	SOC_MARVELL_8K
41options 	SOC_ROCKCHIP_RK3328
42options 	SOC_ROCKCHIP_RK3399
43options 	SOC_XILINX_ZYNQ
44
45# Timer drivers
46device		a10_timer
47
48# Annapurna Alpine drivers
49device		al_ccu			# Alpine Cache Coherency Unit
50device		al_nb_service		# Alpine North Bridge Service
51device		al_iofic		# I/O Fabric Interrupt Controller
52device		al_serdes		# Serializer/Deserializer
53device		al_udma			# Universal DMA
54
55# Qualcomm Snapdragon drivers
56device		qcom_gcc		# Global Clock Controller
57
58# VirtIO support
59device		virtio
60device		virtio_pci
61device		virtio_mmio
62device		virtio_blk
63device		vtnet
64
65# CPU frequency control
66device		cpufreq
67
68# Accelerated software crypto
69device		armv8crypto		# ARMv8 OpenCrypto module
70device		ossl			# OpenSSL OpenCrypto module
71
72# Bus drivers
73device		al_pci		# Annapurna Alpine PCI-E
74options 	PCI_HP			# PCI-Express native HotPlug
75options 	PCI_IOV		# PCI SR-IOV support
76
77# Ethernet NICs
78device		mdio
79device		awg		# Allwinner EMAC Gigabit Ethernet
80device		axa		# AMD Opteron A1100 integrated NIC
81device		neta		# Marvell Armada 370/38x/XP/3700 NIC
82device  	smc		# SMSC LAN91C111
83device		vnic		# Cavium ThunderX NIC
84device		al_eth		# Annapurna Alpine Ethernet NIC
85device		dwc_rk		# Rockchip Designware
86device		dwc_socfpga	# Altera SOCFPGA Ethernet MAC
87device		ice		# Intel 800 Series Physical Function
88device		ice_ddp		# Intel 800 Series DDP Package
89
90# Etherswitch devices
91device		e6000sw		# Marvell mv88e6085 based switches
92
93# NVM Express (NVMe) support
94device		nvme		# base NVMe driver
95options 	NVME_USE_NVD=0	# prefer the cam(4) based nda(4) driver
96device		nvd		# expose NVMe namespaces as disks, depends on nvme
97
98# MMC/SD/SDIO Card slot support
99device		sdhci_xenon		# Marvell Xenon SD/MMC controller
100device		aw_mmc			# Allwinner SD/MMC controller
101device		dwmmc
102device		dwmmc_altera
103device		rk_emmcphy
104
105# Serial (COM) ports
106device		uart_msm	# Qualcomm MSM UART driver
107device		uart_mu		# RPI3 aux port
108device		uart_mvebu	# Armada 3700 UART driver
109device		uart_ns8250	# ns8250-type UART driver
110device		uart_snps
111device		pl011
112
113# USB support
114device		aw_usbphy		# Allwinner USB PHY
115device		dwcotg			# DWC OTG controller
116device		ehci_mv			# Marvell EHCI USB interface
117
118# USB ethernet support
119device		muge
120device		smsc
121
122# Sound support
123device a10_codec
124
125# DMA controller
126device		a31_dmac
127
128# GPIO / PINCTRL
129device		a37x0_gpio	# Marvell Armada 37x0 GPIO controller
130device		aw_gpio		# Allwinner GPIO controller
131device		fdt_pinctrl
132device		mv_gpio		# Marvell GPIO controller
133device		mvebu_pinctrl	# Marvell Pinmux Controller
134device		rk_gpio		# RockChip GPIO Controller
135device		rk_pinctrl	# RockChip Pinmux Controller
136
137# I2C
138device		aw_rsb		# Allwinner Reduced Serial Bus
139device		bcm2835_bsc	# Broadcom BCM283x I2C bus
140device		twsi		# Allwinner I2C controller
141device		rk_i2c		# RockChip I2C controller
142
143# Clock and reset controllers
144device		aw_ccu		# Allwinner clock controller
145
146# Interrupt controllers
147device		aw_nmi		# Allwinner NMI support
148device		mv_cp110_icu	# Marvell CP110 ICU
149device		mv_ap806_gicp	# Marvell AP806 GICP
150
151# Real-time clock support
152device		aw_rtc		# Allwinner Real-time Clock
153device		mv_rtc		# Marvell Real-time Clock
154
155# Watchdog controllers
156device		aw_wdog		# Allwinner Watchdog
157
158# Power management controllers
159device		axp81x		# X-Powers AXP81x PMIC
160device		rk805		# RockChip RK805 PMIC
161
162# EFUSE
163device		aw_sid		# Allwinner Secure ID EFUSE
164
165# Thermal sensors
166device		aw_thermal	# Allwinner Thermal Sensor Controller
167device		mv_thermal	# Marvell Thermal Sensor Controller
168
169# SPI
170device		bcm2835_spi	# Broadcom BCM283x SPI bus
171
172# PWM
173device		pwm
174device		aw_pwm
175
176device		vt_efifb
177
178# EVDEV support
179options		EVDEV_SUPPORT		# evdev support in legacy drivers
180device		aw_cir
181
182# Pseudo devices.
183options 	EFIRT		# EFI Runtime Services
184device		clk
185device		phy
186device		hwreset
187device		nvmem
188device		regulator
189device		syscon
190device		aw_syscon
191
192# Backlight subsystem
193device		backlight
194
195# Misc devices.
196device		pl330		# ARM PL330 dma controller
197device		xdma		# xDMA framework for SoC on-chip dma controllers
198
199# Chip-specific errata
200options 	THUNDERX_PASS_1_1_ERRATA
201
202options 	FDT
203device		acpi
204
205# DTBs
206makeoptions	MODULES_EXTRA="dtb/allwinner dtb/rockchip dtb/rpi"
207
208# Add CAMDEBUG stuff
209options 	CAMDEBUG
210options 	CAM_DEBUG_FLAGS=(CAM_DEBUG_INFO|CAM_DEBUG_PROBE|CAM_DEBUG_PERIPH)
211
212# bring in camified MMC too
213options		MMCCAM
214
215# arm64 doesn't support inb/outb, so disable chipset probing which needs it
216nooptions 	PPC_PROBE_CHIPSET
217
218# These cause weird issues, not sure why
219nooptions 	DEBUG
220
221# Makes assumptions about bus tags that aren't true on arm64
222nodevice	snd_cmi
223
224# arm64 didn't exist for these releases, so doesn't have the required compat
225# support. Just disable them because they are meaningless.
226nooptions 	COMPAT_FREEBSD4
227nooptions 	COMPAT_FREEBSD5
228nooptions 	COMPAT_FREEBSD6
229nooptions 	COMPAT_FREEBSD7
230nooptions 	COMPAT_FREEBSD9
231nooptions 	COMPAT_FREEBSD10
232
233# arm64 supports 32-bit FreeBSD/arm binaries (armv[67] ABIs)
234options 	COMPAT_FREEBSD32	# Compatible with FreeBSD/arm
235
236#####################################################################
237# ZFS support
238
239options		ZFS
240
241#
242# HID-over-I2C support
243#
244device		iichid		# HID-over-I2C support
245options 	IICHID_DEBUG	# Enable HID-over-I2C debug messages
246options 	IICHID_SAMPLING	# Workaround missing GPIO INTR support
247