#       $NetBSD: MINI2440,v 1.35 2025/03/19 21:03:40 jakllsch Exp $
#
#       MINI2440 -- Friendly ARM evaluation board based on Samsung S3C2440
#

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

#options        DEBUG
#options        LOCKDEBUG
#options        DIAGNOSTIC      # internal consistency checks
#makeoptions    DEBUG="-g3"     # compile full symbol table
#makeoptions    PROF="-pg"
#options        GPROF
options         DDB

#options        DEBUG_DMA
#options        SSSDI_DEBUG
#options        SDMMC_DEBUG
#options        SDMMC_DUMP_CSD
#options        MSDOSFS_DEBUG

#options        INCLUDE_CONFIG_FILE     # embed config file in kernel binary

# Enable the hooks used for initializing the root memory-disk.
#options        MEMORY_DISK_HOOKS
#options        MEMORY_DISK_DYNAMIC
#options        MEMORY_DISK_IS_ROOT     # force root on memory disk
#options        MEMORY_DISK_SERVER=1    # no userspace memory disk support
#options        MEMORY_DISK_ROOT_SIZE=4096      # size of memory disk, in blocks
#options        MEMORY_DISK_ROOT_SIZE=2880      # 1.44M, same as a floppy
#
options         NFS_BOOT_BOOTP
options         NFS_BOOT_DHCP

# 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
makeoptions     CPUFLAGS="-march=armv4"
#options        ARM9_CACHE_WRITE_THROUGH

# Architecture options

options         S3C2XX0_XTAL_CLK=12000000     # 12MHz Xtal

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

# These options enable verbose messages for several subsystems.
# Warning, these may compile large string tables into the kernel!
#options        MIIVERBOSE      # verbose PHY autoconfig messages
#options        PCMCIAVERBOSE   # verbose PCMCIA configuration messages
#options        SCSIVERBOSE     # human readable SCSI error messages
#options        USBVERBOSE      # verbose USB device autoconfig messages


# Compatibility options

include         "conf/compat_netbsd40.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

# Miscellaneous kernel options
#options        KTRACE          # system call tracing, a la ktrace(1)
#options        IRQSTATS        # manage IRQ statistics
#options        MODULAR
#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        PCI_DEBUG
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        UVMHIST
#options        VERBOSE_INIT_ARM # verbose bootstraping messages
#options        KGDB
#options        DEBUG_KGDB
#options        DDB             # in-kernel debugger
#options        DDB_HISTORY_SIZE=100    # Enable history editing in DDB
#makeoptions    DEBUG="-g3"     # compile full symbol table

config          netbsd  root on ? type ?

# The main bus device
mainbus0        at root

# The boot CPU
cpu0            at mainbus?

# Core logic on Samsung S3C2440
ssio0   at mainbus?
ssextio0 at ssio0

# integrated UART
sscom0  at ssio? index 0
#sscom1 at ssio? index 1
#sscom2 at ssio? index 2
options         SSCOM0CONSOLE
#options        SSCOM1CONSOLE
options CONSPEED=115200
#options KGDB_DEVNAME="\"sscom1\""   # sscom0 or sscom1
#options KGDB_DEVRATE=115200

# LCD
#device-major   lcd     char 145
lcd0            at ssio?
wsdisplay*      at lcd? console ?
options         WSEMUL_VT100            # VT100 / VT220 emulation
options         WSDISPLAY_DEFAULTSCREENS=1
#options        WSDISPLAY_COMPAT_USL            # wsconscfg VT handling
#options        FONT_VT220L8x16
#options        FONT_VT220L8x10
#options        LCD_DEBUG

sstouch0 at ssio?
wsmouse* at sstouch0 mux 0

ssrtc0 at ssio?

ssiis0 at ssio?
udassio* at ssiis0

sssdi0 at ssio?
sdmmc* at sssdi0
ld*    at sdmmc?

