# $NetBSD: INTEGRATOR,v 1.86 2022/08/07 02:52:25 simonb Exp $
#
# GENERIC -- ARM Integrator board Generic kernel
#
include "arch/evbarm/conf/std.integrator"
#options INCLUDE_CONFIG_FILE # embed config file in kernel binary
# estimated number of users
maxusers 32
# Standard system options
options RTC_OFFSET=0 # hardware clock is this many mins. west of GMT
options NTP # NTP phase/frequency locked loop
# CPU options
options CPU_ARM9 # Support the ARM9TDMI core
options CPU_ARM10 # Support the ARM10 core
options CPU_ARM11 # Support the ARM11 core
options FPU_VFP
# XXX Should be armv5 for ARM10 processor.
makeoptions CPUFLAGS="-march=armv4 -mfpu=vfp"
# File systems
file-system FFS # UFS
#file-system LFS # log-structured file system
file-system MFS # memory file system
file-system NFS # Network file system
#file-system ADOSFS # AmigaDOS-compatible file system
#file-system EXT2FS # second extended file system (linux)
#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 PUFFS # Userspace file systems (e.g. ntfs-3g & sshfs)
#file-system UMAPFS # NULLFS + uid and gid remapping
#file-system UNION # union file system
file-system PTYFS # /dev/pts/N support
# 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
#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
# Compatibility options
include "conf/compat_netbsd15.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 SYSVSHM # System V-like memory sharing
# Device options
#options MEMORY_DISK_HOOKS # boottime setup of ramdisk
#options MEMORY_DISK_ROOT_SIZE=4000 # Size in blocks
#options MEMORY_DISK_IS_ROOT # use memory disk as root
# Miscellaneous kernel options
options KTRACE # system call tracing, a la ktrace(1)
options IRQSTATS # manage IRQ statistics
options SCSIVERBOSE # Verbose SCSI errors
options PCIVERBOSE # Verbose PCI descriptions
options MIIVERBOSE # Verbose MII autoconfuration messages
#options PCI_CONFIG_DUMP # verbosely dump PCI config space
options PCI_NETBSD_CONFIGURE # Do not rely on BIOS/whatever to
# configure PCI devices
options PCI_CONFIGURE_VERBOSE # Show PCI config information
options DDB_KEYCODE=0x1d # Enter ddb on ^]
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 ARM700BUGTRACK # track the ARM700 swi bug
#options PORTMASTER # Enable PortMaster only options
#options DIAGNOSTIC # internal consistency checks
#options UVMHIST # kernhist for uvm/pmap subsystems
options DDB # in-kernel debugger
options DDB_HISTORY_SIZE=100 # Enable history editing in DDB
#options UVMHIST
#makeoptions DEBUG="-g" # compile full symbol table
makeoptions COPY_SYMTAB=1
options PLCONSOLE,PLCOMCNUNIT=0,PLCONSPEED=38400,PLCONMODE=0xB00
config netbsd root on ? type ?
config netbsd-fxp0 root on fxp0 type nfs
config netbsd-sd0 root on sd0 type ffs
# The main bus device
mainbus0 at root
# The boot CPU
cpu0 at mainbus?
# Core logic
ifpga0 at mainbus?
# PL010 uart
plcom0 at ifpga? offset 0x06000000 irq 1
plcom1 at ifpga? offset 0x07000000 irq 2
#options PLCOM_DEBUG
# PL030 real time clock
plrtc0 at ifpga? offset 0x05000000
# PCI bus via ifpga
pci0 at ifpga? # PCI bus
# Compact PCI bus via PCI bridge.
ppb* at pci? dev? function ? # PCI-PCI bridges
pci* at ppb? bus ?
# PCI IDE Controllers and Devices
# PCI IDE controllers - see pciide(4) for supported hardware.
# The 0x0001 flag force the driver to use DMA, even if the driver doesn't know
# how to set up DMA modes for this chip. This may work, or may cause
# a machine hang with some controllers.
#pciide* at pci? dev ? function ? flags 0x0000 # GENERIC pciide driver
#artsata* at pci? dev ? function ? # Intel i31244 SATA controller
#cmdide* at pci? dev ? function ? # CMD tech IDE controllers
#hptide* at pci? dev ? function ? # Triones/HighPoint IDE controllers
#pdcide* at pci? dev ? function ? # Promise IDE controllers
#pdcsata* at pci? dev ? function ? # Promise SATA150 controllers
#satalink* at pci? dev ? function ? # SiI SATALink controllers
# ATA bus support
#atabus* at ata? channel ?
# IDE drives
# Flags are used only with controllers that support DMA operations
# and mode settings (e.g. some pciide controllers)
# The lowest order four bits (rightmost digit) of the flags define the PIO
# mode to use, the next set of four bits the DMA mode and the third set the
# UltraDMA mode. For each set of four bits, the 3 lower bits define the mode
# to use, and the last bit must be 1 for this setting to be used.
# For DMA and UDMA, 0xf (1111) means 'disable'.
# 0x0fac means 'use PIO mode 4, DMA mode 2, disable UltraDMA'.
# (0xc=1100, 0xa=1010, 0xf=1111)
# 0x0000 means "use whatever the drive claims to support".
#wd* at atabus? drive ? flags 0x0000 # the drives themselves
# PCI SCSI Controllers and Buses
ahc* at pci? dev ? function ? # Adaptec [23]94x, aic78x0 SCSI Controllers
scsibus* at ahc?
# SCSI devices
sd* at scsibus? target ? lun ? # SCSI disk drives
st* at scsibus? target ? lun ? # SCSI tape drives
cd* at scsibus? target ? lun ? # SCSI CD-ROM drives
#ch* at scsibus? target ? lun ? # SCSI auto-changers drives
#uk* at scsibus? target ? lun ? # SCSI unknown drives
#ss* at scsibus? target ? lun ? # SCSI scanner
# PCI network interfaces
fxp* at pci? dev ? function ? # I82557/I82558 ethernet cards
#ne* at pci? dev ? function ? # NE2000 compat ethernet
#tlp* at pci? dev ? function ? # DECchip 21x4x and clones
# MII/PHY support
inphy* at mii? phy ? # Intel 82555 PHYs
#lxtphy* at mii? phy ? # Level One LXT-970 PHYs
ukphy* at mii? phy ? # generic unknown PHYs
# WSCONS Support
#options WSEMUL_VT100 # VT100 / VT220 emulation
#options WSDISPLAY_COMPAT_USL # wsconscfg VT handling
#options WS_KERNEL_FG=WSCOL_GREEN
#pckbc0 at isa?
#pckbd* at pckbc?
#wskbd* at pckbd? console ?
#pms* at pckbc?
#wsmouse* at pms? mux 0
#vga* at pci? dev ? function ?
#wsdisplay* at vga? console ?
# Pseudo-Devices
# disk/mass storage pseudo-devices
#pseudo-device md # memory disk device (ramdisk)
pseudo-device vnd # disk-like interface to files
#pseudo-device fss # file system snapshot device
#pseudo-device putter # for puffs and pud
# network pseudo-devices
#pseudo-device bpfilter # Berkeley packet filter
#pseudo-device bridge # simple inter-network bridging
#pseudo-device vether # Virtual Ethernet for bridge
pseudo-device loop # network loopback
# miscellaneous pseudo-devices
pseudo-device pty # pseudo-terminals
pseudo-device clockctl # user control of clock subsystem
pseudo-device ksyms # /dev/ksyms