GENERIC revision 1.109
11.109Ssimonb# $NetBSD: GENERIC,v 1.109 2022/08/07 02:52:30 simonb Exp $
21.11Sgmcgarry#
31.11Sgmcgarry# GENERIC machine description file
41.11Sgmcgarry# 
51.11Sgmcgarry# This machine description file is used to generate the default NetBSD
61.11Sgmcgarry# kernel.  The generic kernel does not include all options, subsystems
71.11Sgmcgarry# and device drivers, but should be useful for most applications.
81.11Sgmcgarry#
91.11Sgmcgarry# The machine description file can be customised for your specific
101.11Sgmcgarry# machine to reduce the kernel size and improve its performance.
111.11Sgmcgarry#
121.11Sgmcgarry# For further information on compiling NetBSD kernels, see the config(8)
131.11Sgmcgarry# man page.
141.11Sgmcgarry#
151.11Sgmcgarry# For further information on hardware support for this architecture, see
161.11Sgmcgarry# the intro(4) man page.  For further information about kernel options
171.11Sgmcgarry# for this architecture, see the options(4) man page.  For an explanation
181.11Sgmcgarry# of each device driver in this file see the section 4 man page for the
191.11Sgmcgarry# device.
201.1Sfredette
211.11Sgmcgarry# Supports Sun2 (2/120, 2/170, 2/50, ...)
221.105Srin# Supports root on: sd*, ... (FFS)
231.1Sfredette
241.11Sgmcgarryinclude 	"arch/sun2/conf/std.sun2"
251.1Sfredette
261.103Srinoptions 	MODULAR			# new style module(7) framework
271.103Srin#options 	MODULAR_DEFAULT_AUTOLOAD
281.103Srinoptions 	INSECURE		# allow modload(8) in multiuser mode
291.103Srin
301.90Stsutsui#options 	INCLUDE_CONFIG_FILE	# embed config file in kernel binary
311.16Satatat
321.109Ssimonb#ident 		"GENERIC-$Revision: 1.109 $"
331.68Stsutsui
341.107Srin# Bootloader has size limit (~2MB). Kernel should be smaller than this
351.107Srin# hard limit. Otherwise, it freezes before adding swap even with 7MB
361.107Srin# memory. -fno-omit-frame-pointer is necessary for backtraces in DDB.
371.107Srinoptions 	NO_KERNEL_RCSIDS
381.107Srinmakeoptions	COPTS="-Os -fno-inline-small-functions -fno-asynchronous-unwind-tables -fno-unwind-tables -fno-omit-frame-pointer"
391.1Sfredette
401.1Sfredette# Machines to be supported by this kernel
411.1Sfredette#options 	FPU_EMULATE
421.1Sfredette
431.1Sfredette# Needs to be set per system.  i.e change these as you see fit
441.68Stsutsuimaxusers	4
451.1Sfredette
461.1Sfredette# Standard system options
471.1Sfredetteoptions 	KTRACE		# system call tracing
481.103Srin#options 	SYSVMSG		# System V message queues
491.103Srin#options 	SYSVSEM		# System V semaphores
501.103Srin#options 	SYSVSHM		# System V shared memory
511.1Sfredette#options 	INSECURE	# disable kernel security level
521.68Stsutsui#options 	USERCONF	# userconf(4) support
531.103Srinoptions 	PIPE_SOCKETPAIR	# smaller, but slower pipe(2)
541.90Stsutsui#options 	SYSCTL_INCLUDE_DESCR	# Include sysctl descriptions in kernel
551.21Sjunyoung
561.99Ssevan# Alternate buffer queue strategies for better responsiveness under high
571.99Ssevan# disk I/O load.
581.40Stsutsui#options 	BUFQ_READPRIO
591.40Stsutsui#options 	BUFQ_PRIOCSCAN
601.1Sfredette
611.1Sfredette# Which kernel debugger?  Uncomment either this:
621.1Sfredetteoptions 	DDB
631.1Sfredette# ... or these for KGDB (gdb remote target)
641.80Smrg#makeoptions	DEBUG="-g"	# debugging symbols for gdb
651.1Sfredette#options 	KGDB
661.8Slukem#options 	KGDB_DEV=0x0C00	# ttya=0C00 ttyb=0C01
671.1Sfredette
681.1Sfredette# Other debugging options
691.1Sfredette#options 	DDB_HISTORY_SIZE=100	# enable history editing in DDB
701.1Sfredette#options 	DEBUG		# kernel debugging code
711.1Sfredette#options 	DIAGNOSTIC	# extra kernel sanity checking
721.1Sfredette#options 	PMAP_DEBUG
731.1Sfredette#options 	SCSIDEBUG
741.1Sfredette#options 	SCSIVERBOSE		# Verbose SCSI errors
751.1Sfredette
761.3Swiz# Compatibility options
771.98Smrginclude 	"conf/compat_netbsd16.config"
781.2Sfredette#options 	COMPAT_SUNOS	# can run SunOS 4.1.1 executables
791.90Stsutsui#options 	COMPAT_AOUT_M68K # support for NetBSD a.out executables
801.90Stsutsui#options 	EXEC_AOUT	# support for a.out executables
811.1Sfredette
821.109Ssimonb# File systems
831.1Sfredettefile-system	FFS		# Berkeley Fast Filesystem
841.103Srin#file-system	NFS		# Sun NFS client support
851.103Srin#file-system	CD9660		# ISO 9660 + Rock Ridge file system
861.90Stsutsui#file-system	FDESC		# /dev/fd/*
871.103Srin#file-system	KERNFS		# /kern
881.103Srin#file-system	NULLFS		# loopback file system
891.68Stsutsui#file-system	OVERLAY		# overlay file system
901.2Sfredette#file-system	PROCFS		# /proc
911.68Stsutsui#file-system	UNION		# union file system
921.103Srin#file-system	MFS		# memory-based filesystem
931.47Schristosfile-system	PTYFS		# /dev/pts/N support
941.90Stsutsui#file-system	TMPFS		# Efficient memory file-system
951.53Sreinoud#file-system	UDF		# experimental - OSTA UDF CD/DVD file-system
961.1Sfredette
971.109Ssimonb# File system options
981.109Ssimonb#options 	FFS_EI		# FFS Endian Independent support
991.109Ssimonboptions 	FFS_NO_SNAPSHOT	# No FFS snapshot support
1001.77Sbouyer#options 	QUOTA		# legacy UFS quotas
1011.77Sbouyer#options 	QUOTA2		# new, in-filesystem UFS quotas
1021.109Ssimonb#options 	UFS_DIRHASH	# UFS Large Directory Hashing
1031.109Ssimonb#options 	UFS_EXTATTR	# Extended attribute support for UFS1
1041.90Stsutsui#options 	WAPBL		# File system journaling support
1051.109Ssimonb#options 	NFSSERVER	# Network File System server
1061.64Syamt#options 	NFS_V2_ONLY	# Exclude NFS3 code to save space
1071.1Sfredette
1081.1Sfredette# Networking options
1091.48Sisakioptions 	INET		# IP protocol stack support
1101.2Sfredette#options 	INET6		# IPV6
1111.1Sfredette#options 	IPSEC		# IP security
1121.1Sfredette#options 	IPSEC_DEBUG	# debug for IP security
1131.1Sfredette#options 	GATEWAY		# IP packet forwarding
1141.6Sabs#options 	TCP_DEBUG	# Record last TCP_NDEBUG packets with SO_DEBUG
1151.1Sfredette
1161.30Sabs#options 	ALTQ		# Manipulate network interfaces' output queues
1171.30Sabs#options 	ALTQ_BLUE	# Stochastic Fair Blue
1181.30Sabs#options 	ALTQ_CBQ	# Class-Based Queueing
1191.30Sabs#options 	ALTQ_CDNR	# Diffserv Traffic Conditioner
1201.30Sabs#options 	ALTQ_FIFOQ	# First-In First-Out Queue
1211.30Sabs#options 	ALTQ_FLOWVALVE	# RED/flow-valve (red-penalty-box)
1221.30Sabs#options 	ALTQ_HFSC	# Hierarchical Fair Service Curve
1231.30Sabs#options 	ALTQ_LOCALQ	# Local queueing discipline
1241.30Sabs#options 	ALTQ_PRIQ	# Priority Queueing
1251.30Sabs#options 	ALTQ_RED	# Random Early Detection
1261.30Sabs#options 	ALTQ_RIO	# RED with IN/OUT
1271.30Sabs#options 	ALTQ_WFQ	# Weighted Fair Queueing
1281.30Sabs
1291.1Sfredette# Work-around for root on slow servers (insurance...)
1301.1Sfredetteoptions 	NFS_BOOT_RWSIZE=1024
1311.1Sfredetteoptions 	NFS_BOOT_BOOTPARAM
1321.1Sfredette
1331.1Sfredetteconfig		netbsd root on ? type ?
1341.1Sfredette
1351.1Sfredette#### Main bus.
1361.1Sfredettemainbus0 at root
1371.1Sfredette
1381.1Sfredette#### Bus types.
1391.1Sfredette
1401.1Sfredetteobio0	at mainbus? 		# all Sun-2
1411.1Sfredetteobmem0	at mainbus?		# all Sun-2
1421.1Sfredettembmem0	at mainbus?		# 2/120, 2/170
1431.1Sfredettembio0	at mainbus?		# 2/120, 2/170
1441.4Sfredettesun68kvme0	at mainbus?	# 2/50, 2/130, 2/160
1451.4Sfredettevme0	at sun68kvme0		# mi VME attachment
1461.1Sfredette
1471.1Sfredette#### Standard system devices.
1481.1Sfredette
1491.1Sfredette## The AM9513 clock chip.
1501.9Slukemclock0	at obio0 addr 0x002800	# 2/120, 2/170
1511.9Slukemclock0	at obio0 addr 0x7f2800	# 2/50, 2/130, 2/160
1521.1Sfredette
1531.1Sfredette## The MM58167 time-of-day chip.
1541.9Slukemtod0	at obio0 addr 0x003800	# 2/120, 2/170
1551.4Sfredettetod0	at vme0 addr 0x200800	# 2/50, 2/130, 2/160
1561.1Sfredette
1571.1Sfredette#### Serial port configuration.
1581.1Sfredette
1591.4Sfredette## Zilog 8530 serial chips.  Each has two channels.
1601.1Sfredette## zs0 is ttya and ttyb.  zs1 is the keyboard and mouse.
1611.2Sfredette## zs0 is REQUIRED to use KGDB.
1621.1Sfredettezs0	at obio0 addr 0x002000	# 2/120, 2/170
1631.4Sfredettezs0	at obio0 addr 0x7f2000	# 2/50
1641.1Sfredettezs1	at obmem0 addr 0x780000	# 2/120, 2/170
1651.4Sfredettezs1	at obio0 addr 0x7f1800	# 2/50
1661.2Sfredettezs2	at mbmem0 addr 0x080800	# 2/120, 2/170 (first sc SCSI)
1671.2Sfredettezs3	at mbmem0 addr 0x081000	# 2/120, 2/170 (first sc SCSI)
1681.2Sfredettezs4	at mbmem0 addr 0x084800	# 2/120, 2/170 (second sc SCSI)
1691.2Sfredettezs5	at mbmem0 addr 0x085000	# 2/120, 2/170 (second sc SCSI)
1701.4Sfredettezstty*	at zs? channel ?	# ttya
1711.4Sfredettekbd0	at zstty?		# keyboard
1721.4Sfredettems0	at zstty?		# mouse
1731.1Sfredette
1741.1Sfredette#### Disk controllers and disks.
1751.1Sfredette
1761.1Sfredette## PAL+logic-based "Sun SCSI 2" Multibus/VME SCSI controller.
1771.1Sfredette## This driver has several flags which may be enabled using
1781.1Sfredette## the "flags" directive.  Valid flags are:
1791.1Sfredette##
1801.1Sfredette## 0x0ff		Set (1<<target) to disable parity checking
1811.1Sfredette## 0x100		Set this bit to disable DMA interrupts (poll)
1821.1Sfredette## 0x200		Set this bit to disable DMA entirely (use PIO)
1831.1Sfredette##
1841.1Sfredette## For example: "flags 0x10f" would disable DMA interrupts,
1851.1Sfredette## and disable parity for targets 0-3
1861.1Sfredette
1871.1Sfredettesc0	at mbmem0 addr 0x80000 ipl 2 flags 0xff
1881.9Slukemsc0	at vme0 addr 0x200000 irq 2 vect 0x40 flags 0xff
1891.1Sfredettesc1	at mbmem0 addr 0x84000 ipl 2 flags 0xff
1901.1Sfredette
1911.1Sfredette## NCR5380-based "Sun SCSI 3" VME SCSI controller.
1921.1Sfredette## This driver has several flags which may be enabled by OR'ing
1931.1Sfredette## the values and using the "flags" directive.
1941.1Sfredette## Valid flags are:
1951.1Sfredette##
1961.1Sfredette##	0x01		Use DMA (may be polled)
1971.1Sfredette##	0x02		Use DMA completion interrupts
1981.1Sfredette##	0x04		Allow disconnect/reselect
1991.1Sfredette##
2001.1Sfredette## E.g. the following would enable DMA, interrupts, and reselect:
2011.1Sfredette## si0	at vme0 addr 0x200000 ipl 3 vect 0x40 flags 0x07
2021.1Sfredette##
2031.1Sfredette## By default, DMA is enabled in the driver.
2041.1Sfredette
2051.4Sfredettesi0	at vme0 addr 0x200000 irq 2 vect 0x40
2061.1Sfredette
2071.1Sfredette## These entries find devices on all SCSI busses and assign
2081.1Sfredette## unit numbers dynamically.
2091.1Sfredettescsibus* at sc?
2101.4Sfredettescsibus* at si?
2111.1Sfredettesd*	at scsibus? target ? lun ?		# SCSI disks
2121.1Sfredettest*	at scsibus? target ? lun ?		# SCSI tapes
2131.1Sfredettecd*	at scsibus? target ? lun ?		# SCSI CD-ROMs
2141.2Sfredette#ch*	at scsibus? target ? lun ?		# SCSI changer devices
2151.2Sfredette#ss*	at scsibus? target ? lun ?		# SCSI scanners
2161.2Sfredette#ses*	at scsibus? target ? lun ?		# SCSI SES/SAF-TE
2171.2Sfredette#uk*	at scsibus? target ? lun ?		# unknown SCSI
2181.10Sfredette
2191.10Sfredette# support old SCSI devices that don't understand the INQUIRY command
2201.10Sfredetteoptions 	SCSI_OLD_NOINQUIRY
2211.1Sfredette
2221.1Sfredette## Xylogics 450 or 451 Multibus/VME SMD disk controllers and disks.
2231.9Slukem#xyc0	at mbio0 addr 0xee40 ipl 2
2241.90Stsutsui#xyc0	at vme0 addr 0xee40 irq 2 vect 0x48
2251.9Slukem#xyc1	at mbio0 addr 0xee48 ipl 2
2261.90Stsutsui#xyc1	at vme0 addr 0xee48 irq 2 vect 0x49
2271.90Stsutsui#xy*	at xyc? drive ?
2281.1Sfredette
2291.70Stls#
2301.70Stls# accept filters
2311.90Stsutsui#pseudo-device   accf_data		# "dataready" accept filter
2321.90Stsutsui#pseudo-device   accf_http		# "httpready" accept filter
2331.70Stls
2341.1Sfredette## Memory-disk device.
2351.104Srin#pseudo-device	md		
2361.1Sfredette
2371.1Sfredette#### Network interfaces.
2381.1Sfredette
2391.1Sfredette## Intel Ethernet (onboard, or Multibus/VME)
2401.4Sfredetteie0	at obio0 addr 0x7f0800 ipl 3		# 2/50
2411.1Sfredetteie0	at mbmem0 addr 0x88000 ipl 3
2421.4Sfredetteie1	at mbmem0 addr 0x8c000 ipl 3
2431.4Sfredette## VME: the first [addr,len] pair specifies the device registers;
2441.4Sfredette##	the second pair specifies the on-board memory buffer
2451.4Sfredetteie1	at vme0 addr 0xe88000,0xe00000 len -1,0x40000 irq 3 vect 0x75
2461.4Sfredette
2471.4Sfredette## 3Com Ethernet (Multibus only)
2481.4Sfredetteec0	at mbmem0 addr 0xe0000 ipl 3
2491.4Sfredetteec1	at mbmem0 addr 0xe2000 ipl 3
2501.62Stsutsui# limit NFS R/W size for poor ec(4) interfaces
2511.62Stsutsuioptions 	NFS_RSIZE=1024,NFS_WSIZE=1024
2521.1Sfredette
2531.1Sfredette## Frame buffers.
2541.1Sfredette
2551.1Sfredette## Sun "bwtwo" black and white framebuffer.
2561.9Slukembwtwo0	at obmem0 addr 0x700000	# 2/120, 2/170
2571.4Sfredettebwtwo0	at obio0 addr 0x0	# 2/50
2581.4Sfredette
2591.4Sfredette## PROM console driver -- if all else fails
2601.4Sfredettepcons0	at mainbus0			# PROM console
2611.1Sfredette
2621.1Sfredette#### Miscellaneous.
2631.86Schristospseudo-device	loop			# network loopback
2641.54Srpaulo#pseudo-device	bpfilter		# packet filter
2651.56Sliamjfoy#pseudo-device	carp			# Common Address Redundancy Protocol
2661.7Satatat#pseudo-device	bridge			# simple inter-network bridging
2671.108Sroy#pseudo-device	vether			# Virtual Ethernet for bridge
2681.55Scube#pseudo-device	sl			# CSLIP
2691.55Scube#pseudo-device	ppp			# PPP
2701.12Smartin#pseudo-device	pppoe			# PPP over Ethernet (RFC 2516)
2711.55Scube#pseudo-device	tun			# network tunneling over tty
2721.34Scube#pseudo-device	tap			# virtual Ethernet
2731.55Scube#pseudo-device	gre			# generic L3 over IP tunnel
2741.101Smaxv#pseudo-device	npf			# NPF packet filter
2751.55Scube#pseudo-device	gif			# IPv[46] over IPv[46] tunnel (RFC1933)
2761.55Scube#pseudo-device	faith			# IPv[46] tcp relay translation i/f
2771.55Scube#pseudo-device	stf			# 6to4 IPv6 over IPv4 encapsulation
2781.1Sfredette
2791.60Stsutsuipseudo-device	pty			# pseudo-terminals
2801.55Scube#pseudo-device	vnd			# paging to files
2811.43Shubertf#options 	VND_COMPRESSION		# compressed vnd(4)
2821.86Schristos#pseudo-device	ccd			# concatenated disks
2831.86Schristos#pseudo-device	cgd			# cryptographic disk devices
2841.87Schristos#pseudo-device	raid			# RAIDframe disk driver
2851.1Sfredette#options 	RAID_AUTOCONFIG		# auto-configuration of RAID components
2861.13Soster# Options to enable various other RAIDframe RAID types.
2871.13Soster# options	RF_INCLUDE_EVENODD=1
2881.13Soster# options	RF_INCLUDE_RAID5_RS=1
2891.13Soster# options	RF_INCLUDE_PARITYLOGGING=1
2901.13Soster# options	RF_INCLUDE_CHAINDECLUSTER=1
2911.13Soster# options	RF_INCLUDE_INTERDECLUSTER=1
2921.13Soster# options 	RF_INCLUDE_PARITY_DECLUSTERING=1
2931.13Soster# options	RF_INCLUDE_PARITY_DECLUSTERING_DS=1
2941.74Spooka#pseudo-device	fss			# file system snapshot device
2951.90Stsutsui#pseudo-device	clockctl		# user control of clock subsystem
2961.25Sraggepseudo-device	ksyms			# /dev/ksyms
2971.52Selad
2981.52Selad# Veriexec
2991.102Ssevan# include "dev/veriexec.config"
300