Deleted Added
full compact
NOTES (232250) NOTES (232337)
1# $FreeBSD: head/sys/conf/NOTES 232250 2012-02-28 13:19:34Z gavin $
1# $FreeBSD: head/sys/conf/NOTES 232337 2012-03-01 13:10:18Z mav $
2#
3# NOTES -- Lines that can be cut/pasted into kernel and hints configs.
4#
5# Lines that begin with 'device', 'options', 'machine', 'ident', 'maxusers',
6# 'makeoptions', 'hints', etc. go into the kernel configuration that you
7# run config(8) with.
8#
9# Lines that begin with 'hint.' are NOT for config(8), they go into your
10# hints file. See /boot/device.hints and/or the 'hints' config(8) directive.
11#
12# Please use ``make LINT'' to create an old-style LINT file if you want to
13# do kernel test-builds.
14#
15# This file contains machine independent kernel configuration notes. For
16# machine dependent notes, look in /sys/<arch>/conf/NOTES.
17#
18
19#
20# NOTES conventions and style guide:
21#
22# Large block comments should begin and end with a line containing only a
23# comment character.
24#
25# To describe a particular object, a block comment (if it exists) should
26# come first. Next should come device, options, and hints lines in that
27# order. All device and option lines must be described by a comment that
28# doesn't just expand the device or option name. Use only a concise
29# comment on the same line if possible. Very detailed descriptions of
30# devices and subsystems belong in man pages.
31#
32# A space followed by a tab separates 'options' from an option name. Two
33# spaces followed by a tab separate 'device' from a device name. Comments
34# after an option or device should use one space after the comment character.
35# To comment out a negative option that disables code and thus should not be
36# enabled for LINT builds, precede 'options' with "#!".
37#
38
39#
40# This is the ``identification'' of the kernel. Usually this should
41# be the same as the name of your kernel.
42#
43ident LINT
44
45#
46# The `maxusers' parameter controls the static sizing of a number of
47# internal system tables by a formula defined in subr_param.c.
48# Omitting this parameter or setting it to 0 will cause the system to
49# auto-size based on physical memory.
50#
51maxusers 10
52
53# To statically compile in device wiring instead of /boot/device.hints
54#hints "LINT.hints" # Default places to look for devices.
55
56# Use the following to compile in values accessible to the kernel
57# through getenv() (or kenv(1) in userland). The format of the file
58# is 'variable=value', see kenv(1)
59#
60#env "LINT.env"
61
62#
63# The `makeoptions' parameter allows variables to be passed to the
64# generated Makefile in the build area.
65#
66# CONF_CFLAGS gives some extra compiler flags that are added to ${CFLAGS}
67# after most other flags. Here we use it to inhibit use of non-optimal
68# gcc built-in functions (e.g., memcmp).
69#
70# DEBUG happens to be magic.
71# The following is equivalent to 'config -g KERNELNAME' and creates
72# 'kernel.debug' compiled with -g debugging as well as a normal
73# 'kernel'. Use 'make install.debug' to install the debug kernel
74# but that isn't normally necessary as the debug symbols are not loaded
75# by the kernel and are not useful there anyway.
76#
77# KERNEL can be overridden so that you can change the default name of your
78# kernel.
79#
80# MODULES_OVERRIDE can be used to limit modules built to a specific list.
81#
82makeoptions CONF_CFLAGS=-fno-builtin #Don't allow use of memcmp, etc.
83#makeoptions DEBUG=-g #Build kernel with gdb(1) debug symbols
84#makeoptions KERNEL=foo #Build kernel "foo" and install "/foo"
85# Only build ext2fs module plus those parts of the sound system I need.
86#makeoptions MODULES_OVERRIDE="ext2fs sound/sound sound/driver/maestro3"
87makeoptions DESTDIR=/tmp
88
89#
90# FreeBSD processes are subject to certain limits to their consumption
91# of system resources. See getrlimit(2) for more details. Each
92# resource limit has two values, a "soft" limit and a "hard" limit.
93# The soft limits can be modified during normal system operation, but
94# the hard limits are set at boot time. Their default values are
95# in sys/<arch>/include/vmparam.h. There are two ways to change them:
96#
97# 1. Set the values at kernel build time. The options below are one
98# way to allow that limit to grow to 1GB. They can be increased
99# further by changing the parameters:
100#
101# 2. In /boot/loader.conf, set the tunables kern.maxswzone,
102# kern.maxbcache, kern.maxtsiz, kern.dfldsiz, kern.maxdsiz,
103# kern.dflssiz, kern.maxssiz and kern.sgrowsiz.
104#
105# The options in /boot/loader.conf override anything in the kernel
106# configuration file. See the function init_param1 in
107# sys/kern/subr_param.c for more details.
108#
109
110options MAXDSIZ=(1024UL*1024*1024)
111options MAXSSIZ=(128UL*1024*1024)
112options DFLDSIZ=(1024UL*1024*1024)
113
114#
115# BLKDEV_IOSIZE sets the default block size used in user block
116# device I/O. Note that this value will be overridden by the label
117# when specifying a block device from a label with a non-0
118# partition blocksize. The default is PAGE_SIZE.
119#
120options BLKDEV_IOSIZE=8192
121
122#
123# MAXPHYS and DFLTPHYS
124#
125# These are the maximal and safe 'raw' I/O block device access sizes.
126# Reads and writes will be split into MAXPHYS chunks for known good
127# devices and DFLTPHYS for the rest. Some applications have better
128# performance with larger raw I/O access sizes. Note that certain VM
129# parameters are derived from these values and making them too large
130# can make an an unbootable kernel.
131#
132# The defaults are 64K and 128K respectively.
133options DFLTPHYS=(64*1024)
134options MAXPHYS=(128*1024)
135
136
137# This allows you to actually store this configuration file into
138# the kernel binary itself. See config(8) for more details.
139#
140options INCLUDE_CONFIG_FILE # Include this file in kernel
141
142options GEOM_AES # Don't use, use GEOM_BDE
143options GEOM_BDE # Disk encryption.
144options GEOM_BSD # BSD disklabels
145options GEOM_CACHE # Disk cache.
146options GEOM_CONCAT # Disk concatenation.
147options GEOM_ELI # Disk encryption.
148options GEOM_FOX # Redundant path mitigation
149options GEOM_GATE # Userland services.
150options GEOM_JOURNAL # Journaling.
151options GEOM_LABEL # Providers labelization.
152options GEOM_LINUX_LVM # Linux LVM2 volumes
153options GEOM_MBR # DOS/MBR partitioning
154options GEOM_MIRROR # Disk mirroring.
155options GEOM_MULTIPATH # Disk multipath
156options GEOM_NOP # Test class.
157options GEOM_PART_APM # Apple partitioning
158options GEOM_PART_BSD # BSD disklabel
159options GEOM_PART_EBR # Extended Boot Records
160options GEOM_PART_EBR_COMPAT # Backward compatible partition names
161options GEOM_PART_GPT # GPT partitioning
162options GEOM_PART_MBR # MBR partitioning
163options GEOM_PART_PC98 # PC-9800 disk partitioning
164options GEOM_PART_VTOC8 # SMI VTOC8 disk label
165options GEOM_PC98 # NEC PC9800 partitioning
166options GEOM_RAID # Soft RAID functionality.
167options GEOM_RAID3 # RAID3 functionality.
168options GEOM_SHSEC # Shared secret.
169options GEOM_STRIPE # Disk striping.
170options GEOM_SUNLABEL # Sun/Solaris partitioning
171options GEOM_UZIP # Read-only compressed disks
172options GEOM_VIRSTOR # Virtual storage.
173options GEOM_VOL # Volume names from UFS superblock
174options GEOM_ZERO # Performance testing helper.
175
176#
177# The root device and filesystem type can be compiled in;
178# this provides a fallback option if the root device cannot
179# be correctly guessed by the bootstrap code, or an override if
180# the RB_DFLTROOT flag (-r) is specified when booting the kernel.
181#
182options ROOTDEVNAME=\"ufs:da0s2e\"
183
184
185#####################################################################
186# Scheduler options:
187#
188# Specifying one of SCHED_4BSD or SCHED_ULE is mandatory. These options
189# select which scheduler is compiled in.
190#
191# SCHED_4BSD is the historical, proven, BSD scheduler. It has a global run
192# queue and no CPU affinity which makes it suboptimal for SMP. It has very
193# good interactivity and priority selection.
194#
195# SCHED_ULE provides significant performance advantages over 4BSD on many
196# workloads on SMP machines. It supports cpu-affinity, per-cpu runqueues
197# and scheduler locks. It also has a stronger notion of interactivity
198# which leads to better responsiveness even on uniprocessor machines. This
199# is the default scheduler.
200#
201# SCHED_STATS is a debugging option which keeps some stats in the sysctl
202# tree at 'kern.sched.stats' and is useful for debugging scheduling decisions.
203#
204options SCHED_4BSD
205options SCHED_STATS
206#options SCHED_ULE
207
208#####################################################################
209# SMP OPTIONS:
210#
211# SMP enables building of a Symmetric MultiProcessor Kernel.
212
213# Mandatory:
214options SMP # Symmetric MultiProcessor Kernel
215
216# MAXCPU defines the maximum number of CPUs that can boot in the system.
217# A default value should be already present, for every architecture.
218options MAXCPU=32
219
220# ADAPTIVE_MUTEXES changes the behavior of blocking mutexes to spin
221# if the thread that currently owns the mutex is executing on another
222# CPU. This behavior is enabled by default, so this option can be used
223# to disable it.
224options NO_ADAPTIVE_MUTEXES
225
226# ADAPTIVE_RWLOCKS changes the behavior of reader/writer locks to spin
227# if the thread that currently owns the rwlock is executing on another
228# CPU. This behavior is enabled by default, so this option can be used
229# to disable it.
230options NO_ADAPTIVE_RWLOCKS
231
232# ADAPTIVE_SX changes the behavior of sx locks to spin if the thread that
233# currently owns the sx lock is executing on another CPU.
234# This behavior is enabled by default, so this option can be used to
235# disable it.
236options NO_ADAPTIVE_SX
237
238# MUTEX_NOINLINE forces mutex operations to call functions to perform each
239# operation rather than inlining the simple cases. This can be used to
240# shrink the size of the kernel text segment. Note that this behavior is
241# already implied by the INVARIANT_SUPPORT, INVARIANTS, KTR, LOCK_PROFILING,
242# and WITNESS options.
243options MUTEX_NOINLINE
244
245# RWLOCK_NOINLINE forces rwlock operations to call functions to perform each
246# operation rather than inlining the simple cases. This can be used to
247# shrink the size of the kernel text segment. Note that this behavior is
248# already implied by the INVARIANT_SUPPORT, INVARIANTS, KTR, LOCK_PROFILING,
249# and WITNESS options.
250options RWLOCK_NOINLINE
251
252# SX_NOINLINE forces sx lock operations to call functions to perform each
253# operation rather than inlining the simple cases. This can be used to
254# shrink the size of the kernel text segment. Note that this behavior is
255# already implied by the INVARIANT_SUPPORT, INVARIANTS, KTR, LOCK_PROFILING,
256# and WITNESS options.
257options SX_NOINLINE
258
259# SMP Debugging Options:
260#
261# PREEMPTION allows the threads that are in the kernel to be preempted by
262# higher priority [interrupt] threads. It helps with interactivity
263# and allows interrupt threads to run sooner rather than waiting.
264# WARNING! Only tested on amd64 and i386.
265# FULL_PREEMPTION instructs the kernel to preempt non-realtime kernel
266# threads. Its sole use is to expose race conditions and other
267# bugs during development. Enabling this option will reduce
268# performance and increase the frequency of kernel panics by
269# design. If you aren't sure that you need it then you don't.
270# Relies on the PREEMPTION option. DON'T TURN THIS ON.
271# MUTEX_DEBUG enables various extra assertions in the mutex code.
272# SLEEPQUEUE_PROFILING enables rudimentary profiling of the hash table
273# used to hold active sleep queues as well as sleep wait message
274# frequency.
275# TURNSTILE_PROFILING enables rudimentary profiling of the hash table
276# used to hold active lock queues.
277# WITNESS enables the witness code which detects deadlocks and cycles
278# during locking operations.
279# WITNESS_KDB causes the witness code to drop into the kernel debugger if
280# a lock hierarchy violation occurs or if locks are held when going to
281# sleep.
282# WITNESS_SKIPSPIN disables the witness checks on spin mutexes.
283options PREEMPTION
284options FULL_PREEMPTION
285options MUTEX_DEBUG
286options WITNESS
287options WITNESS_KDB
288options WITNESS_SKIPSPIN
289
290# LOCK_PROFILING - Profiling locks. See LOCK_PROFILING(9) for details.
291options LOCK_PROFILING
292# Set the number of buffers and the hash size. The hash size MUST be larger
293# than the number of buffers. Hash size should be prime.
294options MPROF_BUFFERS="1536"
295options MPROF_HASH_SIZE="1543"
296
297# Profiling for internal hash tables.
298options SLEEPQUEUE_PROFILING
299options TURNSTILE_PROFILING
300
301
302#####################################################################
303# COMPATIBILITY OPTIONS
304
305#
306# Implement system calls compatible with 4.3BSD and older versions of
307# FreeBSD. You probably do NOT want to remove this as much current code
308# still relies on the 4.3 emulation. Note that some architectures that
309# are supported by FreeBSD do not include support for certain important
310# aspects of this compatibility option, namely those related to the
311# signal delivery mechanism.
312#
313options COMPAT_43
314
315# Old tty interface.
316options COMPAT_43TTY
317
318# Note that as a general rule, COMPAT_FREEBSD<n> depends on
319# COMPAT_FREEBSD<n+1>, COMPAT_FREEBSD<n+2>, etc.
320
321# Enable FreeBSD4 compatibility syscalls
322options COMPAT_FREEBSD4
323
324# Enable FreeBSD5 compatibility syscalls
325options COMPAT_FREEBSD5
326
327# Enable FreeBSD6 compatibility syscalls
328options COMPAT_FREEBSD6
329
330# Enable FreeBSD7 compatibility syscalls
331options COMPAT_FREEBSD7
332
333#
334# These three options provide support for System V Interface
335# Definition-style interprocess communication, in the form of shared
336# memory, semaphores, and message queues, respectively.
337#
338options SYSVSHM
339options SYSVSEM
340options SYSVMSG
341
342
343#####################################################################
344# DEBUGGING OPTIONS
345
346#
347# Compile with kernel debugger related code.
348#
349options KDB
350
351#
352# Print a stack trace of the current thread on the console for a panic.
353#
354options KDB_TRACE
355
356#
357# Don't enter the debugger for a panic. Intended for unattended operation
358# where you may want to enter the debugger from the console, but still want
359# the machine to recover from a panic.
360#
361options KDB_UNATTENDED
362
363#
364# Enable the ddb debugger backend.
365#
366options DDB
367
368#
369# Print the numerical value of symbols in addition to the symbolic
370# representation.
371#
372options DDB_NUMSYM
373
374#
375# Enable the remote gdb debugger backend.
376#
377options GDB
378
379#
380# SYSCTL_DEBUG enables a 'sysctl' debug tree that can be used to dump the
381# contents of the registered sysctl nodes on the console. It is disabled by
382# default because it generates excessively verbose console output that can
383# interfere with serial console operation.
384#
385options SYSCTL_DEBUG
386
387#
388# NO_SYSCTL_DESCR omits the sysctl node descriptions to save space in the
389# resulting kernel.
390options NO_SYSCTL_DESCR
391
392#
393# MALLOC_DEBUG_MAXZONES enables multiple uma zones for malloc(9)
394# allocations that are smaller than a page. The purpose is to isolate
395# different malloc types into hash classes, so that any buffer
396# overruns or use-after-free will usually only affect memory from
397# malloc types in that hash class. This is purely a debugging tool;
398# by varying the hash function and tracking which hash class was
399# corrupted, the intersection of the hash classes from each instance
400# will point to a single malloc type that is being misused. At this
401# point inspection or memguard(9) can be used to catch the offending
402# code.
403#
404options MALLOC_DEBUG_MAXZONES=8
405
406#
407# DEBUG_MEMGUARD builds and enables memguard(9), a replacement allocator
408# for the kernel used to detect modify-after-free scenarios. See the
409# memguard(9) man page for more information on usage.
410#
411options DEBUG_MEMGUARD
412
413#
414# DEBUG_REDZONE enables buffer underflows and buffer overflows detection for
415# malloc(9).
416#
417options DEBUG_REDZONE
418
419#
420# KTRACE enables the system-call tracing facility ktrace(2). To be more
421# SMP-friendly, KTRACE uses a worker thread to process most trace events
422# asynchronously to the thread generating the event. This requires a
423# pre-allocated store of objects representing trace events. The
424# KTRACE_REQUEST_POOL option specifies the initial size of this store.
425# The size of the pool can be adjusted both at boottime and runtime via
426# the kern.ktrace_request_pool tunable and sysctl.
427#
428options KTRACE #kernel tracing
429options KTRACE_REQUEST_POOL=101
430
431#
432# KTR is a kernel tracing facility imported from BSD/OS. It is
433# enabled with the KTR option. KTR_ENTRIES defines the number of
434# entries in the circular trace buffer; it must be a power of two.
435# KTR_COMPILE defines the mask of events to compile into the kernel as
436# defined by the KTR_* constants in <sys/ktr.h>. KTR_MASK defines the
437# initial value of the ktr_mask variable which determines at runtime
438# what events to trace. KTR_CPUMASK determines which CPU's log
439# events, with bit X corresponding to CPU X. The layout of the string
440# passed as KTR_CPUMASK must match a series of bitmasks each of them
441# separated by the ", " characters (ie:
442# KTR_CPUMASK=("0xAF, 0xFFFFFFFFFFFFFFFF")). KTR_VERBOSE enables
443# dumping of KTR events to the console by default. This functionality
444# can be toggled via the debug.ktr_verbose sysctl and defaults to off
445# if KTR_VERBOSE is not defined. See ktr(4) and ktrdump(8) for details.
446#
447options KTR
448options KTR_ENTRIES=1024
449options KTR_COMPILE=(KTR_INTR|KTR_PROC)
450options KTR_MASK=KTR_INTR
451options KTR_CPUMASK=("0x3")
452options KTR_VERBOSE
453
454#
455# ALQ(9) is a facility for the asynchronous queuing of records from the kernel
456# to a vnode, and is employed by services such as ktr(4) to produce trace
457# files based on a kernel event stream. Records are written asynchronously
458# in a worker thread.
459#
460options ALQ
461options KTR_ALQ
462
463#
464# The INVARIANTS option is used in a number of source files to enable
465# extra sanity checking of internal structures. This support is not
466# enabled by default because of the extra time it would take to check
467# for these conditions, which can only occur as a result of
468# programming errors.
469#
470options INVARIANTS
471
472#
473# The INVARIANT_SUPPORT option makes us compile in support for
474# verifying some of the internal structures. It is a prerequisite for
475# 'INVARIANTS', as enabling 'INVARIANTS' will make these functions be
476# called. The intent is that you can set 'INVARIANTS' for single
477# source files (by changing the source file or specifying it on the
478# command line) if you have 'INVARIANT_SUPPORT' enabled. Also, if you
479# wish to build a kernel module with 'INVARIANTS', then adding
480# 'INVARIANT_SUPPORT' to your kernel will provide all the necessary
481# infrastructure without the added overhead.
482#
483options INVARIANT_SUPPORT
484
485#
486# The DIAGNOSTIC option is used to enable extra debugging information
487# from some parts of the kernel. As this makes everything more noisy,
488# it is disabled by default.
489#
490options DIAGNOSTIC
491
492#
493# REGRESSION causes optional kernel interfaces necessary only for regression
494# testing to be enabled. These interfaces may constitute security risks
495# when enabled, as they permit processes to easily modify aspects of the
496# run-time environment to reproduce unlikely or unusual (possibly normally
497# impossible) scenarios.
498#
499options REGRESSION
500
501#
502# This option lets some drivers co-exist that can't co-exist in a running
503# system. This is used to be able to compile all kernel code in one go for
504# quality assurance purposes (like this file, which the option takes it name
505# from.)
506#
507options COMPILING_LINT
508
509#
510# STACK enables the stack(9) facility, allowing the capture of kernel stack
511# for the purpose of procinfo(1), etc. stack(9) will also be compiled in
512# automatically if DDB(4) is compiled into the kernel.
513#
514options STACK
515
516
517#####################################################################
518# PERFORMANCE MONITORING OPTIONS
519
520#
521# The hwpmc driver that allows the use of in-CPU performance monitoring
522# counters for performance monitoring. The base kernel needs to be configured
523# with the 'options' line, while the hwpmc device can be either compiled
524# in or loaded as a loadable kernel module.
525#
526# Additional configuration options may be required on specific architectures,
527# please see hwpmc(4).
528
529device hwpmc # Driver (also a loadable module)
530options HWPMC_HOOKS # Other necessary kernel hooks
531
532
533#####################################################################
534# NETWORKING OPTIONS
535
536#
537# Protocol families
538#
539options INET #Internet communications protocols
540options INET6 #IPv6 communications protocols
541
542options ROUTETABLES=2 # max 16. 1 is back compatible.
543
544# In order to enable IPSEC you MUST also add device crypto to
545# your kernel configuration
546options IPSEC #IP security (requires device crypto)
547#options IPSEC_DEBUG #debug for IP security
548#
549# #DEPRECATED#
550# Set IPSEC_FILTERTUNNEL to change the default of the sysctl to force packets
551# coming through a tunnel to be processed by any configured packet filtering
552# twice. The default is that packets coming out of a tunnel are _not_ processed;
553# they are assumed trusted.
554#
555# IPSEC history is preserved for such packets, and can be filtered
556# using ipfw(8)'s 'ipsec' keyword, when this option is enabled.
557#
558#options IPSEC_FILTERTUNNEL #filter ipsec packets from a tunnel
559#
560# Set IPSEC_NAT_T to enable NAT-Traversal support. This enables
561# optional UDP encapsulation of ESP packets.
562#
563options IPSEC_NAT_T #NAT-T support, UDP encap of ESP
564
565options IPX #IPX/SPX communications protocols
566
567options NCP #NetWare Core protocol
568
569options NETATALK #Appletalk communications protocols
570options NETATALKDEBUG #Appletalk debugging
571
572#
573# SMB/CIFS requester
574# NETSMB enables support for SMB protocol, it requires LIBMCHAIN and LIBICONV
575# options.
576options NETSMB #SMB/CIFS requester
577
578# mchain library. It can be either loaded as KLD or compiled into kernel
579options LIBMCHAIN
580
581# libalias library, performing NAT
582options LIBALIAS
583
584# flowtable cache
585options FLOWTABLE
586
587#
588# SCTP is a NEW transport protocol defined by
589# RFC2960 updated by RFC3309 and RFC3758.. and
590# soon to have a new base RFC and many many more
591# extensions. This release supports all the extensions
592# including many drafts (most about to become RFC's).
593# It is the reference implementation of SCTP
594# and is quite well tested.
595#
596# Note YOU MUST have both INET and INET6 defined.
597# You don't have to enable V6, but SCTP is
598# dual stacked and so far we have not torn apart
599# the V6 and V4.. since an association can span
600# both a V6 and V4 address at the SAME time :-)
601#
602options SCTP
603# There are bunches of options:
604# this one turns on all sorts of
605# nastily printing that you can
606# do. It's all controlled by a
607# bit mask (settable by socket opt and
608# by sysctl). Including will not cause
609# logging until you set the bits.. but it
610# can be quite verbose.. so without this
611# option we don't do any of the tests for
612# bits and prints.. which makes the code run
613# faster.. if you are not debugging don't use.
614options SCTP_DEBUG
615#
616# This option turns off the CRC32c checksum. Basically,
617# you will not be able to talk to anyone else who
618# has not done this. Its more for experimentation to
619# see how much CPU the CRC32c really takes. Most new
620# cards for TCP support checksum offload.. so this
621# option gives you a "view" into what SCTP would be
622# like with such an offload (which only exists in
623# high in iSCSI boards so far). With the new
624# splitting 8's algorithm its not as bad as it used
625# to be.. but it does speed things up try only
626# for in a captured lab environment :-)
627options SCTP_WITH_NO_CSUM
628#
629
630#
631# All that options after that turn on specific types of
632# logging. You can monitor CWND growth, flight size
633# and all sorts of things. Go look at the code and
634# see. I have used this to produce interesting
635# charts and graphs as well :->
636#
637# I have not yet committed the tools to get and print
638# the logs, I will do that eventually .. before then
639# if you want them send me an email rrs@freebsd.org
640# You basically must have ktr(4) enabled for these
641# and you then set the sysctl to turn on/off various
642# logging bits. Use ktrdump(8) to pull the log and run
643# it through a display program.. and graphs and other
644# things too.
645#
646options SCTP_LOCK_LOGGING
647options SCTP_MBUF_LOGGING
648options SCTP_MBCNT_LOGGING
649options SCTP_PACKET_LOGGING
650options SCTP_LTRACE_CHUNKS
651options SCTP_LTRACE_ERRORS
652
653
654# altq(9). Enable the base part of the hooks with the ALTQ option.
655# Individual disciplines must be built into the base system and can not be
656# loaded as modules at this point. ALTQ requires a stable TSC so if yours is
657# broken or changes with CPU throttling then you must also have the ALTQ_NOPCC
658# option.
659options ALTQ
660options ALTQ_CBQ # Class Based Queueing
661options ALTQ_RED # Random Early Detection
662options ALTQ_RIO # RED In/Out
663options ALTQ_HFSC # Hierarchical Packet Scheduler
664options ALTQ_CDNR # Traffic conditioner
665options ALTQ_PRIQ # Priority Queueing
666options ALTQ_NOPCC # Required if the TSC is unusable
667options ALTQ_DEBUG
668
669# netgraph(4). Enable the base netgraph code with the NETGRAPH option.
670# Individual node types can be enabled with the corresponding option
671# listed below; however, this is not strictly necessary as netgraph
672# will automatically load the corresponding KLD module if the node type
673# is not already compiled into the kernel. Each type below has a
674# corresponding man page, e.g., ng_async(8).
675options NETGRAPH # netgraph(4) system
676options NETGRAPH_DEBUG # enable extra debugging, this
677 # affects netgraph(4) and nodes
678# Node types
679options NETGRAPH_ASYNC
680options NETGRAPH_ATMLLC
681options NETGRAPH_ATM_ATMPIF
682options NETGRAPH_BLUETOOTH # ng_bluetooth(4)
683options NETGRAPH_BLUETOOTH_BT3C # ng_bt3c(4)
684options NETGRAPH_BLUETOOTH_HCI # ng_hci(4)
685options NETGRAPH_BLUETOOTH_L2CAP # ng_l2cap(4)
686options NETGRAPH_BLUETOOTH_SOCKET # ng_btsocket(4)
687options NETGRAPH_BLUETOOTH_UBT # ng_ubt(4)
688options NETGRAPH_BLUETOOTH_UBTBCMFW # ubtbcmfw(4)
689options NETGRAPH_BPF
690options NETGRAPH_BRIDGE
691options NETGRAPH_CAR
692options NETGRAPH_CISCO
693options NETGRAPH_DEFLATE
694options NETGRAPH_DEVICE
695options NETGRAPH_ECHO
696options NETGRAPH_EIFACE
697options NETGRAPH_ETHER
698options NETGRAPH_FEC
699options NETGRAPH_FRAME_RELAY
700options NETGRAPH_GIF
701options NETGRAPH_GIF_DEMUX
702options NETGRAPH_HOLE
703options NETGRAPH_IFACE
704options NETGRAPH_IP_INPUT
705options NETGRAPH_IPFW
706options NETGRAPH_KSOCKET
707options NETGRAPH_L2TP
708options NETGRAPH_LMI
709# MPPC compression requires proprietary files (not included)
710#options NETGRAPH_MPPC_COMPRESSION
711options NETGRAPH_MPPC_ENCRYPTION
712options NETGRAPH_NETFLOW
713options NETGRAPH_NAT
714options NETGRAPH_ONE2MANY
715options NETGRAPH_PATCH
716options NETGRAPH_PIPE
717options NETGRAPH_PPP
718options NETGRAPH_PPPOE
719options NETGRAPH_PPTPGRE
720options NETGRAPH_PRED1
721options NETGRAPH_RFC1490
722options NETGRAPH_SOCKET
723options NETGRAPH_SPLIT
724options NETGRAPH_SPPP
725options NETGRAPH_TAG
726options NETGRAPH_TCPMSS
727options NETGRAPH_TEE
728options NETGRAPH_UI
729options NETGRAPH_VJC
730options NETGRAPH_VLAN
731
732# NgATM - Netgraph ATM
733options NGATM_ATM
734options NGATM_ATMBASE
735options NGATM_SSCOP
736options NGATM_SSCFU
737options NGATM_UNI
738options NGATM_CCATM
739
740device mn # Munich32x/Falc54 Nx64kbit/sec cards.
741
742#
743# Network interfaces:
744# The `loop' device is MANDATORY when networking is enabled.
745device loop
746
747# The `ether' device provides generic code to handle
748# Ethernets; it is MANDATORY when an Ethernet device driver is
749# configured or token-ring is enabled.
750device ether
751
752# The `vlan' device implements the VLAN tagging of Ethernet frames
753# according to IEEE 802.1Q.
754device vlan
755
756# The `wlan' device provides generic code to support 802.11
757# drivers, including host AP mode; it is MANDATORY for the wi,
758# and ath drivers and will eventually be required by all 802.11 drivers.
759device wlan
760options IEEE80211_DEBUG #enable debugging msgs
761options IEEE80211_AMPDU_AGE #age frames in AMPDU reorder q's
762options IEEE80211_SUPPORT_MESH #enable 802.11s D3.0 support
763options IEEE80211_SUPPORT_TDMA #enable TDMA support
764
765# The `wlan_wep', `wlan_tkip', and `wlan_ccmp' devices provide
766# support for WEP, TKIP, and AES-CCMP crypto protocols optionally
767# used with 802.11 devices that depend on the `wlan' module.
768device wlan_wep
769device wlan_ccmp
770device wlan_tkip
771
772# The `wlan_xauth' device provides support for external (i.e. user-mode)
773# authenticators for use with 802.11 drivers that use the `wlan'
774# module and support 802.1x and/or WPA security protocols.
775device wlan_xauth
776
777# The `wlan_acl' device provides a MAC-based access control mechanism
778# for use with 802.11 drivers operating in ap mode and using the
779# `wlan' module.
780# The 'wlan_amrr' device provides AMRR transmit rate control algorithm
781device wlan_acl
782device wlan_amrr
783
784# Generic TokenRing
785device token
786
787# The `fddi' device provides generic code to support FDDI.
788device fddi
789
790# The `arcnet' device provides generic code to support Arcnet.
791device arcnet
792
793# The `sppp' device serves a similar role for certain types
794# of synchronous PPP links (like `cx', `ar').
795device sppp
796
797# The `bpf' device enables the Berkeley Packet Filter. Be
798# aware of the legal and administrative consequences of enabling this
799# option. DHCP requires bpf.
800device bpf
801
802# The `netmap' device implements memory-mapped access to network
803# devices from userspace, enabling wire-speed packet capture and
804# generation even at 10Gbit/s. Requires support in the device
805# driver. Supported drivers are ixgbe, e1000, re.
806device netmap
807
808# The `disc' device implements a minimal network interface,
809# which throws away all packets sent and never receives any. It is
810# included for testing and benchmarking purposes.
811device disc
812
813# The `epair' device implements a virtual back-to-back connected Ethernet
814# like interface pair.
815device epair
816
817# The `edsc' device implements a minimal Ethernet interface,
818# which discards all packets sent and receives none.
819device edsc
820
821# The `tap' device is a pty-like virtual Ethernet interface
822device tap
823
824# The `tun' device implements (user-)ppp and nos-tun(8)
825device tun
826
827# The `gif' device implements IPv6 over IP4 tunneling,
828# IPv4 over IPv6 tunneling, IPv4 over IPv4 tunneling and
829# IPv6 over IPv6 tunneling.
830# The `gre' device implements two types of IP4 over IP4 tunneling:
831# GRE and MOBILE, as specified in the RFC1701 and RFC2004.
832# The XBONEHACK option allows the same pair of addresses to be configured on
833# multiple gif interfaces.
834device gif
835device gre
836options XBONEHACK
837
838# The `faith' device captures packets sent to it and diverts them
839# to the IPv4/IPv6 translation daemon.
840# The `stf' device implements 6to4 encapsulation.
841device faith
842device stf
843
844# The `ef' device provides support for multiple ethernet frame types
845# specified via ETHER_* options. See ef(4) for details.
846device ef
847options ETHER_II # enable Ethernet_II frame
848options ETHER_8023 # enable Ethernet_802.3 (Novell) frame
849options ETHER_8022 # enable Ethernet_802.2 frame
850options ETHER_SNAP # enable Ethernet_802.2/SNAP frame
851
852# The pf packet filter consists of three devices:
853# The `pf' device provides /dev/pf and the firewall code itself.
854# The `pflog' device provides the pflog0 interface which logs packets.
855# The `pfsync' device provides the pfsync0 interface used for
856# synchronization of firewall state tables (over the net).
857device pf
858device pflog
859device pfsync
860
861# Bridge interface.
862device if_bridge
863
864# Common Address Redundancy Protocol. See carp(4) for more details.
865device carp
866
867# IPsec interface.
868device enc
869
870# Link aggregation interface.
871device lagg
872
873#
874# Internet family options:
875#
876# MROUTING enables the kernel multicast packet forwarder, which works
877# with mrouted and XORP.
878#
879# IPFIREWALL enables support for IP firewall construction, in
880# conjunction with the `ipfw' program. IPFIREWALL_VERBOSE sends
881# logged packets to the system logger. IPFIREWALL_VERBOSE_LIMIT
882# limits the number of times a matching entry can be logged.
883#
884# WARNING: IPFIREWALL defaults to a policy of "deny ip from any to any"
885# and if you do not add other rules during startup to allow access,
886# YOU WILL LOCK YOURSELF OUT. It is suggested that you set firewall_type=open
887# in /etc/rc.conf when first enabling this feature, then refining the
888# firewall rules in /etc/rc.firewall after you've tested that the new kernel
889# feature works properly.
890#
891# IPFIREWALL_DEFAULT_TO_ACCEPT causes the default rule (at boot) to
892# allow everything. Use with care, if a cracker can crash your
893# firewall machine, they can get to your protected machines. However,
894# if you are using it as an as-needed filter for specific problems as
895# they arise, then this may be for you. Changing the default to 'allow'
896# means that you won't get stuck if the kernel and /sbin/ipfw binary get
897# out of sync.
898#
899# IPDIVERT enables the divert IP sockets, used by ``ipfw divert''. It
900# depends on IPFIREWALL if compiled into the kernel.
901#
902# IPFIREWALL_FORWARD enables changing of the packet destination either
903# to do some sort of policy routing or transparent proxying. Used by
904# ``ipfw forward''. All redirections apply to locally generated
905# packets too. Because of this great care is required when
906# crafting the ruleset.
907#
908# IPFIREWALL_NAT adds support for in kernel nat in ipfw, and it requires
909# LIBALIAS.
910#
911# IPSTEALTH enables code to support stealth forwarding (i.e., forwarding
912# packets without touching the TTL). This can be useful to hide firewalls
913# from traceroute and similar tools.
914#
915# TCPDEBUG enables code which keeps traces of the TCP state machine
916# for sockets with the SO_DEBUG option set, which can then be examined
917# using the trpt(8) utility.
918#
919# RADIX_MPATH provides support for equal-cost multi-path routing.
920#
921options MROUTING # Multicast routing
922options IPFIREWALL #firewall
923options IPFIREWALL_VERBOSE #enable logging to syslogd(8)
924options IPFIREWALL_VERBOSE_LIMIT=100 #limit verbosity
925options IPFIREWALL_DEFAULT_TO_ACCEPT #allow everything by default
926options IPFIREWALL_FORWARD #packet destination changes
927options IPFIREWALL_NAT #ipfw kernel nat support
928options IPDIVERT #divert sockets
929options IPFILTER #ipfilter support
930options IPFILTER_LOG #ipfilter logging
931options IPFILTER_LOOKUP #ipfilter pools
932options IPFILTER_DEFAULT_BLOCK #block all packets by default
933options IPSTEALTH #support for stealth forwarding
934options TCPDEBUG
935options RADIX_MPATH
936
937# The MBUF_STRESS_TEST option enables options which create
938# various random failures / extreme cases related to mbuf
939# functions. See mbuf(9) for a list of available test cases.
940# MBUF_PROFILING enables code to profile the mbuf chains
941# exiting the system (via participating interfaces) and
942# return a logarithmic histogram of monitored parameters
943# (e.g. packet size, wasted space, number of mbufs in chain).
944options MBUF_STRESS_TEST
945options MBUF_PROFILING
946
947# Statically link in accept filters
948options ACCEPT_FILTER_DATA
949options ACCEPT_FILTER_DNS
950options ACCEPT_FILTER_HTTP
951
952# TCP_SIGNATURE adds support for RFC 2385 (TCP-MD5) digests. These are
953# carried in TCP option 19. This option is commonly used to protect
954# TCP sessions (e.g. BGP) where IPSEC is not available nor desirable.
955# This is enabled on a per-socket basis using the TCP_MD5SIG socket option.
956# This requires the use of 'device crypto', 'options IPSEC'
957# or 'device cryptodev'.
958options TCP_SIGNATURE #include support for RFC 2385
959
960# DUMMYNET enables the "dummynet" bandwidth limiter. You need IPFIREWALL
961# as well. See dummynet(4) and ipfw(8) for more info. When you run
962# DUMMYNET it is advisable to also have at least "options HZ=1000" to achieve
963# a smooth scheduling of the traffic.
964options DUMMYNET
965
966# Zero copy sockets support. This enables "zero copy" for sending and
967# receiving data via a socket. The send side works for any type of NIC,
968# the receive side only works for NICs that support MTUs greater than the
969# page size of your architecture and that support header splitting. See
970# zero_copy(9) for more details.
971options ZERO_COPY_SOCKETS
972
973#####################################################################
974# FILESYSTEM OPTIONS
975
976#
977# Only the root filesystem needs to be statically compiled or preloaded
978# as module; everything else will be automatically loaded at mount
979# time. Some people still prefer to statically compile other
980# filesystems as well.
981#
982# NB: The PORTAL filesystem is known to be buggy, and WILL panic your
983# system if you attempt to do anything with it. It is included here
984# as an incentive for some enterprising soul to sit down and fix it.
985# The UNION filesystem was known to be buggy in the past. It is now
986# being actively maintained, although there are still some issues being
987# resolved.
988#
989
990# One of these is mandatory:
991options FFS #Fast filesystem
992options NFSCLIENT #Network File System client
993
994# The rest are optional:
995options CD9660 #ISO 9660 filesystem
996options FDESCFS #File descriptor filesystem
997options HPFS #OS/2 File system
998options MSDOSFS #MS DOS File System (FAT, FAT32)
999options NFSSERVER #Network File System server
1000options NFSLOCKD #Network Lock Manager
1001options NFSCL #experimental NFS client with NFSv4
1002options NFSD #experimental NFS server with NFSv4
1003options KGSSAPI #Kernel GSSAPI implementation
1004
1005# NT File System. Read-mostly, see mount_ntfs(8) for details.
1006# For a full read-write NTFS support consider sysutils/fusefs-ntfs
1007# port/package.
1008options NTFS
1009
1010options NULLFS #NULL filesystem
1011# Broken (depends on NCP):
1012#options NWFS #NetWare filesystem
1013options PORTALFS #Portal filesystem
1014options PROCFS #Process filesystem (requires PSEUDOFS)
1015options PSEUDOFS #Pseudo-filesystem framework
1016options PSEUDOFS_TRACE #Debugging support for PSEUDOFS
1017options SMBFS #SMB/CIFS filesystem
1018options TMPFS #Efficient memory filesystem
1019options UDF #Universal Disk Format
1020options UNIONFS #Union filesystem
1021# The xFS_ROOT options REQUIRE the associated ``options xFS''
1022options NFS_ROOT #NFS usable as root device
1023
1024# Soft updates is a technique for improving filesystem speed and
1025# making abrupt shutdown less risky.
1026#
1027options SOFTUPDATES
1028
1029# Extended attributes allow additional data to be associated with files,
1030# and is used for ACLs, Capabilities, and MAC labels.
1031# See src/sys/ufs/ufs/README.extattr for more information.
1032options UFS_EXTATTR
1033options UFS_EXTATTR_AUTOSTART
1034
1035# Access Control List support for UFS filesystems. The current ACL
1036# implementation requires extended attribute support, UFS_EXTATTR,
1037# for the underlying filesystem.
1038# See src/sys/ufs/ufs/README.acls for more information.
1039options UFS_ACL
1040
1041# Directory hashing improves the speed of operations on very large
1042# directories at the expense of some memory.
1043options UFS_DIRHASH
1044
1045# Gjournal-based UFS journaling support.
1046options UFS_GJOURNAL
1047
1048# Make space in the kernel for a root filesystem on a md device.
1049# Define to the number of kilobytes to reserve for the filesystem.
1050options MD_ROOT_SIZE=10
1051
1052# Make the md device a potential root device, either with preloaded
1053# images of type mfs_root or md_root.
1054options MD_ROOT
1055
1056# Disk quotas are supported when this option is enabled.
1057options QUOTA #enable disk quotas
1058
1059# If you are running a machine just as a fileserver for PC and MAC
1060# users, using SAMBA or Netatalk, you may consider setting this option
1061# and keeping all those users' directories on a filesystem that is
1062# mounted with the suiddir option. This gives new files the same
1063# ownership as the directory (similar to group). It's a security hole
1064# if you let these users run programs, so confine it to file-servers
1065# (but it'll save you lots of headaches in those cases). Root owned
1066# directories are exempt and X bits are cleared. The suid bit must be
1067# set on the directory as well; see chmod(1). PC owners can't see/set
1068# ownerships so they keep getting their toes trodden on. This saves
1069# you all the support calls as the filesystem it's used on will act as
1070# they expect: "It's my dir so it must be my file".
1071#
1072options SUIDDIR
1073
1074# NFS options:
1075options NFS_MINATTRTIMO=3 # VREG attrib cache timeout in sec
1076options NFS_MAXATTRTIMO=60
1077options NFS_MINDIRATTRTIMO=30 # VDIR attrib cache timeout in sec
1078options NFS_MAXDIRATTRTIMO=60
1079options NFS_GATHERDELAY=10 # Default write gather delay (msec)
1080options NFS_WDELAYHASHSIZ=16 # and with this
1081options NFS_DEBUG # Enable NFS Debugging
1082
1083# Coda stuff:
1084options CODA #CODA filesystem.
1085device vcoda #coda minicache <-> venus comm.
1086# Use the old Coda 5.x venus<->kernel interface instead of the new
1087# realms-aware 6.x protocol.
1088#options CODA_COMPAT_5
1089
1090#
1091# Add support for the EXT2FS filesystem of Linux fame. Be a bit
1092# careful with this - the ext2fs code has a tendency to lag behind
1093# changes and not be exercised very much, so mounting read/write could
1094# be dangerous (and even mounting read only could result in panics.)
1095#
1096options EXT2FS
1097
1098#
1099# Add support for the ReiserFS filesystem (used in Linux). Currently,
1100# this is limited to read-only access.
1101#
1102options REISERFS
1103
1104#
1105# Add support for the SGI XFS filesystem. Currently,
1106# this is limited to read-only access.
1107#
1108options XFS
1109
1110# Use real implementations of the aio_* system calls. There are numerous
1111# stability and security issues in the current aio code that make it
1112# unsuitable for inclusion on machines with untrusted local users.
1113options VFS_AIO
1114
1115# Enable mounting of non-MPSAFE filesystems.
1116options VFS_ALLOW_NONMPSAFE
1117
1118# Cryptographically secure random number generator; /dev/random
1119device random
1120
1121# The system memory devices; /dev/mem, /dev/kmem
1122device mem
1123
1124# The kernel symbol table device; /dev/ksyms
1125device ksyms
1126
1127# Optional character code conversion support with LIBICONV.
1128# Each option requires their base file system and LIBICONV.
1129options CD9660_ICONV
1130options MSDOSFS_ICONV
1131options NTFS_ICONV
1132options UDF_ICONV
1133
1134
1135#####################################################################
1136# POSIX P1003.1B
1137
1138# Real time extensions added in the 1993 POSIX
1139# _KPOSIX_PRIORITY_SCHEDULING: Build in _POSIX_PRIORITY_SCHEDULING
1140
1141options _KPOSIX_PRIORITY_SCHEDULING
1142# p1003_1b_semaphores are very experimental,
1143# user should be ready to assist in debugging if problems arise.
1144options P1003_1B_SEMAPHORES
1145
1146# POSIX message queue
1147options P1003_1B_MQUEUE
1148
1149#####################################################################
1150# SECURITY POLICY PARAMETERS
1151
1152# Support for BSM audit
1153options AUDIT
1154
1155# Support for Mandatory Access Control (MAC):
1156options MAC
1157options MAC_BIBA
1158options MAC_BSDEXTENDED
1159options MAC_IFOFF
1160options MAC_LOMAC
1161options MAC_MLS
1162options MAC_NONE
1163options MAC_PARTITION
1164options MAC_PORTACL
1165options MAC_SEEOTHERUIDS
1166options MAC_STUB
1167options MAC_TEST
1168
1169# Support for Capsicum
1170options CAPABILITIES # fine-grained rights on file descriptors
1171options CAPABILITY_MODE # sandboxes with no global namespace access
1172
1173# Support for process descriptors
1174options PROCDESC
1175
1176
1177#####################################################################
1178# CLOCK OPTIONS
1179
1180# The granularity of operation is controlled by the kernel option HZ whose
1181# default value (1000 on most architectures) means a granularity of 1ms
1182# (1s/HZ). Historically, the default was 100, but finer granularity is
1183# required for DUMMYNET and other systems on modern hardware. There are
1184# reasonable arguments that HZ should, in fact, be 100 still; consider,
1185# that reducing the granularity too much might cause excessive overhead in
1186# clock interrupt processing, potentially causing ticks to be missed and thus
1187# actually reducing the accuracy of operation.
1188
1189options HZ=100
1190
1191# Enable support for the kernel PLL to use an external PPS signal,
1192# under supervision of [x]ntpd(8)
1193# More info in ntpd documentation: http://www.eecis.udel.edu/~ntp
1194
1195options PPS_SYNC
1196
1197# Enable support for generic feed-forward clocks in the kernel.
1198# The feed-forward clock support is an alternative to the feedback oriented
1199# ntpd/system clock approach, and is to be used with a feed-forward
1200# synchronization algorithm such as the RADclock:
1201# More info here: http://www.synclab.org/radclock
1202
1203options FFCLOCK
1204
1205
1206#####################################################################
1207# SCSI DEVICES
1208
1209# SCSI DEVICE CONFIGURATION
1210
1211# The SCSI subsystem consists of the `base' SCSI code, a number of
1212# high-level SCSI device `type' drivers, and the low-level host-adapter
1213# device drivers. The host adapters are listed in the ISA and PCI
1214# device configuration sections below.
1215#
1216# It is possible to wire down your SCSI devices so that a given bus,
1217# target, and LUN always come on line as the same device unit. In
1218# earlier versions the unit numbers were assigned in the order that
1219# the devices were probed on the SCSI bus. This means that if you
1220# removed a disk drive, you may have had to rewrite your /etc/fstab
1221# file, and also that you had to be careful when adding a new disk
1222# as it may have been probed earlier and moved your device configuration
1223# around. (See also option GEOM_VOL for a different solution to this
1224# problem.)
1225
1226# This old behavior is maintained as the default behavior. The unit
1227# assignment begins with the first non-wired down unit for a device
1228# type. For example, if you wire a disk as "da3" then the first
1229# non-wired disk will be assigned da4.
1230
1231# The syntax for wiring down devices is:
1232
1233hint.scbus.0.at="ahc0"
1234hint.scbus.1.at="ahc1"
1235hint.scbus.1.bus="0"
1236hint.scbus.3.at="ahc2"
1237hint.scbus.3.bus="0"
1238hint.scbus.2.at="ahc2"
1239hint.scbus.2.bus="1"
1240hint.da.0.at="scbus0"
1241hint.da.0.target="0"
1242hint.da.0.unit="0"
1243hint.da.1.at="scbus3"
1244hint.da.1.target="1"
1245hint.da.2.at="scbus2"
1246hint.da.2.target="3"
1247hint.sa.1.at="scbus1"
1248hint.sa.1.target="6"
1249
1250# "units" (SCSI logical unit number) that are not specified are
1251# treated as if specified as LUN 0.
1252
1253# All SCSI devices allocate as many units as are required.
1254
1255# The ch driver drives SCSI Media Changer ("jukebox") devices.
1256#
1257# The da driver drives SCSI Direct Access ("disk") and Optical Media
1258# ("WORM") devices.
1259#
1260# The sa driver drives SCSI Sequential Access ("tape") devices.
1261#
1262# The cd driver drives SCSI Read Only Direct Access ("cd") devices.
1263#
1264# The ses driver drives SCSI Environment Services ("ses") and
1265# SAF-TE ("SCSI Accessible Fault-Tolerant Enclosure") devices.
1266#
1267# The pt driver drives SCSI Processor devices.
1268#
1269# The sg driver provides a passthrough API that is compatible with the
1270# Linux SG driver. It will work in conjunction with the COMPAT_LINUX
1271# option to run linux SG apps. It can also stand on its own and provide
1272# source level API compatibility for porting apps to FreeBSD.
1273#
1274# Target Mode support is provided here but also requires that a SIM
1275# (SCSI Host Adapter Driver) provide support as well.
1276#
1277# The targ driver provides target mode support as a Processor type device.
1278# It exists to give the minimal context necessary to respond to Inquiry
1279# commands. There is a sample user application that shows how the rest
1280# of the command support might be done in /usr/share/examples/scsi_target.
1281#
1282# The targbh driver provides target mode support and exists to respond
1283# to incoming commands that do not otherwise have a logical unit assigned
1284# to them.
1285#
1286# The "unknown" device (uk? in pre-2.0.5) is now part of the base SCSI
1287# configuration as the "pass" driver.
1288
1289device scbus #base SCSI code
1290device ch #SCSI media changers
1291device da #SCSI direct access devices (aka disks)
1292device sa #SCSI tapes
1293device cd #SCSI CD-ROMs
1294device ses #SCSI Environmental Services (and SAF-TE)
1295device pt #SCSI processor
1296device targ #SCSI Target Mode Code
1297device targbh #SCSI Target Mode Blackhole Device
1298device pass #CAM passthrough driver
1299device sg #Linux SCSI passthrough
1300device ctl #CAM Target Layer
1301
1302# CAM OPTIONS:
1303# debugging options:
1304# -- NOTE -- If you specify one of the bus/target/lun options, you must
1305# specify them all!
1306# CAMDEBUG: When defined enables debugging macros
1307# CAM_DEBUG_BUS: Debug the given bus. Use -1 to debug all busses.
1308# CAM_DEBUG_TARGET: Debug the given target. Use -1 to debug all targets.
1309# CAM_DEBUG_LUN: Debug the given lun. Use -1 to debug all luns.
1310# CAM_DEBUG_FLAGS: OR together CAM_DEBUG_INFO, CAM_DEBUG_TRACE,
1311# CAM_DEBUG_SUBTRACE, and CAM_DEBUG_CDB
1312#
1313# CAM_MAX_HIGHPOWER: Maximum number of concurrent high power (start unit) cmds
1314# SCSI_NO_SENSE_STRINGS: When defined disables sense descriptions
1315# SCSI_NO_OP_STRINGS: When defined disables opcode descriptions
1316# SCSI_DELAY: The number of MILLISECONDS to freeze the SIM (scsi adapter)
1317# queue after a bus reset, and the number of milliseconds to
1318# freeze the device queue after a bus device reset. This
1319# can be changed at boot and runtime with the
1320# kern.cam.scsi_delay tunable/sysctl.
1321options CAMDEBUG
1322options CAM_DEBUG_BUS=-1
1323options CAM_DEBUG_TARGET=-1
1324options CAM_DEBUG_LUN=-1
1325options CAM_DEBUG_FLAGS=(CAM_DEBUG_INFO|CAM_DEBUG_TRACE|CAM_DEBUG_CDB)
1326options CAM_MAX_HIGHPOWER=4
1327options SCSI_NO_SENSE_STRINGS
1328options SCSI_NO_OP_STRINGS
1329options SCSI_DELAY=5000 # Be pessimistic about Joe SCSI device
1330
1331# Options for the CAM CDROM driver:
1332# CHANGER_MIN_BUSY_SECONDS: Guaranteed minimum time quantum for a changer LUN
1333# CHANGER_MAX_BUSY_SECONDS: Maximum time quantum per changer LUN, only
1334# enforced if there is I/O waiting for another LUN
1335# The compiled in defaults for these variables are 2 and 10 seconds,
1336# respectively.
1337#
1338# These can also be changed on the fly with the following sysctl variables:
1339# kern.cam.cd.changer.min_busy_seconds
1340# kern.cam.cd.changer.max_busy_seconds
1341#
1342options CHANGER_MIN_BUSY_SECONDS=2
1343options CHANGER_MAX_BUSY_SECONDS=10
1344
1345# Options for the CAM sequential access driver:
1346# SA_IO_TIMEOUT: Timeout for read/write/wfm operations, in minutes
1347# SA_SPACE_TIMEOUT: Timeout for space operations, in minutes
1348# SA_REWIND_TIMEOUT: Timeout for rewind operations, in minutes
1349# SA_ERASE_TIMEOUT: Timeout for erase operations, in minutes
1350# SA_1FM_AT_EOD: Default to model which only has a default one filemark at EOT.
1351options SA_IO_TIMEOUT=4
1352options SA_SPACE_TIMEOUT=60
1353options SA_REWIND_TIMEOUT=(2*60)
1354options SA_ERASE_TIMEOUT=(4*60)
1355options SA_1FM_AT_EOD
1356
1357# Optional timeout for the CAM processor target (pt) device
1358# This is specified in seconds. The default is 60 seconds.
1359options SCSI_PT_DEFAULT_TIMEOUT=60
1360
1361# Optional enable of doing SES passthrough on other devices (e.g., disks)
1362#
1363# Normally disabled because a lot of newer SCSI disks report themselves
1364# as having SES capabilities, but this can then clot up attempts to build
1365# a topology with the SES device that's on the box these drives are in....
1366options SES_ENABLE_PASSTHROUGH
1367
1368
1369#####################################################################
1370# MISCELLANEOUS DEVICES AND OPTIONS
1371
1372device pty #BSD-style compatibility pseudo ttys
1373device nmdm #back-to-back tty devices
1374device md #Memory/malloc disk
1375device snp #Snoop device - to look at pty/vty/etc..
1376device ccd #Concatenated disk driver
1377device firmware #firmware(9) support
1378
1379# Kernel side iconv library
1380options LIBICONV
1381
1382# Size of the kernel message buffer. Should be N * pagesize.
1383options MSGBUF_SIZE=40960
1384
1385
1386#####################################################################
1387# HARDWARE DEVICE CONFIGURATION
1388
1389# For ISA the required hints are listed.
1390# EISA, MCA, PCI, CardBus, SD/MMC and pccard are self identifying buses, so
1391# no hints are needed.
1392
1393#
1394# Mandatory devices:
1395#
1396
1397# These options are valid for other keyboard drivers as well.
1398options KBD_DISABLE_KEYMAP_LOAD # refuse to load a keymap
1399options KBD_INSTALL_CDEV # install a CDEV entry in /dev
1400
1401options FB_DEBUG # Frame buffer debugging
1402
1403device splash # Splash screen and screen saver support
1404
1405# Various screen savers.
1406device blank_saver
1407device daemon_saver
1408device dragon_saver
1409device fade_saver
1410device fire_saver
1411device green_saver
1412device logo_saver
1413device rain_saver
1414device snake_saver
1415device star_saver
1416device warp_saver
1417
1418# The syscons console driver (SCO color console compatible).
1419device sc
1420hint.sc.0.at="isa"
1421options MAXCONS=16 # number of virtual consoles
1422options SC_ALT_MOUSE_IMAGE # simplified mouse cursor in text mode
1423options SC_DFLT_FONT # compile font in
1424makeoptions SC_DFLT_FONT=cp850
1425options SC_DISABLE_KDBKEY # disable `debug' key
1426options SC_DISABLE_REBOOT # disable reboot key sequence
1427options SC_HISTORY_SIZE=200 # number of history buffer lines
1428options SC_MOUSE_CHAR=0x3 # char code for text mode mouse cursor
1429options SC_PIXEL_MODE # add support for the raster text mode
1430
1431# The following options will let you change the default colors of syscons.
1432options SC_NORM_ATTR=(FG_GREEN|BG_BLACK)
1433options SC_NORM_REV_ATTR=(FG_YELLOW|BG_GREEN)
1434options SC_KERNEL_CONS_ATTR=(FG_RED|BG_BLACK)
1435options SC_KERNEL_CONS_REV_ATTR=(FG_BLACK|BG_RED)
1436
1437# The following options will let you change the default behavior of
1438# cut-n-paste feature
1439options SC_CUT_SPACES2TABS # convert leading spaces into tabs
1440options SC_CUT_SEPCHARS=\"x09\" # set of characters that delimit words
1441 # (default is single space - \"x20\")
1442
1443# If you have a two button mouse, you may want to add the following option
1444# to use the right button of the mouse to paste text.
1445options SC_TWOBUTTON_MOUSE
1446
1447# You can selectively disable features in syscons.
1448options SC_NO_CUTPASTE
1449options SC_NO_FONT_LOADING
1450options SC_NO_HISTORY
1451options SC_NO_MODE_CHANGE
1452options SC_NO_SYSMOUSE
1453options SC_NO_SUSPEND_VTYSWITCH
1454
1455# `flags' for sc
1456# 0x80 Put the video card in the VESA 800x600 dots, 16 color mode
1457# 0x100 Probe for a keyboard device periodically if one is not present
1458
1459# Enable experimental features of the syscons terminal emulator (teken).
1460options TEKEN_CONS25 # cons25-style terminal emulation
1461options TEKEN_UTF8 # UTF-8 output handling
1462
1463#
1464# Optional devices:
1465#
1466
1467#
1468# SCSI host adapters:
1469#
1470# adv: All Narrow SCSI bus AdvanSys controllers.
1471# adw: Second Generation AdvanSys controllers including the ADV940UW.
1472# aha: Adaptec 154x/1535/1640
1473# ahb: Adaptec 174x EISA controllers
1474# ahc: Adaptec 274x/284x/2910/293x/294x/394x/3950x/3960x/398X/4944/
1475# 19160x/29160x, aic7770/aic78xx
1476# ahd: Adaptec 29320/39320 Controllers.
1477# aic: Adaptec 6260/6360, APA-1460 (PC Card), NEC PC9801-100 (C-BUS)
1478# bt: Most Buslogic controllers: including BT-445, BT-54x, BT-64x, BT-74x,
1479# BT-75x, BT-946, BT-948, BT-956, BT-958, SDC3211B, SDC3211F, SDC3222F
1480# esp: Emulex ESP, NCR 53C9x and QLogic FAS families based controllers
1481# including the AMD Am53C974 (found on devices such as the Tekram
1482# DC-390(T)) and the Sun ESP and FAS families of controllers
1483# isp: Qlogic ISP 1020, 1040 and 1040B PCI SCSI host adapters,
1484# ISP 1240 Dual Ultra SCSI, ISP 1080 and 1280 (Dual) Ultra2,
1485# ISP 12160 Ultra3 SCSI,
1486# Qlogic ISP 2100 and ISP 2200 1Gb Fibre Channel host adapters.
1487# Qlogic ISP 2300 and ISP 2312 2Gb Fibre Channel host adapters.
1488# Qlogic ISP 2322 and ISP 6322 2Gb Fibre Channel host adapters.
1489# ispfw: Firmware module for Qlogic host adapters
1490# mpt: LSI-Logic MPT/Fusion 53c1020 or 53c1030 Ultra4
1491# or FC9x9 Fibre Channel host adapters.
1492# ncr: NCR 53C810, 53C825 self-contained SCSI host adapters.
1493# sym: Symbios/Logic 53C8XX family of PCI-SCSI I/O processors:
1494# 53C810, 53C810A, 53C815, 53C825, 53C825A, 53C860, 53C875,
1495# 53C876, 53C885, 53C895, 53C895A, 53C896, 53C897, 53C1510D,
1496# 53C1010-33, 53C1010-66.
1497# trm: Tekram DC395U/UW/F DC315U adapters.
1498# wds: WD7000
1499
1500#
1501# Note that the order is important in order for Buslogic ISA/EISA cards to be
1502# probed correctly.
1503#
1504device bt
1505hint.bt.0.at="isa"
1506hint.bt.0.port="0x330"
1507device adv
1508hint.adv.0.at="isa"
1509device adw
1510device aha
1511hint.aha.0.at="isa"
1512device aic
1513hint.aic.0.at="isa"
1514device ahb
1515device ahc
1516device ahd
1517device esp
1518device iscsi_initiator
1519device isp
1520hint.isp.0.disable="1"
1521hint.isp.0.role="3"
1522hint.isp.0.prefer_iomap="1"
1523hint.isp.0.prefer_memmap="1"
1524hint.isp.0.fwload_disable="1"
1525hint.isp.0.ignore_nvram="1"
1526hint.isp.0.fullduplex="1"
1527hint.isp.0.topology="lport"
1528hint.isp.0.topology="nport"
1529hint.isp.0.topology="lport-only"
1530hint.isp.0.topology="nport-only"
1531# we can't get u_int64_t types, nor can we get strings if it's got
1532# a leading 0x, hence this silly dodge.
1533hint.isp.0.portwnn="w50000000aaaa0000"
1534hint.isp.0.nodewnn="w50000000aaaa0001"
1535device ispfw
1536device mpt
1537device ncr
1538device sym
1539device trm
1540device wds
1541hint.wds.0.at="isa"
1542hint.wds.0.port="0x350"
1543hint.wds.0.irq="11"
1544hint.wds.0.drq="6"
1545
1546# The aic7xxx driver will attempt to use memory mapped I/O for all PCI
1547# controllers that have it configured only if this option is set. Unfortunately,
1548# this doesn't work on some motherboards, which prevents it from being the
1549# default.
1550options AHC_ALLOW_MEMIO
1551
1552# Dump the contents of the ahc controller configuration PROM.
1553options AHC_DUMP_EEPROM
1554
1555# Bitmap of units to enable targetmode operations.
1556options AHC_TMODE_ENABLE
1557
1558# Compile in Aic7xxx Debugging code.
1559options AHC_DEBUG
1560
1561# Aic7xxx driver debugging options. See sys/dev/aic7xxx/aic7xxx.h
1562options AHC_DEBUG_OPTS
1563
1564# Print register bitfields in debug output. Adds ~128k to driver
1565# See ahc(4).
1566options AHC_REG_PRETTY_PRINT
1567
1568# Compile in aic79xx debugging code.
1569options AHD_DEBUG
1570
1571# Aic79xx driver debugging options. Adds ~215k to driver. See ahd(4).
1572options AHD_DEBUG_OPTS=0xFFFFFFFF
1573
1574# Print human-readable register definitions when debugging
1575options AHD_REG_PRETTY_PRINT
1576
1577# Bitmap of units to enable targetmode operations.
1578options AHD_TMODE_ENABLE
1579
1580# The adw driver will attempt to use memory mapped I/O for all PCI
1581# controllers that have it configured only if this option is set.
1582options ADW_ALLOW_MEMIO
1583
1584# Options used in dev/iscsi (Software iSCSI stack)
1585#
1586options ISCSI_INITIATOR_DEBUG=9
1587
1588# Options used in dev/isp/ (Qlogic SCSI/FC driver).
1589#
1590# ISP_TARGET_MODE - enable target mode operation
1591#
1592options ISP_TARGET_MODE=1
1593#
1594# ISP_DEFAULT_ROLES - default role
1595# none=0
1596# target=1
1597# initiator=2
1598# both=3 (not supported currently)
1599#
1600# ISP_INTERNAL_TARGET (trivial internal disk target, for testing)
1601#
1602options ISP_DEFAULT_ROLES=2
1603
1604# Options used in dev/sym/ (Symbios SCSI driver).
1605#options SYM_SETUP_LP_PROBE_MAP #-Low Priority Probe Map (bits)
1606 # Allows the ncr to take precedence
1607 # 1 (1<<0) -> 810a, 860
1608 # 2 (1<<1) -> 825a, 875, 885, 895
1609 # 4 (1<<2) -> 895a, 896, 1510d
1610#options SYM_SETUP_SCSI_DIFF #-HVD support for 825a, 875, 885
1611 # disabled:0 (default), enabled:1
1612#options SYM_SETUP_PCI_PARITY #-PCI parity checking
1613 # disabled:0, enabled:1 (default)
1614#options SYM_SETUP_MAX_LUN #-Number of LUNs supported
1615 # default:8, range:[1..64]
1616
1617# The 'dpt' driver provides support for old DPT controllers (http://www.dpt.com/).
1618# These have hardware RAID-{0,1,5} support, and do multi-initiator I/O.
1619# The DPT controllers are commonly re-licensed under other brand-names -
1620# some controllers by Olivetti, Dec, HP, AT&T, SNI, AST, Alphatronic, NEC and
1621# Compaq are actually DPT controllers.
1622#
1623# See src/sys/dev/dpt for debugging and other subtle options.
1624# DPT_MEASURE_PERFORMANCE Enables a set of (semi)invasive metrics. Various
1625# instruments are enabled. The tools in
1626# /usr/sbin/dpt_* assume these to be enabled.
1627# DPT_HANDLE_TIMEOUTS Normally device timeouts are handled by the DPT.
1628# If you want the driver to handle timeouts, enable
1629# this option. If your system is very busy, this
1630# option will create more trouble than solve.
1631# DPT_TIMEOUT_FACTOR Used to compute the excessive amount of time to
1632# wait when timing out with the above option.
1633# DPT_DEBUG_xxxx These are controllable from sys/dev/dpt/dpt.h
1634# DPT_LOST_IRQ When enabled, will try, once per second, to catch
1635# any interrupt that got lost. Seems to help in some
1636# DPT-firmware/Motherboard combinations. Minimal
1637# cost, great benefit.
1638# DPT_RESET_HBA Make "reset" actually reset the controller
1639# instead of fudging it. Only enable this if you
1640# are 100% certain you need it.
1641
1642device dpt
1643
1644# DPT options
1645#!CAM# options DPT_MEASURE_PERFORMANCE
1646#!CAM# options DPT_HANDLE_TIMEOUTS
1647options DPT_TIMEOUT_FACTOR=4
1648options DPT_LOST_IRQ
1649options DPT_RESET_HBA
1650
1651#
1652# Compaq "CISS" RAID controllers (SmartRAID 5* series)
1653# These controllers have a SCSI-like interface, and require the
1654# CAM infrastructure.
1655#
1656device ciss
1657
1658#
1659# Intel Integrated RAID controllers.
1660# This driver was developed and is maintained by Intel. Contacts
1661# at Intel for this driver are
1662# "Kannanthanam, Boji T" <boji.t.kannanthanam@intel.com> and
1663# "Leubner, Achim" <achim.leubner@intel.com>.
1664#
1665device iir
1666
1667#
1668# Mylex AcceleRAID and eXtremeRAID controllers with v6 and later
1669# firmware. These controllers have a SCSI-like interface, and require
1670# the CAM infrastructure.
1671#
1672device mly
1673
1674#
1675# Compaq Smart RAID, Mylex DAC960 and AMI MegaRAID controllers. Only
1676# one entry is needed; the code will find and configure all supported
1677# controllers.
1678#
1679device ida # Compaq Smart RAID
1680device mlx # Mylex DAC960
1681device amr # AMI MegaRAID
1682device amrp # SCSI Passthrough interface (optional, CAM req.)
1683device mfi # LSI MegaRAID SAS
1684device mfip # LSI MegaRAID SAS passthrough, requires CAM
1685options MFI_DEBUG
1686
1687#
1688# 3ware ATA RAID
1689#
1690device twe # 3ware ATA RAID
1691
1692#
1693# Serial ATA host controllers:
1694#
1695# ahci: Advanced Host Controller Interface (AHCI) compatible
1696# mvs: Marvell 88SX50XX/88SX60XX/88SX70XX/SoC controllers
1697# siis: SiliconImage SiI3124/SiI3132/SiI3531 controllers
1698#
1699# These drivers are part of cam(4) subsystem. They supersede less featured
1700# ata(4) subsystem drivers, supporting same hardware.
1701
1702device ahci
1703device mvs
1704device siis
1705
1706#
1707# The 'ATA' driver supports all ATA and ATAPI devices, including PC Card
1708# devices. You only need one "device ata" for it to find all
1709# PCI and PC Card ATA/ATAPI devices on modern machines.
1710# Alternatively, individual bus and chipset drivers may be chosen by using
1711# the 'atacore' driver then selecting the drivers on a per vendor basis.
1712# For example to build a system which only supports a VIA chipset,
1713# omit 'ata' and include the 'atacore', 'atapci' and 'atavia' drivers.
1714device ata
1715device atadisk # ATA disk drives
1716device ataraid # ATA RAID drives
1717device atapicd # ATAPI CDROM drives
1718device atapifd # ATAPI floppy drives
1719device atapist # ATAPI tape drives
1720device atapicam # emulate ATAPI devices as SCSI ditto via CAM
1721 # needs CAM to be present (scbus & pass)
1722
1723# Modular ATA
1724#device atacore # Core ATA functionality
1725#device atacard # CARDBUS support
1726#device atabus # PC98 cbus support
1727#device ataisa # ISA bus support
1728#device atapci # PCI bus support; only generic chipset support
1729
1730# PCI ATA chipsets
1731#device ataahci # AHCI SATA
1732#device ataacard # ACARD
1733#device ataacerlabs # Acer Labs Inc. (ALI)
1734#device ataadaptec # Adaptec
1735#device ataamd # American Micro Devices (AMD)
1736#device ataati # ATI
1737#device atacenatek # Cenatek
1738#device atacypress # Cypress
1739#device atacyrix # Cyrix
1740#device atahighpoint # HighPoint
1741#device ataintel # Intel
1742#device ataite # Integrated Technology Inc. (ITE)
1743#device atajmicron # JMicron
1744#device atamarvell # Marvell
1745#device atamicron # Micron
1746#device atanational # National
1747#device atanetcell # NetCell
1748#device atanvidia # nVidia
1749#device atapromise # Promise
1750#device ataserverworks # ServerWorks
1751#device atasiliconimage # Silicon Image Inc. (SiI) (formerly CMD)
1752#device atasis # Silicon Integrated Systems Corp.(SiS)
1753#device atavia # VIA Technologies Inc.
1754
1755#
1756# For older non-PCI, non-PnPBIOS systems, these are the hints lines to add:
1757hint.ata.0.at="isa"
1758hint.ata.0.port="0x1f0"
1759hint.ata.0.irq="14"
1760hint.ata.1.at="isa"
1761hint.ata.1.port="0x170"
1762hint.ata.1.irq="15"
1763
1764#
1765# The following options are valid on the ATA driver:
1766#
1767# ATA_STATIC_ID: controller numbering is static ie depends on location
1768# else the device numbers are dynamically allocated.
1769# ATA_REQUEST_TIMEOUT: the number of seconds to wait for an ATA request
1770# before timing out.
1771# ATA_CAM: Turn ata(4) subsystem controller drivers into cam(4)
1772# interface modules. This deprecates all ata(4)
1773# peripheral device drivers (atadisk, ataraid, atapicd,
1774# atapifd, atapist, atapicam) and all user-level APIs.
1775# cam(4) drivers and APIs will be connected instead.
1776
1777options ATA_STATIC_ID
1778#options ATA_REQUEST_TIMEOUT=10
1779options ATA_CAM
1780
1781#
1782# Standard floppy disk controllers and floppy tapes, supports
1783# the Y-E DATA External FDD (PC Card)
1784#
1785device fdc
1786hint.fdc.0.at="isa"
1787hint.fdc.0.port="0x3F0"
1788hint.fdc.0.irq="6"
1789hint.fdc.0.drq="2"
1790#
1791# FDC_DEBUG enables floppy debugging. Since the debug output is huge, you
1792# gotta turn it actually on by setting the variable fd_debug with DDB,
1793# however.
1794options FDC_DEBUG
1795#
1796# Activate this line if you happen to have an Insight floppy tape.
1797# Probing them proved to be dangerous for people with floppy disks only,
1798# so it's "hidden" behind a flag:
1799#hint.fdc.0.flags="1"
1800
1801# Specify floppy devices
1802hint.fd.0.at="fdc0"
1803hint.fd.0.drive="0"
1804hint.fd.1.at="fdc0"
1805hint.fd.1.drive="1"
1806
1807#
1808# uart: newbusified driver for serial interfaces. It consolidates the sio(4),
1809# sab(4) and zs(4) drivers.
1810#
1811device uart
1812
1813# Options for uart(4)
1814options UART_PPS_ON_CTS # Do time pulse capturing using CTS
1815 # instead of DCD.
1816
1817# The following hint should only be used for pure ISA devices. It is not
1818# needed otherwise. Use of hints is strongly discouraged.
1819hint.uart.0.at="isa"
1820
1821# The following 3 hints are used when the UART is a system device (i.e., a
1822# console or debug port), but only on platforms that don't have any other
1823# means to pass the information to the kernel. The unit number of the hint
1824# is only used to bundle the hints together. There is no relation to the
1825# unit number of the probed UART.
1826hint.uart.0.port="0x3f8"
1827hint.uart.0.flags="0x10"
1828hint.uart.0.baud="115200"
1829
1830# `flags' for serial drivers that support consoles like sio(4) and uart(4):
1831# 0x10 enable console support for this unit. Other console flags
1832# (if applicable) are ignored unless this is set. Enabling
1833# console support does not make the unit the preferred console.
1834# Boot with -h or set boot_serial=YES in the loader. For sio(4)
1835# specifically, the 0x20 flag can also be set (see above).
1836# Currently, at most one unit can have console support; the
1837# first one (in config file order) with this flag set is
1838# preferred. Setting this flag for sio0 gives the old behavior.
1839# 0x80 use this port for serial line gdb support in ddb. Also known
1840# as debug port.
1841#
1842
1843# Options for serial drivers that support consoles:
1844options BREAK_TO_DEBUGGER # A BREAK on a serial console goes to
1845 # ddb, if available.
1846
1847# Solaris implements a new BREAK which is initiated by a character
1848# sequence CR ~ ^b which is similar to a familiar pattern used on
1849# Sun servers by the Remote Console. There are FreeBSD extensions:
1850# CR ~ ^p requests force panic and CR ~ ^r requests a clean reboot.
1851options ALT_BREAK_TO_DEBUGGER
1852
1853# Serial Communications Controller
1854# Supports the Siemens SAB 82532 and Zilog Z8530 multi-channel
1855# communications controllers.
1856device scc
1857
1858# PCI Universal Communications driver
1859# Supports various multi port PCI I/O cards.
1860device puc
1861
1862#
1863# Network interfaces:
1864#
1865# MII bus support is required for many PCI Ethernet NICs,
1866# namely those which use MII-compliant transceivers or implement
1867# transceiver control interfaces that operate like an MII. Adding
1868# "device miibus" to the kernel config pulls in support for the generic
1869# miibus API, the common support for for bit-bang'ing the MII and all
1870# of the PHY drivers, including a generic one for PHYs that aren't
1871# specifically handled by an individual driver. Support for specific
1872# PHYs may be built by adding "device mii", "device mii_bitbang" if
1873# needed by the NIC driver and then adding the appropriate PHY driver.
1874device mii # Minimal MII support
1875device mii_bitbang # Common module for bit-bang'ing the MII
1876device miibus # MII support w/ bit-bang'ing and all PHYs
1877
1878device acphy # Altima Communications AC101
1879device amphy # AMD AM79c873 / Davicom DM910{1,2}
1880device atphy # Attansic/Atheros F1
1881device axphy # Asix Semiconductor AX88x9x
1882device bmtphy # Broadcom BCM5201/BCM5202 and 3Com 3c905C
1883device brgphy # Broadcom BCM54xx/57xx 1000baseTX
1884device ciphy # Cicada/Vitesse CS/VSC8xxx
1885device e1000phy # Marvell 88E1000 1000/100/10-BT
1886device gentbi # Generic 10-bit 1000BASE-{LX,SX} fiber ifaces
1887device icsphy # ICS ICS1889-1893
1888device ip1000phy # IC Plus IP1000A/IP1001
1889device jmphy # JMicron JMP211/JMP202
1890device lxtphy # Level One LXT-970
1891device mlphy # Micro Linear 6692
1892device nsgphy # NatSemi DP8361/DP83865/DP83891
1893device nsphy # NatSemi DP83840A
1894device nsphyter # NatSemi DP83843/DP83815
1895device pnaphy # HomePNA
1896device qsphy # Quality Semiconductor QS6612
1897device rdcphy # RDC Semiconductor R6040
1898device rgephy # RealTek 8169S/8110S/8211B/8211C
1899device rlphy # RealTek 8139
1900device rlswitch # RealTek 8305
1901device smcphy # SMSC LAN91C111
1902device tdkphy # TDK 89Q2120
1903device tlphy # Texas Instruments ThunderLAN
1904device truephy # LSI TruePHY
1905device xmphy # XaQti XMAC II
1906
1907# an: Aironet 4500/4800 802.11 wireless adapters. Supports the PCMCIA,
1908# PCI and ISA varieties.
1909# ae: Support for gigabit ethernet adapters based on the Attansic/Atheros
1910# L2 PCI-Express FastEthernet controllers.
1911# age: Support for gigabit ethernet adapters based on the Attansic/Atheros
1912# L1 PCI express gigabit ethernet controllers.
1913# alc: Support for Atheros AR8131/AR8132 PCIe ethernet controllers.
1914# ale: Support for Atheros AR8121/AR8113/AR8114 PCIe ethernet controllers.
1915# ath: Atheros a/b/g WiFi adapters (requires ath_hal and wlan)
1916# bce: Broadcom NetXtreme II (BCM5706/BCM5708) PCI/PCIe Gigabit Ethernet
1917# adapters.
1918# bfe: Broadcom BCM4401 Ethernet adapter.
1919# bge: Support for gigabit ethernet adapters based on the Broadcom
1920# BCM570x family of controllers, including the 3Com 3c996-T,
1921# the Netgear GA302T, the SysKonnect SK-9D21 and SK-9D41, and
1922# the embedded gigE NICs on Dell PowerEdge 2550 servers.
1923# bxe: Broadcom NetXtreme II (BCM57710/57711/57711E) PCIe 10b Ethernet
1924# adapters.
1925# bwi: Broadcom BCM430* and BCM431* family of wireless adapters.
1926# bwn: Broadcom BCM43xx family of wireless adapters.
1927# cas: Sun Cassini/Cassini+ and National Semiconductor DP83065 Saturn
1928# cm: Arcnet SMC COM90c26 / SMC COM90c56
1929# (and SMC COM90c66 in '56 compatibility mode) adapters.
1930# cxgbe: Support for PCI express 10Gb/1Gb adapters based on the Chelsio T4
1931# (Terminator 4) ASIC.
1932# dc: Support for PCI fast ethernet adapters based on the DEC/Intel 21143
1933# and various workalikes including:
1934# the ADMtek AL981 Comet and AN985 Centaur, the ASIX Electronics
1935# AX88140A and AX88141, the Davicom DM9100 and DM9102, the Lite-On
1936# 82c168 and 82c169 PNIC, the Lite-On/Macronix LC82C115 PNIC II
1937# and the Macronix 98713/98713A/98715/98715A/98725 PMAC. This driver
1938# replaces the old al, ax, dm, pn and mx drivers. List of brands:
1939# Digital DE500-BA, Kingston KNE100TX, D-Link DFE-570TX, SOHOware SFA110,
1940# SVEC PN102-TX, CNet Pro110B, 120A, and 120B, Compex RL100-TX,
1941# LinkSys LNE100TX, LNE100TX V2.0, Jaton XpressNet, Alfa Inc GFC2204,
1942# KNE110TX.
1943# de: Digital Equipment DC21040
1944# em: Intel Pro/1000 Gigabit Ethernet 82542, 82543, 82544 based adapters.
1945# igb: Intel Pro/1000 PCI Express Gigabit Ethernet: 82575 and later adapters.
1946# ep: 3Com 3C509, 3C529, 3C556, 3C562D, 3C563D, 3C572, 3C574X, 3C579, 3C589
1947# and PC Card devices using these chipsets.
1948# ex: Intel EtherExpress Pro/10 and other i82595-based adapters,
1949# Olicom Ethernet PC Card devices.
1950# fe: Fujitsu MB86960A/MB86965A Ethernet
1951# fea: DEC DEFEA EISA FDDI adapter
1952# fpa: Support for the Digital DEFPA PCI FDDI. `device fddi' is also needed.
1953# fxp: Intel EtherExpress Pro/100B
1954# (hint of prefer_iomap can be done to prefer I/O instead of Mem mapping)
1955# gem: Apple GMAC/Sun ERI/Sun GEM
1956# hme: Sun HME (Happy Meal Ethernet)
1957# jme: JMicron JMC260 Fast Ethernet/JMC250 Gigabit Ethernet based adapters.
1958# le: AMD Am7900 LANCE and Am79C9xx PCnet
1959# lge: Support for PCI gigabit ethernet adapters based on the Level 1
1960# LXT1001 NetCellerator chipset. This includes the D-Link DGE-500SX,
1961# SMC TigerCard 1000 (SMC9462SX), and some Addtron cards.
1962# malo: Marvell Libertas wireless NICs.
1963# mwl: Marvell 88W8363 802.11n wireless NICs.
1964# msk: Support for gigabit ethernet adapters based on the Marvell/SysKonnect
1965# Yukon II Gigabit controllers, including 88E8021, 88E8022, 88E8061,
1966# 88E8062, 88E8035, 88E8036, 88E8038, 88E8050, 88E8052, 88E8053,
1967# 88E8055, 88E8056 and D-Link 560T/550SX.
1968# lmc: Support for the LMC/SBE wide-area network interface cards.
1969# my: Myson Fast Ethernet (MTD80X, MTD89X)
1970# nge: Support for PCI gigabit ethernet adapters based on the National
1971# Semiconductor DP83820 and DP83821 chipset. This includes the
1972# SMC EZ Card 1000 (SMC9462TX), D-Link DGE-500T, Asante FriendlyNet
1973# GigaNIX 1000TA and 1000TPC, the Addtron AEG320T, the Surecom
1974# EP-320G-TX and the Netgear GA622T.
1975# oce: Emulex 10 Gbit adapters (OneConnect Ethernet)
1976# pcn: Support for PCI fast ethernet adapters based on the AMD Am79c97x
1977# PCnet-FAST, PCnet-FAST+, PCnet-FAST III, PCnet-PRO and PCnet-Home
1978# chipsets. These can also be handled by the le(4) driver if the
1979# pcn(4) driver is left out of the kernel. The le(4) driver does not
1980# support the additional features like the MII bus and burst mode of
1981# the PCnet-FAST and greater chipsets though.
1982# ral: Ralink Technology IEEE 802.11 wireless adapter
1983# re: RealTek 8139C+/8169/816xS/811xS/8101E PCI/PCIe Ethernet adapter
1984# rl: Support for PCI fast ethernet adapters based on the RealTek 8129/8139
1985# chipset. Note that the RealTek driver defaults to using programmed
1986# I/O to do register accesses because memory mapped mode seems to cause
1987# severe lockups on SMP hardware. This driver also supports the
1988# Accton EN1207D `Cheetah' adapter, which uses a chip called
1989# the MPX 5030/5038, which is either a RealTek in disguise or a
1990# RealTek workalike. Note that the D-Link DFE-530TX+ uses the RealTek
1991# chipset and is supported by this driver, not the 'vr' driver.
1992# sf: Support for Adaptec Duralink PCI fast ethernet adapters based on the
1993# Adaptec AIC-6915 "starfire" controller.
1994# This includes dual and quad port cards, as well as one 100baseFX card.
1995# Most of these are 64-bit PCI devices, except for one single port
1996# card which is 32-bit.
1997# sge: Silicon Integrated Systems SiS190/191 Fast/Gigabit Ethernet adapter
1998# sis: Support for NICs based on the Silicon Integrated Systems SiS 900,
1999# SiS 7016 and NS DP83815 PCI fast ethernet controller chips.
2000# sk: Support for the SysKonnect SK-984x series PCI gigabit ethernet NICs.
2001# This includes the SK-9841 and SK-9842 single port cards (single mode
2002# and multimode fiber) and the SK-9843 and SK-9844 dual port cards
2003# (also single mode and multimode).
2004# The driver will autodetect the number of ports on the card and
2005# attach each one as a separate network interface.
2006# sn: Support for ISA and PC Card Ethernet devices using the
2007# SMC91C90/92/94/95 chips.
2008# ste: Sundance Technologies ST201 PCI fast ethernet controller, includes
2009# the D-Link DFE-550TX.
2010# stge: Support for gigabit ethernet adapters based on the Sundance/Tamarack
2011# TC9021 family of controllers, including the Sundance ST2021/ST2023,
2012# the Sundance/Tamarack TC9021, the D-Link DL-4000 and ASUS NX1101.
2013# ti: Support for PCI gigabit ethernet NICs based on the Alteon Networks
2014# Tigon 1 and Tigon 2 chipsets. This includes the Alteon AceNIC, the
2015# 3Com 3c985, the Netgear GA620 and various others. Note that you will
2016# probably want to bump up kern.ipc.nmbclusters a lot to use this driver.
2017# tl: Support for the Texas Instruments TNETE100 series 'ThunderLAN'
2018# cards and integrated ethernet controllers. This includes several
2019# Compaq Netelligent 10/100 cards and the built-in ethernet controllers
2020# in several Compaq Prosignia, Proliant and Deskpro systems. It also
2021# supports several Olicom 10Mbps and 10/100 boards.
2022# tx: SMC 9432 TX, BTX and FTX cards. (SMC EtherPower II series)
2023# txp: Support for 3Com 3cR990 cards with the "Typhoon" chipset
2024# vr: Support for various fast ethernet adapters based on the VIA
2025# Technologies VT3043 `Rhine I' and VT86C100A `Rhine II' chips,
2026# including the D-Link DFE520TX and D-Link DFE530TX (see 'rl' for
2027# DFE530TX+), the Hawking Technologies PN102TX, and the AOpen/Acer ALN-320.
2028# vte: DM&P Vortex86 RDC R6040 Fast Ethernet
2029# vx: 3Com 3C590 and 3C595
2030# wb: Support for fast ethernet adapters based on the Winbond W89C840F chip.
2031# Note: this is not the same as the Winbond W89C940F, which is a
2032# NE2000 clone.
2033# wi: Lucent WaveLAN/IEEE 802.11 PCMCIA adapters. Note: this supports both
2034# the PCMCIA and ISA cards: the ISA card is really a PCMCIA to ISA
2035# bridge with a PCMCIA adapter plugged into it.
2036# xe: Xircom/Intel EtherExpress Pro100/16 PC Card ethernet controller,
2037# Accton Fast EtherCard-16, Compaq Netelligent 10/100 PC Card,
2038# Toshiba 10/100 Ethernet PC Card, Xircom 16-bit Ethernet + Modem 56
2039# xl: Support for the 3Com 3c900, 3c905, 3c905B and 3c905C (Fast)
2040# Etherlink XL cards and integrated controllers. This includes the
2041# integrated 3c905B-TX chips in certain Dell Optiplex and Dell
2042# Precision desktop machines and the integrated 3c905-TX chips
2043# in Dell Latitude laptop docking stations.
2044# Also supported: 3Com 3c980(C)-TX, 3Com 3cSOHO100-TX, 3Com 3c450-TX
2045
2046# Order for ISA/EISA devices is important here
2047
2048device cm
2049hint.cm.0.at="isa"
2050hint.cm.0.port="0x2e0"
2051hint.cm.0.irq="9"
2052hint.cm.0.maddr="0xdc000"
2053device ep
2054device ex
2055device fe
2056hint.fe.0.at="isa"
2057hint.fe.0.port="0x300"
2058device fea
2059device sn
2060hint.sn.0.at="isa"
2061hint.sn.0.port="0x300"
2062hint.sn.0.irq="10"
2063device an
2064device wi
2065device xe
2066
2067# PCI Ethernet NICs that use the common MII bus controller code.
2068device ae # Attansic/Atheros L2 FastEthernet
2069device age # Attansic/Atheros L1 Gigabit Ethernet
2070device alc # Atheros AR8131/AR8132 Ethernet
2071device ale # Atheros AR8121/AR8113/AR8114 Ethernet
2072device bce # Broadcom BCM5706/BCM5708 Gigabit Ethernet
2073device bfe # Broadcom BCM440x 10/100 Ethernet
2074device bge # Broadcom BCM570xx Gigabit Ethernet
2075device cas # Sun Cassini/Cassini+ and NS DP83065 Saturn
2076device cxgb # Chelsio T3 10 Gigabit Ethernet
2077device cxgb_t3fw # Chelsio T3 10 Gigabit Ethernet firmware
2078device dc # DEC/Intel 21143 and various workalikes
2079device et # Agere ET1310 10/100/Gigabit Ethernet
2080device fxp # Intel EtherExpress PRO/100B (82557, 82558)
2081hint.fxp.0.prefer_iomap="0"
2082device gem # Apple GMAC/Sun ERI/Sun GEM
2083device hme # Sun HME (Happy Meal Ethernet)
2084device jme # JMicron JMC250 Gigabit/JMC260 Fast Ethernet
2085device lge # Level 1 LXT1001 gigabit Ethernet
2086device msk # Marvell/SysKonnect Yukon II Gigabit Ethernet
2087device my # Myson Fast Ethernet (MTD80X, MTD89X)
2088device nge # NatSemi DP83820 gigabit Ethernet
2089device re # RealTek 8139C+/8169/8169S/8110S
2090device rl # RealTek 8129/8139
2091device pcn # AMD Am79C97x PCI 10/100 NICs
2092device sf # Adaptec AIC-6915 (``Starfire'')
2093device sge # Silicon Integrated Systems SiS190/191
2094device sis # Silicon Integrated Systems SiS 900/SiS 7016
2095device sk # SysKonnect SK-984x & SK-982x gigabit Ethernet
2096device ste # Sundance ST201 (D-Link DFE-550TX)
2097device stge # Sundance/Tamarack TC9021 gigabit Ethernet
2098device tl # Texas Instruments ThunderLAN
2099device tx # SMC EtherPower II (83c170 ``EPIC'')
2100device vr # VIA Rhine, Rhine II
2101device vte # DM&P Vortex86 RDC R6040 Fast Ethernet
2102device wb # Winbond W89C840F
2103device xl # 3Com 3c90x (``Boomerang'', ``Cyclone'')
2104
2105# PCI Ethernet NICs.
2106device bxe # Broadcom BCM57710/BCM57711/BCM57711E 10Gb Ethernet
2107device cxgbe # Chelsio T4 10GbE PCIe adapter
2108device de # DEC/Intel DC21x4x (``Tulip'')
2109device em # Intel Pro/1000 Gigabit Ethernet
2110device igb # Intel Pro/1000 PCIE Gigabit Ethernet
2111device ixgb # Intel Pro/10Gbe PCI-X Ethernet
2112device ixgbe # Intel Pro/10Gbe PCIE Ethernet
2113device le # AMD Am7900 LANCE and Am79C9xx PCnet
2114device mxge # Myricom Myri-10G 10GbE NIC
2115device nxge # Neterion Xframe 10GbE Server/Storage Adapter
2116device oce # Emulex 10 GbE (OneConnect Ethernet)
2117device ti # Alteon Networks Tigon I/II gigabit Ethernet
2118device txp # 3Com 3cR990 (``Typhoon'')
2119device vx # 3Com 3c590, 3c595 (``Vortex'')
2120device vxge # Exar/Neterion XFrame 3100 10GbE
2121
2122# PCI FDDI NICs.
2123device fpa
2124
2125# PCI WAN adapters.
2126device lmc
2127
2128# PCI IEEE 802.11 Wireless NICs
2129device ath # Atheros pci/cardbus NIC's
2130device ath_hal # pci/cardbus chip support
2131#device ath_ar5210 # AR5210 chips
2132#device ath_ar5211 # AR5211 chips
2133#device ath_ar5212 # AR5212 chips
2134#device ath_rf2413
2135#device ath_rf2417
2136#device ath_rf2425
2137#device ath_rf5111
2138#device ath_rf5112
2139#device ath_rf5413
2140#device ath_ar5416 # AR5416 chips
2141options AH_SUPPORT_AR5416 # enable AR5416 tx/rx descriptors
2142# All of the AR5212 parts have a problem when paired with the AR71xx
2143# CPUS. These parts have a bug that triggers a fatal bus error on the AR71xx
2144# only. Details of the exact nature of the bug are sketchy, but some can be
2145# found at https://forum.openwrt.org/viewtopic.php?pid=70060 on pages 4, 5 and
2146# 6. This option enables this workaround. There is a performance penalty
2147# for this work around, but without it things don't work at all. The DMA
2148# from the card usually bursts 128 bytes, but on the affected CPUs, only
2149# 4 are safe.
2150options AH_RXCFG_SDMAMW_4BYTES
2151#device ath_ar9160 # AR9160 chips
2152#device ath_ar9280 # AR9280 chips
2153#device ath_ar9285 # AR9285 chips
2154device ath_rate_sample # SampleRate tx rate control for ath
2155device bwi # Broadcom BCM430* BCM431*
2156device bwn # Broadcom BCM43xx
2157device malo # Marvell Libertas wireless NICs.
2158device mwl # Marvell 88W8363 802.11n wireless NICs.
2159device ral # Ralink Technology RT2500 wireless NICs.
2160
2161# Use sf_buf(9) interface for jumbo buffers on ti(4) controllers.
2162#options TI_SF_BUF_JUMBO
2163# Turn on the header splitting option for the ti(4) driver firmware. This
2164# only works for Tigon II chips, and has no effect for Tigon I chips.
2165# This option requires the TI_SF_BUF_JUMBO option above.
2166#options TI_JUMBO_HDRSPLIT
2167
2168#
2169# Use header splitting feature on bce(4) adapters.
2170# This may help to reduce the amount of jumbo-sized memory buffers used.
2171#
2172options BCE_JUMBO_HDRSPLIT
2173
2174# These two options allow manipulating the mbuf cluster size and mbuf size,
2175# respectively. Be very careful with NIC driver modules when changing
2176# these from their default values, because that can potentially cause a
2177# mismatch between the mbuf size assumed by the kernel and the mbuf size
2178# assumed by a module. The only driver that currently has the ability to
2179# detect a mismatch is ti(4).
2180options MCLSHIFT=12 # mbuf cluster shift in bits, 12 == 4KB
2181options MSIZE=512 # mbuf size in bytes
2182
2183#
2184# ATM related options (Cranor version)
2185# (note: this driver cannot be used with the HARP ATM stack)
2186#
2187# The `en' device provides support for Efficient Networks (ENI)
2188# ENI-155 PCI midway cards, and the Adaptec 155Mbps PCI ATM cards (ANA-59x0).
2189#
2190# The `hatm' device provides support for Fore/Marconi HE155 and HE622
2191# ATM PCI cards.
2192#
2193# The `fatm' device provides support for Fore PCA200E ATM PCI cards.
2194#
2195# The `patm' device provides support for IDT77252 based cards like
2196# ProSum's ProATM-155 and ProATM-25 and IDT's evaluation boards.
2197#
2198# atm device provides generic atm functions and is required for
2199# atm devices.
2200# NATM enables the netnatm protocol family that can be used to
2201# bypass TCP/IP.
2202#
2203# utopia provides the access to the ATM PHY chips and is required for en,
2204# hatm and fatm.
2205#
2206# the current driver supports only PVC operations (no atm-arp, no multicast).
2207# for more details, please read the original documents at
2208# http://www.ccrc.wustl.edu/pub/chuck/tech/bsdatm/bsdatm.html
2209#
2210device atm
2211device en
2212device fatm #Fore PCA200E
2213device hatm #Fore/Marconi HE155/622
2214device patm #IDT77252 cards (ProATM and IDT)
2215device utopia #ATM PHY driver
2216options NATM #native ATM
2217
2218options LIBMBPOOL #needed by patm, iatm
2219
2220#
2221# Sound drivers
2222#
2223# sound: The generic sound driver.
2224#
2225
2226device sound
2227
2228#
2229# snd_*: Device-specific drivers.
2230#
2231# The flags of the device tell the device a bit more info about the
2232# device that normally is obtained through the PnP interface.
2233# bit 2..0 secondary DMA channel;
2234# bit 4 set if the board uses two dma channels;
2235# bit 15..8 board type, overrides autodetection; leave it
2236# zero if don't know what to put in (and you don't,
2237# since this is unsupported at the moment...).
2238#
2239# snd_ad1816: Analog Devices AD1816 ISA PnP/non-PnP.
2240# snd_als4000: Avance Logic ALS4000 PCI.
2241# snd_atiixp: ATI IXP 200/300/400 PCI.
2242# snd_audiocs: Crystal Semiconductor CS4231 SBus/EBus. Only
2243# for sparc64.
2244# snd_cmi: CMedia CMI8338/CMI8738 PCI.
2245# snd_cs4281: Crystal Semiconductor CS4281 PCI.
2246# snd_csa: Crystal Semiconductor CS461x/428x PCI. (except
2247# 4281)
2248# snd_ds1: Yamaha DS-1 PCI.
2249# snd_emu10k1: Creative EMU10K1 PCI and EMU10K2 (Audigy) PCI.
2250# snd_emu10kx: Creative SoundBlaster Live! and Audigy
2251# snd_envy24: VIA Envy24 and compatible, needs snd_spicds.
2252# snd_envy24ht: VIA Envy24HT and compatible, needs snd_spicds.
2253# snd_es137x: Ensoniq AudioPCI ES137x PCI.
2254# snd_ess: Ensoniq ESS ISA PnP/non-PnP, to be used in
2255# conjunction with snd_sbc.
2256# snd_fm801: Forte Media FM801 PCI.
2257# snd_gusc: Gravis UltraSound ISA PnP/non-PnP.
2258# snd_hda: Intel High Definition Audio (Controller) and
2259# compatible.
2#
3# NOTES -- Lines that can be cut/pasted into kernel and hints configs.
4#
5# Lines that begin with 'device', 'options', 'machine', 'ident', 'maxusers',
6# 'makeoptions', 'hints', etc. go into the kernel configuration that you
7# run config(8) with.
8#
9# Lines that begin with 'hint.' are NOT for config(8), they go into your
10# hints file. See /boot/device.hints and/or the 'hints' config(8) directive.
11#
12# Please use ``make LINT'' to create an old-style LINT file if you want to
13# do kernel test-builds.
14#
15# This file contains machine independent kernel configuration notes. For
16# machine dependent notes, look in /sys/<arch>/conf/NOTES.
17#
18
19#
20# NOTES conventions and style guide:
21#
22# Large block comments should begin and end with a line containing only a
23# comment character.
24#
25# To describe a particular object, a block comment (if it exists) should
26# come first. Next should come device, options, and hints lines in that
27# order. All device and option lines must be described by a comment that
28# doesn't just expand the device or option name. Use only a concise
29# comment on the same line if possible. Very detailed descriptions of
30# devices and subsystems belong in man pages.
31#
32# A space followed by a tab separates 'options' from an option name. Two
33# spaces followed by a tab separate 'device' from a device name. Comments
34# after an option or device should use one space after the comment character.
35# To comment out a negative option that disables code and thus should not be
36# enabled for LINT builds, precede 'options' with "#!".
37#
38
39#
40# This is the ``identification'' of the kernel. Usually this should
41# be the same as the name of your kernel.
42#
43ident LINT
44
45#
46# The `maxusers' parameter controls the static sizing of a number of
47# internal system tables by a formula defined in subr_param.c.
48# Omitting this parameter or setting it to 0 will cause the system to
49# auto-size based on physical memory.
50#
51maxusers 10
52
53# To statically compile in device wiring instead of /boot/device.hints
54#hints "LINT.hints" # Default places to look for devices.
55
56# Use the following to compile in values accessible to the kernel
57# through getenv() (or kenv(1) in userland). The format of the file
58# is 'variable=value', see kenv(1)
59#
60#env "LINT.env"
61
62#
63# The `makeoptions' parameter allows variables to be passed to the
64# generated Makefile in the build area.
65#
66# CONF_CFLAGS gives some extra compiler flags that are added to ${CFLAGS}
67# after most other flags. Here we use it to inhibit use of non-optimal
68# gcc built-in functions (e.g., memcmp).
69#
70# DEBUG happens to be magic.
71# The following is equivalent to 'config -g KERNELNAME' and creates
72# 'kernel.debug' compiled with -g debugging as well as a normal
73# 'kernel'. Use 'make install.debug' to install the debug kernel
74# but that isn't normally necessary as the debug symbols are not loaded
75# by the kernel and are not useful there anyway.
76#
77# KERNEL can be overridden so that you can change the default name of your
78# kernel.
79#
80# MODULES_OVERRIDE can be used to limit modules built to a specific list.
81#
82makeoptions CONF_CFLAGS=-fno-builtin #Don't allow use of memcmp, etc.
83#makeoptions DEBUG=-g #Build kernel with gdb(1) debug symbols
84#makeoptions KERNEL=foo #Build kernel "foo" and install "/foo"
85# Only build ext2fs module plus those parts of the sound system I need.
86#makeoptions MODULES_OVERRIDE="ext2fs sound/sound sound/driver/maestro3"
87makeoptions DESTDIR=/tmp
88
89#
90# FreeBSD processes are subject to certain limits to their consumption
91# of system resources. See getrlimit(2) for more details. Each
92# resource limit has two values, a "soft" limit and a "hard" limit.
93# The soft limits can be modified during normal system operation, but
94# the hard limits are set at boot time. Their default values are
95# in sys/<arch>/include/vmparam.h. There are two ways to change them:
96#
97# 1. Set the values at kernel build time. The options below are one
98# way to allow that limit to grow to 1GB. They can be increased
99# further by changing the parameters:
100#
101# 2. In /boot/loader.conf, set the tunables kern.maxswzone,
102# kern.maxbcache, kern.maxtsiz, kern.dfldsiz, kern.maxdsiz,
103# kern.dflssiz, kern.maxssiz and kern.sgrowsiz.
104#
105# The options in /boot/loader.conf override anything in the kernel
106# configuration file. See the function init_param1 in
107# sys/kern/subr_param.c for more details.
108#
109
110options MAXDSIZ=(1024UL*1024*1024)
111options MAXSSIZ=(128UL*1024*1024)
112options DFLDSIZ=(1024UL*1024*1024)
113
114#
115# BLKDEV_IOSIZE sets the default block size used in user block
116# device I/O. Note that this value will be overridden by the label
117# when specifying a block device from a label with a non-0
118# partition blocksize. The default is PAGE_SIZE.
119#
120options BLKDEV_IOSIZE=8192
121
122#
123# MAXPHYS and DFLTPHYS
124#
125# These are the maximal and safe 'raw' I/O block device access sizes.
126# Reads and writes will be split into MAXPHYS chunks for known good
127# devices and DFLTPHYS for the rest. Some applications have better
128# performance with larger raw I/O access sizes. Note that certain VM
129# parameters are derived from these values and making them too large
130# can make an an unbootable kernel.
131#
132# The defaults are 64K and 128K respectively.
133options DFLTPHYS=(64*1024)
134options MAXPHYS=(128*1024)
135
136
137# This allows you to actually store this configuration file into
138# the kernel binary itself. See config(8) for more details.
139#
140options INCLUDE_CONFIG_FILE # Include this file in kernel
141
142options GEOM_AES # Don't use, use GEOM_BDE
143options GEOM_BDE # Disk encryption.
144options GEOM_BSD # BSD disklabels
145options GEOM_CACHE # Disk cache.
146options GEOM_CONCAT # Disk concatenation.
147options GEOM_ELI # Disk encryption.
148options GEOM_FOX # Redundant path mitigation
149options GEOM_GATE # Userland services.
150options GEOM_JOURNAL # Journaling.
151options GEOM_LABEL # Providers labelization.
152options GEOM_LINUX_LVM # Linux LVM2 volumes
153options GEOM_MBR # DOS/MBR partitioning
154options GEOM_MIRROR # Disk mirroring.
155options GEOM_MULTIPATH # Disk multipath
156options GEOM_NOP # Test class.
157options GEOM_PART_APM # Apple partitioning
158options GEOM_PART_BSD # BSD disklabel
159options GEOM_PART_EBR # Extended Boot Records
160options GEOM_PART_EBR_COMPAT # Backward compatible partition names
161options GEOM_PART_GPT # GPT partitioning
162options GEOM_PART_MBR # MBR partitioning
163options GEOM_PART_PC98 # PC-9800 disk partitioning
164options GEOM_PART_VTOC8 # SMI VTOC8 disk label
165options GEOM_PC98 # NEC PC9800 partitioning
166options GEOM_RAID # Soft RAID functionality.
167options GEOM_RAID3 # RAID3 functionality.
168options GEOM_SHSEC # Shared secret.
169options GEOM_STRIPE # Disk striping.
170options GEOM_SUNLABEL # Sun/Solaris partitioning
171options GEOM_UZIP # Read-only compressed disks
172options GEOM_VIRSTOR # Virtual storage.
173options GEOM_VOL # Volume names from UFS superblock
174options GEOM_ZERO # Performance testing helper.
175
176#
177# The root device and filesystem type can be compiled in;
178# this provides a fallback option if the root device cannot
179# be correctly guessed by the bootstrap code, or an override if
180# the RB_DFLTROOT flag (-r) is specified when booting the kernel.
181#
182options ROOTDEVNAME=\"ufs:da0s2e\"
183
184
185#####################################################################
186# Scheduler options:
187#
188# Specifying one of SCHED_4BSD or SCHED_ULE is mandatory. These options
189# select which scheduler is compiled in.
190#
191# SCHED_4BSD is the historical, proven, BSD scheduler. It has a global run
192# queue and no CPU affinity which makes it suboptimal for SMP. It has very
193# good interactivity and priority selection.
194#
195# SCHED_ULE provides significant performance advantages over 4BSD on many
196# workloads on SMP machines. It supports cpu-affinity, per-cpu runqueues
197# and scheduler locks. It also has a stronger notion of interactivity
198# which leads to better responsiveness even on uniprocessor machines. This
199# is the default scheduler.
200#
201# SCHED_STATS is a debugging option which keeps some stats in the sysctl
202# tree at 'kern.sched.stats' and is useful for debugging scheduling decisions.
203#
204options SCHED_4BSD
205options SCHED_STATS
206#options SCHED_ULE
207
208#####################################################################
209# SMP OPTIONS:
210#
211# SMP enables building of a Symmetric MultiProcessor Kernel.
212
213# Mandatory:
214options SMP # Symmetric MultiProcessor Kernel
215
216# MAXCPU defines the maximum number of CPUs that can boot in the system.
217# A default value should be already present, for every architecture.
218options MAXCPU=32
219
220# ADAPTIVE_MUTEXES changes the behavior of blocking mutexes to spin
221# if the thread that currently owns the mutex is executing on another
222# CPU. This behavior is enabled by default, so this option can be used
223# to disable it.
224options NO_ADAPTIVE_MUTEXES
225
226# ADAPTIVE_RWLOCKS changes the behavior of reader/writer locks to spin
227# if the thread that currently owns the rwlock is executing on another
228# CPU. This behavior is enabled by default, so this option can be used
229# to disable it.
230options NO_ADAPTIVE_RWLOCKS
231
232# ADAPTIVE_SX changes the behavior of sx locks to spin if the thread that
233# currently owns the sx lock is executing on another CPU.
234# This behavior is enabled by default, so this option can be used to
235# disable it.
236options NO_ADAPTIVE_SX
237
238# MUTEX_NOINLINE forces mutex operations to call functions to perform each
239# operation rather than inlining the simple cases. This can be used to
240# shrink the size of the kernel text segment. Note that this behavior is
241# already implied by the INVARIANT_SUPPORT, INVARIANTS, KTR, LOCK_PROFILING,
242# and WITNESS options.
243options MUTEX_NOINLINE
244
245# RWLOCK_NOINLINE forces rwlock operations to call functions to perform each
246# operation rather than inlining the simple cases. This can be used to
247# shrink the size of the kernel text segment. Note that this behavior is
248# already implied by the INVARIANT_SUPPORT, INVARIANTS, KTR, LOCK_PROFILING,
249# and WITNESS options.
250options RWLOCK_NOINLINE
251
252# SX_NOINLINE forces sx lock operations to call functions to perform each
253# operation rather than inlining the simple cases. This can be used to
254# shrink the size of the kernel text segment. Note that this behavior is
255# already implied by the INVARIANT_SUPPORT, INVARIANTS, KTR, LOCK_PROFILING,
256# and WITNESS options.
257options SX_NOINLINE
258
259# SMP Debugging Options:
260#
261# PREEMPTION allows the threads that are in the kernel to be preempted by
262# higher priority [interrupt] threads. It helps with interactivity
263# and allows interrupt threads to run sooner rather than waiting.
264# WARNING! Only tested on amd64 and i386.
265# FULL_PREEMPTION instructs the kernel to preempt non-realtime kernel
266# threads. Its sole use is to expose race conditions and other
267# bugs during development. Enabling this option will reduce
268# performance and increase the frequency of kernel panics by
269# design. If you aren't sure that you need it then you don't.
270# Relies on the PREEMPTION option. DON'T TURN THIS ON.
271# MUTEX_DEBUG enables various extra assertions in the mutex code.
272# SLEEPQUEUE_PROFILING enables rudimentary profiling of the hash table
273# used to hold active sleep queues as well as sleep wait message
274# frequency.
275# TURNSTILE_PROFILING enables rudimentary profiling of the hash table
276# used to hold active lock queues.
277# WITNESS enables the witness code which detects deadlocks and cycles
278# during locking operations.
279# WITNESS_KDB causes the witness code to drop into the kernel debugger if
280# a lock hierarchy violation occurs or if locks are held when going to
281# sleep.
282# WITNESS_SKIPSPIN disables the witness checks on spin mutexes.
283options PREEMPTION
284options FULL_PREEMPTION
285options MUTEX_DEBUG
286options WITNESS
287options WITNESS_KDB
288options WITNESS_SKIPSPIN
289
290# LOCK_PROFILING - Profiling locks. See LOCK_PROFILING(9) for details.
291options LOCK_PROFILING
292# Set the number of buffers and the hash size. The hash size MUST be larger
293# than the number of buffers. Hash size should be prime.
294options MPROF_BUFFERS="1536"
295options MPROF_HASH_SIZE="1543"
296
297# Profiling for internal hash tables.
298options SLEEPQUEUE_PROFILING
299options TURNSTILE_PROFILING
300
301
302#####################################################################
303# COMPATIBILITY OPTIONS
304
305#
306# Implement system calls compatible with 4.3BSD and older versions of
307# FreeBSD. You probably do NOT want to remove this as much current code
308# still relies on the 4.3 emulation. Note that some architectures that
309# are supported by FreeBSD do not include support for certain important
310# aspects of this compatibility option, namely those related to the
311# signal delivery mechanism.
312#
313options COMPAT_43
314
315# Old tty interface.
316options COMPAT_43TTY
317
318# Note that as a general rule, COMPAT_FREEBSD<n> depends on
319# COMPAT_FREEBSD<n+1>, COMPAT_FREEBSD<n+2>, etc.
320
321# Enable FreeBSD4 compatibility syscalls
322options COMPAT_FREEBSD4
323
324# Enable FreeBSD5 compatibility syscalls
325options COMPAT_FREEBSD5
326
327# Enable FreeBSD6 compatibility syscalls
328options COMPAT_FREEBSD6
329
330# Enable FreeBSD7 compatibility syscalls
331options COMPAT_FREEBSD7
332
333#
334# These three options provide support for System V Interface
335# Definition-style interprocess communication, in the form of shared
336# memory, semaphores, and message queues, respectively.
337#
338options SYSVSHM
339options SYSVSEM
340options SYSVMSG
341
342
343#####################################################################
344# DEBUGGING OPTIONS
345
346#
347# Compile with kernel debugger related code.
348#
349options KDB
350
351#
352# Print a stack trace of the current thread on the console for a panic.
353#
354options KDB_TRACE
355
356#
357# Don't enter the debugger for a panic. Intended for unattended operation
358# where you may want to enter the debugger from the console, but still want
359# the machine to recover from a panic.
360#
361options KDB_UNATTENDED
362
363#
364# Enable the ddb debugger backend.
365#
366options DDB
367
368#
369# Print the numerical value of symbols in addition to the symbolic
370# representation.
371#
372options DDB_NUMSYM
373
374#
375# Enable the remote gdb debugger backend.
376#
377options GDB
378
379#
380# SYSCTL_DEBUG enables a 'sysctl' debug tree that can be used to dump the
381# contents of the registered sysctl nodes on the console. It is disabled by
382# default because it generates excessively verbose console output that can
383# interfere with serial console operation.
384#
385options SYSCTL_DEBUG
386
387#
388# NO_SYSCTL_DESCR omits the sysctl node descriptions to save space in the
389# resulting kernel.
390options NO_SYSCTL_DESCR
391
392#
393# MALLOC_DEBUG_MAXZONES enables multiple uma zones for malloc(9)
394# allocations that are smaller than a page. The purpose is to isolate
395# different malloc types into hash classes, so that any buffer
396# overruns or use-after-free will usually only affect memory from
397# malloc types in that hash class. This is purely a debugging tool;
398# by varying the hash function and tracking which hash class was
399# corrupted, the intersection of the hash classes from each instance
400# will point to a single malloc type that is being misused. At this
401# point inspection or memguard(9) can be used to catch the offending
402# code.
403#
404options MALLOC_DEBUG_MAXZONES=8
405
406#
407# DEBUG_MEMGUARD builds and enables memguard(9), a replacement allocator
408# for the kernel used to detect modify-after-free scenarios. See the
409# memguard(9) man page for more information on usage.
410#
411options DEBUG_MEMGUARD
412
413#
414# DEBUG_REDZONE enables buffer underflows and buffer overflows detection for
415# malloc(9).
416#
417options DEBUG_REDZONE
418
419#
420# KTRACE enables the system-call tracing facility ktrace(2). To be more
421# SMP-friendly, KTRACE uses a worker thread to process most trace events
422# asynchronously to the thread generating the event. This requires a
423# pre-allocated store of objects representing trace events. The
424# KTRACE_REQUEST_POOL option specifies the initial size of this store.
425# The size of the pool can be adjusted both at boottime and runtime via
426# the kern.ktrace_request_pool tunable and sysctl.
427#
428options KTRACE #kernel tracing
429options KTRACE_REQUEST_POOL=101
430
431#
432# KTR is a kernel tracing facility imported from BSD/OS. It is
433# enabled with the KTR option. KTR_ENTRIES defines the number of
434# entries in the circular trace buffer; it must be a power of two.
435# KTR_COMPILE defines the mask of events to compile into the kernel as
436# defined by the KTR_* constants in <sys/ktr.h>. KTR_MASK defines the
437# initial value of the ktr_mask variable which determines at runtime
438# what events to trace. KTR_CPUMASK determines which CPU's log
439# events, with bit X corresponding to CPU X. The layout of the string
440# passed as KTR_CPUMASK must match a series of bitmasks each of them
441# separated by the ", " characters (ie:
442# KTR_CPUMASK=("0xAF, 0xFFFFFFFFFFFFFFFF")). KTR_VERBOSE enables
443# dumping of KTR events to the console by default. This functionality
444# can be toggled via the debug.ktr_verbose sysctl and defaults to off
445# if KTR_VERBOSE is not defined. See ktr(4) and ktrdump(8) for details.
446#
447options KTR
448options KTR_ENTRIES=1024
449options KTR_COMPILE=(KTR_INTR|KTR_PROC)
450options KTR_MASK=KTR_INTR
451options KTR_CPUMASK=("0x3")
452options KTR_VERBOSE
453
454#
455# ALQ(9) is a facility for the asynchronous queuing of records from the kernel
456# to a vnode, and is employed by services such as ktr(4) to produce trace
457# files based on a kernel event stream. Records are written asynchronously
458# in a worker thread.
459#
460options ALQ
461options KTR_ALQ
462
463#
464# The INVARIANTS option is used in a number of source files to enable
465# extra sanity checking of internal structures. This support is not
466# enabled by default because of the extra time it would take to check
467# for these conditions, which can only occur as a result of
468# programming errors.
469#
470options INVARIANTS
471
472#
473# The INVARIANT_SUPPORT option makes us compile in support for
474# verifying some of the internal structures. It is a prerequisite for
475# 'INVARIANTS', as enabling 'INVARIANTS' will make these functions be
476# called. The intent is that you can set 'INVARIANTS' for single
477# source files (by changing the source file or specifying it on the
478# command line) if you have 'INVARIANT_SUPPORT' enabled. Also, if you
479# wish to build a kernel module with 'INVARIANTS', then adding
480# 'INVARIANT_SUPPORT' to your kernel will provide all the necessary
481# infrastructure without the added overhead.
482#
483options INVARIANT_SUPPORT
484
485#
486# The DIAGNOSTIC option is used to enable extra debugging information
487# from some parts of the kernel. As this makes everything more noisy,
488# it is disabled by default.
489#
490options DIAGNOSTIC
491
492#
493# REGRESSION causes optional kernel interfaces necessary only for regression
494# testing to be enabled. These interfaces may constitute security risks
495# when enabled, as they permit processes to easily modify aspects of the
496# run-time environment to reproduce unlikely or unusual (possibly normally
497# impossible) scenarios.
498#
499options REGRESSION
500
501#
502# This option lets some drivers co-exist that can't co-exist in a running
503# system. This is used to be able to compile all kernel code in one go for
504# quality assurance purposes (like this file, which the option takes it name
505# from.)
506#
507options COMPILING_LINT
508
509#
510# STACK enables the stack(9) facility, allowing the capture of kernel stack
511# for the purpose of procinfo(1), etc. stack(9) will also be compiled in
512# automatically if DDB(4) is compiled into the kernel.
513#
514options STACK
515
516
517#####################################################################
518# PERFORMANCE MONITORING OPTIONS
519
520#
521# The hwpmc driver that allows the use of in-CPU performance monitoring
522# counters for performance monitoring. The base kernel needs to be configured
523# with the 'options' line, while the hwpmc device can be either compiled
524# in or loaded as a loadable kernel module.
525#
526# Additional configuration options may be required on specific architectures,
527# please see hwpmc(4).
528
529device hwpmc # Driver (also a loadable module)
530options HWPMC_HOOKS # Other necessary kernel hooks
531
532
533#####################################################################
534# NETWORKING OPTIONS
535
536#
537# Protocol families
538#
539options INET #Internet communications protocols
540options INET6 #IPv6 communications protocols
541
542options ROUTETABLES=2 # max 16. 1 is back compatible.
543
544# In order to enable IPSEC you MUST also add device crypto to
545# your kernel configuration
546options IPSEC #IP security (requires device crypto)
547#options IPSEC_DEBUG #debug for IP security
548#
549# #DEPRECATED#
550# Set IPSEC_FILTERTUNNEL to change the default of the sysctl to force packets
551# coming through a tunnel to be processed by any configured packet filtering
552# twice. The default is that packets coming out of a tunnel are _not_ processed;
553# they are assumed trusted.
554#
555# IPSEC history is preserved for such packets, and can be filtered
556# using ipfw(8)'s 'ipsec' keyword, when this option is enabled.
557#
558#options IPSEC_FILTERTUNNEL #filter ipsec packets from a tunnel
559#
560# Set IPSEC_NAT_T to enable NAT-Traversal support. This enables
561# optional UDP encapsulation of ESP packets.
562#
563options IPSEC_NAT_T #NAT-T support, UDP encap of ESP
564
565options IPX #IPX/SPX communications protocols
566
567options NCP #NetWare Core protocol
568
569options NETATALK #Appletalk communications protocols
570options NETATALKDEBUG #Appletalk debugging
571
572#
573# SMB/CIFS requester
574# NETSMB enables support for SMB protocol, it requires LIBMCHAIN and LIBICONV
575# options.
576options NETSMB #SMB/CIFS requester
577
578# mchain library. It can be either loaded as KLD or compiled into kernel
579options LIBMCHAIN
580
581# libalias library, performing NAT
582options LIBALIAS
583
584# flowtable cache
585options FLOWTABLE
586
587#
588# SCTP is a NEW transport protocol defined by
589# RFC2960 updated by RFC3309 and RFC3758.. and
590# soon to have a new base RFC and many many more
591# extensions. This release supports all the extensions
592# including many drafts (most about to become RFC's).
593# It is the reference implementation of SCTP
594# and is quite well tested.
595#
596# Note YOU MUST have both INET and INET6 defined.
597# You don't have to enable V6, but SCTP is
598# dual stacked and so far we have not torn apart
599# the V6 and V4.. since an association can span
600# both a V6 and V4 address at the SAME time :-)
601#
602options SCTP
603# There are bunches of options:
604# this one turns on all sorts of
605# nastily printing that you can
606# do. It's all controlled by a
607# bit mask (settable by socket opt and
608# by sysctl). Including will not cause
609# logging until you set the bits.. but it
610# can be quite verbose.. so without this
611# option we don't do any of the tests for
612# bits and prints.. which makes the code run
613# faster.. if you are not debugging don't use.
614options SCTP_DEBUG
615#
616# This option turns off the CRC32c checksum. Basically,
617# you will not be able to talk to anyone else who
618# has not done this. Its more for experimentation to
619# see how much CPU the CRC32c really takes. Most new
620# cards for TCP support checksum offload.. so this
621# option gives you a "view" into what SCTP would be
622# like with such an offload (which only exists in
623# high in iSCSI boards so far). With the new
624# splitting 8's algorithm its not as bad as it used
625# to be.. but it does speed things up try only
626# for in a captured lab environment :-)
627options SCTP_WITH_NO_CSUM
628#
629
630#
631# All that options after that turn on specific types of
632# logging. You can monitor CWND growth, flight size
633# and all sorts of things. Go look at the code and
634# see. I have used this to produce interesting
635# charts and graphs as well :->
636#
637# I have not yet committed the tools to get and print
638# the logs, I will do that eventually .. before then
639# if you want them send me an email rrs@freebsd.org
640# You basically must have ktr(4) enabled for these
641# and you then set the sysctl to turn on/off various
642# logging bits. Use ktrdump(8) to pull the log and run
643# it through a display program.. and graphs and other
644# things too.
645#
646options SCTP_LOCK_LOGGING
647options SCTP_MBUF_LOGGING
648options SCTP_MBCNT_LOGGING
649options SCTP_PACKET_LOGGING
650options SCTP_LTRACE_CHUNKS
651options SCTP_LTRACE_ERRORS
652
653
654# altq(9). Enable the base part of the hooks with the ALTQ option.
655# Individual disciplines must be built into the base system and can not be
656# loaded as modules at this point. ALTQ requires a stable TSC so if yours is
657# broken or changes with CPU throttling then you must also have the ALTQ_NOPCC
658# option.
659options ALTQ
660options ALTQ_CBQ # Class Based Queueing
661options ALTQ_RED # Random Early Detection
662options ALTQ_RIO # RED In/Out
663options ALTQ_HFSC # Hierarchical Packet Scheduler
664options ALTQ_CDNR # Traffic conditioner
665options ALTQ_PRIQ # Priority Queueing
666options ALTQ_NOPCC # Required if the TSC is unusable
667options ALTQ_DEBUG
668
669# netgraph(4). Enable the base netgraph code with the NETGRAPH option.
670# Individual node types can be enabled with the corresponding option
671# listed below; however, this is not strictly necessary as netgraph
672# will automatically load the corresponding KLD module if the node type
673# is not already compiled into the kernel. Each type below has a
674# corresponding man page, e.g., ng_async(8).
675options NETGRAPH # netgraph(4) system
676options NETGRAPH_DEBUG # enable extra debugging, this
677 # affects netgraph(4) and nodes
678# Node types
679options NETGRAPH_ASYNC
680options NETGRAPH_ATMLLC
681options NETGRAPH_ATM_ATMPIF
682options NETGRAPH_BLUETOOTH # ng_bluetooth(4)
683options NETGRAPH_BLUETOOTH_BT3C # ng_bt3c(4)
684options NETGRAPH_BLUETOOTH_HCI # ng_hci(4)
685options NETGRAPH_BLUETOOTH_L2CAP # ng_l2cap(4)
686options NETGRAPH_BLUETOOTH_SOCKET # ng_btsocket(4)
687options NETGRAPH_BLUETOOTH_UBT # ng_ubt(4)
688options NETGRAPH_BLUETOOTH_UBTBCMFW # ubtbcmfw(4)
689options NETGRAPH_BPF
690options NETGRAPH_BRIDGE
691options NETGRAPH_CAR
692options NETGRAPH_CISCO
693options NETGRAPH_DEFLATE
694options NETGRAPH_DEVICE
695options NETGRAPH_ECHO
696options NETGRAPH_EIFACE
697options NETGRAPH_ETHER
698options NETGRAPH_FEC
699options NETGRAPH_FRAME_RELAY
700options NETGRAPH_GIF
701options NETGRAPH_GIF_DEMUX
702options NETGRAPH_HOLE
703options NETGRAPH_IFACE
704options NETGRAPH_IP_INPUT
705options NETGRAPH_IPFW
706options NETGRAPH_KSOCKET
707options NETGRAPH_L2TP
708options NETGRAPH_LMI
709# MPPC compression requires proprietary files (not included)
710#options NETGRAPH_MPPC_COMPRESSION
711options NETGRAPH_MPPC_ENCRYPTION
712options NETGRAPH_NETFLOW
713options NETGRAPH_NAT
714options NETGRAPH_ONE2MANY
715options NETGRAPH_PATCH
716options NETGRAPH_PIPE
717options NETGRAPH_PPP
718options NETGRAPH_PPPOE
719options NETGRAPH_PPTPGRE
720options NETGRAPH_PRED1
721options NETGRAPH_RFC1490
722options NETGRAPH_SOCKET
723options NETGRAPH_SPLIT
724options NETGRAPH_SPPP
725options NETGRAPH_TAG
726options NETGRAPH_TCPMSS
727options NETGRAPH_TEE
728options NETGRAPH_UI
729options NETGRAPH_VJC
730options NETGRAPH_VLAN
731
732# NgATM - Netgraph ATM
733options NGATM_ATM
734options NGATM_ATMBASE
735options NGATM_SSCOP
736options NGATM_SSCFU
737options NGATM_UNI
738options NGATM_CCATM
739
740device mn # Munich32x/Falc54 Nx64kbit/sec cards.
741
742#
743# Network interfaces:
744# The `loop' device is MANDATORY when networking is enabled.
745device loop
746
747# The `ether' device provides generic code to handle
748# Ethernets; it is MANDATORY when an Ethernet device driver is
749# configured or token-ring is enabled.
750device ether
751
752# The `vlan' device implements the VLAN tagging of Ethernet frames
753# according to IEEE 802.1Q.
754device vlan
755
756# The `wlan' device provides generic code to support 802.11
757# drivers, including host AP mode; it is MANDATORY for the wi,
758# and ath drivers and will eventually be required by all 802.11 drivers.
759device wlan
760options IEEE80211_DEBUG #enable debugging msgs
761options IEEE80211_AMPDU_AGE #age frames in AMPDU reorder q's
762options IEEE80211_SUPPORT_MESH #enable 802.11s D3.0 support
763options IEEE80211_SUPPORT_TDMA #enable TDMA support
764
765# The `wlan_wep', `wlan_tkip', and `wlan_ccmp' devices provide
766# support for WEP, TKIP, and AES-CCMP crypto protocols optionally
767# used with 802.11 devices that depend on the `wlan' module.
768device wlan_wep
769device wlan_ccmp
770device wlan_tkip
771
772# The `wlan_xauth' device provides support for external (i.e. user-mode)
773# authenticators for use with 802.11 drivers that use the `wlan'
774# module and support 802.1x and/or WPA security protocols.
775device wlan_xauth
776
777# The `wlan_acl' device provides a MAC-based access control mechanism
778# for use with 802.11 drivers operating in ap mode and using the
779# `wlan' module.
780# The 'wlan_amrr' device provides AMRR transmit rate control algorithm
781device wlan_acl
782device wlan_amrr
783
784# Generic TokenRing
785device token
786
787# The `fddi' device provides generic code to support FDDI.
788device fddi
789
790# The `arcnet' device provides generic code to support Arcnet.
791device arcnet
792
793# The `sppp' device serves a similar role for certain types
794# of synchronous PPP links (like `cx', `ar').
795device sppp
796
797# The `bpf' device enables the Berkeley Packet Filter. Be
798# aware of the legal and administrative consequences of enabling this
799# option. DHCP requires bpf.
800device bpf
801
802# The `netmap' device implements memory-mapped access to network
803# devices from userspace, enabling wire-speed packet capture and
804# generation even at 10Gbit/s. Requires support in the device
805# driver. Supported drivers are ixgbe, e1000, re.
806device netmap
807
808# The `disc' device implements a minimal network interface,
809# which throws away all packets sent and never receives any. It is
810# included for testing and benchmarking purposes.
811device disc
812
813# The `epair' device implements a virtual back-to-back connected Ethernet
814# like interface pair.
815device epair
816
817# The `edsc' device implements a minimal Ethernet interface,
818# which discards all packets sent and receives none.
819device edsc
820
821# The `tap' device is a pty-like virtual Ethernet interface
822device tap
823
824# The `tun' device implements (user-)ppp and nos-tun(8)
825device tun
826
827# The `gif' device implements IPv6 over IP4 tunneling,
828# IPv4 over IPv6 tunneling, IPv4 over IPv4 tunneling and
829# IPv6 over IPv6 tunneling.
830# The `gre' device implements two types of IP4 over IP4 tunneling:
831# GRE and MOBILE, as specified in the RFC1701 and RFC2004.
832# The XBONEHACK option allows the same pair of addresses to be configured on
833# multiple gif interfaces.
834device gif
835device gre
836options XBONEHACK
837
838# The `faith' device captures packets sent to it and diverts them
839# to the IPv4/IPv6 translation daemon.
840# The `stf' device implements 6to4 encapsulation.
841device faith
842device stf
843
844# The `ef' device provides support for multiple ethernet frame types
845# specified via ETHER_* options. See ef(4) for details.
846device ef
847options ETHER_II # enable Ethernet_II frame
848options ETHER_8023 # enable Ethernet_802.3 (Novell) frame
849options ETHER_8022 # enable Ethernet_802.2 frame
850options ETHER_SNAP # enable Ethernet_802.2/SNAP frame
851
852# The pf packet filter consists of three devices:
853# The `pf' device provides /dev/pf and the firewall code itself.
854# The `pflog' device provides the pflog0 interface which logs packets.
855# The `pfsync' device provides the pfsync0 interface used for
856# synchronization of firewall state tables (over the net).
857device pf
858device pflog
859device pfsync
860
861# Bridge interface.
862device if_bridge
863
864# Common Address Redundancy Protocol. See carp(4) for more details.
865device carp
866
867# IPsec interface.
868device enc
869
870# Link aggregation interface.
871device lagg
872
873#
874# Internet family options:
875#
876# MROUTING enables the kernel multicast packet forwarder, which works
877# with mrouted and XORP.
878#
879# IPFIREWALL enables support for IP firewall construction, in
880# conjunction with the `ipfw' program. IPFIREWALL_VERBOSE sends
881# logged packets to the system logger. IPFIREWALL_VERBOSE_LIMIT
882# limits the number of times a matching entry can be logged.
883#
884# WARNING: IPFIREWALL defaults to a policy of "deny ip from any to any"
885# and if you do not add other rules during startup to allow access,
886# YOU WILL LOCK YOURSELF OUT. It is suggested that you set firewall_type=open
887# in /etc/rc.conf when first enabling this feature, then refining the
888# firewall rules in /etc/rc.firewall after you've tested that the new kernel
889# feature works properly.
890#
891# IPFIREWALL_DEFAULT_TO_ACCEPT causes the default rule (at boot) to
892# allow everything. Use with care, if a cracker can crash your
893# firewall machine, they can get to your protected machines. However,
894# if you are using it as an as-needed filter for specific problems as
895# they arise, then this may be for you. Changing the default to 'allow'
896# means that you won't get stuck if the kernel and /sbin/ipfw binary get
897# out of sync.
898#
899# IPDIVERT enables the divert IP sockets, used by ``ipfw divert''. It
900# depends on IPFIREWALL if compiled into the kernel.
901#
902# IPFIREWALL_FORWARD enables changing of the packet destination either
903# to do some sort of policy routing or transparent proxying. Used by
904# ``ipfw forward''. All redirections apply to locally generated
905# packets too. Because of this great care is required when
906# crafting the ruleset.
907#
908# IPFIREWALL_NAT adds support for in kernel nat in ipfw, and it requires
909# LIBALIAS.
910#
911# IPSTEALTH enables code to support stealth forwarding (i.e., forwarding
912# packets without touching the TTL). This can be useful to hide firewalls
913# from traceroute and similar tools.
914#
915# TCPDEBUG enables code which keeps traces of the TCP state machine
916# for sockets with the SO_DEBUG option set, which can then be examined
917# using the trpt(8) utility.
918#
919# RADIX_MPATH provides support for equal-cost multi-path routing.
920#
921options MROUTING # Multicast routing
922options IPFIREWALL #firewall
923options IPFIREWALL_VERBOSE #enable logging to syslogd(8)
924options IPFIREWALL_VERBOSE_LIMIT=100 #limit verbosity
925options IPFIREWALL_DEFAULT_TO_ACCEPT #allow everything by default
926options IPFIREWALL_FORWARD #packet destination changes
927options IPFIREWALL_NAT #ipfw kernel nat support
928options IPDIVERT #divert sockets
929options IPFILTER #ipfilter support
930options IPFILTER_LOG #ipfilter logging
931options IPFILTER_LOOKUP #ipfilter pools
932options IPFILTER_DEFAULT_BLOCK #block all packets by default
933options IPSTEALTH #support for stealth forwarding
934options TCPDEBUG
935options RADIX_MPATH
936
937# The MBUF_STRESS_TEST option enables options which create
938# various random failures / extreme cases related to mbuf
939# functions. See mbuf(9) for a list of available test cases.
940# MBUF_PROFILING enables code to profile the mbuf chains
941# exiting the system (via participating interfaces) and
942# return a logarithmic histogram of monitored parameters
943# (e.g. packet size, wasted space, number of mbufs in chain).
944options MBUF_STRESS_TEST
945options MBUF_PROFILING
946
947# Statically link in accept filters
948options ACCEPT_FILTER_DATA
949options ACCEPT_FILTER_DNS
950options ACCEPT_FILTER_HTTP
951
952# TCP_SIGNATURE adds support for RFC 2385 (TCP-MD5) digests. These are
953# carried in TCP option 19. This option is commonly used to protect
954# TCP sessions (e.g. BGP) where IPSEC is not available nor desirable.
955# This is enabled on a per-socket basis using the TCP_MD5SIG socket option.
956# This requires the use of 'device crypto', 'options IPSEC'
957# or 'device cryptodev'.
958options TCP_SIGNATURE #include support for RFC 2385
959
960# DUMMYNET enables the "dummynet" bandwidth limiter. You need IPFIREWALL
961# as well. See dummynet(4) and ipfw(8) for more info. When you run
962# DUMMYNET it is advisable to also have at least "options HZ=1000" to achieve
963# a smooth scheduling of the traffic.
964options DUMMYNET
965
966# Zero copy sockets support. This enables "zero copy" for sending and
967# receiving data via a socket. The send side works for any type of NIC,
968# the receive side only works for NICs that support MTUs greater than the
969# page size of your architecture and that support header splitting. See
970# zero_copy(9) for more details.
971options ZERO_COPY_SOCKETS
972
973#####################################################################
974# FILESYSTEM OPTIONS
975
976#
977# Only the root filesystem needs to be statically compiled or preloaded
978# as module; everything else will be automatically loaded at mount
979# time. Some people still prefer to statically compile other
980# filesystems as well.
981#
982# NB: The PORTAL filesystem is known to be buggy, and WILL panic your
983# system if you attempt to do anything with it. It is included here
984# as an incentive for some enterprising soul to sit down and fix it.
985# The UNION filesystem was known to be buggy in the past. It is now
986# being actively maintained, although there are still some issues being
987# resolved.
988#
989
990# One of these is mandatory:
991options FFS #Fast filesystem
992options NFSCLIENT #Network File System client
993
994# The rest are optional:
995options CD9660 #ISO 9660 filesystem
996options FDESCFS #File descriptor filesystem
997options HPFS #OS/2 File system
998options MSDOSFS #MS DOS File System (FAT, FAT32)
999options NFSSERVER #Network File System server
1000options NFSLOCKD #Network Lock Manager
1001options NFSCL #experimental NFS client with NFSv4
1002options NFSD #experimental NFS server with NFSv4
1003options KGSSAPI #Kernel GSSAPI implementation
1004
1005# NT File System. Read-mostly, see mount_ntfs(8) for details.
1006# For a full read-write NTFS support consider sysutils/fusefs-ntfs
1007# port/package.
1008options NTFS
1009
1010options NULLFS #NULL filesystem
1011# Broken (depends on NCP):
1012#options NWFS #NetWare filesystem
1013options PORTALFS #Portal filesystem
1014options PROCFS #Process filesystem (requires PSEUDOFS)
1015options PSEUDOFS #Pseudo-filesystem framework
1016options PSEUDOFS_TRACE #Debugging support for PSEUDOFS
1017options SMBFS #SMB/CIFS filesystem
1018options TMPFS #Efficient memory filesystem
1019options UDF #Universal Disk Format
1020options UNIONFS #Union filesystem
1021# The xFS_ROOT options REQUIRE the associated ``options xFS''
1022options NFS_ROOT #NFS usable as root device
1023
1024# Soft updates is a technique for improving filesystem speed and
1025# making abrupt shutdown less risky.
1026#
1027options SOFTUPDATES
1028
1029# Extended attributes allow additional data to be associated with files,
1030# and is used for ACLs, Capabilities, and MAC labels.
1031# See src/sys/ufs/ufs/README.extattr for more information.
1032options UFS_EXTATTR
1033options UFS_EXTATTR_AUTOSTART
1034
1035# Access Control List support for UFS filesystems. The current ACL
1036# implementation requires extended attribute support, UFS_EXTATTR,
1037# for the underlying filesystem.
1038# See src/sys/ufs/ufs/README.acls for more information.
1039options UFS_ACL
1040
1041# Directory hashing improves the speed of operations on very large
1042# directories at the expense of some memory.
1043options UFS_DIRHASH
1044
1045# Gjournal-based UFS journaling support.
1046options UFS_GJOURNAL
1047
1048# Make space in the kernel for a root filesystem on a md device.
1049# Define to the number of kilobytes to reserve for the filesystem.
1050options MD_ROOT_SIZE=10
1051
1052# Make the md device a potential root device, either with preloaded
1053# images of type mfs_root or md_root.
1054options MD_ROOT
1055
1056# Disk quotas are supported when this option is enabled.
1057options QUOTA #enable disk quotas
1058
1059# If you are running a machine just as a fileserver for PC and MAC
1060# users, using SAMBA or Netatalk, you may consider setting this option
1061# and keeping all those users' directories on a filesystem that is
1062# mounted with the suiddir option. This gives new files the same
1063# ownership as the directory (similar to group). It's a security hole
1064# if you let these users run programs, so confine it to file-servers
1065# (but it'll save you lots of headaches in those cases). Root owned
1066# directories are exempt and X bits are cleared. The suid bit must be
1067# set on the directory as well; see chmod(1). PC owners can't see/set
1068# ownerships so they keep getting their toes trodden on. This saves
1069# you all the support calls as the filesystem it's used on will act as
1070# they expect: "It's my dir so it must be my file".
1071#
1072options SUIDDIR
1073
1074# NFS options:
1075options NFS_MINATTRTIMO=3 # VREG attrib cache timeout in sec
1076options NFS_MAXATTRTIMO=60
1077options NFS_MINDIRATTRTIMO=30 # VDIR attrib cache timeout in sec
1078options NFS_MAXDIRATTRTIMO=60
1079options NFS_GATHERDELAY=10 # Default write gather delay (msec)
1080options NFS_WDELAYHASHSIZ=16 # and with this
1081options NFS_DEBUG # Enable NFS Debugging
1082
1083# Coda stuff:
1084options CODA #CODA filesystem.
1085device vcoda #coda minicache <-> venus comm.
1086# Use the old Coda 5.x venus<->kernel interface instead of the new
1087# realms-aware 6.x protocol.
1088#options CODA_COMPAT_5
1089
1090#
1091# Add support for the EXT2FS filesystem of Linux fame. Be a bit
1092# careful with this - the ext2fs code has a tendency to lag behind
1093# changes and not be exercised very much, so mounting read/write could
1094# be dangerous (and even mounting read only could result in panics.)
1095#
1096options EXT2FS
1097
1098#
1099# Add support for the ReiserFS filesystem (used in Linux). Currently,
1100# this is limited to read-only access.
1101#
1102options REISERFS
1103
1104#
1105# Add support for the SGI XFS filesystem. Currently,
1106# this is limited to read-only access.
1107#
1108options XFS
1109
1110# Use real implementations of the aio_* system calls. There are numerous
1111# stability and security issues in the current aio code that make it
1112# unsuitable for inclusion on machines with untrusted local users.
1113options VFS_AIO
1114
1115# Enable mounting of non-MPSAFE filesystems.
1116options VFS_ALLOW_NONMPSAFE
1117
1118# Cryptographically secure random number generator; /dev/random
1119device random
1120
1121# The system memory devices; /dev/mem, /dev/kmem
1122device mem
1123
1124# The kernel symbol table device; /dev/ksyms
1125device ksyms
1126
1127# Optional character code conversion support with LIBICONV.
1128# Each option requires their base file system and LIBICONV.
1129options CD9660_ICONV
1130options MSDOSFS_ICONV
1131options NTFS_ICONV
1132options UDF_ICONV
1133
1134
1135#####################################################################
1136# POSIX P1003.1B
1137
1138# Real time extensions added in the 1993 POSIX
1139# _KPOSIX_PRIORITY_SCHEDULING: Build in _POSIX_PRIORITY_SCHEDULING
1140
1141options _KPOSIX_PRIORITY_SCHEDULING
1142# p1003_1b_semaphores are very experimental,
1143# user should be ready to assist in debugging if problems arise.
1144options P1003_1B_SEMAPHORES
1145
1146# POSIX message queue
1147options P1003_1B_MQUEUE
1148
1149#####################################################################
1150# SECURITY POLICY PARAMETERS
1151
1152# Support for BSM audit
1153options AUDIT
1154
1155# Support for Mandatory Access Control (MAC):
1156options MAC
1157options MAC_BIBA
1158options MAC_BSDEXTENDED
1159options MAC_IFOFF
1160options MAC_LOMAC
1161options MAC_MLS
1162options MAC_NONE
1163options MAC_PARTITION
1164options MAC_PORTACL
1165options MAC_SEEOTHERUIDS
1166options MAC_STUB
1167options MAC_TEST
1168
1169# Support for Capsicum
1170options CAPABILITIES # fine-grained rights on file descriptors
1171options CAPABILITY_MODE # sandboxes with no global namespace access
1172
1173# Support for process descriptors
1174options PROCDESC
1175
1176
1177#####################################################################
1178# CLOCK OPTIONS
1179
1180# The granularity of operation is controlled by the kernel option HZ whose
1181# default value (1000 on most architectures) means a granularity of 1ms
1182# (1s/HZ). Historically, the default was 100, but finer granularity is
1183# required for DUMMYNET and other systems on modern hardware. There are
1184# reasonable arguments that HZ should, in fact, be 100 still; consider,
1185# that reducing the granularity too much might cause excessive overhead in
1186# clock interrupt processing, potentially causing ticks to be missed and thus
1187# actually reducing the accuracy of operation.
1188
1189options HZ=100
1190
1191# Enable support for the kernel PLL to use an external PPS signal,
1192# under supervision of [x]ntpd(8)
1193# More info in ntpd documentation: http://www.eecis.udel.edu/~ntp
1194
1195options PPS_SYNC
1196
1197# Enable support for generic feed-forward clocks in the kernel.
1198# The feed-forward clock support is an alternative to the feedback oriented
1199# ntpd/system clock approach, and is to be used with a feed-forward
1200# synchronization algorithm such as the RADclock:
1201# More info here: http://www.synclab.org/radclock
1202
1203options FFCLOCK
1204
1205
1206#####################################################################
1207# SCSI DEVICES
1208
1209# SCSI DEVICE CONFIGURATION
1210
1211# The SCSI subsystem consists of the `base' SCSI code, a number of
1212# high-level SCSI device `type' drivers, and the low-level host-adapter
1213# device drivers. The host adapters are listed in the ISA and PCI
1214# device configuration sections below.
1215#
1216# It is possible to wire down your SCSI devices so that a given bus,
1217# target, and LUN always come on line as the same device unit. In
1218# earlier versions the unit numbers were assigned in the order that
1219# the devices were probed on the SCSI bus. This means that if you
1220# removed a disk drive, you may have had to rewrite your /etc/fstab
1221# file, and also that you had to be careful when adding a new disk
1222# as it may have been probed earlier and moved your device configuration
1223# around. (See also option GEOM_VOL for a different solution to this
1224# problem.)
1225
1226# This old behavior is maintained as the default behavior. The unit
1227# assignment begins with the first non-wired down unit for a device
1228# type. For example, if you wire a disk as "da3" then the first
1229# non-wired disk will be assigned da4.
1230
1231# The syntax for wiring down devices is:
1232
1233hint.scbus.0.at="ahc0"
1234hint.scbus.1.at="ahc1"
1235hint.scbus.1.bus="0"
1236hint.scbus.3.at="ahc2"
1237hint.scbus.3.bus="0"
1238hint.scbus.2.at="ahc2"
1239hint.scbus.2.bus="1"
1240hint.da.0.at="scbus0"
1241hint.da.0.target="0"
1242hint.da.0.unit="0"
1243hint.da.1.at="scbus3"
1244hint.da.1.target="1"
1245hint.da.2.at="scbus2"
1246hint.da.2.target="3"
1247hint.sa.1.at="scbus1"
1248hint.sa.1.target="6"
1249
1250# "units" (SCSI logical unit number) that are not specified are
1251# treated as if specified as LUN 0.
1252
1253# All SCSI devices allocate as many units as are required.
1254
1255# The ch driver drives SCSI Media Changer ("jukebox") devices.
1256#
1257# The da driver drives SCSI Direct Access ("disk") and Optical Media
1258# ("WORM") devices.
1259#
1260# The sa driver drives SCSI Sequential Access ("tape") devices.
1261#
1262# The cd driver drives SCSI Read Only Direct Access ("cd") devices.
1263#
1264# The ses driver drives SCSI Environment Services ("ses") and
1265# SAF-TE ("SCSI Accessible Fault-Tolerant Enclosure") devices.
1266#
1267# The pt driver drives SCSI Processor devices.
1268#
1269# The sg driver provides a passthrough API that is compatible with the
1270# Linux SG driver. It will work in conjunction with the COMPAT_LINUX
1271# option to run linux SG apps. It can also stand on its own and provide
1272# source level API compatibility for porting apps to FreeBSD.
1273#
1274# Target Mode support is provided here but also requires that a SIM
1275# (SCSI Host Adapter Driver) provide support as well.
1276#
1277# The targ driver provides target mode support as a Processor type device.
1278# It exists to give the minimal context necessary to respond to Inquiry
1279# commands. There is a sample user application that shows how the rest
1280# of the command support might be done in /usr/share/examples/scsi_target.
1281#
1282# The targbh driver provides target mode support and exists to respond
1283# to incoming commands that do not otherwise have a logical unit assigned
1284# to them.
1285#
1286# The "unknown" device (uk? in pre-2.0.5) is now part of the base SCSI
1287# configuration as the "pass" driver.
1288
1289device scbus #base SCSI code
1290device ch #SCSI media changers
1291device da #SCSI direct access devices (aka disks)
1292device sa #SCSI tapes
1293device cd #SCSI CD-ROMs
1294device ses #SCSI Environmental Services (and SAF-TE)
1295device pt #SCSI processor
1296device targ #SCSI Target Mode Code
1297device targbh #SCSI Target Mode Blackhole Device
1298device pass #CAM passthrough driver
1299device sg #Linux SCSI passthrough
1300device ctl #CAM Target Layer
1301
1302# CAM OPTIONS:
1303# debugging options:
1304# -- NOTE -- If you specify one of the bus/target/lun options, you must
1305# specify them all!
1306# CAMDEBUG: When defined enables debugging macros
1307# CAM_DEBUG_BUS: Debug the given bus. Use -1 to debug all busses.
1308# CAM_DEBUG_TARGET: Debug the given target. Use -1 to debug all targets.
1309# CAM_DEBUG_LUN: Debug the given lun. Use -1 to debug all luns.
1310# CAM_DEBUG_FLAGS: OR together CAM_DEBUG_INFO, CAM_DEBUG_TRACE,
1311# CAM_DEBUG_SUBTRACE, and CAM_DEBUG_CDB
1312#
1313# CAM_MAX_HIGHPOWER: Maximum number of concurrent high power (start unit) cmds
1314# SCSI_NO_SENSE_STRINGS: When defined disables sense descriptions
1315# SCSI_NO_OP_STRINGS: When defined disables opcode descriptions
1316# SCSI_DELAY: The number of MILLISECONDS to freeze the SIM (scsi adapter)
1317# queue after a bus reset, and the number of milliseconds to
1318# freeze the device queue after a bus device reset. This
1319# can be changed at boot and runtime with the
1320# kern.cam.scsi_delay tunable/sysctl.
1321options CAMDEBUG
1322options CAM_DEBUG_BUS=-1
1323options CAM_DEBUG_TARGET=-1
1324options CAM_DEBUG_LUN=-1
1325options CAM_DEBUG_FLAGS=(CAM_DEBUG_INFO|CAM_DEBUG_TRACE|CAM_DEBUG_CDB)
1326options CAM_MAX_HIGHPOWER=4
1327options SCSI_NO_SENSE_STRINGS
1328options SCSI_NO_OP_STRINGS
1329options SCSI_DELAY=5000 # Be pessimistic about Joe SCSI device
1330
1331# Options for the CAM CDROM driver:
1332# CHANGER_MIN_BUSY_SECONDS: Guaranteed minimum time quantum for a changer LUN
1333# CHANGER_MAX_BUSY_SECONDS: Maximum time quantum per changer LUN, only
1334# enforced if there is I/O waiting for another LUN
1335# The compiled in defaults for these variables are 2 and 10 seconds,
1336# respectively.
1337#
1338# These can also be changed on the fly with the following sysctl variables:
1339# kern.cam.cd.changer.min_busy_seconds
1340# kern.cam.cd.changer.max_busy_seconds
1341#
1342options CHANGER_MIN_BUSY_SECONDS=2
1343options CHANGER_MAX_BUSY_SECONDS=10
1344
1345# Options for the CAM sequential access driver:
1346# SA_IO_TIMEOUT: Timeout for read/write/wfm operations, in minutes
1347# SA_SPACE_TIMEOUT: Timeout for space operations, in minutes
1348# SA_REWIND_TIMEOUT: Timeout for rewind operations, in minutes
1349# SA_ERASE_TIMEOUT: Timeout for erase operations, in minutes
1350# SA_1FM_AT_EOD: Default to model which only has a default one filemark at EOT.
1351options SA_IO_TIMEOUT=4
1352options SA_SPACE_TIMEOUT=60
1353options SA_REWIND_TIMEOUT=(2*60)
1354options SA_ERASE_TIMEOUT=(4*60)
1355options SA_1FM_AT_EOD
1356
1357# Optional timeout for the CAM processor target (pt) device
1358# This is specified in seconds. The default is 60 seconds.
1359options SCSI_PT_DEFAULT_TIMEOUT=60
1360
1361# Optional enable of doing SES passthrough on other devices (e.g., disks)
1362#
1363# Normally disabled because a lot of newer SCSI disks report themselves
1364# as having SES capabilities, but this can then clot up attempts to build
1365# a topology with the SES device that's on the box these drives are in....
1366options SES_ENABLE_PASSTHROUGH
1367
1368
1369#####################################################################
1370# MISCELLANEOUS DEVICES AND OPTIONS
1371
1372device pty #BSD-style compatibility pseudo ttys
1373device nmdm #back-to-back tty devices
1374device md #Memory/malloc disk
1375device snp #Snoop device - to look at pty/vty/etc..
1376device ccd #Concatenated disk driver
1377device firmware #firmware(9) support
1378
1379# Kernel side iconv library
1380options LIBICONV
1381
1382# Size of the kernel message buffer. Should be N * pagesize.
1383options MSGBUF_SIZE=40960
1384
1385
1386#####################################################################
1387# HARDWARE DEVICE CONFIGURATION
1388
1389# For ISA the required hints are listed.
1390# EISA, MCA, PCI, CardBus, SD/MMC and pccard are self identifying buses, so
1391# no hints are needed.
1392
1393#
1394# Mandatory devices:
1395#
1396
1397# These options are valid for other keyboard drivers as well.
1398options KBD_DISABLE_KEYMAP_LOAD # refuse to load a keymap
1399options KBD_INSTALL_CDEV # install a CDEV entry in /dev
1400
1401options FB_DEBUG # Frame buffer debugging
1402
1403device splash # Splash screen and screen saver support
1404
1405# Various screen savers.
1406device blank_saver
1407device daemon_saver
1408device dragon_saver
1409device fade_saver
1410device fire_saver
1411device green_saver
1412device logo_saver
1413device rain_saver
1414device snake_saver
1415device star_saver
1416device warp_saver
1417
1418# The syscons console driver (SCO color console compatible).
1419device sc
1420hint.sc.0.at="isa"
1421options MAXCONS=16 # number of virtual consoles
1422options SC_ALT_MOUSE_IMAGE # simplified mouse cursor in text mode
1423options SC_DFLT_FONT # compile font in
1424makeoptions SC_DFLT_FONT=cp850
1425options SC_DISABLE_KDBKEY # disable `debug' key
1426options SC_DISABLE_REBOOT # disable reboot key sequence
1427options SC_HISTORY_SIZE=200 # number of history buffer lines
1428options SC_MOUSE_CHAR=0x3 # char code for text mode mouse cursor
1429options SC_PIXEL_MODE # add support for the raster text mode
1430
1431# The following options will let you change the default colors of syscons.
1432options SC_NORM_ATTR=(FG_GREEN|BG_BLACK)
1433options SC_NORM_REV_ATTR=(FG_YELLOW|BG_GREEN)
1434options SC_KERNEL_CONS_ATTR=(FG_RED|BG_BLACK)
1435options SC_KERNEL_CONS_REV_ATTR=(FG_BLACK|BG_RED)
1436
1437# The following options will let you change the default behavior of
1438# cut-n-paste feature
1439options SC_CUT_SPACES2TABS # convert leading spaces into tabs
1440options SC_CUT_SEPCHARS=\"x09\" # set of characters that delimit words
1441 # (default is single space - \"x20\")
1442
1443# If you have a two button mouse, you may want to add the following option
1444# to use the right button of the mouse to paste text.
1445options SC_TWOBUTTON_MOUSE
1446
1447# You can selectively disable features in syscons.
1448options SC_NO_CUTPASTE
1449options SC_NO_FONT_LOADING
1450options SC_NO_HISTORY
1451options SC_NO_MODE_CHANGE
1452options SC_NO_SYSMOUSE
1453options SC_NO_SUSPEND_VTYSWITCH
1454
1455# `flags' for sc
1456# 0x80 Put the video card in the VESA 800x600 dots, 16 color mode
1457# 0x100 Probe for a keyboard device periodically if one is not present
1458
1459# Enable experimental features of the syscons terminal emulator (teken).
1460options TEKEN_CONS25 # cons25-style terminal emulation
1461options TEKEN_UTF8 # UTF-8 output handling
1462
1463#
1464# Optional devices:
1465#
1466
1467#
1468# SCSI host adapters:
1469#
1470# adv: All Narrow SCSI bus AdvanSys controllers.
1471# adw: Second Generation AdvanSys controllers including the ADV940UW.
1472# aha: Adaptec 154x/1535/1640
1473# ahb: Adaptec 174x EISA controllers
1474# ahc: Adaptec 274x/284x/2910/293x/294x/394x/3950x/3960x/398X/4944/
1475# 19160x/29160x, aic7770/aic78xx
1476# ahd: Adaptec 29320/39320 Controllers.
1477# aic: Adaptec 6260/6360, APA-1460 (PC Card), NEC PC9801-100 (C-BUS)
1478# bt: Most Buslogic controllers: including BT-445, BT-54x, BT-64x, BT-74x,
1479# BT-75x, BT-946, BT-948, BT-956, BT-958, SDC3211B, SDC3211F, SDC3222F
1480# esp: Emulex ESP, NCR 53C9x and QLogic FAS families based controllers
1481# including the AMD Am53C974 (found on devices such as the Tekram
1482# DC-390(T)) and the Sun ESP and FAS families of controllers
1483# isp: Qlogic ISP 1020, 1040 and 1040B PCI SCSI host adapters,
1484# ISP 1240 Dual Ultra SCSI, ISP 1080 and 1280 (Dual) Ultra2,
1485# ISP 12160 Ultra3 SCSI,
1486# Qlogic ISP 2100 and ISP 2200 1Gb Fibre Channel host adapters.
1487# Qlogic ISP 2300 and ISP 2312 2Gb Fibre Channel host adapters.
1488# Qlogic ISP 2322 and ISP 6322 2Gb Fibre Channel host adapters.
1489# ispfw: Firmware module for Qlogic host adapters
1490# mpt: LSI-Logic MPT/Fusion 53c1020 or 53c1030 Ultra4
1491# or FC9x9 Fibre Channel host adapters.
1492# ncr: NCR 53C810, 53C825 self-contained SCSI host adapters.
1493# sym: Symbios/Logic 53C8XX family of PCI-SCSI I/O processors:
1494# 53C810, 53C810A, 53C815, 53C825, 53C825A, 53C860, 53C875,
1495# 53C876, 53C885, 53C895, 53C895A, 53C896, 53C897, 53C1510D,
1496# 53C1010-33, 53C1010-66.
1497# trm: Tekram DC395U/UW/F DC315U adapters.
1498# wds: WD7000
1499
1500#
1501# Note that the order is important in order for Buslogic ISA/EISA cards to be
1502# probed correctly.
1503#
1504device bt
1505hint.bt.0.at="isa"
1506hint.bt.0.port="0x330"
1507device adv
1508hint.adv.0.at="isa"
1509device adw
1510device aha
1511hint.aha.0.at="isa"
1512device aic
1513hint.aic.0.at="isa"
1514device ahb
1515device ahc
1516device ahd
1517device esp
1518device iscsi_initiator
1519device isp
1520hint.isp.0.disable="1"
1521hint.isp.0.role="3"
1522hint.isp.0.prefer_iomap="1"
1523hint.isp.0.prefer_memmap="1"
1524hint.isp.0.fwload_disable="1"
1525hint.isp.0.ignore_nvram="1"
1526hint.isp.0.fullduplex="1"
1527hint.isp.0.topology="lport"
1528hint.isp.0.topology="nport"
1529hint.isp.0.topology="lport-only"
1530hint.isp.0.topology="nport-only"
1531# we can't get u_int64_t types, nor can we get strings if it's got
1532# a leading 0x, hence this silly dodge.
1533hint.isp.0.portwnn="w50000000aaaa0000"
1534hint.isp.0.nodewnn="w50000000aaaa0001"
1535device ispfw
1536device mpt
1537device ncr
1538device sym
1539device trm
1540device wds
1541hint.wds.0.at="isa"
1542hint.wds.0.port="0x350"
1543hint.wds.0.irq="11"
1544hint.wds.0.drq="6"
1545
1546# The aic7xxx driver will attempt to use memory mapped I/O for all PCI
1547# controllers that have it configured only if this option is set. Unfortunately,
1548# this doesn't work on some motherboards, which prevents it from being the
1549# default.
1550options AHC_ALLOW_MEMIO
1551
1552# Dump the contents of the ahc controller configuration PROM.
1553options AHC_DUMP_EEPROM
1554
1555# Bitmap of units to enable targetmode operations.
1556options AHC_TMODE_ENABLE
1557
1558# Compile in Aic7xxx Debugging code.
1559options AHC_DEBUG
1560
1561# Aic7xxx driver debugging options. See sys/dev/aic7xxx/aic7xxx.h
1562options AHC_DEBUG_OPTS
1563
1564# Print register bitfields in debug output. Adds ~128k to driver
1565# See ahc(4).
1566options AHC_REG_PRETTY_PRINT
1567
1568# Compile in aic79xx debugging code.
1569options AHD_DEBUG
1570
1571# Aic79xx driver debugging options. Adds ~215k to driver. See ahd(4).
1572options AHD_DEBUG_OPTS=0xFFFFFFFF
1573
1574# Print human-readable register definitions when debugging
1575options AHD_REG_PRETTY_PRINT
1576
1577# Bitmap of units to enable targetmode operations.
1578options AHD_TMODE_ENABLE
1579
1580# The adw driver will attempt to use memory mapped I/O for all PCI
1581# controllers that have it configured only if this option is set.
1582options ADW_ALLOW_MEMIO
1583
1584# Options used in dev/iscsi (Software iSCSI stack)
1585#
1586options ISCSI_INITIATOR_DEBUG=9
1587
1588# Options used in dev/isp/ (Qlogic SCSI/FC driver).
1589#
1590# ISP_TARGET_MODE - enable target mode operation
1591#
1592options ISP_TARGET_MODE=1
1593#
1594# ISP_DEFAULT_ROLES - default role
1595# none=0
1596# target=1
1597# initiator=2
1598# both=3 (not supported currently)
1599#
1600# ISP_INTERNAL_TARGET (trivial internal disk target, for testing)
1601#
1602options ISP_DEFAULT_ROLES=2
1603
1604# Options used in dev/sym/ (Symbios SCSI driver).
1605#options SYM_SETUP_LP_PROBE_MAP #-Low Priority Probe Map (bits)
1606 # Allows the ncr to take precedence
1607 # 1 (1<<0) -> 810a, 860
1608 # 2 (1<<1) -> 825a, 875, 885, 895
1609 # 4 (1<<2) -> 895a, 896, 1510d
1610#options SYM_SETUP_SCSI_DIFF #-HVD support for 825a, 875, 885
1611 # disabled:0 (default), enabled:1
1612#options SYM_SETUP_PCI_PARITY #-PCI parity checking
1613 # disabled:0, enabled:1 (default)
1614#options SYM_SETUP_MAX_LUN #-Number of LUNs supported
1615 # default:8, range:[1..64]
1616
1617# The 'dpt' driver provides support for old DPT controllers (http://www.dpt.com/).
1618# These have hardware RAID-{0,1,5} support, and do multi-initiator I/O.
1619# The DPT controllers are commonly re-licensed under other brand-names -
1620# some controllers by Olivetti, Dec, HP, AT&T, SNI, AST, Alphatronic, NEC and
1621# Compaq are actually DPT controllers.
1622#
1623# See src/sys/dev/dpt for debugging and other subtle options.
1624# DPT_MEASURE_PERFORMANCE Enables a set of (semi)invasive metrics. Various
1625# instruments are enabled. The tools in
1626# /usr/sbin/dpt_* assume these to be enabled.
1627# DPT_HANDLE_TIMEOUTS Normally device timeouts are handled by the DPT.
1628# If you want the driver to handle timeouts, enable
1629# this option. If your system is very busy, this
1630# option will create more trouble than solve.
1631# DPT_TIMEOUT_FACTOR Used to compute the excessive amount of time to
1632# wait when timing out with the above option.
1633# DPT_DEBUG_xxxx These are controllable from sys/dev/dpt/dpt.h
1634# DPT_LOST_IRQ When enabled, will try, once per second, to catch
1635# any interrupt that got lost. Seems to help in some
1636# DPT-firmware/Motherboard combinations. Minimal
1637# cost, great benefit.
1638# DPT_RESET_HBA Make "reset" actually reset the controller
1639# instead of fudging it. Only enable this if you
1640# are 100% certain you need it.
1641
1642device dpt
1643
1644# DPT options
1645#!CAM# options DPT_MEASURE_PERFORMANCE
1646#!CAM# options DPT_HANDLE_TIMEOUTS
1647options DPT_TIMEOUT_FACTOR=4
1648options DPT_LOST_IRQ
1649options DPT_RESET_HBA
1650
1651#
1652# Compaq "CISS" RAID controllers (SmartRAID 5* series)
1653# These controllers have a SCSI-like interface, and require the
1654# CAM infrastructure.
1655#
1656device ciss
1657
1658#
1659# Intel Integrated RAID controllers.
1660# This driver was developed and is maintained by Intel. Contacts
1661# at Intel for this driver are
1662# "Kannanthanam, Boji T" <boji.t.kannanthanam@intel.com> and
1663# "Leubner, Achim" <achim.leubner@intel.com>.
1664#
1665device iir
1666
1667#
1668# Mylex AcceleRAID and eXtremeRAID controllers with v6 and later
1669# firmware. These controllers have a SCSI-like interface, and require
1670# the CAM infrastructure.
1671#
1672device mly
1673
1674#
1675# Compaq Smart RAID, Mylex DAC960 and AMI MegaRAID controllers. Only
1676# one entry is needed; the code will find and configure all supported
1677# controllers.
1678#
1679device ida # Compaq Smart RAID
1680device mlx # Mylex DAC960
1681device amr # AMI MegaRAID
1682device amrp # SCSI Passthrough interface (optional, CAM req.)
1683device mfi # LSI MegaRAID SAS
1684device mfip # LSI MegaRAID SAS passthrough, requires CAM
1685options MFI_DEBUG
1686
1687#
1688# 3ware ATA RAID
1689#
1690device twe # 3ware ATA RAID
1691
1692#
1693# Serial ATA host controllers:
1694#
1695# ahci: Advanced Host Controller Interface (AHCI) compatible
1696# mvs: Marvell 88SX50XX/88SX60XX/88SX70XX/SoC controllers
1697# siis: SiliconImage SiI3124/SiI3132/SiI3531 controllers
1698#
1699# These drivers are part of cam(4) subsystem. They supersede less featured
1700# ata(4) subsystem drivers, supporting same hardware.
1701
1702device ahci
1703device mvs
1704device siis
1705
1706#
1707# The 'ATA' driver supports all ATA and ATAPI devices, including PC Card
1708# devices. You only need one "device ata" for it to find all
1709# PCI and PC Card ATA/ATAPI devices on modern machines.
1710# Alternatively, individual bus and chipset drivers may be chosen by using
1711# the 'atacore' driver then selecting the drivers on a per vendor basis.
1712# For example to build a system which only supports a VIA chipset,
1713# omit 'ata' and include the 'atacore', 'atapci' and 'atavia' drivers.
1714device ata
1715device atadisk # ATA disk drives
1716device ataraid # ATA RAID drives
1717device atapicd # ATAPI CDROM drives
1718device atapifd # ATAPI floppy drives
1719device atapist # ATAPI tape drives
1720device atapicam # emulate ATAPI devices as SCSI ditto via CAM
1721 # needs CAM to be present (scbus & pass)
1722
1723# Modular ATA
1724#device atacore # Core ATA functionality
1725#device atacard # CARDBUS support
1726#device atabus # PC98 cbus support
1727#device ataisa # ISA bus support
1728#device atapci # PCI bus support; only generic chipset support
1729
1730# PCI ATA chipsets
1731#device ataahci # AHCI SATA
1732#device ataacard # ACARD
1733#device ataacerlabs # Acer Labs Inc. (ALI)
1734#device ataadaptec # Adaptec
1735#device ataamd # American Micro Devices (AMD)
1736#device ataati # ATI
1737#device atacenatek # Cenatek
1738#device atacypress # Cypress
1739#device atacyrix # Cyrix
1740#device atahighpoint # HighPoint
1741#device ataintel # Intel
1742#device ataite # Integrated Technology Inc. (ITE)
1743#device atajmicron # JMicron
1744#device atamarvell # Marvell
1745#device atamicron # Micron
1746#device atanational # National
1747#device atanetcell # NetCell
1748#device atanvidia # nVidia
1749#device atapromise # Promise
1750#device ataserverworks # ServerWorks
1751#device atasiliconimage # Silicon Image Inc. (SiI) (formerly CMD)
1752#device atasis # Silicon Integrated Systems Corp.(SiS)
1753#device atavia # VIA Technologies Inc.
1754
1755#
1756# For older non-PCI, non-PnPBIOS systems, these are the hints lines to add:
1757hint.ata.0.at="isa"
1758hint.ata.0.port="0x1f0"
1759hint.ata.0.irq="14"
1760hint.ata.1.at="isa"
1761hint.ata.1.port="0x170"
1762hint.ata.1.irq="15"
1763
1764#
1765# The following options are valid on the ATA driver:
1766#
1767# ATA_STATIC_ID: controller numbering is static ie depends on location
1768# else the device numbers are dynamically allocated.
1769# ATA_REQUEST_TIMEOUT: the number of seconds to wait for an ATA request
1770# before timing out.
1771# ATA_CAM: Turn ata(4) subsystem controller drivers into cam(4)
1772# interface modules. This deprecates all ata(4)
1773# peripheral device drivers (atadisk, ataraid, atapicd,
1774# atapifd, atapist, atapicam) and all user-level APIs.
1775# cam(4) drivers and APIs will be connected instead.
1776
1777options ATA_STATIC_ID
1778#options ATA_REQUEST_TIMEOUT=10
1779options ATA_CAM
1780
1781#
1782# Standard floppy disk controllers and floppy tapes, supports
1783# the Y-E DATA External FDD (PC Card)
1784#
1785device fdc
1786hint.fdc.0.at="isa"
1787hint.fdc.0.port="0x3F0"
1788hint.fdc.0.irq="6"
1789hint.fdc.0.drq="2"
1790#
1791# FDC_DEBUG enables floppy debugging. Since the debug output is huge, you
1792# gotta turn it actually on by setting the variable fd_debug with DDB,
1793# however.
1794options FDC_DEBUG
1795#
1796# Activate this line if you happen to have an Insight floppy tape.
1797# Probing them proved to be dangerous for people with floppy disks only,
1798# so it's "hidden" behind a flag:
1799#hint.fdc.0.flags="1"
1800
1801# Specify floppy devices
1802hint.fd.0.at="fdc0"
1803hint.fd.0.drive="0"
1804hint.fd.1.at="fdc0"
1805hint.fd.1.drive="1"
1806
1807#
1808# uart: newbusified driver for serial interfaces. It consolidates the sio(4),
1809# sab(4) and zs(4) drivers.
1810#
1811device uart
1812
1813# Options for uart(4)
1814options UART_PPS_ON_CTS # Do time pulse capturing using CTS
1815 # instead of DCD.
1816
1817# The following hint should only be used for pure ISA devices. It is not
1818# needed otherwise. Use of hints is strongly discouraged.
1819hint.uart.0.at="isa"
1820
1821# The following 3 hints are used when the UART is a system device (i.e., a
1822# console or debug port), but only on platforms that don't have any other
1823# means to pass the information to the kernel. The unit number of the hint
1824# is only used to bundle the hints together. There is no relation to the
1825# unit number of the probed UART.
1826hint.uart.0.port="0x3f8"
1827hint.uart.0.flags="0x10"
1828hint.uart.0.baud="115200"
1829
1830# `flags' for serial drivers that support consoles like sio(4) and uart(4):
1831# 0x10 enable console support for this unit. Other console flags
1832# (if applicable) are ignored unless this is set. Enabling
1833# console support does not make the unit the preferred console.
1834# Boot with -h or set boot_serial=YES in the loader. For sio(4)
1835# specifically, the 0x20 flag can also be set (see above).
1836# Currently, at most one unit can have console support; the
1837# first one (in config file order) with this flag set is
1838# preferred. Setting this flag for sio0 gives the old behavior.
1839# 0x80 use this port for serial line gdb support in ddb. Also known
1840# as debug port.
1841#
1842
1843# Options for serial drivers that support consoles:
1844options BREAK_TO_DEBUGGER # A BREAK on a serial console goes to
1845 # ddb, if available.
1846
1847# Solaris implements a new BREAK which is initiated by a character
1848# sequence CR ~ ^b which is similar to a familiar pattern used on
1849# Sun servers by the Remote Console. There are FreeBSD extensions:
1850# CR ~ ^p requests force panic and CR ~ ^r requests a clean reboot.
1851options ALT_BREAK_TO_DEBUGGER
1852
1853# Serial Communications Controller
1854# Supports the Siemens SAB 82532 and Zilog Z8530 multi-channel
1855# communications controllers.
1856device scc
1857
1858# PCI Universal Communications driver
1859# Supports various multi port PCI I/O cards.
1860device puc
1861
1862#
1863# Network interfaces:
1864#
1865# MII bus support is required for many PCI Ethernet NICs,
1866# namely those which use MII-compliant transceivers or implement
1867# transceiver control interfaces that operate like an MII. Adding
1868# "device miibus" to the kernel config pulls in support for the generic
1869# miibus API, the common support for for bit-bang'ing the MII and all
1870# of the PHY drivers, including a generic one for PHYs that aren't
1871# specifically handled by an individual driver. Support for specific
1872# PHYs may be built by adding "device mii", "device mii_bitbang" if
1873# needed by the NIC driver and then adding the appropriate PHY driver.
1874device mii # Minimal MII support
1875device mii_bitbang # Common module for bit-bang'ing the MII
1876device miibus # MII support w/ bit-bang'ing and all PHYs
1877
1878device acphy # Altima Communications AC101
1879device amphy # AMD AM79c873 / Davicom DM910{1,2}
1880device atphy # Attansic/Atheros F1
1881device axphy # Asix Semiconductor AX88x9x
1882device bmtphy # Broadcom BCM5201/BCM5202 and 3Com 3c905C
1883device brgphy # Broadcom BCM54xx/57xx 1000baseTX
1884device ciphy # Cicada/Vitesse CS/VSC8xxx
1885device e1000phy # Marvell 88E1000 1000/100/10-BT
1886device gentbi # Generic 10-bit 1000BASE-{LX,SX} fiber ifaces
1887device icsphy # ICS ICS1889-1893
1888device ip1000phy # IC Plus IP1000A/IP1001
1889device jmphy # JMicron JMP211/JMP202
1890device lxtphy # Level One LXT-970
1891device mlphy # Micro Linear 6692
1892device nsgphy # NatSemi DP8361/DP83865/DP83891
1893device nsphy # NatSemi DP83840A
1894device nsphyter # NatSemi DP83843/DP83815
1895device pnaphy # HomePNA
1896device qsphy # Quality Semiconductor QS6612
1897device rdcphy # RDC Semiconductor R6040
1898device rgephy # RealTek 8169S/8110S/8211B/8211C
1899device rlphy # RealTek 8139
1900device rlswitch # RealTek 8305
1901device smcphy # SMSC LAN91C111
1902device tdkphy # TDK 89Q2120
1903device tlphy # Texas Instruments ThunderLAN
1904device truephy # LSI TruePHY
1905device xmphy # XaQti XMAC II
1906
1907# an: Aironet 4500/4800 802.11 wireless adapters. Supports the PCMCIA,
1908# PCI and ISA varieties.
1909# ae: Support for gigabit ethernet adapters based on the Attansic/Atheros
1910# L2 PCI-Express FastEthernet controllers.
1911# age: Support for gigabit ethernet adapters based on the Attansic/Atheros
1912# L1 PCI express gigabit ethernet controllers.
1913# alc: Support for Atheros AR8131/AR8132 PCIe ethernet controllers.
1914# ale: Support for Atheros AR8121/AR8113/AR8114 PCIe ethernet controllers.
1915# ath: Atheros a/b/g WiFi adapters (requires ath_hal and wlan)
1916# bce: Broadcom NetXtreme II (BCM5706/BCM5708) PCI/PCIe Gigabit Ethernet
1917# adapters.
1918# bfe: Broadcom BCM4401 Ethernet adapter.
1919# bge: Support for gigabit ethernet adapters based on the Broadcom
1920# BCM570x family of controllers, including the 3Com 3c996-T,
1921# the Netgear GA302T, the SysKonnect SK-9D21 and SK-9D41, and
1922# the embedded gigE NICs on Dell PowerEdge 2550 servers.
1923# bxe: Broadcom NetXtreme II (BCM57710/57711/57711E) PCIe 10b Ethernet
1924# adapters.
1925# bwi: Broadcom BCM430* and BCM431* family of wireless adapters.
1926# bwn: Broadcom BCM43xx family of wireless adapters.
1927# cas: Sun Cassini/Cassini+ and National Semiconductor DP83065 Saturn
1928# cm: Arcnet SMC COM90c26 / SMC COM90c56
1929# (and SMC COM90c66 in '56 compatibility mode) adapters.
1930# cxgbe: Support for PCI express 10Gb/1Gb adapters based on the Chelsio T4
1931# (Terminator 4) ASIC.
1932# dc: Support for PCI fast ethernet adapters based on the DEC/Intel 21143
1933# and various workalikes including:
1934# the ADMtek AL981 Comet and AN985 Centaur, the ASIX Electronics
1935# AX88140A and AX88141, the Davicom DM9100 and DM9102, the Lite-On
1936# 82c168 and 82c169 PNIC, the Lite-On/Macronix LC82C115 PNIC II
1937# and the Macronix 98713/98713A/98715/98715A/98725 PMAC. This driver
1938# replaces the old al, ax, dm, pn and mx drivers. List of brands:
1939# Digital DE500-BA, Kingston KNE100TX, D-Link DFE-570TX, SOHOware SFA110,
1940# SVEC PN102-TX, CNet Pro110B, 120A, and 120B, Compex RL100-TX,
1941# LinkSys LNE100TX, LNE100TX V2.0, Jaton XpressNet, Alfa Inc GFC2204,
1942# KNE110TX.
1943# de: Digital Equipment DC21040
1944# em: Intel Pro/1000 Gigabit Ethernet 82542, 82543, 82544 based adapters.
1945# igb: Intel Pro/1000 PCI Express Gigabit Ethernet: 82575 and later adapters.
1946# ep: 3Com 3C509, 3C529, 3C556, 3C562D, 3C563D, 3C572, 3C574X, 3C579, 3C589
1947# and PC Card devices using these chipsets.
1948# ex: Intel EtherExpress Pro/10 and other i82595-based adapters,
1949# Olicom Ethernet PC Card devices.
1950# fe: Fujitsu MB86960A/MB86965A Ethernet
1951# fea: DEC DEFEA EISA FDDI adapter
1952# fpa: Support for the Digital DEFPA PCI FDDI. `device fddi' is also needed.
1953# fxp: Intel EtherExpress Pro/100B
1954# (hint of prefer_iomap can be done to prefer I/O instead of Mem mapping)
1955# gem: Apple GMAC/Sun ERI/Sun GEM
1956# hme: Sun HME (Happy Meal Ethernet)
1957# jme: JMicron JMC260 Fast Ethernet/JMC250 Gigabit Ethernet based adapters.
1958# le: AMD Am7900 LANCE and Am79C9xx PCnet
1959# lge: Support for PCI gigabit ethernet adapters based on the Level 1
1960# LXT1001 NetCellerator chipset. This includes the D-Link DGE-500SX,
1961# SMC TigerCard 1000 (SMC9462SX), and some Addtron cards.
1962# malo: Marvell Libertas wireless NICs.
1963# mwl: Marvell 88W8363 802.11n wireless NICs.
1964# msk: Support for gigabit ethernet adapters based on the Marvell/SysKonnect
1965# Yukon II Gigabit controllers, including 88E8021, 88E8022, 88E8061,
1966# 88E8062, 88E8035, 88E8036, 88E8038, 88E8050, 88E8052, 88E8053,
1967# 88E8055, 88E8056 and D-Link 560T/550SX.
1968# lmc: Support for the LMC/SBE wide-area network interface cards.
1969# my: Myson Fast Ethernet (MTD80X, MTD89X)
1970# nge: Support for PCI gigabit ethernet adapters based on the National
1971# Semiconductor DP83820 and DP83821 chipset. This includes the
1972# SMC EZ Card 1000 (SMC9462TX), D-Link DGE-500T, Asante FriendlyNet
1973# GigaNIX 1000TA and 1000TPC, the Addtron AEG320T, the Surecom
1974# EP-320G-TX and the Netgear GA622T.
1975# oce: Emulex 10 Gbit adapters (OneConnect Ethernet)
1976# pcn: Support for PCI fast ethernet adapters based on the AMD Am79c97x
1977# PCnet-FAST, PCnet-FAST+, PCnet-FAST III, PCnet-PRO and PCnet-Home
1978# chipsets. These can also be handled by the le(4) driver if the
1979# pcn(4) driver is left out of the kernel. The le(4) driver does not
1980# support the additional features like the MII bus and burst mode of
1981# the PCnet-FAST and greater chipsets though.
1982# ral: Ralink Technology IEEE 802.11 wireless adapter
1983# re: RealTek 8139C+/8169/816xS/811xS/8101E PCI/PCIe Ethernet adapter
1984# rl: Support for PCI fast ethernet adapters based on the RealTek 8129/8139
1985# chipset. Note that the RealTek driver defaults to using programmed
1986# I/O to do register accesses because memory mapped mode seems to cause
1987# severe lockups on SMP hardware. This driver also supports the
1988# Accton EN1207D `Cheetah' adapter, which uses a chip called
1989# the MPX 5030/5038, which is either a RealTek in disguise or a
1990# RealTek workalike. Note that the D-Link DFE-530TX+ uses the RealTek
1991# chipset and is supported by this driver, not the 'vr' driver.
1992# sf: Support for Adaptec Duralink PCI fast ethernet adapters based on the
1993# Adaptec AIC-6915 "starfire" controller.
1994# This includes dual and quad port cards, as well as one 100baseFX card.
1995# Most of these are 64-bit PCI devices, except for one single port
1996# card which is 32-bit.
1997# sge: Silicon Integrated Systems SiS190/191 Fast/Gigabit Ethernet adapter
1998# sis: Support for NICs based on the Silicon Integrated Systems SiS 900,
1999# SiS 7016 and NS DP83815 PCI fast ethernet controller chips.
2000# sk: Support for the SysKonnect SK-984x series PCI gigabit ethernet NICs.
2001# This includes the SK-9841 and SK-9842 single port cards (single mode
2002# and multimode fiber) and the SK-9843 and SK-9844 dual port cards
2003# (also single mode and multimode).
2004# The driver will autodetect the number of ports on the card and
2005# attach each one as a separate network interface.
2006# sn: Support for ISA and PC Card Ethernet devices using the
2007# SMC91C90/92/94/95 chips.
2008# ste: Sundance Technologies ST201 PCI fast ethernet controller, includes
2009# the D-Link DFE-550TX.
2010# stge: Support for gigabit ethernet adapters based on the Sundance/Tamarack
2011# TC9021 family of controllers, including the Sundance ST2021/ST2023,
2012# the Sundance/Tamarack TC9021, the D-Link DL-4000 and ASUS NX1101.
2013# ti: Support for PCI gigabit ethernet NICs based on the Alteon Networks
2014# Tigon 1 and Tigon 2 chipsets. This includes the Alteon AceNIC, the
2015# 3Com 3c985, the Netgear GA620 and various others. Note that you will
2016# probably want to bump up kern.ipc.nmbclusters a lot to use this driver.
2017# tl: Support for the Texas Instruments TNETE100 series 'ThunderLAN'
2018# cards and integrated ethernet controllers. This includes several
2019# Compaq Netelligent 10/100 cards and the built-in ethernet controllers
2020# in several Compaq Prosignia, Proliant and Deskpro systems. It also
2021# supports several Olicom 10Mbps and 10/100 boards.
2022# tx: SMC 9432 TX, BTX and FTX cards. (SMC EtherPower II series)
2023# txp: Support for 3Com 3cR990 cards with the "Typhoon" chipset
2024# vr: Support for various fast ethernet adapters based on the VIA
2025# Technologies VT3043 `Rhine I' and VT86C100A `Rhine II' chips,
2026# including the D-Link DFE520TX and D-Link DFE530TX (see 'rl' for
2027# DFE530TX+), the Hawking Technologies PN102TX, and the AOpen/Acer ALN-320.
2028# vte: DM&P Vortex86 RDC R6040 Fast Ethernet
2029# vx: 3Com 3C590 and 3C595
2030# wb: Support for fast ethernet adapters based on the Winbond W89C840F chip.
2031# Note: this is not the same as the Winbond W89C940F, which is a
2032# NE2000 clone.
2033# wi: Lucent WaveLAN/IEEE 802.11 PCMCIA adapters. Note: this supports both
2034# the PCMCIA and ISA cards: the ISA card is really a PCMCIA to ISA
2035# bridge with a PCMCIA adapter plugged into it.
2036# xe: Xircom/Intel EtherExpress Pro100/16 PC Card ethernet controller,
2037# Accton Fast EtherCard-16, Compaq Netelligent 10/100 PC Card,
2038# Toshiba 10/100 Ethernet PC Card, Xircom 16-bit Ethernet + Modem 56
2039# xl: Support for the 3Com 3c900, 3c905, 3c905B and 3c905C (Fast)
2040# Etherlink XL cards and integrated controllers. This includes the
2041# integrated 3c905B-TX chips in certain Dell Optiplex and Dell
2042# Precision desktop machines and the integrated 3c905-TX chips
2043# in Dell Latitude laptop docking stations.
2044# Also supported: 3Com 3c980(C)-TX, 3Com 3cSOHO100-TX, 3Com 3c450-TX
2045
2046# Order for ISA/EISA devices is important here
2047
2048device cm
2049hint.cm.0.at="isa"
2050hint.cm.0.port="0x2e0"
2051hint.cm.0.irq="9"
2052hint.cm.0.maddr="0xdc000"
2053device ep
2054device ex
2055device fe
2056hint.fe.0.at="isa"
2057hint.fe.0.port="0x300"
2058device fea
2059device sn
2060hint.sn.0.at="isa"
2061hint.sn.0.port="0x300"
2062hint.sn.0.irq="10"
2063device an
2064device wi
2065device xe
2066
2067# PCI Ethernet NICs that use the common MII bus controller code.
2068device ae # Attansic/Atheros L2 FastEthernet
2069device age # Attansic/Atheros L1 Gigabit Ethernet
2070device alc # Atheros AR8131/AR8132 Ethernet
2071device ale # Atheros AR8121/AR8113/AR8114 Ethernet
2072device bce # Broadcom BCM5706/BCM5708 Gigabit Ethernet
2073device bfe # Broadcom BCM440x 10/100 Ethernet
2074device bge # Broadcom BCM570xx Gigabit Ethernet
2075device cas # Sun Cassini/Cassini+ and NS DP83065 Saturn
2076device cxgb # Chelsio T3 10 Gigabit Ethernet
2077device cxgb_t3fw # Chelsio T3 10 Gigabit Ethernet firmware
2078device dc # DEC/Intel 21143 and various workalikes
2079device et # Agere ET1310 10/100/Gigabit Ethernet
2080device fxp # Intel EtherExpress PRO/100B (82557, 82558)
2081hint.fxp.0.prefer_iomap="0"
2082device gem # Apple GMAC/Sun ERI/Sun GEM
2083device hme # Sun HME (Happy Meal Ethernet)
2084device jme # JMicron JMC250 Gigabit/JMC260 Fast Ethernet
2085device lge # Level 1 LXT1001 gigabit Ethernet
2086device msk # Marvell/SysKonnect Yukon II Gigabit Ethernet
2087device my # Myson Fast Ethernet (MTD80X, MTD89X)
2088device nge # NatSemi DP83820 gigabit Ethernet
2089device re # RealTek 8139C+/8169/8169S/8110S
2090device rl # RealTek 8129/8139
2091device pcn # AMD Am79C97x PCI 10/100 NICs
2092device sf # Adaptec AIC-6915 (``Starfire'')
2093device sge # Silicon Integrated Systems SiS190/191
2094device sis # Silicon Integrated Systems SiS 900/SiS 7016
2095device sk # SysKonnect SK-984x & SK-982x gigabit Ethernet
2096device ste # Sundance ST201 (D-Link DFE-550TX)
2097device stge # Sundance/Tamarack TC9021 gigabit Ethernet
2098device tl # Texas Instruments ThunderLAN
2099device tx # SMC EtherPower II (83c170 ``EPIC'')
2100device vr # VIA Rhine, Rhine II
2101device vte # DM&P Vortex86 RDC R6040 Fast Ethernet
2102device wb # Winbond W89C840F
2103device xl # 3Com 3c90x (``Boomerang'', ``Cyclone'')
2104
2105# PCI Ethernet NICs.
2106device bxe # Broadcom BCM57710/BCM57711/BCM57711E 10Gb Ethernet
2107device cxgbe # Chelsio T4 10GbE PCIe adapter
2108device de # DEC/Intel DC21x4x (``Tulip'')
2109device em # Intel Pro/1000 Gigabit Ethernet
2110device igb # Intel Pro/1000 PCIE Gigabit Ethernet
2111device ixgb # Intel Pro/10Gbe PCI-X Ethernet
2112device ixgbe # Intel Pro/10Gbe PCIE Ethernet
2113device le # AMD Am7900 LANCE and Am79C9xx PCnet
2114device mxge # Myricom Myri-10G 10GbE NIC
2115device nxge # Neterion Xframe 10GbE Server/Storage Adapter
2116device oce # Emulex 10 GbE (OneConnect Ethernet)
2117device ti # Alteon Networks Tigon I/II gigabit Ethernet
2118device txp # 3Com 3cR990 (``Typhoon'')
2119device vx # 3Com 3c590, 3c595 (``Vortex'')
2120device vxge # Exar/Neterion XFrame 3100 10GbE
2121
2122# PCI FDDI NICs.
2123device fpa
2124
2125# PCI WAN adapters.
2126device lmc
2127
2128# PCI IEEE 802.11 Wireless NICs
2129device ath # Atheros pci/cardbus NIC's
2130device ath_hal # pci/cardbus chip support
2131#device ath_ar5210 # AR5210 chips
2132#device ath_ar5211 # AR5211 chips
2133#device ath_ar5212 # AR5212 chips
2134#device ath_rf2413
2135#device ath_rf2417
2136#device ath_rf2425
2137#device ath_rf5111
2138#device ath_rf5112
2139#device ath_rf5413
2140#device ath_ar5416 # AR5416 chips
2141options AH_SUPPORT_AR5416 # enable AR5416 tx/rx descriptors
2142# All of the AR5212 parts have a problem when paired with the AR71xx
2143# CPUS. These parts have a bug that triggers a fatal bus error on the AR71xx
2144# only. Details of the exact nature of the bug are sketchy, but some can be
2145# found at https://forum.openwrt.org/viewtopic.php?pid=70060 on pages 4, 5 and
2146# 6. This option enables this workaround. There is a performance penalty
2147# for this work around, but without it things don't work at all. The DMA
2148# from the card usually bursts 128 bytes, but on the affected CPUs, only
2149# 4 are safe.
2150options AH_RXCFG_SDMAMW_4BYTES
2151#device ath_ar9160 # AR9160 chips
2152#device ath_ar9280 # AR9280 chips
2153#device ath_ar9285 # AR9285 chips
2154device ath_rate_sample # SampleRate tx rate control for ath
2155device bwi # Broadcom BCM430* BCM431*
2156device bwn # Broadcom BCM43xx
2157device malo # Marvell Libertas wireless NICs.
2158device mwl # Marvell 88W8363 802.11n wireless NICs.
2159device ral # Ralink Technology RT2500 wireless NICs.
2160
2161# Use sf_buf(9) interface for jumbo buffers on ti(4) controllers.
2162#options TI_SF_BUF_JUMBO
2163# Turn on the header splitting option for the ti(4) driver firmware. This
2164# only works for Tigon II chips, and has no effect for Tigon I chips.
2165# This option requires the TI_SF_BUF_JUMBO option above.
2166#options TI_JUMBO_HDRSPLIT
2167
2168#
2169# Use header splitting feature on bce(4) adapters.
2170# This may help to reduce the amount of jumbo-sized memory buffers used.
2171#
2172options BCE_JUMBO_HDRSPLIT
2173
2174# These two options allow manipulating the mbuf cluster size and mbuf size,
2175# respectively. Be very careful with NIC driver modules when changing
2176# these from their default values, because that can potentially cause a
2177# mismatch between the mbuf size assumed by the kernel and the mbuf size
2178# assumed by a module. The only driver that currently has the ability to
2179# detect a mismatch is ti(4).
2180options MCLSHIFT=12 # mbuf cluster shift in bits, 12 == 4KB
2181options MSIZE=512 # mbuf size in bytes
2182
2183#
2184# ATM related options (Cranor version)
2185# (note: this driver cannot be used with the HARP ATM stack)
2186#
2187# The `en' device provides support for Efficient Networks (ENI)
2188# ENI-155 PCI midway cards, and the Adaptec 155Mbps PCI ATM cards (ANA-59x0).
2189#
2190# The `hatm' device provides support for Fore/Marconi HE155 and HE622
2191# ATM PCI cards.
2192#
2193# The `fatm' device provides support for Fore PCA200E ATM PCI cards.
2194#
2195# The `patm' device provides support for IDT77252 based cards like
2196# ProSum's ProATM-155 and ProATM-25 and IDT's evaluation boards.
2197#
2198# atm device provides generic atm functions and is required for
2199# atm devices.
2200# NATM enables the netnatm protocol family that can be used to
2201# bypass TCP/IP.
2202#
2203# utopia provides the access to the ATM PHY chips and is required for en,
2204# hatm and fatm.
2205#
2206# the current driver supports only PVC operations (no atm-arp, no multicast).
2207# for more details, please read the original documents at
2208# http://www.ccrc.wustl.edu/pub/chuck/tech/bsdatm/bsdatm.html
2209#
2210device atm
2211device en
2212device fatm #Fore PCA200E
2213device hatm #Fore/Marconi HE155/622
2214device patm #IDT77252 cards (ProATM and IDT)
2215device utopia #ATM PHY driver
2216options NATM #native ATM
2217
2218options LIBMBPOOL #needed by patm, iatm
2219
2220#
2221# Sound drivers
2222#
2223# sound: The generic sound driver.
2224#
2225
2226device sound
2227
2228#
2229# snd_*: Device-specific drivers.
2230#
2231# The flags of the device tell the device a bit more info about the
2232# device that normally is obtained through the PnP interface.
2233# bit 2..0 secondary DMA channel;
2234# bit 4 set if the board uses two dma channels;
2235# bit 15..8 board type, overrides autodetection; leave it
2236# zero if don't know what to put in (and you don't,
2237# since this is unsupported at the moment...).
2238#
2239# snd_ad1816: Analog Devices AD1816 ISA PnP/non-PnP.
2240# snd_als4000: Avance Logic ALS4000 PCI.
2241# snd_atiixp: ATI IXP 200/300/400 PCI.
2242# snd_audiocs: Crystal Semiconductor CS4231 SBus/EBus. Only
2243# for sparc64.
2244# snd_cmi: CMedia CMI8338/CMI8738 PCI.
2245# snd_cs4281: Crystal Semiconductor CS4281 PCI.
2246# snd_csa: Crystal Semiconductor CS461x/428x PCI. (except
2247# 4281)
2248# snd_ds1: Yamaha DS-1 PCI.
2249# snd_emu10k1: Creative EMU10K1 PCI and EMU10K2 (Audigy) PCI.
2250# snd_emu10kx: Creative SoundBlaster Live! and Audigy
2251# snd_envy24: VIA Envy24 and compatible, needs snd_spicds.
2252# snd_envy24ht: VIA Envy24HT and compatible, needs snd_spicds.
2253# snd_es137x: Ensoniq AudioPCI ES137x PCI.
2254# snd_ess: Ensoniq ESS ISA PnP/non-PnP, to be used in
2255# conjunction with snd_sbc.
2256# snd_fm801: Forte Media FM801 PCI.
2257# snd_gusc: Gravis UltraSound ISA PnP/non-PnP.
2258# snd_hda: Intel High Definition Audio (Controller) and
2259# compatible.
2260# snd_hdspe: RME HDSPe AIO and RayDAT.
2260# snd_ich: Intel ICH AC'97 and some more audio controllers
2261# embedded in a chipset, for example nVidia
2262# nForce controllers.
2263# snd_maestro: ESS Technology Maestro-1/2x PCI.
2264# snd_maestro3: ESS Technology Maestro-3/Allegro PCI.
2265# snd_mss: Microsoft Sound System ISA PnP/non-PnP.
2266# snd_neomagic: Neomagic 256 AV/ZX PCI.
2267# snd_sb16: Creative SoundBlaster16, to be used in
2268# conjunction with snd_sbc.
2269# snd_sb8: Creative SoundBlaster (pre-16), to be used in
2270# conjunction with snd_sbc.
2271# snd_sbc: Creative SoundBlaster ISA PnP/non-PnP.
2272# Supports ESS and Avance ISA chips as well.
2273# snd_solo: ESS Solo-1x PCI.
2274# snd_spicds: SPI codec driver, needed by Envy24/Envy24HT drivers.
2275# snd_t4dwave: Trident 4DWave DX/NX PCI, Sis 7018 PCI and Acer Labs
2276# M5451 PCI.
2277# snd_uaudio: USB audio.
2278# snd_via8233: VIA VT8233x PCI.
2279# snd_via82c686: VIA VT82C686A PCI.
2280# snd_vibes: S3 Sonicvibes PCI.
2281
2282device snd_ad1816
2283device snd_als4000
2284device snd_atiixp
2285#device snd_audiocs
2286device snd_cmi
2287device snd_cs4281
2288device snd_csa
2289device snd_ds1
2290device snd_emu10k1
2291device snd_emu10kx
2292device snd_envy24
2293device snd_envy24ht
2294device snd_es137x
2295device snd_ess
2296device snd_fm801
2297device snd_gusc
2298device snd_hda
2261# snd_ich: Intel ICH AC'97 and some more audio controllers
2262# embedded in a chipset, for example nVidia
2263# nForce controllers.
2264# snd_maestro: ESS Technology Maestro-1/2x PCI.
2265# snd_maestro3: ESS Technology Maestro-3/Allegro PCI.
2266# snd_mss: Microsoft Sound System ISA PnP/non-PnP.
2267# snd_neomagic: Neomagic 256 AV/ZX PCI.
2268# snd_sb16: Creative SoundBlaster16, to be used in
2269# conjunction with snd_sbc.
2270# snd_sb8: Creative SoundBlaster (pre-16), to be used in
2271# conjunction with snd_sbc.
2272# snd_sbc: Creative SoundBlaster ISA PnP/non-PnP.
2273# Supports ESS and Avance ISA chips as well.
2274# snd_solo: ESS Solo-1x PCI.
2275# snd_spicds: SPI codec driver, needed by Envy24/Envy24HT drivers.
2276# snd_t4dwave: Trident 4DWave DX/NX PCI, Sis 7018 PCI and Acer Labs
2277# M5451 PCI.
2278# snd_uaudio: USB audio.
2279# snd_via8233: VIA VT8233x PCI.
2280# snd_via82c686: VIA VT82C686A PCI.
2281# snd_vibes: S3 Sonicvibes PCI.
2282
2283device snd_ad1816
2284device snd_als4000
2285device snd_atiixp
2286#device snd_audiocs
2287device snd_cmi
2288device snd_cs4281
2289device snd_csa
2290device snd_ds1
2291device snd_emu10k1
2292device snd_emu10kx
2293device snd_envy24
2294device snd_envy24ht
2295device snd_es137x
2296device snd_ess
2297device snd_fm801
2298device snd_gusc
2299device snd_hda
2300device snd_hdspe
2299device snd_ich
2300device snd_maestro
2301device snd_maestro3
2302device snd_mss
2303device snd_neomagic
2304device snd_sb16
2305device snd_sb8
2306device snd_sbc
2307device snd_solo
2308device snd_spicds
2309device snd_t4dwave
2310device snd_uaudio
2311device snd_via8233
2312device snd_via82c686
2313device snd_vibes
2314
2315# For non-PnP sound cards:
2316hint.pcm.0.at="isa"
2317hint.pcm.0.irq="10"
2318hint.pcm.0.drq="1"
2319hint.pcm.0.flags="0x0"
2320hint.sbc.0.at="isa"
2321hint.sbc.0.port="0x220"
2322hint.sbc.0.irq="5"
2323hint.sbc.0.drq="1"
2324hint.sbc.0.flags="0x15"
2325hint.gusc.0.at="isa"
2326hint.gusc.0.port="0x220"
2327hint.gusc.0.irq="5"
2328hint.gusc.0.drq="1"
2329hint.gusc.0.flags="0x13"
2330
2331#
2332# Following options are intended for debugging/testing purposes:
2333#
2334# SND_DEBUG Enable extra debugging code that includes
2335# sanity checking and possible increase of
2336# verbosity.
2337#
2338# SND_DIAGNOSTIC Similar in a spirit of INVARIANTS/DIAGNOSTIC,
2339# zero tolerance against inconsistencies.
2340#
2341# SND_FEEDER_MULTIFORMAT By default, only 16/32 bit feeders are compiled
2342# in. This options enable most feeder converters
2343# except for 8bit. WARNING: May bloat the kernel.
2344#
2345# SND_FEEDER_FULL_MULTIFORMAT Ditto, but includes 8bit feeders as well.
2346#
2347# SND_FEEDER_RATE_HP (feeder_rate) High precision 64bit arithmetic
2348# as much as possible (the default trying to
2349# avoid it). Possible slowdown.
2350#
2351# SND_PCM_64 (Only applicable for i386/32bit arch)
2352# Process 32bit samples through 64bit
2353# integer/arithmetic. Slight increase of dynamic
2354# range at a cost of possible slowdown.
2355#
2356# SND_OLDSTEREO Only 2 channels are allowed, effectively
2357# disabling multichannel processing.
2358#
2359options SND_DEBUG
2360options SND_DIAGNOSTIC
2361options SND_FEEDER_MULTIFORMAT
2362options SND_FEEDER_FULL_MULTIFORMAT
2363options SND_FEEDER_RATE_HP
2364options SND_PCM_64
2365options SND_OLDSTEREO
2366
2367#
2368# IEEE-488 hardware:
2369# pcii: PCIIA cards (uPD7210 based isa cards)
2370# tnt4882: National Instruments PCI-GPIB card.
2371
2372device pcii
2373hint.pcii.0.at="isa"
2374hint.pcii.0.port="0x2e1"
2375hint.pcii.0.irq="5"
2376hint.pcii.0.drq="1"
2377
2378device tnt4882
2379
2380#
2381# Miscellaneous hardware:
2382#
2383# scd: Sony CD-ROM using proprietary (non-ATAPI) interface
2384# mcd: Mitsumi CD-ROM using proprietary (non-ATAPI) interface
2385# bktr: Brooktree bt848/848a/849a/878/879 video capture and TV Tuner board
2386# joy: joystick (including IO DATA PCJOY PC Card joystick)
2387# cmx: OmniKey CardMan 4040 pccard smartcard reader
2388
2389# Mitsumi CD-ROM
2390device mcd
2391hint.mcd.0.at="isa"
2392hint.mcd.0.port="0x300"
2393# for the Sony CDU31/33A CDROM
2394device scd
2395hint.scd.0.at="isa"
2396hint.scd.0.port="0x230"
2397device joy # PnP aware, hints for non-PnP only
2398hint.joy.0.at="isa"
2399hint.joy.0.port="0x201"
2400device cmx
2401
2402#
2403# The 'bktr' device is a PCI video capture device using the Brooktree
2404# bt848/bt848a/bt849a/bt878/bt879 chipset. When used with a TV Tuner it forms a
2405# TV card, e.g. Miro PC/TV, Hauppauge WinCast/TV WinTV, VideoLogic Captivator,
2406# Intel Smart Video III, AverMedia, IMS Turbo, FlyVideo.
2407#
2408# options OVERRIDE_CARD=xxx
2409# options OVERRIDE_TUNER=xxx
2410# options OVERRIDE_MSP=1
2411# options OVERRIDE_DBX=1
2412# These options can be used to override the auto detection
2413# The current values for xxx are found in src/sys/dev/bktr/bktr_card.h
2414# Using sysctl(8) run-time overrides on a per-card basis can be made
2415#
2416# options BROOKTREE_SYSTEM_DEFAULT=BROOKTREE_PAL
2417# or
2418# options BROOKTREE_SYSTEM_DEFAULT=BROOKTREE_NTSC
2419# Specifies the default video capture mode.
2420# This is required for Dual Crystal (28&35MHz) boards where PAL is used
2421# to prevent hangs during initialization, e.g. VideoLogic Captivator PCI.
2422#
2423# options BKTR_USE_PLL
2424# This is required for PAL or SECAM boards with a 28MHz crystal and no 35MHz
2425# crystal, e.g. some new Bt878 cards.
2426#
2427# options BKTR_GPIO_ACCESS
2428# This enables IOCTLs which give user level access to the GPIO port.
2429#
2430# options BKTR_NO_MSP_RESET
2431# Prevents the MSP34xx reset. Good if you initialize the MSP in another OS first
2432#
2433# options BKTR_430_FX_MODE
2434# Switch Bt878/879 cards into Intel 430FX chipset compatibility mode.
2435#
2436# options BKTR_SIS_VIA_MODE
2437# Switch Bt878/879 cards into SIS/VIA chipset compatibility mode which is
2438# needed for some old SiS and VIA chipset motherboards.
2439# This also allows Bt878/879 chips to work on old OPTi (<1997) chipset
2440# motherboards and motherboards with bad or incomplete PCI 2.1 support.
2441# As a rough guess, old = before 1998
2442#
2443# options BKTR_NEW_MSP34XX_DRIVER
2444# Use new, more complete initialization scheme for the msp34* soundchip.
2445# Should fix stereo autodetection if the old driver does only output
2446# mono sound.
2447
2448#
2449# options BKTR_USE_FREEBSD_SMBUS
2450# Compile with FreeBSD SMBus implementation
2451#
2452# Brooktree driver has been ported to the new I2C framework. Thus,
2453# you'll need to have the following 3 lines in the kernel config.
2454# device smbus
2455# device iicbus
2456# device iicbb
2457# device iicsmb
2458# The iic and smb devices are only needed if you want to control other
2459# I2C slaves connected to the external connector of some cards.
2460#
2461device bktr
2462
2463#
2464# PC Card/PCMCIA and Cardbus
2465#
2466# cbb: pci/cardbus bridge implementing YENTA interface
2467# pccard: pccard slots
2468# cardbus: cardbus slots
2469device cbb
2470device pccard
2471device cardbus
2472
2473#
2474# MMC/SD
2475#
2476# mmc MMC/SD bus
2477# mmcsd MMC/SD memory card
2478# sdhci Generic PCI SD Host Controller
2479#
2480device mmc
2481device mmcsd
2482device sdhci
2483
2484#
2485# SMB bus
2486#
2487# System Management Bus support is provided by the 'smbus' device.
2488# Access to the SMBus device is via the 'smb' device (/dev/smb*),
2489# which is a child of the 'smbus' device.
2490#
2491# Supported devices:
2492# smb standard I/O through /dev/smb*
2493#
2494# Supported SMB interfaces:
2495# iicsmb I2C to SMB bridge with any iicbus interface
2496# bktr brooktree848 I2C hardware interface
2497# intpm Intel PIIX4 (82371AB, 82443MX) Power Management Unit
2498# alpm Acer Aladdin-IV/V/Pro2 Power Management Unit
2499# ichsmb Intel ICH SMBus controller chips (82801AA, 82801AB, 82801BA)
2500# viapm VIA VT82C586B/596B/686A and VT8233 Power Management Unit
2501# amdpm AMD 756 Power Management Unit
2502# amdsmb AMD 8111 SMBus 2.0 Controller
2503# nfpm NVIDIA nForce Power Management Unit
2504# nfsmb NVIDIA nForce2/3/4 MCP SMBus 2.0 Controller
2505#
2506device smbus # Bus support, required for smb below.
2507
2508device intpm
2509device alpm
2510device ichsmb
2511device viapm
2512device amdpm
2513device amdsmb
2514device nfpm
2515device nfsmb
2516
2517device smb
2518
2519#
2520# I2C Bus
2521#
2522# Philips i2c bus support is provided by the `iicbus' device.
2523#
2524# Supported devices:
2525# ic i2c network interface
2526# iic i2c standard io
2527# iicsmb i2c to smb bridge. Allow i2c i/o with smb commands.
2528#
2529# Supported interfaces:
2530# bktr brooktree848 I2C software interface
2531#
2532# Other:
2533# iicbb generic I2C bit-banging code (needed by lpbb, bktr)
2534#
2535device iicbus # Bus support, required for ic/iic/iicsmb below.
2536device iicbb
2537
2538device ic
2539device iic
2540device iicsmb # smb over i2c bridge
2541
2542# I2C peripheral devices
2543#
2544# ds133x Dallas Semiconductor DS1337, DS1338 and DS1339 RTC
2545# ds1672 Dallas Semiconductor DS1672 RTC
2546#
2547device ds133x
2548device ds1672
2549
2550# Parallel-Port Bus
2551#
2552# Parallel port bus support is provided by the `ppbus' device.
2553# Multiple devices may be attached to the parallel port, devices
2554# are automatically probed and attached when found.
2555#
2556# Supported devices:
2557# vpo Iomega Zip Drive
2558# Requires SCSI disk support ('scbus' and 'da'), best
2559# performance is achieved with ports in EPP 1.9 mode.
2560# lpt Parallel Printer
2561# plip Parallel network interface
2562# ppi General-purpose I/O ("Geek Port") + IEEE1284 I/O
2563# pps Pulse per second Timing Interface
2564# lpbb Philips official parallel port I2C bit-banging interface
2565# pcfclock Parallel port clock driver.
2566#
2567# Supported interfaces:
2568# ppc ISA-bus parallel port interfaces.
2569#
2570
2571options PPC_PROBE_CHIPSET # Enable chipset specific detection
2572 # (see flags in ppc(4))
2573options DEBUG_1284 # IEEE1284 signaling protocol debug
2574options PERIPH_1284 # Makes your computer act as an IEEE1284
2575 # compliant peripheral
2576options DONTPROBE_1284 # Avoid boot detection of PnP parallel devices
2577options VP0_DEBUG # ZIP/ZIP+ debug
2578options LPT_DEBUG # Printer driver debug
2579options PPC_DEBUG # Parallel chipset level debug
2580options PLIP_DEBUG # Parallel network IP interface debug
2581options PCFCLOCK_VERBOSE # Verbose pcfclock driver
2582options PCFCLOCK_MAX_RETRIES=5 # Maximum read tries (default 10)
2583
2584device ppc
2585hint.ppc.0.at="isa"
2586hint.ppc.0.irq="7"
2587device ppbus
2588device vpo
2589device lpt
2590device plip
2591device ppi
2592device pps
2593device lpbb
2594device pcfclock
2595
2596# Kernel BOOTP support
2597
2598options BOOTP # Use BOOTP to obtain IP address/hostname
2599 # Requires NFSCLIENT and NFS_ROOT
2600options BOOTP_NFSROOT # NFS mount root filesystem using BOOTP info
2601options BOOTP_NFSV3 # Use NFS v3 to NFS mount root
2602options BOOTP_COMPAT # Workaround for broken bootp daemons.
2603options BOOTP_WIRED_TO=fxp0 # Use interface fxp0 for BOOTP
2604options BOOTP_BLOCKSIZE=8192 # Override NFS block size
2605
2606#
2607# Add software watchdog routines.
2608#
2609options SW_WATCHDOG
2610
2611#
2612# Add the software deadlock resolver thread.
2613#
2614options DEADLKRES
2615
2616#
2617# Disable swapping of stack pages. This option removes all
2618# code which actually performs swapping, so it's not possible to turn
2619# it back on at run-time.
2620#
2621# This is sometimes usable for systems which don't have any swap space
2622# (see also sysctls "vm.defer_swapspace_pageouts" and
2623# "vm.disable_swapspace_pageouts")
2624#
2625#options NO_SWAPPING
2626
2627# Set the number of sf_bufs to allocate. sf_bufs are virtual buffers
2628# for sendfile(2) that are used to map file VM pages, and normally
2629# default to a quantity that is roughly 16*MAXUSERS+512. You would
2630# typically want about 4 of these for each simultaneous file send.
2631#
2632options NSFBUFS=1024
2633
2634#
2635# Enable extra debugging code for locks. This stores the filename and
2636# line of whatever acquired the lock in the lock itself, and changes a
2637# number of function calls to pass around the relevant data. This is
2638# not at all useful unless you are debugging lock code. Also note
2639# that it is likely to break e.g. fstat(1) unless you recompile your
2640# userland with -DDEBUG_LOCKS as well.
2641#
2642options DEBUG_LOCKS
2643
2644
2645#####################################################################
2646# USB support
2647# UHCI controller
2648device uhci
2649# OHCI controller
2650device ohci
2651# EHCI controller
2652device ehci
2653# XHCI controller
2654device xhci
2655# SL811 Controller
2656#device slhci
2657# General USB code (mandatory for USB)
2658device usb
2659#
2660# USB Double Bulk Pipe devices
2661device udbp
2662# USB Fm Radio
2663device ufm
2664# Human Interface Device (anything with buttons and dials)
2665device uhid
2666# USB keyboard
2667device ukbd
2668# USB printer
2669device ulpt
2670# USB mass storage driver (Requires scbus and da)
2671device umass
2672# USB mass storage driver for device-side mode
2673device usfs
2674# USB support for Belkin F5U109 and Magic Control Technology serial adapters
2675device umct
2676# USB modem support
2677device umodem
2678# USB mouse
2679device ums
2680# eGalax USB touch screen
2681device uep
2682# Diamond Rio 500 MP3 player
2683device urio
2684#
2685# USB serial support
2686device ucom
2687# USB support for 3G modem cards by Option, Novatel, Huawei and Sierra
2688device u3g
2689# USB support for Technologies ARK3116 based serial adapters
2690device uark
2691# USB support for Belkin F5U103 and compatible serial adapters
2692device ubsa
2693# USB support for serial adapters based on the FT8U100AX and FT8U232AM
2694device uftdi
2695# USB support for some Windows CE based serial communication.
2696device uipaq
2697# USB support for Prolific PL-2303 serial adapters
2698device uplcom
2699# USB support for Silicon Laboratories CP2101/CP2102 based USB serial adapters
2700device uslcom
2701# USB Visor and Palm devices
2702device uvisor
2703# USB serial support for DDI pocket's PHS
2704device uvscom
2705#
2706# ADMtek USB ethernet. Supports the LinkSys USB100TX,
2707# the Billionton USB100, the Melco LU-ATX, the D-Link DSB-650TX
2708# and the SMC 2202USB. Also works with the ADMtek AN986 Pegasus
2709# eval board.
2710device aue
2711
2712# ASIX Electronics AX88172 USB 2.0 ethernet driver. Used in the
2713# LinkSys USB200M and various other adapters.
2714device axe
2715
2716#
2717# Devices which communicate using Ethernet over USB, particularly
2718# Communication Device Class (CDC) Ethernet specification. Supports
2719# Sharp Zaurus PDAs, some DOCSIS cable modems and so on.
2720device cdce
2721#
2722# CATC USB-EL1201A USB ethernet. Supports the CATC Netmate
2723# and Netmate II, and the Belkin F5U111.
2724device cue
2725#
2726# Kawasaki LSI ethernet. Supports the LinkSys USB10T,
2727# Entrega USB-NET-E45, Peracom Ethernet Adapter, the
2728# 3Com 3c19250, the ADS Technologies USB-10BT, the ATen UC10T,
2729# the Netgear EA101, the D-Link DSB-650, the SMC 2102USB
2730# and 2104USB, and the Corega USB-T.
2731device kue
2732#
2733# RealTek RTL8150 USB to fast ethernet. Supports the Melco LUA-KTX
2734# and the GREEN HOUSE GH-USB100B.
2735device rue
2736#
2737# Davicom DM9601E USB to fast ethernet. Supports the Corega FEther USB-TXC.
2738device udav
2739#
2740# Moschip MCS7730/MCS7840 USB to fast ethernet. Supports the Sitecom LN030.
2741device mos
2742#
2743# HSxPA devices from Option N.V
2744device uhso
2745
2746#
2747# Ralink Technology RT2501USB/RT2601USB wireless driver
2748device rum
2749# Ralink Technology RT2700U/RT2800U/RT3000U wireless driver
2750device run
2751#
2752# Atheros AR5523 wireless driver
2753device uath
2754#
2755# Conexant/Intersil PrismGT wireless driver
2756device upgt
2757#
2758# Ralink Technology RT2500USB wireless driver
2759device ural
2760#
2761# Realtek RTL8187B/L wireless driver
2762device urtw
2763#
2764# ZyDas ZD1211/ZD1211B wireless driver
2765device zyd
2766
2767#
2768# debugging options for the USB subsystem
2769#
2770options USB_DEBUG
2771options U3G_DEBUG
2772
2773# options for ukbd:
2774options UKBD_DFLT_KEYMAP # specify the built-in keymap
2775makeoptions UKBD_DFLT_KEYMAP=it.iso
2776
2777# options for uplcom:
2778options UPLCOM_INTR_INTERVAL=100 # interrupt pipe interval
2779 # in milliseconds
2780
2781# options for uvscom:
2782options UVSCOM_DEFAULT_OPKTSIZE=8 # default output packet size
2783options UVSCOM_INTR_INTERVAL=100 # interrupt pipe interval
2784 # in milliseconds
2785
2786#####################################################################
2787# FireWire support
2788
2789device firewire # FireWire bus code
2790device sbp # SCSI over Firewire (Requires scbus and da)
2791device sbp_targ # SBP-2 Target mode (Requires scbus and targ)
2792device fwe # Ethernet over FireWire (non-standard!)
2793device fwip # IP over FireWire (RFC2734 and RFC3146)
2794
2795#####################################################################
2796# dcons support (Dumb Console Device)
2797
2798device dcons # dumb console driver
2799device dcons_crom # FireWire attachment
2800options DCONS_BUF_SIZE=16384 # buffer size
2801options DCONS_POLL_HZ=100 # polling rate
2802options DCONS_FORCE_CONSOLE=0 # force to be the primary console
2803options DCONS_FORCE_GDB=1 # force to be the gdb device
2804
2805#####################################################################
2806# crypto subsystem
2807#
2808# This is a port of the OpenBSD crypto framework. Include this when
2809# configuring IPSEC and when you have a h/w crypto device to accelerate
2810# user applications that link to OpenSSL.
2811#
2812# Drivers are ports from OpenBSD with some simple enhancements that have
2813# been fed back to OpenBSD.
2814
2815device crypto # core crypto support
2816device cryptodev # /dev/crypto for access to h/w
2817
2818device rndtest # FIPS 140-2 entropy tester
2819
2820device hifn # Hifn 7951, 7781, etc.
2821options HIFN_DEBUG # enable debugging support: hw.hifn.debug
2822options HIFN_RNDTEST # enable rndtest support
2823
2824device ubsec # Broadcom 5501, 5601, 58xx
2825options UBSEC_DEBUG # enable debugging support: hw.ubsec.debug
2826options UBSEC_RNDTEST # enable rndtest support
2827
2828#####################################################################
2829
2830
2831#
2832# Embedded system options:
2833#
2834# An embedded system might want to run something other than init.
2835options INIT_PATH=/sbin/init:/rescue/init
2836
2837# Debug options
2838options BUS_DEBUG # enable newbus debugging
2839options DEBUG_VFS_LOCKS # enable VFS lock debugging
2840options SOCKBUF_DEBUG # enable sockbuf last record/mb tail checking
2841
2842#
2843# Verbose SYSINIT
2844#
2845# Make the SYSINIT process performed by mi_startup() verbose. This is very
2846# useful when porting to a new architecture. If DDB is also enabled, this
2847# will print function names instead of addresses.
2848options VERBOSE_SYSINIT
2849
2850#####################################################################
2851# SYSV IPC KERNEL PARAMETERS
2852#
2853# Maximum number of System V semaphores that can be used on the system at
2854# one time.
2855options SEMMNI=11
2856
2857# Total number of semaphores system wide
2858options SEMMNS=61
2859
2860# Total number of undo structures in system
2861options SEMMNU=31
2862
2863# Maximum number of System V semaphores that can be used by a single process
2864# at one time.
2865options SEMMSL=61
2866
2867# Maximum number of operations that can be outstanding on a single System V
2868# semaphore at one time.
2869options SEMOPM=101
2870
2871# Maximum number of undo operations that can be outstanding on a single
2872# System V semaphore at one time.
2873options SEMUME=11
2874
2875# Maximum number of shared memory pages system wide.
2876options SHMALL=1025
2877
2878# Maximum size, in bytes, of a single System V shared memory region.
2879options SHMMAX=(SHMMAXPGS*PAGE_SIZE+1)
2880options SHMMAXPGS=1025
2881
2882# Minimum size, in bytes, of a single System V shared memory region.
2883options SHMMIN=2
2884
2885# Maximum number of shared memory regions that can be used on the system
2886# at one time.
2887options SHMMNI=33
2888
2889# Maximum number of System V shared memory regions that can be attached to
2890# a single process at one time.
2891options SHMSEG=9
2892
2893# Compress user core dumps.
2894options COMPRESS_USER_CORES
2895# required to compress file output from kernel for COMPRESS_USER_CORES.
2896device gzio
2897
2898# Set the amount of time (in seconds) the system will wait before
2899# rebooting automatically when a kernel panic occurs. If set to (-1),
2900# the system will wait indefinitely until a key is pressed on the
2901# console.
2902options PANIC_REBOOT_WAIT_TIME=16
2903
2904# Attempt to bypass the buffer cache and put data directly into the
2905# userland buffer for read operation when O_DIRECT flag is set on the
2906# file. Both offset and length of the read operation must be
2907# multiples of the physical media sector size.
2908#
2909options DIRECTIO
2910
2911# Specify a lower limit for the number of swap I/O buffers. They are
2912# (among other things) used when bypassing the buffer cache due to
2913# DIRECTIO kernel option enabled and O_DIRECT flag set on file.
2914#
2915options NSWBUF_MIN=120
2916
2917#####################################################################
2918
2919# More undocumented options for linting.
2920# Note that documenting these is not considered an affront.
2921
2922options CAM_DEBUG_DELAY
2923
2924# VFS cluster debugging.
2925options CLUSTERDEBUG
2926
2927options DEBUG
2928
2929# Kernel filelock debugging.
2930options LOCKF_DEBUG
2931
2932# System V compatible message queues
2933# Please note that the values provided here are used to test kernel
2934# building. The defaults in the sources provide almost the same numbers.
2935# MSGSSZ must be a power of 2 between 8 and 1024.
2936options MSGMNB=2049 # Max number of chars in queue
2937options MSGMNI=41 # Max number of message queue identifiers
2938options MSGSEG=2049 # Max number of message segments
2939options MSGSSZ=16 # Size of a message segment
2940options MSGTQL=41 # Max number of messages in system
2941
2942options NBUF=512 # Number of buffer headers
2943
2944options SCSI_NCR_DEBUG
2945options SCSI_NCR_MAX_SYNC=10000
2946options SCSI_NCR_MAX_WIDE=1
2947options SCSI_NCR_MYADDR=7
2948
2949options SC_DEBUG_LEVEL=5 # Syscons debug level
2950options SC_RENDER_DEBUG # syscons rendering debugging
2951
2952options VFS_BIO_DEBUG # VFS buffer I/O debugging
2953
2954options KSTACK_MAX_PAGES=32 # Maximum pages to give the kernel stack
2955
2956# Adaptec Array Controller driver options
2957options AAC_DEBUG # Debugging levels:
2958 # 0 - quiet, only emit warnings
2959 # 1 - noisy, emit major function
2960 # points and things done
2961 # 2 - extremely noisy, emit trace
2962 # items in loops, etc.
2963
2964# Resource Accounting
2965options RACCT
2966
2967# Resource Limits
2968options RCTL
2969
2970# Yet more undocumented options for linting.
2971# BKTR_ALLOC_PAGES has no effect except to cause warnings, and
2972# BROOKTREE_ALLOC_PAGES hasn't actually been superseded by it, since the
2973# driver still mostly spells this option BROOKTREE_ALLOC_PAGES.
2974##options BKTR_ALLOC_PAGES=(217*4+1)
2975options BROOKTREE_ALLOC_PAGES=(217*4+1)
2976options MAXFILES=999
2977
2301device snd_ich
2302device snd_maestro
2303device snd_maestro3
2304device snd_mss
2305device snd_neomagic
2306device snd_sb16
2307device snd_sb8
2308device snd_sbc
2309device snd_solo
2310device snd_spicds
2311device snd_t4dwave
2312device snd_uaudio
2313device snd_via8233
2314device snd_via82c686
2315device snd_vibes
2316
2317# For non-PnP sound cards:
2318hint.pcm.0.at="isa"
2319hint.pcm.0.irq="10"
2320hint.pcm.0.drq="1"
2321hint.pcm.0.flags="0x0"
2322hint.sbc.0.at="isa"
2323hint.sbc.0.port="0x220"
2324hint.sbc.0.irq="5"
2325hint.sbc.0.drq="1"
2326hint.sbc.0.flags="0x15"
2327hint.gusc.0.at="isa"
2328hint.gusc.0.port="0x220"
2329hint.gusc.0.irq="5"
2330hint.gusc.0.drq="1"
2331hint.gusc.0.flags="0x13"
2332
2333#
2334# Following options are intended for debugging/testing purposes:
2335#
2336# SND_DEBUG Enable extra debugging code that includes
2337# sanity checking and possible increase of
2338# verbosity.
2339#
2340# SND_DIAGNOSTIC Similar in a spirit of INVARIANTS/DIAGNOSTIC,
2341# zero tolerance against inconsistencies.
2342#
2343# SND_FEEDER_MULTIFORMAT By default, only 16/32 bit feeders are compiled
2344# in. This options enable most feeder converters
2345# except for 8bit. WARNING: May bloat the kernel.
2346#
2347# SND_FEEDER_FULL_MULTIFORMAT Ditto, but includes 8bit feeders as well.
2348#
2349# SND_FEEDER_RATE_HP (feeder_rate) High precision 64bit arithmetic
2350# as much as possible (the default trying to
2351# avoid it). Possible slowdown.
2352#
2353# SND_PCM_64 (Only applicable for i386/32bit arch)
2354# Process 32bit samples through 64bit
2355# integer/arithmetic. Slight increase of dynamic
2356# range at a cost of possible slowdown.
2357#
2358# SND_OLDSTEREO Only 2 channels are allowed, effectively
2359# disabling multichannel processing.
2360#
2361options SND_DEBUG
2362options SND_DIAGNOSTIC
2363options SND_FEEDER_MULTIFORMAT
2364options SND_FEEDER_FULL_MULTIFORMAT
2365options SND_FEEDER_RATE_HP
2366options SND_PCM_64
2367options SND_OLDSTEREO
2368
2369#
2370# IEEE-488 hardware:
2371# pcii: PCIIA cards (uPD7210 based isa cards)
2372# tnt4882: National Instruments PCI-GPIB card.
2373
2374device pcii
2375hint.pcii.0.at="isa"
2376hint.pcii.0.port="0x2e1"
2377hint.pcii.0.irq="5"
2378hint.pcii.0.drq="1"
2379
2380device tnt4882
2381
2382#
2383# Miscellaneous hardware:
2384#
2385# scd: Sony CD-ROM using proprietary (non-ATAPI) interface
2386# mcd: Mitsumi CD-ROM using proprietary (non-ATAPI) interface
2387# bktr: Brooktree bt848/848a/849a/878/879 video capture and TV Tuner board
2388# joy: joystick (including IO DATA PCJOY PC Card joystick)
2389# cmx: OmniKey CardMan 4040 pccard smartcard reader
2390
2391# Mitsumi CD-ROM
2392device mcd
2393hint.mcd.0.at="isa"
2394hint.mcd.0.port="0x300"
2395# for the Sony CDU31/33A CDROM
2396device scd
2397hint.scd.0.at="isa"
2398hint.scd.0.port="0x230"
2399device joy # PnP aware, hints for non-PnP only
2400hint.joy.0.at="isa"
2401hint.joy.0.port="0x201"
2402device cmx
2403
2404#
2405# The 'bktr' device is a PCI video capture device using the Brooktree
2406# bt848/bt848a/bt849a/bt878/bt879 chipset. When used with a TV Tuner it forms a
2407# TV card, e.g. Miro PC/TV, Hauppauge WinCast/TV WinTV, VideoLogic Captivator,
2408# Intel Smart Video III, AverMedia, IMS Turbo, FlyVideo.
2409#
2410# options OVERRIDE_CARD=xxx
2411# options OVERRIDE_TUNER=xxx
2412# options OVERRIDE_MSP=1
2413# options OVERRIDE_DBX=1
2414# These options can be used to override the auto detection
2415# The current values for xxx are found in src/sys/dev/bktr/bktr_card.h
2416# Using sysctl(8) run-time overrides on a per-card basis can be made
2417#
2418# options BROOKTREE_SYSTEM_DEFAULT=BROOKTREE_PAL
2419# or
2420# options BROOKTREE_SYSTEM_DEFAULT=BROOKTREE_NTSC
2421# Specifies the default video capture mode.
2422# This is required for Dual Crystal (28&35MHz) boards where PAL is used
2423# to prevent hangs during initialization, e.g. VideoLogic Captivator PCI.
2424#
2425# options BKTR_USE_PLL
2426# This is required for PAL or SECAM boards with a 28MHz crystal and no 35MHz
2427# crystal, e.g. some new Bt878 cards.
2428#
2429# options BKTR_GPIO_ACCESS
2430# This enables IOCTLs which give user level access to the GPIO port.
2431#
2432# options BKTR_NO_MSP_RESET
2433# Prevents the MSP34xx reset. Good if you initialize the MSP in another OS first
2434#
2435# options BKTR_430_FX_MODE
2436# Switch Bt878/879 cards into Intel 430FX chipset compatibility mode.
2437#
2438# options BKTR_SIS_VIA_MODE
2439# Switch Bt878/879 cards into SIS/VIA chipset compatibility mode which is
2440# needed for some old SiS and VIA chipset motherboards.
2441# This also allows Bt878/879 chips to work on old OPTi (<1997) chipset
2442# motherboards and motherboards with bad or incomplete PCI 2.1 support.
2443# As a rough guess, old = before 1998
2444#
2445# options BKTR_NEW_MSP34XX_DRIVER
2446# Use new, more complete initialization scheme for the msp34* soundchip.
2447# Should fix stereo autodetection if the old driver does only output
2448# mono sound.
2449
2450#
2451# options BKTR_USE_FREEBSD_SMBUS
2452# Compile with FreeBSD SMBus implementation
2453#
2454# Brooktree driver has been ported to the new I2C framework. Thus,
2455# you'll need to have the following 3 lines in the kernel config.
2456# device smbus
2457# device iicbus
2458# device iicbb
2459# device iicsmb
2460# The iic and smb devices are only needed if you want to control other
2461# I2C slaves connected to the external connector of some cards.
2462#
2463device bktr
2464
2465#
2466# PC Card/PCMCIA and Cardbus
2467#
2468# cbb: pci/cardbus bridge implementing YENTA interface
2469# pccard: pccard slots
2470# cardbus: cardbus slots
2471device cbb
2472device pccard
2473device cardbus
2474
2475#
2476# MMC/SD
2477#
2478# mmc MMC/SD bus
2479# mmcsd MMC/SD memory card
2480# sdhci Generic PCI SD Host Controller
2481#
2482device mmc
2483device mmcsd
2484device sdhci
2485
2486#
2487# SMB bus
2488#
2489# System Management Bus support is provided by the 'smbus' device.
2490# Access to the SMBus device is via the 'smb' device (/dev/smb*),
2491# which is a child of the 'smbus' device.
2492#
2493# Supported devices:
2494# smb standard I/O through /dev/smb*
2495#
2496# Supported SMB interfaces:
2497# iicsmb I2C to SMB bridge with any iicbus interface
2498# bktr brooktree848 I2C hardware interface
2499# intpm Intel PIIX4 (82371AB, 82443MX) Power Management Unit
2500# alpm Acer Aladdin-IV/V/Pro2 Power Management Unit
2501# ichsmb Intel ICH SMBus controller chips (82801AA, 82801AB, 82801BA)
2502# viapm VIA VT82C586B/596B/686A and VT8233 Power Management Unit
2503# amdpm AMD 756 Power Management Unit
2504# amdsmb AMD 8111 SMBus 2.0 Controller
2505# nfpm NVIDIA nForce Power Management Unit
2506# nfsmb NVIDIA nForce2/3/4 MCP SMBus 2.0 Controller
2507#
2508device smbus # Bus support, required for smb below.
2509
2510device intpm
2511device alpm
2512device ichsmb
2513device viapm
2514device amdpm
2515device amdsmb
2516device nfpm
2517device nfsmb
2518
2519device smb
2520
2521#
2522# I2C Bus
2523#
2524# Philips i2c bus support is provided by the `iicbus' device.
2525#
2526# Supported devices:
2527# ic i2c network interface
2528# iic i2c standard io
2529# iicsmb i2c to smb bridge. Allow i2c i/o with smb commands.
2530#
2531# Supported interfaces:
2532# bktr brooktree848 I2C software interface
2533#
2534# Other:
2535# iicbb generic I2C bit-banging code (needed by lpbb, bktr)
2536#
2537device iicbus # Bus support, required for ic/iic/iicsmb below.
2538device iicbb
2539
2540device ic
2541device iic
2542device iicsmb # smb over i2c bridge
2543
2544# I2C peripheral devices
2545#
2546# ds133x Dallas Semiconductor DS1337, DS1338 and DS1339 RTC
2547# ds1672 Dallas Semiconductor DS1672 RTC
2548#
2549device ds133x
2550device ds1672
2551
2552# Parallel-Port Bus
2553#
2554# Parallel port bus support is provided by the `ppbus' device.
2555# Multiple devices may be attached to the parallel port, devices
2556# are automatically probed and attached when found.
2557#
2558# Supported devices:
2559# vpo Iomega Zip Drive
2560# Requires SCSI disk support ('scbus' and 'da'), best
2561# performance is achieved with ports in EPP 1.9 mode.
2562# lpt Parallel Printer
2563# plip Parallel network interface
2564# ppi General-purpose I/O ("Geek Port") + IEEE1284 I/O
2565# pps Pulse per second Timing Interface
2566# lpbb Philips official parallel port I2C bit-banging interface
2567# pcfclock Parallel port clock driver.
2568#
2569# Supported interfaces:
2570# ppc ISA-bus parallel port interfaces.
2571#
2572
2573options PPC_PROBE_CHIPSET # Enable chipset specific detection
2574 # (see flags in ppc(4))
2575options DEBUG_1284 # IEEE1284 signaling protocol debug
2576options PERIPH_1284 # Makes your computer act as an IEEE1284
2577 # compliant peripheral
2578options DONTPROBE_1284 # Avoid boot detection of PnP parallel devices
2579options VP0_DEBUG # ZIP/ZIP+ debug
2580options LPT_DEBUG # Printer driver debug
2581options PPC_DEBUG # Parallel chipset level debug
2582options PLIP_DEBUG # Parallel network IP interface debug
2583options PCFCLOCK_VERBOSE # Verbose pcfclock driver
2584options PCFCLOCK_MAX_RETRIES=5 # Maximum read tries (default 10)
2585
2586device ppc
2587hint.ppc.0.at="isa"
2588hint.ppc.0.irq="7"
2589device ppbus
2590device vpo
2591device lpt
2592device plip
2593device ppi
2594device pps
2595device lpbb
2596device pcfclock
2597
2598# Kernel BOOTP support
2599
2600options BOOTP # Use BOOTP to obtain IP address/hostname
2601 # Requires NFSCLIENT and NFS_ROOT
2602options BOOTP_NFSROOT # NFS mount root filesystem using BOOTP info
2603options BOOTP_NFSV3 # Use NFS v3 to NFS mount root
2604options BOOTP_COMPAT # Workaround for broken bootp daemons.
2605options BOOTP_WIRED_TO=fxp0 # Use interface fxp0 for BOOTP
2606options BOOTP_BLOCKSIZE=8192 # Override NFS block size
2607
2608#
2609# Add software watchdog routines.
2610#
2611options SW_WATCHDOG
2612
2613#
2614# Add the software deadlock resolver thread.
2615#
2616options DEADLKRES
2617
2618#
2619# Disable swapping of stack pages. This option removes all
2620# code which actually performs swapping, so it's not possible to turn
2621# it back on at run-time.
2622#
2623# This is sometimes usable for systems which don't have any swap space
2624# (see also sysctls "vm.defer_swapspace_pageouts" and
2625# "vm.disable_swapspace_pageouts")
2626#
2627#options NO_SWAPPING
2628
2629# Set the number of sf_bufs to allocate. sf_bufs are virtual buffers
2630# for sendfile(2) that are used to map file VM pages, and normally
2631# default to a quantity that is roughly 16*MAXUSERS+512. You would
2632# typically want about 4 of these for each simultaneous file send.
2633#
2634options NSFBUFS=1024
2635
2636#
2637# Enable extra debugging code for locks. This stores the filename and
2638# line of whatever acquired the lock in the lock itself, and changes a
2639# number of function calls to pass around the relevant data. This is
2640# not at all useful unless you are debugging lock code. Also note
2641# that it is likely to break e.g. fstat(1) unless you recompile your
2642# userland with -DDEBUG_LOCKS as well.
2643#
2644options DEBUG_LOCKS
2645
2646
2647#####################################################################
2648# USB support
2649# UHCI controller
2650device uhci
2651# OHCI controller
2652device ohci
2653# EHCI controller
2654device ehci
2655# XHCI controller
2656device xhci
2657# SL811 Controller
2658#device slhci
2659# General USB code (mandatory for USB)
2660device usb
2661#
2662# USB Double Bulk Pipe devices
2663device udbp
2664# USB Fm Radio
2665device ufm
2666# Human Interface Device (anything with buttons and dials)
2667device uhid
2668# USB keyboard
2669device ukbd
2670# USB printer
2671device ulpt
2672# USB mass storage driver (Requires scbus and da)
2673device umass
2674# USB mass storage driver for device-side mode
2675device usfs
2676# USB support for Belkin F5U109 and Magic Control Technology serial adapters
2677device umct
2678# USB modem support
2679device umodem
2680# USB mouse
2681device ums
2682# eGalax USB touch screen
2683device uep
2684# Diamond Rio 500 MP3 player
2685device urio
2686#
2687# USB serial support
2688device ucom
2689# USB support for 3G modem cards by Option, Novatel, Huawei and Sierra
2690device u3g
2691# USB support for Technologies ARK3116 based serial adapters
2692device uark
2693# USB support for Belkin F5U103 and compatible serial adapters
2694device ubsa
2695# USB support for serial adapters based on the FT8U100AX and FT8U232AM
2696device uftdi
2697# USB support for some Windows CE based serial communication.
2698device uipaq
2699# USB support for Prolific PL-2303 serial adapters
2700device uplcom
2701# USB support for Silicon Laboratories CP2101/CP2102 based USB serial adapters
2702device uslcom
2703# USB Visor and Palm devices
2704device uvisor
2705# USB serial support for DDI pocket's PHS
2706device uvscom
2707#
2708# ADMtek USB ethernet. Supports the LinkSys USB100TX,
2709# the Billionton USB100, the Melco LU-ATX, the D-Link DSB-650TX
2710# and the SMC 2202USB. Also works with the ADMtek AN986 Pegasus
2711# eval board.
2712device aue
2713
2714# ASIX Electronics AX88172 USB 2.0 ethernet driver. Used in the
2715# LinkSys USB200M and various other adapters.
2716device axe
2717
2718#
2719# Devices which communicate using Ethernet over USB, particularly
2720# Communication Device Class (CDC) Ethernet specification. Supports
2721# Sharp Zaurus PDAs, some DOCSIS cable modems and so on.
2722device cdce
2723#
2724# CATC USB-EL1201A USB ethernet. Supports the CATC Netmate
2725# and Netmate II, and the Belkin F5U111.
2726device cue
2727#
2728# Kawasaki LSI ethernet. Supports the LinkSys USB10T,
2729# Entrega USB-NET-E45, Peracom Ethernet Adapter, the
2730# 3Com 3c19250, the ADS Technologies USB-10BT, the ATen UC10T,
2731# the Netgear EA101, the D-Link DSB-650, the SMC 2102USB
2732# and 2104USB, and the Corega USB-T.
2733device kue
2734#
2735# RealTek RTL8150 USB to fast ethernet. Supports the Melco LUA-KTX
2736# and the GREEN HOUSE GH-USB100B.
2737device rue
2738#
2739# Davicom DM9601E USB to fast ethernet. Supports the Corega FEther USB-TXC.
2740device udav
2741#
2742# Moschip MCS7730/MCS7840 USB to fast ethernet. Supports the Sitecom LN030.
2743device mos
2744#
2745# HSxPA devices from Option N.V
2746device uhso
2747
2748#
2749# Ralink Technology RT2501USB/RT2601USB wireless driver
2750device rum
2751# Ralink Technology RT2700U/RT2800U/RT3000U wireless driver
2752device run
2753#
2754# Atheros AR5523 wireless driver
2755device uath
2756#
2757# Conexant/Intersil PrismGT wireless driver
2758device upgt
2759#
2760# Ralink Technology RT2500USB wireless driver
2761device ural
2762#
2763# Realtek RTL8187B/L wireless driver
2764device urtw
2765#
2766# ZyDas ZD1211/ZD1211B wireless driver
2767device zyd
2768
2769#
2770# debugging options for the USB subsystem
2771#
2772options USB_DEBUG
2773options U3G_DEBUG
2774
2775# options for ukbd:
2776options UKBD_DFLT_KEYMAP # specify the built-in keymap
2777makeoptions UKBD_DFLT_KEYMAP=it.iso
2778
2779# options for uplcom:
2780options UPLCOM_INTR_INTERVAL=100 # interrupt pipe interval
2781 # in milliseconds
2782
2783# options for uvscom:
2784options UVSCOM_DEFAULT_OPKTSIZE=8 # default output packet size
2785options UVSCOM_INTR_INTERVAL=100 # interrupt pipe interval
2786 # in milliseconds
2787
2788#####################################################################
2789# FireWire support
2790
2791device firewire # FireWire bus code
2792device sbp # SCSI over Firewire (Requires scbus and da)
2793device sbp_targ # SBP-2 Target mode (Requires scbus and targ)
2794device fwe # Ethernet over FireWire (non-standard!)
2795device fwip # IP over FireWire (RFC2734 and RFC3146)
2796
2797#####################################################################
2798# dcons support (Dumb Console Device)
2799
2800device dcons # dumb console driver
2801device dcons_crom # FireWire attachment
2802options DCONS_BUF_SIZE=16384 # buffer size
2803options DCONS_POLL_HZ=100 # polling rate
2804options DCONS_FORCE_CONSOLE=0 # force to be the primary console
2805options DCONS_FORCE_GDB=1 # force to be the gdb device
2806
2807#####################################################################
2808# crypto subsystem
2809#
2810# This is a port of the OpenBSD crypto framework. Include this when
2811# configuring IPSEC and when you have a h/w crypto device to accelerate
2812# user applications that link to OpenSSL.
2813#
2814# Drivers are ports from OpenBSD with some simple enhancements that have
2815# been fed back to OpenBSD.
2816
2817device crypto # core crypto support
2818device cryptodev # /dev/crypto for access to h/w
2819
2820device rndtest # FIPS 140-2 entropy tester
2821
2822device hifn # Hifn 7951, 7781, etc.
2823options HIFN_DEBUG # enable debugging support: hw.hifn.debug
2824options HIFN_RNDTEST # enable rndtest support
2825
2826device ubsec # Broadcom 5501, 5601, 58xx
2827options UBSEC_DEBUG # enable debugging support: hw.ubsec.debug
2828options UBSEC_RNDTEST # enable rndtest support
2829
2830#####################################################################
2831
2832
2833#
2834# Embedded system options:
2835#
2836# An embedded system might want to run something other than init.
2837options INIT_PATH=/sbin/init:/rescue/init
2838
2839# Debug options
2840options BUS_DEBUG # enable newbus debugging
2841options DEBUG_VFS_LOCKS # enable VFS lock debugging
2842options SOCKBUF_DEBUG # enable sockbuf last record/mb tail checking
2843
2844#
2845# Verbose SYSINIT
2846#
2847# Make the SYSINIT process performed by mi_startup() verbose. This is very
2848# useful when porting to a new architecture. If DDB is also enabled, this
2849# will print function names instead of addresses.
2850options VERBOSE_SYSINIT
2851
2852#####################################################################
2853# SYSV IPC KERNEL PARAMETERS
2854#
2855# Maximum number of System V semaphores that can be used on the system at
2856# one time.
2857options SEMMNI=11
2858
2859# Total number of semaphores system wide
2860options SEMMNS=61
2861
2862# Total number of undo structures in system
2863options SEMMNU=31
2864
2865# Maximum number of System V semaphores that can be used by a single process
2866# at one time.
2867options SEMMSL=61
2868
2869# Maximum number of operations that can be outstanding on a single System V
2870# semaphore at one time.
2871options SEMOPM=101
2872
2873# Maximum number of undo operations that can be outstanding on a single
2874# System V semaphore at one time.
2875options SEMUME=11
2876
2877# Maximum number of shared memory pages system wide.
2878options SHMALL=1025
2879
2880# Maximum size, in bytes, of a single System V shared memory region.
2881options SHMMAX=(SHMMAXPGS*PAGE_SIZE+1)
2882options SHMMAXPGS=1025
2883
2884# Minimum size, in bytes, of a single System V shared memory region.
2885options SHMMIN=2
2886
2887# Maximum number of shared memory regions that can be used on the system
2888# at one time.
2889options SHMMNI=33
2890
2891# Maximum number of System V shared memory regions that can be attached to
2892# a single process at one time.
2893options SHMSEG=9
2894
2895# Compress user core dumps.
2896options COMPRESS_USER_CORES
2897# required to compress file output from kernel for COMPRESS_USER_CORES.
2898device gzio
2899
2900# Set the amount of time (in seconds) the system will wait before
2901# rebooting automatically when a kernel panic occurs. If set to (-1),
2902# the system will wait indefinitely until a key is pressed on the
2903# console.
2904options PANIC_REBOOT_WAIT_TIME=16
2905
2906# Attempt to bypass the buffer cache and put data directly into the
2907# userland buffer for read operation when O_DIRECT flag is set on the
2908# file. Both offset and length of the read operation must be
2909# multiples of the physical media sector size.
2910#
2911options DIRECTIO
2912
2913# Specify a lower limit for the number of swap I/O buffers. They are
2914# (among other things) used when bypassing the buffer cache due to
2915# DIRECTIO kernel option enabled and O_DIRECT flag set on file.
2916#
2917options NSWBUF_MIN=120
2918
2919#####################################################################
2920
2921# More undocumented options for linting.
2922# Note that documenting these is not considered an affront.
2923
2924options CAM_DEBUG_DELAY
2925
2926# VFS cluster debugging.
2927options CLUSTERDEBUG
2928
2929options DEBUG
2930
2931# Kernel filelock debugging.
2932options LOCKF_DEBUG
2933
2934# System V compatible message queues
2935# Please note that the values provided here are used to test kernel
2936# building. The defaults in the sources provide almost the same numbers.
2937# MSGSSZ must be a power of 2 between 8 and 1024.
2938options MSGMNB=2049 # Max number of chars in queue
2939options MSGMNI=41 # Max number of message queue identifiers
2940options MSGSEG=2049 # Max number of message segments
2941options MSGSSZ=16 # Size of a message segment
2942options MSGTQL=41 # Max number of messages in system
2943
2944options NBUF=512 # Number of buffer headers
2945
2946options SCSI_NCR_DEBUG
2947options SCSI_NCR_MAX_SYNC=10000
2948options SCSI_NCR_MAX_WIDE=1
2949options SCSI_NCR_MYADDR=7
2950
2951options SC_DEBUG_LEVEL=5 # Syscons debug level
2952options SC_RENDER_DEBUG # syscons rendering debugging
2953
2954options VFS_BIO_DEBUG # VFS buffer I/O debugging
2955
2956options KSTACK_MAX_PAGES=32 # Maximum pages to give the kernel stack
2957
2958# Adaptec Array Controller driver options
2959options AAC_DEBUG # Debugging levels:
2960 # 0 - quiet, only emit warnings
2961 # 1 - noisy, emit major function
2962 # points and things done
2963 # 2 - extremely noisy, emit trace
2964 # items in loops, etc.
2965
2966# Resource Accounting
2967options RACCT
2968
2969# Resource Limits
2970options RCTL
2971
2972# Yet more undocumented options for linting.
2973# BKTR_ALLOC_PAGES has no effect except to cause warnings, and
2974# BROOKTREE_ALLOC_PAGES hasn't actually been superseded by it, since the
2975# driver still mostly spells this option BROOKTREE_ALLOC_PAGES.
2976##options BKTR_ALLOC_PAGES=(217*4+1)
2977options BROOKTREE_ALLOC_PAGES=(217*4+1)
2978options MAXFILES=999
2979