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

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

options         INCLUDE_CONFIG_FILE     # embed config file in kernel binary

ident           "MPC8536DS-$Revision: 1.30 $"

maxusers        32

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

#options        UVMHIST
#options        UVMHIST_PRINT

options         MPC8536
options         PIXIS
#options        HZ=1000

#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          nfsnetbsd       root on tsec0 type nfs

#
# Device configuration
#

mainbus0 at root                        # Processor Local Bus

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

cpu0            at cpunode?

obio0           at cpunode?             # On-chip Peripheral Bus
#mkclock0       at obio0 addr 0xf8000000 size 8192

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

e500wdog*       at cpunode?             # Watchdog timer

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

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

ehci*           at cpunode?             # usb

diic*           at cpunode?             # i2c bus
iic*            at diic?
spdmem*         at iic1 addr 0x51       # DDR
dsrtc*          at iic1 addr 0x68       # RTC

pq3pcie*        at cpunode?             # PCI-Express controller
pq3pci*         at cpunode?             # PCI(X)
pci*            at pq3pcie?
pci*            at pq3pci?

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

#ohci1          at pci1 dev 0 function 2
#ehci1          at pci1 dev 0 function 3
ohci*           at pci? dev ? function ?
ehci*           at pci? dev ? function ?
#uhci*          at pci? dev ? function ?
usb*            at ehci?
usb*            at ohci?
#usb*           at uhci?
uhub*           at usb?
umass*          at uhub? port ?
scsibus*        at umass? channel ?
sd*             at scsibus? target ? lun ?

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

#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

include "dev/veriexec.config"