# $NetBSD: OPENBLOCKS_AX3,v 1.36 2022/08/07 02:52:25 simonb Exp $
#
# OPENBLOCKS_AX3 -- Plat'Home. OpenBlockS AX3 kernel
#
include "arch/evbarm/conf/std.marvell"
options INCLUDE_CONFIG_FILE # embed config file in kernel binary
# estimated number of users
maxusers 32
# Board Type
makeoptions BOARDTYPE="openblocks_ax3"
options EVBARM_BOARDTYPE=openblocks_ax3
# CPU options
options CPU_PJ4B
options L2CACHE_ENABLE
#options AURORA_IO_CACHE_COHERENCY
options AURORA_L2_PT_WALK
options ARM_HAS_VBAR
options FPU_VFP
makeoptions CPUFLAGS="-march=armv7-a -mfpu=neon"
# Architecture options
options ARMADAXP
options PIC_MAXSOURCES=128
options __HAVE_MM_MD_DIRECT_MAPPED_PHYS
#options MULTIPROCESSOR
options TPIDRPRW_IS_CURCPU
makeoptions KERNEL_BASE_VIRT="0x80008000"
# Standard system options
options RTC_OFFSET=0 # hardware clock is this many mins. west of GMT
options NTP # NTP phase/frequency locked loop
# File systems
file-system FFS # UFS
file-system EXT2FS # second extended file system (linux)
#file-system LFS # log-structured file system
#file-system MFS # memory file system
file-system NFS # Network file system
file-system CD9660 # ISO 9660 + Rock Ridge file system
file-system MSDOSFS # MS-DOS file system
#file-system FDESC # /dev/fd
file-system KERNFS # /kern
file-system NULLFS # loopback file system
file-system PROCFS # /proc
file-system PTYFS # /dev/pts/N support
#file-system PUFFS # Pass-to-Userspace Framework File System
#file-system UMAPFS # NULLFS + uid and gid remapping
file-system UNION # union file system
file-system TMPFS # Efficient memory file-system
# File system options
options FFS_EI # FFS Endian Independent support
#options FFS_NO_SNAPSHOT # No FFS snapshot support
#options QUOTA # legacy UFS quotas
#options QUOTA2 # new, in-filesystem UFS quotas
options UFS_DIRHASH # UFS Large Directory Hashing
#options UFS_EXTATTR # Extended attribute support for UFS1
options WAPBL # File system journaling support
#options DISKLABEL_EI # disklabel Endian Independent support
options NFSSERVER # Network File System server
# Networking options
options GATEWAY # packet forwarding
options INET # IP + ICMP + TCP + UDP
options INET6 # IPv6
options IPSEC # IP security
#options IPSEC_DEBUG # debug for IP security
options MROUTING # IP multicast routing
options PIM # Protocol Independent Multicast
options NETATALK # AppleTalk networking protocols
options PPP_BSDCOMP # BSD-Compress compression support for PPP
options PPP_DEFLATE # Deflate compression support for PPP
options PPP_FILTER # Active filter support for PPP (requires bpf)
#options TCP_DEBUG # Record last TCP_NDEBUG packets with SO_DEBUG
#options NFS_BOOT_BOOTP
options NFS_BOOT_DHCP
#options NFS_BOOT_BOOTPARAM
#options NFS_BOOT_RWSIZE=1024
# Compatibility options
include "conf/compat_netbsd50.config"
options COMPAT_NETBSD32 # allow running arm (e.g. non-earm) binaries
# Shared memory options
options SYSVMSG # System V-like message queues
options SYSVSEM # System V-like semaphores
#options SEMMNI=10 # number of semaphore identifiers
#options SEMMNS=60 # number of semaphores in system
#options SEMUME=10 # max number of undo entries per process
#options SEMMNU=30 # number of undo structures in system
options SYSVSHM # System V-like memory sharing
# Device options
#options MEMORY_DISK_HOOKS # boottime setup of ramdisk
#options MEMORY_DISK_IS_ROOT # use memory disk as root
#options MEMORY_DISK_DYNAMIC
#options MINIROOTSIZE=1000 # Size in blocks
#options MEMORY_DISK_ROOT_SIZE=22528 # Size in blocks
#options MEMORY_RBFLAGS=RB_AUTOBOOT
# Miscellaneous kernel options
#options KTRACE # system call tracing, a la ktrace(1)
options IRQSTATS # manage IRQ statistics
#options MIIVERBOSE # Verbose MII auto configuration messages
#options PCIVERBOSE # Verbose PCI descriptions
#options SCSIVERBOSE # Verbose SCSI errors
options USBVERBOSE # Verbose USB device auto configuration messages
#options DDB_KEYCODE=0x40
#options USERCONF # userconf(4) support
#options PIPE_SOCKETPAIR # smaller, but slower pipe(2)
#options SYSCTL_INCLUDE_DESCR # Include sysctl descriptions in kernel
# Development and Debugging options
options DIAGNOSTIC # internal consistency checks
options DEBUG
#options UVMHIST # kernhist for uvm/pmap subsystems
#options VERBOSE_INIT_ARM # verbose bootstraping messages
options DDB # in-kernel debugger
options DDB_ONPANIC=1
#options DDB_HISTORY_SIZE=100 # Enable history editing in DDB
#options KGDB
#options DEBUG_KGDB
makeoptions DEBUG="-g" # compile full symbol table
makeoptions COPY_SYMTAB=1
config netbsd root on ? type ?
# The main bus device
mainbus0 at root
# The boot cpu
cpu0 at mainbus?
# Marvell MV88F78260 ARMADA XP System-on-chip
mvsoc0 at mainbus?
options MVSOC_INTERREGS_PBASE=0xd0000000
options MVSOC_FIXUP_DEVID=0x7826
# On-chip Serial-ATA II Host Controller (SATAHC)
mvsata* at mvsoc? offset ? irq ?
# On-chip Gigabit Ethernet Controller Interface (backward compatible mode)
mvgbec* at mvsoc? offset ?
mvgbe* at mvgbec? port ? irq ?
# On-chip Gigabit Ethernet Controller Interface (counter mode)
#mvxpbm* at mvsoc? offset ?
#mvxpe* at mvsoc? irq ?
#options MVXPE_EVENT_COUNTERS
#options MVXPE_DEBUG=0
makphy* at mii? phy ?
# On-chip USB 2.0 Interface
ehci* at mvsoc? offset ? irq ?
# Serial Peripheral Interface (SPI)
#mvspi* at mvsoc? offset ? irq ?
#spi* at mvspi?
# On-chip Two-Wire Serial Interface (TWSI)
gttwsi* at mvsoc? offset ? irq ?
iic* at gttwsi?
s390rtc* at iic1 addr 0x30
# On-chip Cryptographic Engines and Security Accelerator (DMA)
#mvxpsec* at mvsoc? offset ? irq ?
#options MVXPSEC_DEBUG=MVXPSEC_DEBUG_ALL
# On-chip UART Interface
com* at mvsoc? offset ? irq ?
options COM_16750 # XXXX: required
#options COM_DEBUG
# On-chip PCI Express Interface
mvpex* at mvsoc? offset ? irq ?
# On-chip IDMA Controller
gtidmac* at mvsoc? offset ? irq ?
# On-chip Thermal Sensor
mvsocts* at mvsoc? offset ? irq ?
# On-chip Timers
mvsoctmr* at mvsoc? offset ? irq ?
# PCI bus support
options PCI_NETBSD_CONFIGURE
#options PCI_CONFIG_DUMP # verbosely dump PCI config space
pci* at mvpex?
pchb* at pci? dev ? function ? # PCI-Host bridges
#athn* at pci? dev ? function ? # Atheros AR9k (802.11a/g/n)
# ATA (IDE) bus support
atabus* at ata?
#options ATADEBUG
# IDE drives
wd* at atabus? drive ? flags 0x0000
# ATAPI bus support
atapibus* at atapi?
# ATAPI devices
# flags have the same meaning as for IDE drives.
cd* at atapibus? drive ? flags 0x0000 # ATAPI CD-ROM drives
sd* at atapibus? drive ? flags 0x0000 # ATAPI disk drives
# USB bus support
usb* at ehci?
# USB Hubs
uhub* at usb?
uhub* at uhub? port ?
# USB Mass Storage
umass* at uhub? port ? configuration ? interface ?
scsibus* at scsi?
sd* at scsibus? target ? lun ? # SCSI disk drives
cd* at scsibus? target ? lun ? # SCSI CD-ROM drives
# USB Generic driver
ugen* at uhub? port ?
# Pseudo-Devices
pseudo-device crypto # /dev/crypto device
pseudo-device swcrypto # software crypto implementation
# disk/mass storage pseudo-devices
#pseudo-device bio # RAID control device driver
#pseudo-device ccd # concatenated/striped disk devices
#pseudo-device cgd # cryptographic disk devices
#pseudo-device raid # RAIDframe disk driver
#options RAID_AUTOCONFIG # auto-configuration of RAID components
# Options to enable various other RAIDframe RAID types.
#options RF_INCLUDE_EVENODD=1
#options RF_INCLUDE_RAID5_RS=1
#options RF_INCLUDE_PARITYLOGGING=1
#options RF_INCLUDE_CHAINDECLUSTER=1
#options RF_INCLUDE_INTERDECLUSTER=1
#options RF_INCLUDE_PARITY_DECLUSTERING=1
#options RF_INCLUDE_PARITY_DECLUSTERING_DS=1
#pseudo-device fss # file system snapshot device
#pseudo-device putter # for puffs and pud
#pseudo-device md # memory disk device (ramdisk)
pseudo-device vnd # disk-like interface to files
options VND_COMPRESSION # compressed vnd(4)
# network pseudo-devices
pseudo-device bpfilter # Berkeley packet filter
#pseudo-device carp # Common Address Redundancy Protocol
pseudo-device npf # NPF packet filter
pseudo-device loop # network loopback
pseudo-device ppp # Point-to-Point Protocol
pseudo-device pppoe # PPP over Ethernet (RFC 2516)
pseudo-device sl # Serial Line IP
#pseudo-device irframetty # IrDA frame line discipline
pseudo-device tap # virtual Ethernet
pseudo-device tun # network tunneling over tty
pseudo-device gre # generic L3 over IP tunnel
pseudo-device gif # IPv[46] over IPv[46] tunnel (RFC 1933)
pseudo-device faith # IPv[46] TCP relay translation i/f
pseudo-device stf # 6to4 IPv6 over IPv4 encapsulation
pseudo-device vlan # IEEE 802.1q encapsulation
pseudo-device bridge # simple inter-network bridging
pseudo-device vether # Virtual Ethernet for bridge
pseudo-device agr # IEEE 802.3ad link aggregation
# miscellaneous pseudo-devices
pseudo-device pty # pseudo-terminals
#pseudo-device sequencer # MIDI sequencer
#options RND_COM
pseudo-device clockctl # user control of clock subsystem
pseudo-device ksyms # /dev/ksyms
# a pseudo device needed for Coda # also needs CODA (above)
#pseudo-device vcoda # coda minicache <-> venus comm.
# wscons pseudo-devices
#pseudo-device wsmux # mouse & keyboard multiplexor
#pseudo-device wsfont
# data mover pseudo-devices
pseudo-device swdmover # software dmover(9) back-end
pseudo-device dmoverio # /dev/dmover dmover(9) interface
# Veriexec
# include "dev/veriexec.config"
#options PAX_MPROTECT=0 # PaX mprotect(2) restrictions
#options PAX_ASLR=0 # PaX Address Space Layout Randomization