# SPI port
#ssspi0 at ssio? index 0
#ssspi1 at ssio? index 1

#vsdsp0 at ssspi0

# on-board keyboard controller (Semtech SPICoder-SA01) via SPI1
#sskbd0 at ssspi1       intr 1
#wskbd* at sskbd? # console ?

# SCSI bus support
scsibus* at scsi?

# 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 autochangers
#ses*   at scsibus? target ? lun ?      # SCSI Enclosure Services devices
#ss*    at scsibus? target ? lun ?      # SCSI scanners
#uk*    at scsibus? target ? lun ?      # SCSI unknown

# 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

# MIDI support
#midi*  at midibus?
# midi* at pcppi?               # MIDI interface to the PC speaker

# Audio support
audio*  at audiobus?

spkr*   at audio?               # PC speaker (synthesized)

dme0     at ssextio? intr 7 addr 0x20000300

#options        MINI2440_ETHER_ADDR_FIXED="0x08,0x08,0x11,0x18,0x12,0x27"

# built-in OHCI USB controller
ohci0   at ssio? addr 0x49000000 intr 26
#options        OHCI_DEBUG
#
usb*    at ohci0

# USB Hubs
uhub*   at usb?
uhub*   at uhub? port ?

# USB HID device
#uhidev*        at uhub? port ? configuration ? interface ?

# USB Mice
#ums*   at uhidev? reportid ?
#wsmouse* at ums? mux 0

# USB Keyboards
#ukbd*  at uhidev? reportid ?
#wskbd* at ukbd? console ? mux 1

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

# USB Generic HID devices
#uhid*  at uhidev? reportid ?

# USB Printer
#ulpt*  at uhub? port ? configuration ? interface ?

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

# USB Mass Storage
umass*  at uhub? port ? configuration ? interface ?

# USB audio
#uaudio*        at uhub? port ? configuration ?

# USB MIDI
#umidi* at uhub? port ? configuration ?

# USB IrDA
# USB-IrDA bridge spec
#uirda* at uhub? port ? configuration ? interface ?
#irframe* at uirda?

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

# MII/PHY support
#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

# USB Ethernet adapters
#aue*   at uhub? port ?         # ADMtek AN986 Pegasus based adapters
#axe*   at uhub? port ?         # ASIX AX88172 based adapters
#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
#ure*   at uhub? port ?         # Realtek RTL8152/RTL8153 based adapters
#url*   at uhub? port ?         # Realtek RTL8150L based adapters

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

# Serial adapters
#ubsa*  at uhub? port ?         # Belkin serial adapter
#ucom*  at ubsa? portno ?
#
#uftdi* at uhub? port ?         # FTDI FT8U100AX serial adapter
#ucom*  at uftdi? 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 ?
#
#uvscom*        at uhub? port ?         # SUNTAC Slipper U VS-10U serial adapter
#ucom*  at uvscom? portno ?

# USB Handspring Visor
#uvisor*        at uhub? port ?
#ucom*  at uvisor?

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

# USB scanners that use SCSI emulation, e.g., HP5300
#usscanner* at uhub? port ?

# D-Link DSB-R100 USB radio
#udsbr* at uhub? port ?
#radio* at udsbr?

# USB Generic driver
#ugen*  at uhub? port ?

# 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  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  tun                     # network tunneling over tty
#pseudo-device  tap                     # virtual Ethernet
#pseudo-device  gre                     # generic L3 over IP tunnel
#pseudo-device  gif                     # IPv[46] over IPv[46] tunnel (RFC1933)
#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

# miscellaneous pseudo-devices
pseudo-device   pty                     # pseudo-terminals
#pseudo-device  rnd                     # /dev/random and in-kernel generator
pseudo-device   clockctl                # user control of clock subsystem

# wscons pseudo-devices
pseudo-device   wsmux                   # mouse & keyboard multiplexor
#pseudo-device  wsfont

pseudo-device   ksyms                   # /dev/ksyms