#       $NetBSD: OPENBLOCKS_A6,v 1.47 2025/06/01 05:43:55 rin Exp $
#
#       OPENBLOCKS_A6 -- Plat'Home. OpenBlockS A6/A7 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_a6"
options         EVBARM_BOARDTYPE=openblocks_a6

# CPU options
options         CPU_SHEEVA
#options        SHEEVA_L2_CACHE
#options        SHEEVA_L2_CACHE_WT
makeoptions     CPUFLAGS="-march=armv5te"

# Marvell SoC options
options         KIRKWOOD

# 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    OVERLAY         # overlay file system
file-system     PROCFS          # /proc
file-system     PTYFS           # /dev/ptm 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    CODA            # Coda File System; also needs vcoda (below)
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        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

# 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         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        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_HISTORY_SIZE=100    # Enable history editing in DDB
#options        KGDB
#options        DEBUG_KGDB
makeoptions     DEBUG="-g"      # compile full symbol table
#makeoptions    COPTS="-O2"
makeoptions     COPY_SYMTAB=1
#options        AUDIO_DEBUG=2

config          netbsd          root on ? type ?

# The main bus device
mainbus0 at root

# The boot cpu
cpu0    at mainbus?

# Marvell MV88F6xxx Kirkwood System-on-chip
mvsoc0  at mainbus?

# 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 ?

# MII/PHY support
makphy* at mii? phy ?
#rgephy* at mii? phy ?                  # Realtek 8169S/8110S/8211 PHYs
#rlphy* at mii? phy ?                   # Realtek 8139/8201L PHYs
#ukphy* at mii? phy ?                   # generic unknown PHYs
#urlphy* at mii? phy ?                  # Realtek RTL8150L internal PHYs

# 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?
s390rtc* at iic1 addr 0x30

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

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

# On-chip Thermal Sensor
mvsocts* at mvsoc? offset ?

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

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

# 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 HID device
uhidev* at uhub? port ? configuration ? interface ?

# USB TEMPer and TEMPerHUM
#uthum* at uhidev? reportid ?

# USB serial adapter
#ucycom* at uhidev? reportid ?

# USB Modem
#umodem* at uhub? port ? configuration ?
#ucom*  at umodem?

# Option N.V. Wireless WAN modems
#uhso*  at uhub? port ? configuration ?

# 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 IrDA
# USB-IrDA bridge spec
#uirda* at uhub? port ? configuration ? interface ?
#irframe* at uirda?

#stuirda* at uhub? port ? configuration ? interface ?
#irframe* at stuirda?

# SigmaTel STIr4200 USB/IrDA Bridge
#ustir* at uhub? port ?
#irframe* at ustir?

# USB Ethernet adapters
#aue*   at uhub? port ?         # ADMtek AN986 Pegasus based adapters
#axe*   at uhub? port ?         # ASIX AX88172 based adapters
#cdce*  at uhub? port ?         # CDC, Ethernet Networking Control Model
#cue*   at uhub? port ?         # CATC USB-EL1201A based adapters
#kue*   at uhub? port ?         # Kawasaki LSI KL5KUSB101B based adapters
#mue*   at uhub? port ?         # Microchip LAN75xx/LAN78xx based adapters
#udav*  at uhub? port ?         # Davicom DM9601 based adapters
#ure*   at uhub? port ?         # Realtek RTL8152/RTL8153 based adapters
#url*   at uhub? port ?         # Realtek RTL8150L based adapters

# USB 802.11 adapters
#atu*   at uhub? port ?         # Atmel AT76C50XX based adapters
#ural*  at uhub? port ?         # Ralink Technology RT2500USB 802.11a/b/g
#rum*   at uhub? port ?         # Ralink Technology RT2501/RT2601 802.11a/b/g
#zyd*   at uhub? port ?         # Zydas ZD1211

# Prolific PL2301/PL2302 host-to-host adapter
#upl*   at uhub? port ?

# Serial adapters
#ubsa*  at uhub? port ?         # Belkin serial adapter
#ucom*  at ubsa? portno ?

#uchcom* at uhub? port ?        # WinChipHead CH341/CH340 serial adapter
#ucom*  at uchcom? portno ?

#uftdi* at uhub? port ?         # FTDI FT8U100AX serial adapter
#ucom*  at uftdi? portno ?

#uipaq* at uhub? port ?         # iPAQ PDAs
#ucom*  at uipaq? portno ?

#umct*  at uhub? port ?         # MCT USB-RS232 serial adapter
#ucom*  at umct? portno ?

#uplcom* at uhub? port ?        # I/O DATA USB-RSAQ2 serial adapter
#ucom*  at uplcom? portno ?

#uslsa* at uhub? port ?         # Silicon Labs USB-RS232 serial adapter
#ucom*  at uslsa? portno ?

#uvscom* at uhub? port ?        # SUNTAC Slipper U VS-10U serial adapter
#ucom*  at uvscom? portno ?

# Kyocera AIR-EDGE PHONE
#ukyopon* at uhub? port ?
#ucom*  at ukyopon? portno ?

# USB Generic driver
ugen*   at uhub? port ?

# USB generic serial port (e.g., data over cellular)
#ugensa* at uhub? port ?
#ucom*  at ugensa?

# Bluetooth Controller and Device support

# Bluetooth USB Controllers
#ubt* at uhub? port ?
#aubtfwl* at uhub? port ?

# Bluetooth Device Hub
#bthub* at ubt?

# 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