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