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