xref: /freebsd/sys/conf/NOTES (revision 0ea3482342b4d7d6e71f3007ce4dafe445c639fd)
1#
2# LINT -- config file for checking all the sources, tries to pull in
3#	as much of the source tree as it can.
4#
5#	$Id: LINT,v 1.212 1995/11/05 17:02:54 gibbs Exp $
6#
7# NB: You probably don't want to try running a kernel built from this
8# file.  Instead, you should start from GENERIC, and add options from
9# this file as required.
10#
11
12#
13# This directive is mandatory; it defines the architecture to be
14# configured for; in this case, the 386 family.  You must also specify
15# at least one CPU (the one you intend to run on); deleting the
16# specification for CPUs you don't need to use may make parts of the
17# system run faster
18#
19machine		"i386"
20cpu		"I386_CPU"
21cpu		"I486_CPU"
22cpu		"I586_CPU"		# aka Pentium(tm)
23
24#
25# This is the ``identification'' of the kernel.  Usually this should
26# be the same as the name of your kernel.
27#
28ident		LINT
29
30#
31# The `maxusers' parameter controls the static sizing of a number of
32# internal system tables by a complicated formula defined in param.c.
33#
34maxusers	10
35
36#
37# Under some circumstances it is necessary to make the default max
38# number of processes per user and open files per user more than the
39# defaults on bootup.  (an example is a large news server in which
40# the uid, news, can sometimes need > 100 simultaneous processes running,
41# or perhaps a user using lots of windows under X).
42options		"CHILD_MAX=128"
43options		"OPEN_MAX=128"
44
45#
46# A math emulator is mandatory if you wish to run on hardware which
47# does not have a floating-point processor.  Pick either the original,
48# bogus (but freely-distributable) math emulator, or a much more
49# fully-featured but GPL-licensed emulator taken from Linux.
50#
51options		MATH_EMULATE		#Support for x87 emulation
52#options        GPL_MATH_EMULATE        #Support for x87 emualtion via
53                                        #new math emulator
54
55#
56# This directive defines a number of things:
57#  - The compiled kernel is to be called `kernel'
58#  - The root filesystem might be on partition wd0a
59#  - Crash dumps will be written to wd0b, if possible.  Specifying the
60#    dump device here is not recommended.  Use dumpon(8).
61#
62config		kernel	root on wd0 dumps on wd0
63
64
65#####################################################################
66# COMPATIBILITY OPTIONS
67
68#
69# Implement system calls compatible with 4.3BSD and older versions of
70# FreeBSD.
71#
72options		"COMPAT_43"
73
74#
75# Allow user-mode programs to manipulat their local descriptor tables.
76# This option is required for the WINE Windows(tm) emulator, and is
77# not used by anything else (that we know of).
78#
79options		USER_LDT		#allow user-level control of i386 ldt
80
81#
82# These three options provide support for System V Interface
83# Definition-style interprocess communication, in the form of shared
84# memory, semaphores, and message queues, respectively.
85#
86options		SYSVSHM
87options		SYSVSEM
88options		SYSVMSG
89
90
91#####################################################################
92# DEBUGGING OPTIONS
93
94#
95# Enable the kernel debugger.
96#
97options		DDB
98
99#
100# KTRACE enables the system-call tracing facility ktrace(2).
101#
102options		KTRACE			#kernel tracing
103
104#
105# The DIAGNOSTIC option is used in a number of source files to enable
106# extra sanity checking of internal structures.  This support is not
107# enabled by default because of the extra time it would take to check
108# for these conditions, which can only occur as a result of
109# programming errors.
110#
111options		DIAGNOSTIC
112
113#
114# Allow ordinary users to take the console - this is useful for X.
115options		UCONSOLE
116
117
118#####################################################################
119# NETWORKING OPTIONS
120
121#
122# Protocol families:
123#  Only the INET (Internet) family is officially supported in FreeBSD.
124#  Source code for the NS (Xerox Network Service), ISO (OSI), and
125#  CCITT (X.25) families is provided for amusement value, although we
126#  try to ensure that it actually compiles.
127#
128options		INET			#Internet communications protocols
129options		CCITT			#X.25 network layer
130options		NS			#Xerox NS communications protocols
131
132options		IPX			#IPX/SPX communications protocols
133options		IPXIP			#IPX in IP encapsulation (not available)
134options		IPTUNNEL		#IP in IPX encapsulation (not available)
135options		"IPXPRINTFS=0"		#IPX/SPX Console Debugging Information
136options		"IPX_ERRPRINTFS=0"	#IPX/SPX Console Debugging Information
137
138# These are currently broken and don't compile
139#options		ISO
140#options		TPIP			#ISO TP class 4 over IP
141#options		TPCONS			#ISO TP class 0 over X.25
142
143#
144# Network interfaces:
145#  The `loop' pseudo-device is mandatory when networking is enabled.
146#  The `ether' pseudo-device provides generic code to handle
147#  Ethernets; it is mandatory when a Ethernet device driver is
148#  configured.
149#  The 'fddi' pseudo-device provides generic code to support FDDI.
150#  The `sppp' pseudo-device serves a similar role for certain types
151#  of synchronous PPP links (like `cx').
152#  The `sl' pseudo-device implements the Serial Line IP (SLIP) service.
153#  The `ppp' pseudo-device implements the Point-to-Point Protocol.
154#  The `bpfilter' pseudo-device enables the Berkeley Packet Filter.  Be
155#  aware of the legal and administrative consequences of enabling this
156#  option.  The number of devices determines the maximum number of
157#  simultaneous BPF clients programs runnable.
158#  The `disc' pseudo-device implements a minimal network interface,
159#  which throws away all packets sent and never receives any.  It is
160#  included for testing purposes.
161#  The `tun' pseudo-device implements the User Process PPP (iijppp)
162#
163pseudo-device	ether			#Generic Ethernet
164pseudo-device	fddi			#Generic FDDI
165pseudo-device	sppp			#Generic Synchronous PPP
166pseudo-device	loop			#Network loopback device
167pseudo-device	sl	2		#Serial Line IP
168pseudo-device	ppp	2		#Point-to-point protocol
169pseudo-device	bpfilter	4	#Berkeley packet filter
170pseudo-device	disc			#Discard device
171pseudo-device	tun	1		#Tunnel driver(user process ppp)
172
173options		NSIP			#XNS over IP
174options		LLC			#X.25 link layer for Ethernets
175options		HDLC			#X.25 link layer for serial lines
176
177# broken
178#options		EON			#ISO CLNP over IP
179
180#
181# Internet family options:
182#
183# TCP_COMPAT_42 causes the TCP code to emulate certain bugs present in
184# 4.2BSD.  This option should not be used unless you have a 4.2BSD
185# machine and TCP connections fail.
186#
187# GATEWAY allows the machine to forward packets, and also configures
188# larger static sizes of a number of system tables.
189#
190# MROUTING enables the kernel multicast packet forwarder, which works
191# with mrouted(8).
192#
193# IPFIREWALL enables support for IP firewall construction, in
194# conjunction with the `ipfw' program.  IPFIREWALL_VERBOSE does
195# the obvious thing.
196# IPACCT enables IP accounting.
197#
198# ARP_PROXYALL enables global proxy ARP.  Beware!  This can burn
199# your house down!  See netinet/if_ether.c for the gory details.
200# (Eventually there will be a better management interface.)
201#
202# TCPDEBUG is undocumented.
203#
204options		"TCP_COMPAT_42"		#emulate 4.2BSD TCP bugs
205options		GATEWAY			#internetwork gateway
206options		MROUTING		# Multicast routing
207options         IPFIREWALL              #firewall
208options         IPFIREWALL_VERBOSE      #print information about
209options		IPACCT			#ipaccounting
210					# dropped packets
211options		ARP_PROXYALL		# global proxy ARP
212options		TCPDEBUG
213
214
215#####################################################################
216# FILESYSTEM OPTIONS
217
218#
219# Only the root, /usr, and /tmp filesystems need be statically
220# compiled; everything else will be automatically loaded at mount
221# time.  (Exception: the UFS family---FFS, MFS, and LFS---cannot
222# currently be demand-loaded.)  Some people still prefer to statically
223# compile other filesystems as well.
224#
225# NB: The LFS, PORTAL, and UNION filesystems are known to be buggy,
226# and WILL panic your system if you attempt to do anything with them.
227# They are included here as an incentive for some enterprising soul to
228# sit down and fix them.
229#
230# Note: 4.4BSD NQNFS lease checking has relatively high cost for
231# _local_ I/O as well as remote I/O. Don't use it unless you will
232# using NQNFS.
233#
234
235# One of these is mandatory:
236options		FFS			#Fast filesystem
237options		NFS			#Network File System
238
239# The rest are optional:
240options		NQNFS			#Enable NQNFS lease checking
241options		"CD9660"		#ISO 9660 filesystem
242options		FDESC			#File descriptor filesystem
243options		KERNFS			#Kernel filesystem
244options		LFS			#Log filesystem
245options		MFS			#Memory File System
246options		MSDOSFS			#MS DOS File System
247options		NULLFS			#NULL filesystem
248options		PORTAL			#Portal filesystem
249options		PROCFS			#Process filesystem
250options		UMAPFS			#UID map filesystem
251options		UNION			#Union filesystem
252
253# Make space in the kernel for a MFS rootfilesystem.  Define to the number
254# of kilobytes to reserve for the filesystem.
255options		"MFS_ROOT=10"
256
257# Allow this many swap-devices.
258options		"NSWAPDEV=20"
259
260# Disk quotas are supported when this option is enabled.  If you
261# change the value of this option, you must do a `make clean' in your
262# kernel compile directory in order to get a working kernel.
263#
264options		QUOTA			#enable disk quotas
265
266
267#####################################################################
268# SCSI DEVICES
269
270# SCSI DEVICE CONFIGURATION
271
272# The SCSI subsystem consists of the `base' SCSI code, a number of
273# high-level SCSI device `type' drivers, and the low-level host-adapter
274# device drivers.  The host adapters are listed in the ISA and PCI
275# device configuration sections below.
276#
277# Beginning with FreeBSD 2.0.5 you can wire down your SCSI devices so
278# that a given bus, target, and LUN always come on line as the same
279# device unit.  In earlier versions the unit numbers were assigned
280# in the order that the devices were probed on the SCSI bus.  This
281# means that if you removed a disk drive, you may have had to rewrite
282# your /etc/fstab file, and also that you had to be careful when adding
283# a new disk as it may have been probed earlier and moved your device
284# configuration around.
285
286# This old behavior is maintained as the default behavior.  The unit
287# assignment begins with the first non-wired down unit for a device
288# type.  For example, if you wire a disk as "sd3" then the first
289# non-wired disk will be assigned sd4.
290
291# The syntax for wiring down devices is:
292
293# controller	scbus0 at ahc0		# Single bus device
294# controller	scbus1 at ahc1 bus 0	# Single bus device
295# controller	scbus3 at ahc2 bus 0	# Twin bus device
296# controller	scbus2 at ahc2 bus 1	# Twin bus device
297# disk 		sd0 at scbus0 target 0 unit 0
298# disk		sd1 at scbus3 target 1
299# disk		sd2 at scbus2 target 3
300# tape		st1 at scbus1 target 6
301# device	cd0 at scbus?
302
303# "units" (SCSI logical unit number) that are not specified are
304# treated as if specified as LUN 0.
305
306# All SCSI devices allocate as many units as are required.
307
308# The "unknown" device (uk? in pre-2.0.5) is now part of the base SCSI
309# configuration and doesn't have to be explicitly configured.
310
311controller	scbus0	#base SCSI code
312device		ch0	#SCSI media changers
313device		sd0	#SCSI disks
314device		st0	#SCSI tapes
315device		cd0	#SCSI CD-ROMs
316device		od0	#SCSI optical disk
317
318# The previous devices (ch, sd, st, cd) are recognized by config.
319# config doesn't (and shouldn't) know about these newer ones,
320# so we have to specify that they are on a SCSI bus with the "at scbus?"
321# clause.
322
323device worm0 at scbus?	# SCSI worm
324device pt0 at scbus?	# SCSI processor type
325device sctarg0 at scbus? # SCSI target
326
327# SCSI OPTIONS:
328
329# SCSIDEBUG: When defined enables debugging macros
330# NO_SCSI_SENSE: When defined disables sense descriptions (about 4k)
331# SCSI_REPORT_GEOMETRY: Always report disk geometry at boot up instead
332#                       of only when booting verbosely.
333options		SCSIDEBUG
334#options	NO_SCSI_SENSE
335options		SCSI_REPORT_GEOMETRY
336
337
338#####################################################################
339# MISCELLANEOUS DEVICES AND OPTIONS
340
341#
342# Of these, only the `log' device is truly mandatory.  The `pty'
343# device usually turns out to be ``effectively mandatory'', as it is
344# required for `telnetd', `rlogind', `screen', `emacs', and `xterm',
345# among others.  The `isdn', `ii', `ity', `itel', and `ispy' devices
346# are all required when ISDN support is used.
347#
348pseudo-device	pty	16	#Pseudo ttys - can go as high as 64
349pseudo-device	speaker		#Play IBM BASIC-style noises out your speaker
350pseudo-device	log		#Kernel syslog interface (/dev/klog)
351pseudo-device	gzip		#Exec gzipped a.out's
352pseudo-device	vn		#Vnode driver (turns a file into a device)
353pseudo-device	snp	3	#Snoop device - to look at pty/vty/etc..
354
355# These are non-optional for ISDN
356pseudo-device   isdn
357pseudo-device   ii      4
358pseudo-device   ity     4
359pseudo-device   itel    2
360pseudo-device   ispy    1
361
362# These are only for watching for bitrot in old tty code.
363# broken
364#pseudo-device	tb
365
366# These are only for watching for bitrot in old SCSI code.
367pseudo-device	su		#scsi user
368pseudo-device	ssc		#super scsi
369
370
371#####################################################################
372# HARDWARE DEVICE CONFIGURATION
373
374# ISA and EISA devices:
375# Currently there is no separate support for EISA.  There should be.
376# Micro Channel is not supported at all.
377
378#
379# Mandatory ISA devices: isa, sc or vt, npx
380#
381controller	isa0
382
383#
384# Options for `isa':
385#
386# AUTO_EOI_1 enables the `automatic EOI' feature for the master 8259A
387# interrupt controller.  This saves about 1.25 usec for each interrupt.
388# No problems are known to be caused by this option.
389#
390# AUTO_EOI_2 enables the `automatic EOI' feature for the slave 8259A
391# interrupt controller.  This saves about 1.25 usec for each interrupt.
392# Automatic EOI is documented not to work for for the slave with the
393# original i8259A, but it works for some clones and some integrated
394# versions.
395#
396# BOUNCE_BUFFERS provides support for ISA DMA on machines with more
397# than 16 megabytes of memory.  It doesn't hurt on other machines.
398# Some broken EISA and VLB hardware may need this, too.
399#
400# DUMMY_NOPS disables extra delays for some bus operations.  The delays
401# are mostly for older systems and aren't used consistently.  Probably
402# works OK on most EISA bus machines.
403#
404# TUNE_1542 enables the automatic ISA bus speed selection for the
405# Adaptec 1542 boards. Does not work for all boards, use it with caution.
406#
407# BROKEN_KEYBOARD_RESET disables the use of the keyboard controller to
408# reset the CPU for reboot.  This is needed on some systems with broken
409# keyboard controllers.
410options		"AUTO_EOI_1"
411#options	"AUTO_EOI_2"
412options		BOUNCE_BUFFERS
413#options	DUMMY_NOPS
414#options        "TUNE_1542"
415#options	"BROKEN_KEYBOARD_RESET"
416
417# Enable this and PCVT_FREEBSD for pcvt vt220 compatible console driver
418device		vt0	at isa? port "IO_KBD" tty irq 1 vector pcrint
419options		"PCVT_FREEBSD=210"	# pcvt running on FreeBSD 2.0.5
420options		XSERVER			# include code for XFree86
421options		FAT_CURSOR		# start with block cursor
422
423# The syscons console driver (sco color console compatible) - default.
424device		sc0	at isa? port "IO_KBD" tty irq 1 vector scintr
425
426#
427# Options for `sc':
428#
429# HARDFONTS allows the driver to load an ISO-8859-1 font to replace
430# the default font in your display adapter's memory.
431#
432options		HARDFONTS
433#
434# MAXCONS is maximum number of virtual consoles, no more than 16
435# default value: 12
436#
437options         "MAXCONS=16"
438
439device		npx0	at isa? port "IO_NPX" irq 13 vector npxintr
440
441#
442# Optional ISA and EISA devices:
443#
444
445#
446# SCSI host adapters: `aha', `aic', `bt', `nca'
447#
448# aha: Adaptec 154x
449# ahc: Adaptec 274x/284x/294x
450# aic: Adaptec 152x and sound cards using the Adaptec AIC-6360 (slow!)
451# bt: Most Buslogic controllers
452# nca: ProAudioSpectrum cards using the NCR 5380 or Trantor T130
453# uha: UltraStore 14F and 34F
454# sea: Seagate ST01/02 8 bit controller (slow!)
455# wds: Western Digital WD7000 controller (no scatter/gather!).
456#
457# Note that the order is important in order for Buslogic cards to be
458# probed correctly.
459#
460
461controller	bt0	at isa? port "IO_BT0" bio irq ? vector btintr
462controller	aha0	at isa? port "IO_AHA0" bio irq ? drq 5 vector ahaintr
463controller	uha0	at isa? port "IO_UHA0" bio irq ? drq 5 vector uhaintr
464
465controller      aic0    at isa? port 0x340 bio irq 11 vector aicintr
466controller	nca0	at isa? port 0x1f88 bio irq 10 vector ncaintr
467controller	nca1	at isa? port 0x1f84
468controller	nca2	at isa? port 0x1f8c
469controller	nca3	at isa? port 0x1e88
470controller	nca4	at isa? port 0x350 bio irq 5 vector ncaintr
471
472controller	sea0	at isa? bio irq 5 iomem 0xdc000 iosiz 0x2000 vector seaintr
473controller	wds0	at isa? port 0x350 bio irq 15 drq 6 vector wdsintr
474
475#
476# ST-506, ESDI, and IDE hard disks: `wdc' and `wd'
477#
478# NB: ``Enhanced IDE'' is NOT supported at this time.
479#
480# The flags fields are used to enable the multi-sector I/O and
481# the 32BIT I/O modes.  The flags may be used in either the controller
482# definition or in the individual disk definitions.  The controller
483# definition is supported for the boot configuration stuff.
484#
485# Each drive has a 16 bit flags value defined:
486#	The low 8 bits are the maximum value for the multi-sector I/O,
487#	where 0xff defaults to the maximum that the drive can handle.
488#	The high bit of the 16 bit flags (0x8000) allows probing for
489#	32 bit transfers.
490#
491# The flags field for the drives can be specified in the controller
492# specification with the low 16 bits for drive 0, and the high 16 bits
493# for drive 1.
494# e.g.:
495#controller	wdc0	at isa? port "IO_WD1" bio irq 14 flags 0x00ff8004 vector wdintr
496#
497# specifies that drive 0 will be allowed to probe for 32 bit transfers and
498# a maximum multi-sector transfer of 4 sectors, and drive 1 will not be
499# allowed to probe for 32 bit transfers, but will allow multi-sector
500# transfers up to the maximum that the drive supports.
501#
502
503#
504controller	wdc0	at isa? port "IO_WD1" bio irq 14 vector wdintr
505disk		wd0	at wdc0 drive 0
506disk		wd1	at wdc0 drive 1
507controller	wdc1	at isa? port "IO_WD2" bio irq 15 vector wdintr
508disk		wd2	at wdc1 drive 0
509disk		wd3	at wdc1 drive 1
510
511#
512# Options for `wdc':
513#
514# ATAPI enables the support for ATAPI-compatible IDE devices
515#
516options         ATAPI   #Enable ATAPI support for IDE bus
517
518# IDE CD-ROM driver - requires wdc controller and ATAPI option
519device          wcd0
520
521#
522# Standard floppy disk controllers and floppy tapes: `fdc', `fd', and `ft'
523#
524controller	fdc0	at isa? port "IO_FD1" bio irq 6 drq 2 vector fdintr
525#
526# Activate this line instead of the fdc0 line above if you happen to
527# have an Insight floppy tape.  Probing them proved to be dangerous
528# for people with floppy disks only, so it's "hidden" behind a flag:
529#controller fdc0 at isa? port "IO_FD1" bio flags 1 irq 6 drq 2 vector fdintr
530
531disk		fd0	at fdc0 drive 0
532disk		fd1	at fdc0 drive 1
533tape		ft0	at fdc0 drive 2
534
535
536#
537# Options for `fd':
538#
539# FDSEEKWAIT selects a non-default head-settle time (i.e., the time to
540# wait after a seek is performed).  The default value (1/32 s) is
541# usually sufficient.  The units are inverse seconds, so a value of 16
542# here means to wait 1/16th of a second; you should choose a power of
543# two.
544#
545options	FDSEEKWAIT="16"
546
547#
548# Other standard PC hardware: `lpt', `mse', `psm', `sio', etc.
549#
550# lpt: printer port
551#	lpt specials:
552#		port can be specified as ?, this will cause the driver to scan
553#		the BIOS port list;
554#		the irq and vector clauses may be omitted, this
555#		will force the port into polling mode.
556# mse: Logitech and ATI InPort bus mouse ports
557# psm: PS/2 mouse port [note: conflicts with sc0/vt0, thus "conflicts" keywd]
558# sio: serial ports (see sio(4))
559
560device		lpt0	at isa? port? tty irq 7 vector lptintr
561device		lpt1	at isa? port "IO_LPT3" tty irq 5 vector lptintr
562device		mse0	at isa? port 0x23c tty irq 5 vector mseintr
563device		psm0	at isa? port "IO_KBD" conflicts tty irq 12 vector psmintr
564# Options for psm:
565options		PSM_NO_RESET		#don't reset mouse hardware (some laptops)
566
567device		sio0	at isa? port "IO_COM1" tty irq 4 vector siointr
568
569# Options for sio:
570options		COMCONSOLE		#prefer serial console to video console
571options		COM_MULTIPORT		#code for some cards with shared IRQs
572options		DSI_SOFT_MODEM		#code for DSI Softmodems
573options		BREAK_TO_DEBUGGER	#a BREAK on a comconsole goes to
574					#DDB, if available.
575
576#
577# Network interfaces: `cx', `ed', `el', `ep', `ie', `is', `le', `lnc'
578#
579# cx: Cronyx/Sigma multiport sync/async (with Cisco or PPP framing)
580# ed: Western Digital and SMC 80xx; Novell NE1000 and NE2000; 3Com 3C503
581# el: 3Com 3C501 (slow!)
582# ep: 3Com 3C509 (buggy)
583# fe: Fujitsu MB86960A/MB86965A Ethernet
584# fea: DEC DEFEA EISA FDDI adapter
585# ie: AT&T StarLAN 10 and EN100; 3Com 3C507; unknown NI5210
586# le: Digital Equipment EtherWorks 2 and EtherWorks 3 (DEPCA, DE100,
587#     DE101, DE200, DE201, DE202, DE203, DE204, DE205, DE422)
588# lnc: Lance/PCnet cards (Isolan, Novell NE2100, NE32-VL)
589# ze: IBM/National Semiconductor PCMCIA ethernet controller.
590# zp: 3Com PCMCIA Etherlink III (It does not require shared memory for
591#     send/receive operation, but it needs 'iomem' to read/write the
592#     attribute memory)
593#
594
595device cx0 at isa? port 0x240 net irq 15 drq 7 vector cxintr
596device ed0 at isa? port 0x280 net irq 5 iomem 0xd8000 vector edintr
597device eg0 at isa? port 0x310 net irq 5 vector egintr
598device el0 at isa? port 0x300 net irq 9 vector elintr
599device ep0 at isa? port 0x300 net irq 10 vector epintr
600device fe0 at isa? port 0x240 net irq ? vector feintr
601device fea0 at isa? net irq ? vector feaintr
602device ie0 at isa? port 0x360 net irq 7 iomem 0xd0000 vector ieintr
603device ix0 at isa? port 0x300 net irq 10 iomem 0xd0000 iosiz 32768 vector ixintr
604device le0 at isa? port 0x300 net irq 5 iomem 0xd0000 vector le_intr
605device lnc0 at isa? port 0x300 net irq 10 drq 0 vector lncintr
606device ze0 at isa? port 0x300 net irq 5 iomem 0xd8000 vector zeintr
607device zp0 at isa? port 0x300 net irq 10 iomem 0xd8000 vector zpintr
608
609
610#
611# ISDN drivers - `isdn'.
612#
613# Uncomment one (and only one) of the following two drivers for the appropriate
614# ISDN device you have.  For more information on what's considered appropriate
615# for your given set of circumstances, please read
616# /usr/src/gnu/usr.sbin/isdn/docs/INSTALL.  It's a bit sparse at present, but
617# it's the best we have right now.  The snic driver is also disabled at present,
618# waiting for someone to upgrade the driver to 2.0 (it's in /sys/gnu/scsi/).
619#
620device nic0 at isa? port "IO_COM3" iomem 0xe0000 tty irq 9 vector nicintr
621device nnic0 at isa? port 0x150 iomem 0xe0000 tty irq 12 vector nnicintr
622
623#
624# Audio drivers: `snd', `sb', `pas', `gus', `pca'
625#
626# snd: Voxware sound support code
627# sb: SoundBlaster PCM - SoundBlaster, SB Pro, SB16, ProAudioSpectrum
628# sbxvi: SoundBlaster 16
629# sbmidi: SoundBlaster 16 MIDI interface
630# pas: ProAudioSpectrum PCM and MIDI
631# gus: Gravis Ultrasound - Ultrasound, Ultrasound 16, Ultrasound MAX
632# gusxvi: Gravis Ultrasound 16-bit PCM	(do not use)
633# mss: Microsoft Sound System
634# opl: Yamaha OPL-2 and OPL-3 FM - SB, SB Pro, SB 16, ProAudioSpectrum
635# uart: stand-alone 6850 UART for MIDI
636# mpu: Roland MPU-401 stand-alone card
637#
638# Beware!  The addresses specified below are also hard-coded in
639# i386/isa/sound/sound_config.h.  If you change the values here, you
640# must also change the values in the include file.
641#
642# pca: PCM audio through your PC speaker
643#
644# If you don't have a lpt0 device at IRQ 7, you can remove the
645# ``conflicts'' specification in the appropriate device entries below.
646#
647# If you have a GUS-MAX card and want to use the CS4231 codec on the
648# card the drqs for the gus max must be 8 bit (1, 2, or 3).
649#
650# If you would like to use the full duplex option on the gus, then define
651# flags to be the ``read dma channel''.
652#
653# options BROKEN_BUS_CLOCK	#PAS-16 isn't working and OPTI chipset
654# options SYMPHONY_PAS		#PAS-16 isn't working and SYMPHONY chipset
655# options EXCLUDE_SBPRO		#PAS-16
656# options "SBC_IRQ=5"		#PAS-16. Must match irq on sb0 line.
657# PAS16: The order of the pas0/sb0/opl0 is important since the
658#	sb emulation is enabled in the pas-16 attach.
659#
660# The i386/isa/sound/sound.doc has more information.
661
662# Controls all sound devices
663controller	snd0
664device pas0     at isa? port 0x388 irq 10 drq 6 vector pasintr
665device sb0      at isa? port 0x220 irq 7 conflicts drq 1 vector sbintr
666device sbxvi0   at isa? drq 5
667device sbmidi0  at isa? port 0x330
668device gus0 at isa? port 0x220 irq 12 drq 1 vector gusintr
669#device gus0 at isa? port 0x220 irq 12 drq 1 flags 0x3 vector gusintr
670device mss0 at isa? port 0x530 irq 10 drq 1 vector adintr
671device opl0     at isa? port 0x388 conflicts
672device mpu0     at isa? port 0x330 irq 6 drq 0
673device uart0 at isa? port 0x330 irq 5 vector "m6850intr"
674
675# More undocumented sound devices with bogus configurations for linting.
676# broken
677#device sscape0  at isa? port 0x330 irq 6 drq 0
678#device trix0    at isa? port 0x330 irq 6 drq 0 vector sscapeintr
679
680# Not controlled by `snd'
681device pca0 at isa? port IO_TIMER1 tty
682
683#
684# Miscellaneous hardware:
685#
686# mcd: Mitsumi CD-ROM
687# scd: Sony CD-ROM
688# matcd: Matsushita/Panasonic CD-ROM
689# wt: Wangtek and Archive QIC-02/QIC-36 tape drives
690# ctx: Cortex-I frame grabber
691# apm: Laptop Advanced Power Management (experimental)
692# spigot: The Creative Labs Video Spigot video-aquisition board
693# meteor: Matrox Meteor video capture board
694# cy: Cyclades serial driver
695# dgb: Digiboard PC/Xi and PC/Xe series driver (ALPHA QUALITY!)
696# gp:  National Instruments AT-GPIB and AT-GPIB/TNT board
697# asc: GI1904-based hand scanners, e.g. the Trust Amiscan Grey
698# gsc: Genius GS-4500 hand scanner.
699# joy: joystick
700# labpc: National Instrument's Lab-PC and Lab-PC+
701# rc: RISCom/8 multiport card
702# tw: TW-523 power line interface for use with X-10 home control products
703# si: Specialix SI/XIO 4-32 port terminal multiplexor
704
705#
706# Notes on the spigot:
707#  The video spigot is at 0xad6.  This port address can not be changed.
708#  The irq values may only be 10, 11, or 15
709#  I/O memory is an 8kb region.  Possible values are:
710#    0a0000, 0a2000, ..., 0fffff, f00000, f02000, ..., ffffff
711#  Note that the start address must be on an even boundary.
712
713# Notes on the Digiboard driver:
714#
715# The following flag values have special meanings:
716#	0x01 - alternate layout of pins
717#	0x02 - use the windowed PC/Xe in 64K mode
718
719# Notes on the Specialix SI/XIO driver:
720#  **This is NOT a Specialix supported Driver!**
721#  The host card is memory, not IO mapped.
722#  The Rev 1 host cards use a 64K chunk, on a 32K boundary.
723#  The Rev 2 host cards use a 32K chunk, on a 32K boundary.
724#  The cards can use an IRQ of 11, 12 or 15.
725
726device		mcd0	at isa? port 0x300 bio irq 10 vector mcdintr
727# for the Sony CDU31/33A CDROM
728device		scd0	at isa? port 0x230 bio
729# for the soundblaster 16 multicd - up to 4 devices
730controller      matcd0  at isa? port 0x230 bio
731device		wt0	at isa? port 0x300 bio irq 5 drq 1 vector wtintr
732device		ctx0	at isa? port 0x230 iomem 0xd0000
733device		spigot0 at isa? port 0xad6 irq 15 iomem 0xee000 vector spigintr
734device		apm0	at isa?
735device		gp0	at isa? port 0x2c0 tty
736device		gsc0	at isa? port "IO_GSC1" tty drq 3
737device		joy0	at isa? port "IO_GAME"
738device		cy0	at isa? tty irq 10 iomem 0xd4000 iosiz 0x2000 vector cyintr
739device		dgb0	at isa? port 0x220 iomem 0xfc0000 iosiz ? tty
740device		labpc0	at isa? port 0x260 tty irq 5 vector labpcintr
741device          rc0     at isa? port 0x220 tty irq 12 vector rcintr
742# the port and irq for tw0 are fictitious
743device          tw0     at isa? port 0x380 tty irq 11 vector twintr
744device		si0	at isa? iomem 0xd0000 tty irq 12 vector siintr
745device		asc0	at isa? port IO_ASC1 tty drq 3 irq 10 vector ascintr
746device		bqu0	at isa? port 0x150
747
748#
749# EISA devices:
750#
751# The EISA bus device is eisa0.  It provides auto-detection and
752# configuration support for all devices on the EISA bus.
753#
754# The `ahb' device provides support for the Adaptec 174X adapter.
755#
756# The `ahc' device provides support for the Adaptec 274X and 284X
757# adapters.  The 284X, although a VLB card responds to EISA probes.
758#
759controller	eisa0
760controller	ahb0
761controller	ahc0
762
763#
764# PCI devices:
765#
766# The main PCI bus device is `pci'.  It provides auto-detection and
767# configuration support for all devices on the PCI bus, using either
768# configuration mode defined in the PCI specification.
769#
770# The `ahc' device provides support for the Adaptec 29/3940(U)(W)
771# and motherboard based AIC7870/AIC7880 adapters.
772#
773# The `ncr' device provides support for the NCR 53C810 and 53C825
774# self-contained SCSI host adapters.
775#
776# The `de' device provides support for the Digital Equipment DC21040
777# self-contained Ethernet adapter.
778#
779# The `vx' device provides support for the 3Com 3C590
780# early support
781#
782# The `fpa' device provides support for the Digital DEFPA PCI FDDI
783# adapter. pseudo-device fddi is also needed.
784#
785# The PROBE_VERBOSE option enables a long listing of chip set registers
786# for supported PCI chip sets (currently only intel Saturn and Mercury).
787#
788# The 'meteor' device is a PCI video capture board. It can also have the
789# following options:
790#   options "METEOR_ALLOC_PAGES=xxx"	preallocate kernel pages for data entry
791#	figure (ROWS*COLUMN*BYTES_PER_PIXEL*FRAME+PAGE_SIZE-1)/PAGE_SIZE
792#   options METEOR_DEALLOC_PAGES	remove all allocated pages on close(2)
793#   options "METEOR_DEALLOC_ABOVE=xxx"	remove all allocated pages above the
794#	specified amount. If this value is below the allocated amount no action
795#	taken
796#
797controller	pci0
798controller	ahc1
799device		ncr0
800device		de0
801device		vx0 at pci0 port? irq? vector vxintr
802device		fpa0
803device		meteor0
804options		PROBE_VERBOSE
805
806
807#
808# PCCARD/PCMCIA
809#
810controller	crd0
811controller	pcic0 at crd?
812
813#
814# Laptop/Notebook options:
815#
816# See also:
817#  apm under `Miscellaneous hardare'
818#  options		PSM_NO_RESET  for the `psm' driver
819# above.
820
821# For older notebooks that signal a powerfail condition (external
822# power supply dropped, or battery state low) by issuing an NMI:
823
824options		POWERFAIL_NMI	# make it beep instead of panicing
825
826# More undocumented options for linting.
827options		COMPAT_LINUX
828options		"IBCS2"
829