GENERIC32_IP2x revision 1.109
1#	$NetBSD: GENERIC32_IP2x,v 1.109 2017/07/28 19:26:16 maxv Exp $
2#
3# GENERIC32_IP2x machine description file
4# 
5# This machine description file is used to generate the default NetBSD
6# kernel.  The generic kernel does not include all options, subsystems
7# and device drivers, but should be useful for most applications.
8#
9# The machine description file can be customised for your specific
10# machine to reduce the kernel size and improve its performance.
11#
12# For further information on compiling NetBSD kernels, see the config(8)
13# man page.
14#
15# For further information on hardware support for this architecture, see
16# the intro(4) man page.  For further information about kernel options
17# for this architecture, see the options(4) man page.  For an explanation
18# of each device driver in this file see the section 4 man page for the
19# device.
20#
21#
22# Currently this config file supports Indigo R4k, Indigo2 and Indy
23# (IP20, IP22 and IP24, respectively).
24#
25
26include		"arch/sgimips/conf/std.sgimips"
27
28makeoptions	TEXTADDR=0x88069000	# entry point
29
30options 	INCLUDE_CONFIG_FILE	# embed config file in kernel binary
31
32#ident		"GENERIC32-IP2x-$Revision: 1.109 $"
33
34maxusers	32
35
36# CPU related options
37options 	MIPS3		# MIPS3 support
38options 	INDY_R4600_CACHE	# Include routines to handle special
39					# R4600 cache -- required for Indy.
40
41makeoptions	WANT_ECOFF="yes"	# Create an ECOFF kernel in addition
42					# to an ELF kernel -- required for
43					# netbooting Indigo (IP20) and some
44					# Indigo2 (IP22) machines
45
46#options 	BLINK		# blinkenlitzen
47
48# Standard system options
49#options 	INSECURE	# disable kernel security levels
50
51#options 	NTP		# NTP phase/frequence locked loop
52options 	KTRACE		# system call tracing via ktrace(1)
53
54options 	SYSVMSG		# System V message queues
55options 	SYSVSEM		# System V semaphores
56options 	SYSVSHM		# System V shared memory
57
58options 	USERCONF	# userconf(4) support
59#options 	PIPE_SOCKETPAIR	# smaller, but slower pipe(2)
60options 	SYSCTL_INCLUDE_DESCR	# Include sysctl descriptions in kernel
61
62# Enable experimental buffer queue strategy for better responsiveness under 
63# high disk I/O load. Use it with caution - it's not proven to be stable yet.
64#options 	BUFQ_READPRIO
65#options 	BUFQ_PRIOCSCAN
66
67# Diagnostic/debugging support options
68#options 	DIAGNOSTIC	# expensive kernel consistency checks
69#options 	DEBUG		# expensive debugging checks/support
70options 	DDB		# in-kernel debugger
71options 	DDB_HISTORY_SIZE=512	# enable history editing in DDB
72#options 	KGDB		# remote debugger
73#options 	KGDB_DEV=0x2301		# KGDB port - this is Serial(1)
74#options 	KGDB_DEVRATE=19200	# KGDB Baud Rate
75#makeoptions	DEBUG="-g"	# compile full symbol table
76
77# Compatibility options
78options 	COMPAT_15	# NetBSD 1.5,
79options 	COMPAT_16	# NetBSD 1.6,
80options 	COMPAT_20	# NetBSD 2.0,
81options 	COMPAT_30	# NetBSD 3.0,
82options 	COMPAT_40	# NetBSD 4.0,
83options 	COMPAT_50	# NetBSD 5.0,
84options 	COMPAT_60	# NetBSD 6.0, and
85options 	COMPAT_70	# NetBSD 7.0 binary compatibility.
86
87options 	COMPAT_LINUX	# binary compatibility with Linux
88#options 	COMPAT_ULTRIX	# binary compatibility with Ultrix 
89options 	COMPAT_BSDPTY	# /dev/[pt]ty?? ptys.
90
91# File systems
92file-system 	FFS		# UFS
93file-system 	EXT2FS		# second extended file system (linux)
94file-system 	LFS		# log-structured file system
95file-system 	MFS		# memory file system
96file-system 	NFS		# Network File System client
97file-system 	NTFS		# Windows/NT file system (experimental)
98file-system 	CD9660		# ISO 9660 + Rock Ridge file system
99file-system 	MSDOSFS		# MS-DOS file system
100file-system 	FDESC		# /dev/fd
101file-system 	KERNFS		# /kern
102file-system 	NULLFS		# loopback file system
103file-system 	OVERLAY		# overlay file system
104file-system	PUFFS		# Userspace file systems (e.g. ntfs-3g & sshfs)
105file-system 	PROCFS		# /proc
106file-system 	UMAPFS		# NULLFS + uid and gid remapping
107file-system 	UNION		# union file system
108file-system	CODA		# Coda File System; also needs vcoda (below)
109file-system	PTYFS		# /dev/pts/N support
110file-system	TMPFS		# Efficient memory file-system
111#file-system	UDF		# experimental - OSTA UDF CD/DVD file-system
112file-system	EFS		# Silicon Graphics Extent File System
113
114# File system options
115options 	QUOTA		# legacy UFS quotas
116options 	QUOTA2		# new, in-filesystem UFS quotas
117#options 	FFS_EI		# FFS Endian Independent support
118options 	WAPBL		# File system journaling support
119#options 	UFS_DIRHASH	# UFS Large Directory Hashing - Experimental
120options 	NFSSERVER	# Network File System server
121#options 	FFS_NO_SNAPSHOT	# No FFS snapshot support
122options 	UFS_EXTATTR	# Extended attribute support for UFS1
123#options 	EXT2FS_SYSTEM_FLAGS # makes ext2fs file flags (append and
124				# immutable) behave as system flags.
125
126# Networking options
127#options 	GATEWAY		# packet forwarding
128options 	INET		# IP + ICMP + TCP + UDP
129options 	INET6		# IPV6
130#options 	IPSEC		# IP security
131#options 	IPSEC_DEBUG	# debug for IP security
132#options 	MROUTING	# IP multicast routing
133#options 	PIM		# Protocol Independent Multicast
134options 	NETATALK	# AppleTalk networking protocols
135options 	PPP_BSDCOMP	# BSD-Compress compression support for PPP
136options 	PPP_DEFLATE	# Deflate compression support for PPP
137options 	PPP_FILTER	# Active filter support for PPP (requires bpf)
138options 	IPFILTER_LOG	# ipmon(8) log support
139options 	IPFILTER_LOOKUP	# ippool(8) support
140#options 	IPFILTER_DEFAULT_BLOCK	# block all packets by default
141#options 	TCP_DEBUG	# Record last TCP_NDEBUG packets with SO_DEBUG
142
143#options 	ALTQ		# Manipulate network interfaces' output queues
144#options 	ALTQ_BLUE	# Stochastic Fair Blue
145#options 	ALTQ_CBQ	# Class-Based Queueing
146#options 	ALTQ_CDNR	# Diffserv Traffic Conditioner
147#options 	ALTQ_FIFOQ	# First-In First-Out Queue
148#options 	ALTQ_FLOWVALVE	# RED/flow-valve (red-penalty-box)
149#options 	ALTQ_HFSC	# Hierarchical Fair Service Curve
150#options 	ALTQ_LOCALQ	# Local queueing discipline
151#options 	ALTQ_PRIQ	# Priority Queueing
152#options 	ALTQ_RED	# Random Early Detection
153#options 	ALTQ_RIO	# RED with IN/OUT
154#options 	ALTQ_WFQ	# Weighted Fair Queueing
155
156# JIT compiler for bpfilter
157#options	SLJIT
158#options	BPFJIT
159
160# These options enable verbose messages for several subsystems.
161# Warning, these may compile large string tables into the kernel!
162options 	MIIVERBOSE	# verbose PHY autoconfig messages
163options 	SCSIVERBOSE	# human readable SCSI error messages
164
165options 	NFS_BOOT_DHCP,NFS_BOOT_BOOTPARAM
166
167#options 	MEMORY_DISK_HOOKS
168#options 	MEMORY_DISK_IS_ROOT
169#options 	MEMORY_DISK_SERVER=0
170#options 	MINIROOTSIZE=8192
171
172#options 	SCSI_DELAY=5
173
174#
175# wscons options
176#
177# builtin terminal emulations
178#options 	WSEMUL_SUN		# sun terminal emulation
179options 	WSEMUL_VT100		# VT100 / VT220 emulation
180options 	WSDISPLAY_COMPAT_USL		# wsconscfg VT handling
181# different kernel output - see dev/wscons/wsdisplayvar.h
182options 	WS_KERNEL_FG=WSCOL_GREEN
183#options 	WS_KERNEL_BG=WSCOL_BLACK
184# compatibility to other console drivers
185options 	WSDISPLAY_COMPAT_RAWKBD		# can get raw scancodes
186# see dev/pckbport/wskbdmap_mfii.c for implemented layouts
187#options 	PCKBD_LAYOUT="(KB_DE | KB_NODEAD)"
188
189
190# Kernel root file system and dump configuration.
191config		netbsd	root on ? type ?
192
193# Main bus and CPU
194mainbus0 	at root
195cpu0 		at mainbus?
196
197sd*     at scsibus? target ? lun ?	# SCSI disks
198st*     at scsibus? target ? lun ?	# SCSI tapes
199cd*     at scsibus? target ? lun ?	# SCSI CD-ROMs
200ch*     at scsibus? target ? lun ?	# SCSI changer devices
201ss*     at scsibus? target ? lun ?	# SCSI scanners
202ses*    at scsibus? target ? lun ?	# SCSI SES/SAF-TE devices
203uk*     at scsibus? target ? lun ?	# unknown SCSI
204
205# Personal Iris / Indigo R3k
206pic0		at mainbus0 addr 0x1fa00000
207gio0		at pic0
208
209# Indy / Indigo^2
210imc0 		at mainbus0 addr 0x1fa00000
211gio0 		at imc0
212eisa0 		at imc0
213
214int0		at mainbus0		# Interrupt controller
215
216# Some clocks actually in HPC space, but not all
217dpclock0	at mainbus0 addr 0x1fb80e00	# IP12 / IP20
218dsclock0	at mainbus0 addr 0x1fbe0000	# IP22 / 24
219
220hpc0 		at gio? addr 0x1fb80000
221hpc1 		at gio? addr 0x1fb00000
222hpc2 		at gio? addr 0x1f980000
223
224newport*	at gio?			# Newport (NG1) graphics
225wsdisplay* 	at newport? console ?
226
227grtwo*		at gio?			# Express (GR2) graphics
228wsdisplay*	at grtwo? console ?
229
230light*		at gio?			# Light/Starter/Entry (LG1/LG2) graphics
231wsdisplay*	at light? console ?
232
233# PCI Fast Ethernet cards glued to the GIO bus
234giopci*		at gio? slot?
235pci*		at giopci? bus?
236options 	PCI_NETBSD_CONFIGURE
237
238tlp*		at pci? dev ? function ? # Phobos G100/130/160 Fast Ethernet
239lxtphy*		at mii? phy ?		 # Level One LXT-970 PHYs 
240
241tl*		at pci? dev ? function ? # Set Engineering GIO Fast Ethernet
242nsphy*		at mii? phy ?		 # NS83840 PHYs
243tlphy*		at mii? phy ?		 # ThunderLAN PHY (unused)
244
245# HPC devices
246sq* 		at hpc? offset ?	# On-board ethernet / E++ adapter
247wdsc* 		at hpc? offset ?	# On-board SCSI / GIO32 SCSI adapter
248haltwo*         at hpc0 offset ?	# IP22 / 24
249panel*		at hpc0 offset ?	# front panel buttons on Indy
250pckbc*		at hpc0 offset ?
251
252pckbd*  	at pckbc?
253pms* 		at pckbc?
254wskbd* 		at pckbd? console ?
255wskbd*		at zskbd? console ?
256wsmouse* 	at pms? mux 0
257wsmouse*	at zsms? mux 0
258
259# I/O Controller -- IP22/24
260ioc0		at mainbus0 addr 0x1fbd9800
261
262# IOC's parallel port
263pi1ppc0		at hpc0 offset ? 
264options 	PI1PPC_INDY_ACK_HACK	# Indy hardware bug workaround.
265ppbus*		at pi1ppc?
266lpt*		at ppbus?		# Parallel printer
267
268#
269# As always, the zs chip is wired funny, so channel 1 is actually the
270# first serial port and channel 0 is the second.
271#
272zsc0 		at hpc0 offset ?
273zstty*		at zsc0 channel ?
274
275zsc1 		at hpc0 offset ?	# IP20 keyboard/mouse
276zskbd0		at zsc1 channel 0
277zsms0		at zsc1 channel 1
278
279scsibus*	at scsi?		# HPC SCSI
280audio*  	at audiobus?
281
282spkr*		at audio?		# PC speaker (synthesized)
283
284# Pseudo-Devices
285
286# disk/mass storage pseudo-devices
287pseudo-device	ccd			# concatenated/striped disk devices
288#pseudo-device	cgd			# cryptographic disk devices
289#pseudo-device	raid			# RAIDframe disk driver
290#options 	RAID_AUTOCONFIG		# auto-configuration of RAID components
291pseudo-device	fss			# file system snapshot device
292pseudo-device	md			# memory disk device (ramdisk)
293pseudo-device	vnd			# disk-like interface to files
294#options 	VND_COMPRESSION		# compressed vnd(4)
295
296# network pseudo-devices
297pseudo-device	bpfilter		# Berkeley packet filter
298#pseudo-device	carp			# Common Address Redundancy Protocol
299pseudo-device	ipfilter		# IP filter (firewall) and NAT
300pseudo-device	loop			# network loopback
301pseudo-device	ppp			# Point-to-Point Protocol
302pseudo-device	sl			# Serial Line IP
303pseudo-device	strip			# Starmode Radio IP (Metricom)
304pseudo-device	tun			# network tunneling over tty
305pseudo-device	tap			# virtual Ethernet
306pseudo-device	gre			# generic L3 over IP tunnel
307pseudo-device	gif			# IPv[46] over IPv[46] tunnel (RFC1933)
308#pseudo-device	faith			# IPv[46] tcp relay translation i/f
309pseudo-device	stf			# 6to4 IPv6 over IPv4 encapsulation
310pseudo-device	vlan			# IEEE 802.1q encapsulation
311pseudo-device	bridge			# simple inter-network bridging
312pseudo-device	agr			# IEEE 802.3ad link aggregation
313#options 	BRIDGE_IPF		# bridge uses IP/IPv6 pfil hooks too
314#pseudo-device	pf			# PF packet filter
315#pseudo-device	pflog			# PF log if
316pseudo-device   accf_data		# "dataready" accept filter
317pseudo-device   accf_http		# "httpready" accept filter
318
319# miscellaneous pseudo-devices
320pseudo-device	pty			# pseudo-terminals
321pseudo-device	sequencer		# MIDI sequencer
322pseudo-device	clockctl		# user control of clock subsystem
323pseudo-device	ksyms			# /dev/ksyms
324pseudo-device	wsmux                   # mouse & keyboard multiplexor
325pseudo-device	wsfont
326pseudo-device	putter			# for puffs and pud
327
328# a pseudo device needed for Coda	# also needs CODA (above)
329pseudo-device	vcoda			# coda minicache <-> venus comm.
330
331# Veriexec
332#
333# a pseudo device needed for veriexec
334#pseudo-device	veriexec
335#
336# Uncomment the fingerprint methods below that are desired. Note that
337# removing fingerprint methods will have almost no impact on the kernel
338# code size.
339#
340#options VERIFIED_EXEC_FP_RMD160
341#options VERIFIED_EXEC_FP_SHA256
342#options VERIFIED_EXEC_FP_SHA384
343#options VERIFIED_EXEC_FP_SHA512
344#options VERIFIED_EXEC_FP_SHA1
345#options VERIFIED_EXEC_FP_MD5
346