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