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