GENERIC3X revision 1.119
11.119Schristos# $NetBSD: GENERIC3X,v 1.119 2013/04/27 18:19:54 christos Exp $
21.11Sgwr
31.18Sgwr# GENERIC Sun3X (3/80, 3/470)
41.18Sgwr# Supports root on: ie0, le0, sd*, ...
51.1Sjeremy
61.82Stsutsuiinclude 	"arch/sun3/conf/std.sun3x"
71.50Satatat
81.50Satatatoptions 	INCLUDE_CONFIG_FILE	# embed config file in kernel binary
91.1Sjeremy
101.119Schristos#ident		"GENERIC3X-$Revision: 1.119 $"
111.100Stsutsui
121.100Stsutsuimakeoptions	COPTS="-Os"	# bootloader has size limit (~2MB)
131.82Stsutsui
141.19Sgwr# Machines to be supported by this kernel
151.82Stsutsui#options 	FPU_EMULATE	# XXX - Ever needed?
161.82Stsutsui#options 	HAVE_IOCACHE	# XXX - Not yet supported.
171.1Sjeremy
181.1Sjeremy# Needs to be set per system.  i.e change these as you see fit
191.1Sjeremymaxusers	4
201.1Sjeremy
211.1Sjeremy# Standard system options
221.10Sgwroptions 	KTRACE		# system call tracing
231.10Sgwroptions 	SYSVMSG		# System V message queues
241.10Sgwroptions 	SYSVSEM		# System V semaphores
251.10Sgwroptions 	SYSVSHM		# System V shared memory
261.108Stsutsui
271.110Stsutsui#options 	MODULAR		# new style module(7) framework
281.108Stsutsui
291.10Sgwr#options 	INSECURE	# disable kernel security level
301.100Stsutsui#options 	USERCONF	# userconf(4) support
311.96Stsutsui#options 	PIPE_SOCKETPAIR	# smaller, but slower pipe(2)
321.64Satatatoptions 	SYSCTL_INCLUDE_DESCR	# Include sysctl descriptions in kernel
331.1Sjeremy
341.55Swiz# Enable experimental buffer queue strategy for better responsiveness under 
351.54Stsutsui# high disk I/O load. Use it with caution - it's not proven to be stable yet.
361.73Stsutsui#options 	BUFQ_READPRIO
371.73Stsutsui#options 	BUFQ_PRIOCSCAN
381.54Stsutsui
391.10Sgwr# Which kernel debugger?  Uncomment either this:
401.1Sjeremyoptions 	DDB
411.1Sjeremy# ... or these for KGDB (gdb remote target)
421.44Slukem#makeoptions	DEBUG="-g"	# debugging symbols for gdb
431.1Sjeremy#options 	KGDB
441.43Slukem#options 	KGDB_DEV=0x0C01	# ttya=0C00 ttyb=0C01
451.10Sgwr
461.10Sgwr# Other debugging options
471.14Slukem#options 	DDB_HISTORY_SIZE=100	# enable history editing in DDB
481.10Sgwr#options 	DEBUG		# kernel debugging code
491.10Sgwr#options 	DIAGNOSTIC	# extra kernel sanity checking
501.10Sgwr#options 	KMEMSTATS	# kernel memory statistics (vmstat -m)
511.10Sgwr#options 	PMAP_DEBUG
521.10Sgwr#options 	SCSIDEBUG
531.9Smjacob#options 	SCSIVERBOSE		# Verbose SCSI errors
541.1Sjeremy
551.39Swiz# Compatibility options
561.10Sgwroptions 	COMPAT_SUNOS	# can run SunOS 4.1.1 executables
571.25Skleink#options 	COMPAT_SVR4	# can run SVR4 executables
581.10Sgwroptions 	COMPAT_43	# and 4.3BSD and ...
591.13Sgwroptions 	COMPAT_10	# NetBSD 1.0
601.13Sgwroptions 	COMPAT_11	# NetBSD 1.1
611.10Sgwroptions 	COMPAT_12	# NetBSD 1.2
621.16Skleinkoptions 	COMPAT_13	# NetBSD 1.3
631.26Saugustssoptions 	COMPAT_14	# NetBSD 1.4
641.93Smanuoptions 	COMPAT_15	# NetBSD 1.5
651.58Scloptions 	COMPAT_16	# NetBSD 1.6
661.67Stsutsuioptions 	COMPAT_20	# NetBSD 2.0
671.96Stsutsuioptions 	COMPAT_30	# NetBSD 3.0
681.105Stsutsuioptions 	COMPAT_40	# NetBSD 4.0
691.105Stsutsuioptions 	COMPAT_50	# NetBSD 5.0 compatibility.
701.116Sapboptions 	COMPAT_60	# NetBSD 6.0 compatibility.
711.38Schsoptions 	COMPAT_AOUT_M68K # support for NetBSD a.out executables
721.23Sgwr#options 	COMPAT_LINUX	# can run Linux/m68k executables
731.38Schsoptions 	EXEC_AOUT	# support for a.out executables
741.40Sabs#options 	TCP_COMPAT_42	# 4.2BSD TCP/IP bug compat. Not recommended.
751.96Stsutsuioptions 	COMPAT_BSDPTY	# /dev/[pt]ty?? ptys.
761.10Sgwr
771.1Sjeremy# Filesystem options
781.10Sgwrfile-system	FFS		# Berkeley Fast Filesystem
791.10Sgwrfile-system	NFS		# Sun NFS client support
801.7Slukemfile-system	CD9660		# ISO 9660 + Rock Ridge file system
811.5Sjeremyfile-system	MSDOSFS		# MS-DOS FAT file system
821.7Slukemfile-system	FDESC		# /dev/fd/*
831.7Slukemfile-system	KERNFS		# /kern
841.7Slukemfile-system	NULLFS		# loopback file system
851.100Stsutsui#file-system	OVERLAY		# overlay file system
861.7Slukemfile-system	PROCFS		# /proc
871.100Stsutsui#file-system	UNION		# union file system
881.7Slukemfile-system	MFS		# memory-based filesystem
891.80Schristosfile-system	PTYFS		# /dev/pts/N support
901.107Schsfile-system	TMPFS		# Efficient memory file-system
911.85Stsutsui#file-system	UDF		# experimental - OSTA UDF CD/DVD file-system
921.1Sjeremy
931.1Sjeremyoptions 	NFSSERVER	# nfs server support
941.111Sbouyer#options 	QUOTA		# legacy UFS quotas
951.111Sbouyer#options 	QUOTA2		# new, in-filesystem UFS quotas
961.112Swiz#options 	FFS_EI		# FFS Endian Independent support
971.114Sdhollandoptions 	WAPBL		# File system journaling support
981.96Stsutsui#options 	UFS_DIRHASH	# UFS Large Directory Hashing - Experimental
991.100Stsutsuioptions 	FFS_NO_SNAPSHOT	# No FFS snapshot support
1001.28Stsutsui
1011.1Sjeremy# Networking options
1021.81Sisakioptions 	INET		# IP protocol stack support
1031.28Stsutsuioptions 	INET6		# IPV6
1041.28Stsutsui#options 	IPSEC		# IP security
1051.75Stron#options 	IPSEC_NAT_T	# IPsec NAT traversal (NAT-T)
1061.28Stsutsui#options 	IPSEC_DEBUG	# debug for IP security
1071.7Slukem#options 	GATEWAY		# IP packet forwarding
1081.82Stsutsuioptions 	PFIL_HOOKS	# pfil(9) packet filter hooks.
1091.40Sabs#options 	TCP_DEBUG	# Record last TCP_NDEBUG packets with SO_DEBUG
1101.10Sgwr
1111.62Sabs#options 	ALTQ		# Manipulate network interfaces' output queues
1121.62Sabs#options 	ALTQ_BLUE	# Stochastic Fair Blue
1131.62Sabs#options 	ALTQ_CBQ	# Class-Based Queueing
1141.62Sabs#options 	ALTQ_CDNR	# Diffserv Traffic Conditioner
1151.62Sabs#options 	ALTQ_FIFOQ	# First-In First-Out Queue
1161.62Sabs#options 	ALTQ_FLOWVALVE	# RED/flow-valve (red-penalty-box)
1171.62Sabs#options 	ALTQ_HFSC	# Hierarchical Fair Service Curve
1181.62Sabs#options 	ALTQ_LOCALQ	# Local queueing discipline
1191.62Sabs#options 	ALTQ_PRIQ	# Priority Queueing
1201.62Sabs#options 	ALTQ_RED	# Random Early Detection
1211.62Sabs#options 	ALTQ_RIO	# RED with IN/OUT
1221.62Sabs#options 	ALTQ_WFQ	# Weighted Fair Queueing
1231.62Sabs
1241.10Sgwr# Work-around for root on slow servers (insurance...)
1251.1Sjeremyoptions 	NFS_BOOT_RWSIZE=1024
1261.18Sgwroptions 	NFS_BOOT_BOOTPARAM
1271.1Sjeremy
1281.1Sjeremyconfig		netbsd root on ? type ?
1291.1Sjeremy
1301.18Sgwr# On-board I/O space (required)
1311.18Sgwrinclude "arch/sun3/conf/obio.sun3x"
1321.18Sgwr
1331.18Sgwr# On-board memory (optional)
1341.18Sgwr# See frame-buffers
1351.18Sgwrobmem0 at mainbus?
1361.18Sgwr
1371.18Sgwr# VME bus support (optional)
1381.18Sgwr# One unit for each address space
1391.18Sgwrvme0 at mainbus? # A16/D16
1401.18Sgwrvme1 at mainbus? # A16/D32
1411.18Sgwrvme2 at mainbus? # A24/D16
1421.18Sgwrvme3 at mainbus? # A24/D32
1431.18Sgwrvme4 at mainbus? # A32/D16
1441.18Sgwrvme5 at mainbus? # A32/D32
1451.18Sgwr
1461.1Sjeremy#
1471.1Sjeremy# Serial ports
1481.1Sjeremy#
1491.11Sgwrzstty0	at zsc1 channel 0	# ttya
1501.11Sgwrzstty1	at zsc1 channel 1	# ttyb
1511.1Sjeremy
1521.11Sgwrkbd0	at zsc0 channel 0	# keyboard
1531.11Sgwrms0	at zsc0 channel 1	# mouse
1541.1Sjeremy
1551.1Sjeremy#
1561.1Sjeremy# Network devices
1571.1Sjeremy#
1581.10Sgwr
1591.18Sgwr# Intel Ethernet (onboard, or VME)
1601.10Sgwrie0 at obio0 addr 0x65000000 ipl 3
1611.44Slukemie1 at vme2 addr 0xe88000 ipl 3 vect 0x75
1621.1Sjeremy
1631.1Sjeremy# Lance Ethernet (only onboard)
1641.1Sjeremyle0 at obio0 addr 0x65002000 ipl 3
1651.1Sjeremy
1661.1Sjeremy#
1671.1Sjeremy# Disk and tape devices
1681.1Sjeremy#
1691.1Sjeremy
1701.11Sgwr# Emulex SCSI (3/80 only)
1711.24Sgwr# Both `dma' and `esp' are needed.
1721.24Sgwr# The following flags may be set for the NCR53c94 based esp driver:
1731.6Sgwr#	bits 0-7:  disable disconnect/reselect for the corresponding target
1741.24Sgwr#	bits 8-15: disable synchronous negotiation for target [bit-8]
1751.6Sgwr#
1761.24Sgwrdma0 at obio0 addr 0x66001000 ipl 2
1771.69Stsutsuiesp0 at obio0 addr 0x66000000 ipl 2 flags 0x000000
1781.5Sjeremy
1791.5Sjeremy# Floppy drive
1801.5Sjeremyfdc0 at obio0 addr 0x6e000000 ipl 6 vect 0x40
1811.44Slukemfd0	at fdc0	# First (and only) floppy drive.
1821.12Sgwr
1831.12Sgwr# Sun3 "si" SCSI controller (NCR 5380)
1841.12Sgwr# This driver has several flags which may be enabled using
1851.12Sgwr# the "flags" directive.  Valid flags are:
1861.12Sgwr#
1871.12Sgwr# 0x000ff	Set (1<<target) to disable disconnect/reselect
1881.12Sgwr# 0x0ff00	Set (1<<(target+8)) to disable parity checking
1891.12Sgwr# 0x10000	Set this bit to disable DMA interrupts (poll)
1901.12Sgwr# 0x20000	Set this bit to disable DMA entirely (use PIO)
1911.12Sgwr#
1921.12Sgwr# For example: "flags 0x1000f" would disable DMA interrupts,
1931.12Sgwr# and disable disconnect/reselect for targets 0-3
1941.44Slukemsi0 at vme2 addr 0x200000 ipl 2 vect 0x40
1951.44Slukemsi1 at vme2 addr 0x204000 ipl 2 vect 0x41
1961.18Sgwr
1971.18Sgwr# Xylogics 450/451 controllers (VME A16/D16)
1981.18Sgwrxyc0 at vme0 addr 0xee40 ipl 2 vect 0x48
1991.18Sgwrxyc1 at vme0 addr 0xee48 ipl 2 vect 0x49
2001.18Sgwrxy* at xyc? drive ?
2011.18Sgwr
2021.18Sgwr# Xylogics 7053 controllers (VME A16/D32)
2031.18Sgwrxdc0 at vme1 addr 0xee80 ipl 2 vect 0x44
2041.18Sgwrxdc1 at vme1 addr 0xee90 ipl 2 vect 0x45
2051.18Sgwrxd* at xdc? drive ?
2061.18Sgwr
2071.18Sgwr# Xylogics 472 tape controllers?
2081.1Sjeremy
2091.1Sjeremy#
2101.1Sjeremy# Frame buffer devices
2111.1Sjeremy#
2121.1Sjeremy
2131.19Sgwr# P4 Monochrome frame buffer.
2141.44Slukembwtwo0	at obmem0 addr 0x50300000
2151.19Sgwr
2161.19Sgwr# P4 8-bit color frame buffer
2171.19Sgwrcgfour0 at obmem0 addr 0x50300000
2181.19Sgwr
2191.19Sgwr# P4 accelerated 8-bit color frame buffer
2201.23Sgwr# cgsix0 at obmem0 addr 0x50000000
2211.19Sgwr
2221.19Sgwr# P4 24-bit color frame buffer
2231.19Sgwr# cgeight0 at obmem0 addr 0x50300000
2241.19Sgwr
2251.19Sgwr# Sun-3 color board, or CG5 8-bit frame buffer (VME A24/D16).
2261.19Sgwr# This driver is going to need work in its mmap function.
2271.19Sgwr# cgtwo0 at vme2 addr 0x400000 ipl 4 vect 0xA8
2281.19Sgwr
2291.19Sgwr# Support for the CG9 24-bit frame buffer (VME A32/D32).
2301.19Sgwr# cgnine0 at vme5 addr 0x08000000 ipl 4 vect 0xAA
2311.1Sjeremy
2321.1Sjeremy#
2331.1Sjeremy# SCSI infrastructure
2341.1Sjeremy#
2351.1Sjeremyscsibus* at scsi?
2361.1Sjeremy
2371.1Sjeremysd* at scsibus? target ? lun ?		# SCSI disks
2381.1Sjeremyst* at scsibus? target ? lun ?		# SCSI tapes
2391.1Sjeremycd* at scsibus? target ? lun ?		# SCSI CD-ROMs
2401.100Stsutsui#ch* at scsibus? target ? lun ?		# SCSI changer devices
2411.100Stsutsui#ss* at scsibus? target ? lun ?		# SCSI scanners
2421.1Sjeremyuk* at scsibus? target ? lun ?		# unknown SCSI devices
2431.1Sjeremy
2441.102Stsutsui#
2451.102Stsutsui# accept filters
2461.102Stsutsuipseudo-device	accf_data		# "dataready" accept filter
2471.102Stsutsuipseudo-device	accf_http		# "httpready" accept filter
2481.102Stsutsui
2491.1Sjeremy# Memory-disk drivers
2501.109Shannkenpseudo-device	md		
2511.1Sjeremy
2521.1Sjeremy# Misc.
2531.119Schristospseudo-device	loop			# network loopback
2541.86Srpaulopseudo-device	bpfilter		# packet filter
2551.89Stsutsui#pseudo-device	carp			# Common Address Redundancy Protocol
2561.87Scubepseudo-device	sl			# CSLIP
2571.87Scubepseudo-device	ppp			# PPP
2581.100Stsutsui#pseudo-device	pppoe			# PPP over Ethernet (RFC 2516)
2591.100Stsutsui#pseudo-device	tun			# network tunneling over tty
2601.100Stsutsui#pseudo-device	tap			# virtual Ethernet
2611.87Scube#pseudo-device	gre			# generic L3 over IP tunnel
2621.1Sjeremy#pseudo-device	ipfilter		# ip filter
2631.100Stsutsui#pseudo-device	gif			# IPv[46] over IPv[46] tunnel (RFC1933)
2641.87Scube#pseudo-device	faith			# IPv[46] tcp relay translation i/f
2651.100Stsutsui#pseudo-device	stf			# 6to4 IPv6 over IPv4 encapsulation
2661.36Stsutsuipseudo-device	vlan			# IEEE 802.1q encapsulation
2671.100Stsutsui#pseudo-device	bridge			# simple inter-network bridging
2681.100Stsutsui#pseudo-device	agr			# IEEE 802.3ad link aggregation
2691.57Stsutsui#options 	BRIDGE_IPF		# bridge uses IP/IPv6 pfil hooks too
2701.1Sjeremy
2711.33Sjdolecekpseudo-device	pty			# pseudo-terminals
2721.87Scubepseudo-device	vnd			# paging to files
2731.76Shubertf#options 	VND_COMPRESSION		# compressed vnd(4)
2741.119Schristos#pseudo-device	ccd			# concatenated disks
2751.119Schristos#pseudo-device	cgd			# cryptographic disk devices
2761.23Sgwr#pseudo-device	raid		4	# RAIDframe disk driver
2771.29Stsutsui#options 	RAID_AUTOCONFIG		# auto-configuration of RAID components
2781.47Soster# Options to enable various other RAIDframe RAID types.
2791.96Stsutsui#options 	RF_INCLUDE_EVENODD=1
2801.96Stsutsui#options 	RF_INCLUDE_RAID5_RS=1
2811.96Stsutsui#options 	RF_INCLUDE_PARITYLOGGING=1
2821.96Stsutsui#options 	RF_INCLUDE_CHAINDECLUSTER=1
2831.96Stsutsui#options 	RF_INCLUDE_INTERDECLUSTER=1
2841.96Stsutsui#options 	RF_INCLUDE_PARITY_DECLUSTERING=1
2851.96Stsutsui#options 	RF_INCLUDE_PARITY_DECLUSTERING_DS=1
2861.106Spooka#pseudo-device	fss			# file system snapshot device
2871.51Slukempseudo-device	clockctl		# user control of clock subsystem
2881.57Stsutsuipseudo-device	ksyms			# /dev/ksyms
2891.61Sitojun#pseudo-device	pf			# PF packet filter
2901.61Sitojun#pseudo-device	pflog			# PF log if
2911.84Stsutsui
2921.84Stsutsui# Veriexec
2931.84Stsutsui#
2941.84Stsutsui# a pseudo device needed for veriexec
2951.84Stsutsui#pseudo-device	veriexec		1
2961.84Stsutsui#
2971.84Stsutsui# Uncomment the fingerprint methods below that are desired. Note that
2981.84Stsutsui# removing fingerprint methods will have almost no impact on the kernel
2991.84Stsutsui# code size.
3001.84Stsutsui#
3011.84Stsutsui#options VERIFIED_EXEC_FP_RMD160
3021.84Stsutsui#options VERIFIED_EXEC_FP_SHA256
3031.84Stsutsui#options VERIFIED_EXEC_FP_SHA384
3041.84Stsutsui#options VERIFIED_EXEC_FP_SHA512
3051.84Stsutsui#options VERIFIED_EXEC_FP_SHA1
3061.84Stsutsui#options VERIFIED_EXEC_FP_MD5
307