#       $NetBSD: MV2120,v 1.47 2024/01/29 18:27:11 christos Exp $
#
#  This configuration supports for HP MV2120/MV5140/MV5150.

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

options         INCLUDE_CONFIG_FILE     # embed config file in kernel binary
makeoptions     COPY_SYMTAB=1

makeoptions     DEBUG="-g"

# estimated number of users

maxusers        32

# Board Type
makeoptions     BOARDTYPE="mv2120"
options         EVBARM_BOARDTYPE=mv2120

# CPU options
options         CPU_ARM9E
makeoptions     CPUFLAGS="-mcpu=arm926ej-s -mtune=arm926ej-s -Os"

# Marvell SoC options
options         ORION

# Standard system options

options         MSGBUFSIZE=32768

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 client
file-system     NTFS            # Windows/NT file system (experimental)
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     OVERLAY         # overlay file system
file-system     PUFFS           # Userspace file systems (e.g. ntfs-3g & sshfs)
file-system     PROCFS          # /proc
file-system     UMAPFS          # NULLFS + uid and gid remapping
file-system     UNION           # union file system
file-system     CODA            # Coda File System; also needs vcoda (below)
file-system     PTYFS           # /dev/ptm support
file-system     TMPFS           # Efficient memory file-system
file-system     UDF             # experimental - OSTA UDF CD/DVD file-system
file-system     HFS             # experimental - Apple HFS+ (read-only)

# File system options
#options        FFS_EI          # FFS Endian Independent support
#options        FFS_NO_SNAPSHOT # No FFS snapshot support
options         QUOTA           # legacy UFS quotas
options         UFS_DIRHASH     # UFS Large Directory Hashing
#options        UFS_EXTATTR     # Extended attribute support for UFS1
options         WAPBL           # File system journaling support
options         LFS_DIRHASH     # LFS version of UFS_DIRHASH - experimental
#options        DISKLABEL_EI    # disklabel Endian Independent support
options         NFSSERVER       # Network File System server

# Networking options

options TCP_CSUM_COUNTERS
options UDP_CSUM_COUNTERS

#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_BOOTPARAM
options         NFS_BOOT_DHCP
options         NFS_BOOT_TCP

# Compatibility options

include         "conf/compat_netbsd16.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_IS_ROOT     # use memory disk as root
#options        MEMORY_DISK_DYNAMIC
#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         DDB             # in-kernel debugger
options         MIIVERBOSE      # Verbose MII autoconfuration messages
#options        PCIVERBOSE      # Verbose PCI descriptions
options         SCSIVERBOSE     # human readable SCSI error messages
options         USBVERBOSE      # verbose USB device autoconfig 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

config          netbsd          root on ? type ?
config          netbsd-mvgbe0   root on mvgbe0 type nfs
config          netbsd-wd0e     root on wd0e type ?
config          netbsd-wd0f     root on wd0f type ?
config          netbsd-wd0g     root on wd0g type ?
config          netbsd-wd0h     root on wd0h type ?

# The main bus device
mainbus0 at root

# The boot cpu
cpu0    at mainbus?

# Mervell MV88Fxx81 Orion System-on-Chip
mvsoc0  at mainbus?

# On-chip PCI Express Interface
#mvpex* at mvsoc? offset ? irq ?

# On-chip PCI Interface
#gtpci* at mvsoc? offset ? irq ?

# PCI bus support
#options        PCI_NETBSD_CONFIGURE
#options        PCI_CONFIG_DUMP         # verbosely dump PCI config space

#pci*   at mvpex?
#pci*   at gtpci?

#pchb*  at pci? dev ? function ?        # PCI-Host bridges

# PCI IDE Controller
#mvsata*        at pci? dev ? function ?        # Marvell SATA Controller

# On-chip Serial-ATA II Host Controller (SATAHC)
mvsata* at mvsoc? offset ? irq ?

# On-chip Gigabit Ethernet Controller Interface
mvgbec* at mvsoc? offset ?
mvgbe*  at mvgbec? port ? irq ?

# On-chip USB 2.0 Interface
ehci*   at mvsoc? offset ? irq ?

# On-chip Cryptographic Engines and Security Accelerator
#mvcesa* at mvsoc? offset ? irq ?

# On-chip Two-Wire Serial Interface (TWSI)
gttwsi* at mvsoc? offset ? irq ?
iic*    at gttwsi?                              # I2C bus

# On-chip UART Interface
com*    at mvsoc? offset ? irq ?

# On-chip IDMA Controller
#gtidmac* at mvsoc? offset ? irq ?

# On-chip General Purpose I/O Port Interface
mvsocgpp* at mvsoc? offset ? irq ?
gpio*   at mvsocgpp?

# On-chip Timers
mvsoctmr* at mvsoc? offset ? irq ?

# Real Time Clock
pcf8563rtc* at iic? addr 0x51

# MII/PHY support
makphy* at mii? phy ?                   # Marvell Semiconductor 88E1000 PHYs
rgephy* at mii? phy ?                   # Realtek 8169S/8110S/8211 PHYs
rlphy*  at mii? phy ?                   # Realtek 8139/8201L PHYs
ukphy*  at mii? phy ?                   # generic unknown PHYs

# ATA (IDE) bus support
atabus* at ata?
#options        ATADEBUG

# IDE drives
wd0     at atabus0 drive 0 flags 0x0000
wd1     at atabus1 drive 0 flags 0x0000
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
st*     at atapibus? drive ? flags 0x0000       # ATAPI tape drives
uk*     at atapibus? drive ? flags 0x0000       # ATAPI unknown

# SCSI bus support
scsibus* at scsi?

# SCSI devices
sd*     at scsibus? target ? lun ?      # SCSI disk drives
cd*     at scsibus? target ? lun ?      # SCSI CD-ROM drives
st*     at scsibus? target ? lun ?      # SCSI tape drives
uk*     at scsibus? target ? lun ?      # SCSI unknown

usb* at ehci?
include "dev/usb/usbdevices.config"
include "dev/bluetooth/bluetoothdevices.config"

audio*  at audiobus?
midi*   at midibus?

spkr*   at audio?               # PC speaker (synthesized)

# 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

pseudo-device   dm

# Veriexec
include "dev/veriexec.config"

options         PAX_MPROTECT=0          # PaX mprotect(2) restrictions
options         PAX_ASLR=0              # PaX Address Space Layout Randomization

pseudo-device drvctl

# Wedge support
options         DKWEDGE_AUTODISCOVER    # Automatically add dk(4) instances
options         DKWEDGE_METHOD_GPT      # Supports GPT partitions as wedges

# Alternate buffer queue strategies for better responsiveness under high
# disk I/O load.
options BUFQ_READPRIO
options BUFQ_PRIOCSCAN