#       $NetBSD: VIPER,v 1.44 2022/08/07 02:52:25 simonb Exp $
#
#       Arcom Viper
#

include "arch/evbarm/conf/std.viper"

#options        INCLUDE_CONFIG_FILE     # embed config file in kernel binary
#options        MSGBUFSIZE=65536
#options        KSTACK_CHECK_MAGIC

# 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_XSCALE_PXA250 # XScale PXA255
makeoptions     CPUFLAGS="-mcpu=xscale"
#options        CPU_XSCALE_CCLKCFG=xyz

# 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    FILECORE        # Acorn filecore file system
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        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        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        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_DHCP
options         NFS_BOOT_BOOTPARAM
options         NFS_BOOT_RWSIZE=1024

# Compatibility options

include         "conf/compat_netbsd30.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=3400      # Size in blocks
#options        MEMORY_DISK_IS_ROOT     # use memory disk as root

# Console options.  The default console is speed is 115200 bps.
#options        CONSPEED=9600           # Console speed

# 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        DDB_KEYCODE=0x40
#options        USERCONF        # userconf(4) support
#options        PIPE_SOCKETPAIR # smaller, but slower pipe(2)

# 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
#makeoptions    DEBUG="-g"      # compile full symbol table
makeoptions     COPY_SYMTAB=1

##options       PMAP_INCLUDE_PTE_SYNC
##options       LOCKDEBUG

config          netbsd          root on ? type ?

# The main bus device
mainbus0        at root

# The boot CPU
cpu0            at mainbus?

# peripherals
pxaip0          at mainbus0

# interrupt controller & gpio pins
pxaintc0        at pxaip0
pxagpio0        at pxaip0

# serial ports
options         COM_PXA2X0
options         FFUARTCONSOLE
com0    at pxaip0 addr 0x40100000 intr 22  # FFUART
com1    at pxaip0 addr 0x40200000 intr 21  # BTUART
com2    at pxaip0 addr 0x40700000 intr 20

# these two are not hanging off of pxaip, not really tested either
#com3   at pxaip0 addr 0x14300000       # COM5
#com4   at pxaip0 addr 0x14300010       # COM4

# SMC91C111 ethernet
sm0     at pxaip0 addr 0x08000300 intr 0

# MII/PHY support
sqphy*  at mii? phy ?                   # Seeq 80220/80221/80223 PHYs

# 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   loop                    # network loopback
pseudo-device   kttcp                   # network loopback

# miscellaneous pseudo-devices
pseudo-device   pty                     # pseudo-terminals
#options        RND_COM
pseudo-device   clockctl                # user control of clock subsystem
pseudo-device   ksyms                   # /dev/ksyms

# data mover pseudo-devices
#pseudo-device  swdmover                # software dmover(9) back-end
#pseudo-device  dmoverio                # /dev/dmover dmover(9) interface