#       $NetBSD: P2020RDB,v 1.33 2024/01/29 18:27:12 christos Exp $
#
#       P2020RBD -- everything that's currently supported
#

include         "arch/evbppc/conf/std.mpc85xx"

options         INCLUDE_CONFIG_FILE     # embed config file in kernel binary

ident           "P2020RBD-$Revision: 1.33 $"

maxusers        32

makeoptions     NEED_BINARY="yes"
makeoptions     NEED_UBOOTIMAGE="yes"

#options        UVMHIST
#options        UVMHIST_PRINT

options         P2020
options         SYS_CLK=100000000
#options        HZ=1000

#options        SDHC_DEBUG

#options        INSECURE        # disable kernel security levels
#options        NTP             # NTP phase/frequency locked loop
options         KTRACE          # system call tracing via ktrace(1)

options         SYSVMSG         # System V message queues
options         SYSVSEM         # System V semaphores
options         SYSVSHM         # System V shared memory

options         USERCONF        # userconf(4) support
#options        PIPE_SOCKETPAIR # smaller, but slower pipe(2)
#options        SYSCTL_INCLUDE_DESCR    # Include sysctl descriptions in kernel

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

# Diagnostic/debugging support options
options         DIAGNOSTIC      # cheap kernel consistency checks
#options        DEBUG           # expensive debugging checks/support
#options        SYSCALL_DEBUG   # syscall debugging
options         DDB             # in-kernel debugger
options         DDB_HISTORY_SIZE=512    # enable history editing in DDB
options         TRAP_PANICWAIT
makeoptions     COPY_SYMTAB=1   # size for embedded symbol table

makeoptions     DEBUG="-g"      # compile full symbol table

# Compatibility options

include         "conf/compat_netbsd13.config"
#options        COMPAT_386BSD_MBRPART # recognize old partition ID

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

# 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     CD9660          # ISO 9660 + Rock Ridge file system
file-system     MSDOSFS         # MS-DOS file system
#file-system    FDESC           # /dev/fd
file-system     TMPFS           # efficient memory file system
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     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        LFS_DIRHASH     # LFS version of UFS_DIRHASH - experimental
#options        DISKLABEL_EI    # disklabel Endian Independent support
options         NFSSERVER       # Network File System server

options         NFS_BOOT_DHCP   # Support DHCP NFS root

# Networking options
#options        GATEWAY         # packet forwarding
options         INET            # IP + ICMP + TCP + UDP
options         INET_CSUM_COUNTERS
options         TCP_CSUM_COUNTERS
options         UDP_CSUM_COUNTERS
#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

# These options enable verbose messages for several subsystems.
# Warning, these may compile large string tables into the kernel!
options         PCIVERBOSE      # verbose PCI device autoconfig messages
options         MIIVERBOSE      # verbose PHY autoconfig messages
#options        PCI_CONFIG_DUMP # verbosely dump PCI config space
options         SCSIVERBOSE     # human readable SCSI error messages
#options        PCI_NETBSD_CONFIGURE    # Do not rely on BIOS/whatever to configure PCI devices
#options        PCI_CONFIGURE_VERBOSE   # Show PCI config information

# wscons options
#options        WSEMUL_SUN              # sun terminal emulation
#options        WSEMUL_VT100            # VT100 / VT220 emulation
#options        WSDISPLAY_COMPAT_USL            # wsconscfg VT handling

# Kernel root file system and dump configuration.
config          netbsd          root on ? type ?
config          netbsd-sd0a     root on sd0a type ffs
config          nfsnetbsd       root on tsec0 type nfs

#
# Device configuration
#

mainbus0 at root                        # Processor Local Bus

cpunode*        at mainbus? node ?
gpio*           at gpiobus?

cpu*            at cpunode?

obio0           at cpunode?             # On-chip Peripheral Bus
#nandfcm*       at obio0 cs ?           # nand flash
#nand*          at nandfcm?
#flash*         at nand?

# NOR Flash
#options        NOR_VERBOSE
cfi0            at obio0 cs 0
nor*            at cfi?
flash*          at nor? offset 0 size 0x1000000

e500wdog*       at cpunode?             # Watchdog timer

ddrc*           at cpunode?
duart*          at cpunode?
com*            at duart? port ?
options         CONSADDR="DUART1_BASE"

tsec0           at cpunode? phy 32 # Enhanced 3-Speed Ethernet Controller
mdio0           at tsec0
tsec1           at cpunode? mdio 0 phy 0 # Enhanced 3-Speed Ethernet Controller
tsec2           at cpunode? mdio 0 phy 1 # Enhanced 3-Speed Ethernet Controller
ukphy*          at mii?
#options        ETSEC_EVENT_COUNTERS

diic*           at cpunode?             # i2c bus
iic*            at diic?
dsrtc*          at iic0 addr 0x68 flags 1339    # RTC DS1339

pq3pcie*        at cpunode?             # PCI-Express controller
pci*            at pq3pcie?

ppb*            at pci? dev ? function ?        # PCI-PCI bridges
pci*            at ppb?

ahcisata*       at pci? dev ? function ?
atabus*         at ahcisata? channel ?
wd*             at atabus? drive ?
atapibus*       at atabus?

sdhc*           at pci? dev ? function ?

sdhc*           at cpunode?             # sdmmc
sdmmc*          at sdhc?                # SD/MMC bus
ld*             at sdmmc?

ehci*           at cpunode?             # usb
usb*            at ehci?
uhub*           at usb?
umass*          at uhub? port ?
scsibus*        at umass? channel ?
sd*             at scsibus? target ? lun ?

#siisata*       at pci? dev ? function ?
#atabus*        at siisata? channel ?
#jmide*         at pci? dev ? function ?        # JMicron PCI-e PATA/SATA controllers
#ahcisata*      at jmide?
#atabus*        at ahcisata? channel ?

#viaide*        at pci? dev ? function ?
#atabus*        at viaide? channel ?
#wd*            at atabus? drive ?
#rtk*           at pci? dev ? function ?
#wm*            at pci? dev ? function ?        # Intel Ethernet

#inphy*         at mii? phy ?                   # Intel 82555 PHYs
#iophy*         at mii? phy ?                   # Intel 82553 PHYs
#makphy*        at mii? phy ?                   # Marvell PHYs
#ukphy*         at mii? phy ?                   # generic unknown PHYs

pseudo-device   loop                    # network loopback
pseudo-device   bpfilter                # packet filter
pseudo-device   carp                    # Common Address Redundancy Protocol
pseudo-device   clockctl                # user control of clock subsystem
pseudo-device   drvctl                  # user control of disk subsystem
pseudo-device   ksyms                   # /dev/ksyms
pseudo-device   pty                     # pseudo-terminals
pseudo-device   kttcp                   # kernel ttcp
pseudo-device   vlan                    # 802.1Q VLANs
pseudo-device   vnd                     # disk-like interface to files
pseudo-device   putter                  # for puffs and pud

include "dev/veriexec.config"