NOTES revision 132155
1#
2# NOTES -- Lines that can be cut/pasted into kernel and hints configs.
3#
4# This file contains machine dependent kernel configuration notes.  For
5# machine independent notes, look in /sys/conf/NOTES.
6#
7# $FreeBSD: head/sys/pc98/conf/NOTES 132155 2004-07-14 17:50:08Z des $
8#
9
10#
11# This directive is mandatory; it defines the architecture to be
12# configured for; in this case, the 386 family based PC-98 and
13# compatibles.
14#
15machine		pc98
16options 	PC98
17
18#
19# We want LINT to cover profiling as well.
20profile         2
21
22
23#####################################################################
24# SMP OPTIONS:
25#
26# The apic device enables the use of the I/O APIC for interrupt delivery.
27# The apic device can be used in both UP and SMP kernels, but is required
28# for SMP kernels.  Thus, the apic device is not strictly an SMP option,
29# but it is a prerequisite for SMP.
30#
31# Notes:
32#
33# Be sure to disable 'cpu I386_CPU' for SMP kernels.
34#
35# By default, mixed mode is used to route IRQ0 from the AT timer via
36# the 8259A master PIC through the ExtINT pin on the first I/O APIC.
37# This can be disabled via the NO_MIXED_MODE option.  In that case,
38# IRQ0 will be routed via an intpin on the first I/O APIC.  Not all
39# motherboards hook IRQ0 up to the first I/O APIC even though their
40# MP table or MADT may claim to do so.  That is why mixed mode is
41# enabled by default.
42#
43
44# Mandatory:
45device		apic			# I/O apic
46
47# Optional:
48options 	NO_MIXED_MODE		# Disable use of mixed mode
49
50
51#####################################################################
52# CPU OPTIONS
53
54#
55# You must specify at least one CPU (the one you intend to run on);
56# deleting the specification for CPUs you don't need to use may make
57# parts of the system run faster.
58# I386_CPU is mutually exclusive with the other CPU types.
59# I386_CPU is deprecated and will be removed in 6.0-RELEASE.
60#
61#cpu		I386_CPU
62cpu		I486_CPU
63cpu		I586_CPU		# aka Pentium(tm)
64cpu		I686_CPU		# aka Pentium Pro(tm)
65
66#
67# Options for CPU features.
68#
69# CPU_BLUELIGHTNING_3X enables triple-clock mode on IBM Blue Lightning
70# CPU if CPU supports it.  The default is double-clock mode on
71# BlueLightning CPU box.
72#
73# CPU_BLUELIGHTNING_FPU_OP_CACHE enables FPU operand cache on IBM
74# BlueLightning CPU.  It works only with Cyrix FPU, and this option
75# should not be used with Intel FPU.
76#
77# CPU_BTB_EN enables branch target buffer on Cyrix 5x86 (NOTE 1).
78#
79# CPU_CYRIX_NO_LOCK enables weak locking for the entire address space
80# of Cyrix 6x86 and 6x86MX CPUs by setting the NO_LOCK bit of CCR1.
81# Otherwise, the NO_LOCK bit of CCR1 is cleared.  (NOTE 3)
82#
83# CPU_DIRECT_MAPPED_CACHE sets L1 cache of Cyrix 486DLC CPU in direct
84# mapped mode.  Default is 2-way set associative mode.
85#
86# CPU_DISABLE_5X86_LSSER disables load store serialize (i.e., enables
87# reorder).  This option should not be used if you use memory mapped
88# I/O device(s).
89#
90# CPU_DISABLE_CMPXCHG disables the CMPXCHG instruction on > i386 IA32
91# machines.  VmWare seems to emulate this instruction poorly, causing
92# the guest OS to run very slowly.  Enabling this with an SMP kernel
93# will cause the kernel to be unusable.
94#
95# CPU_DISABLE_SSE explicitly prevents I686_CPU from turning on SSE.
96#
97# CPU_ENABLE_SSE enables SSE/MMX2 instructions support.  This is default
98# on I686_CPU and above.
99#
100# CPU_FASTER_5X86_FPU enables faster FPU exception handler.
101#
102# CPU_I486_ON_386 enables CPU cache on i486 based CPU upgrade products
103# for i386 machines.
104#
105# CPU_IORT defines I/O clock delay time (NOTE 1).  Default values of
106# I/O clock delay time on Cyrix 5x86 and 6x86 are 0 and 7,respectively
107# (no clock delay).
108#
109# CPU_L2_LATENCY specifies the L2 cache latency value.  This option is used
110# only when CPU_PPRO2CELERON is defined and Mendocino Celeron is detected.
111# The default value is 5.
112#
113# CPU_LOOP_EN prevents flushing the prefetch buffer if the destination
114# of a jump is already present in the prefetch buffer on Cyrix 5x86(NOTE
115# 1).
116#
117# CPU_PPRO2CELERON enables L2 cache of Mendocino Celeron CPUs.  This option
118# is useful when you use Socket 8 to Socket 370 converter, because most Pentium
119# Pro BIOSs do not enable L2 cache of Mendocino Celeron CPUs.
120#
121# CPU_RSTK_EN enables return stack on Cyrix 5x86 (NOTE 1).
122#
123# CPU_SUSP_HLT enables suspend on HALT.  If this option is set, CPU
124# enters suspend mode following execution of HALT instruction.
125#
126# CPU_UPGRADE_HW_CACHE eliminates unneeded cache flush instruction(s).
127#
128# CPU_WT_ALLOC enables write allocation on Cyrix 6x86/6x86MX and AMD
129# K5/K6/K6-2 CPUs.
130#
131# CYRIX_CACHE_WORKS enables CPU cache on Cyrix 486 CPUs with cache
132# flush at hold state.
133#
134# CYRIX_CACHE_REALLY_WORKS enables (1) CPU cache on Cyrix 486 CPUs
135# without cache flush at hold state, and (2) write-back CPU cache on
136# Cyrix 6x86 whose revision < 2.7 (NOTE 2).
137#
138# NO_F00F_HACK disables the hack that prevents Pentiums (and ONLY
139# Pentiums) from locking up when a LOCK CMPXCHG8B instruction is
140# executed.  This option is only needed if I586_CPU is also defined,
141# and should be included for any non-Pentium CPU that defines it.
142#
143# NO_MEMORY_HOLE is an optimisation for systems with AMD K6 processors
144# which indicates that the 15-16MB range is *definitely* not being
145# occupied by an ISA memory hole.
146#
147# NOTE 1: The options, CPU_BTB_EN, CPU_LOOP_EN, CPU_IORT,
148# CPU_LOOP_EN and CPU_RSTK_EN should not be used because of CPU bugs.
149# These options may crash your system.
150#
151# NOTE 2: If CYRIX_CACHE_REALLY_WORKS is not set, CPU cache is enabled
152# in write-through mode when revision < 2.7.  If revision of Cyrix
153# 6x86 >= 2.7, CPU cache is always enabled in write-back mode.
154#
155# NOTE 3: This option may cause failures for software that requires
156# locked cycles in order to operate correctly.
157#
158options 	CPU_BLUELIGHTNING_3X
159options 	CPU_BLUELIGHTNING_FPU_OP_CACHE
160options 	CPU_BTB_EN
161options 	CPU_DIRECT_MAPPED_CACHE
162options 	CPU_DISABLE_5X86_LSSER
163options 	CPU_DISABLE_CMPXCHG
164#options 	CPU_DISABLE_SSE
165options 	CPU_ENABLE_SSE
166options 	CPU_FASTER_5X86_FPU
167options 	CPU_I486_ON_386
168options 	CPU_IORT
169options 	CPU_L2_LATENCY=5
170options 	CPU_LOOP_EN
171options 	CPU_PPRO2CELERON
172options 	CPU_RSTK_EN
173options 	CPU_SUSP_HLT
174options 	CPU_UPGRADE_HW_CACHE
175options 	CPU_WT_ALLOC
176options 	CYRIX_CACHE_WORKS
177options 	CYRIX_CACHE_REALLY_WORKS
178#options 	NO_F00F_HACK
179
180# Debug options
181options 	NPX_DEBUG	# enable npx debugging
182
183#
184# PERFMON causes the driver for Pentium/Pentium Pro performance counters
185# to be compiled.  See perfmon(4) for more information.
186#
187options 	PERFMON
188
189
190#####################################################################
191# NETWORKING OPTIONS
192
193#
194# DEVICE_POLLING adds support for mixed interrupt-polling handling
195# of network device drivers, which has significant benefits in terms
196# of robustness to overloads and responsivity, as well as permitting
197# accurate scheduling of the CPU time between kernel network processing
198# and other activities.  The drawback is a moderate (up to 1/HZ seconds)
199# potential increase in response times.
200# It is strongly recommended to use HZ=1000 or 2000 with DEVICE_POLLING
201# to achieve smoother behaviour.
202# Additionally, you can enable/disable polling at runtime with the
203# sysctl variable kern.polling.enable (defaults off), and select
204# the CPU fraction reserved to userland with the sysctl variable
205# kern.polling.user_frac (default 50, range 0..100).
206#
207# Not all device drivers support this mode of operation at the time of
208# this writing.  See polling(4) for more details.
209
210options 	DEVICE_POLLING
211
212
213#####################################################################
214# CLOCK OPTIONS
215
216# The following options are used for debugging clock behavior only, and
217# should not be used for production systems.
218
219# CLK_CALIBRATION_LOOP causes clock calibration to be run in a loop at
220# startup until the user presses a key.  (The i8254 clock is always
221# calibrated relative to the RTC (mc146818a) and this option causes the
222# calibration to be repeated.)
223options 	CLK_CALIBRATION_LOOP
224
225# CLK_USE_I8254_CALIBRATION causes the calibrated frequency of the i8254
226# clock to actually be used.
227options 	CLK_USE_I8254_CALIBRATION
228
229
230#####################################################################
231# MISCELLANEOUS DEVICES AND OPTIONS
232
233device		speaker		#Play IBM BASIC-style noises out your speaker
234hint.speaker.0.at="isa"
235hint.speaker.0.port="0x35"
236device		gzip		#Exec gzipped a.out's.  REQUIRES COMPAT_AOUT!
237device		apm_saver	# Requires APM
238
239
240#####################################################################
241# HARDWARE BUS CONFIGURATION
242
243#
244# ISA bus
245#
246device		isa
247
248#
249# Options for `isa':
250#
251# AUTO_EOI_1 enables the `automatic EOI' feature for the master 8259A
252# interrupt controller.  This saves about 0.7-1.25 usec for each interrupt.
253# This option breaks suspend/resume on some portables.
254#
255# MAXMEM specifies the amount of RAM on the machine; if this is not
256# specified, FreeBSD will first read the amount of memory from the CMOS
257# RAM, so the amount of memory will initially be limited to 64MB or 16MB
258# depending on the BIOS.  If the BIOS reports 64MB, a memory probe will
259# then attempt to detect the installed amount of RAM.  If this probe
260# fails to detect >64MB RAM you will have to use the MAXMEM option.
261# The amount is in kilobytes, so for a machine with 128MB of RAM, it would
262# be 131072 (128 * 1024).
263#
264# BROKEN_KEYBOARD_RESET disables the use of the keyboard controller to
265# reset the CPU for reboot.  This is needed on some systems with broken
266# keyboard controllers.
267
268options 	AUTO_EOI_1
269
270options 	MAXMEM=(128*1024)
271#options 	BROKEN_KEYBOARD_RESET
272options 	EPSON_BOUNCEDMA
273options 	EPSON_MEMWIN
274
275#
276# PCI bus & PCI options:
277#
278device		pci
279
280#
281# AGP GART support
282device		agp
283
284
285#####################################################################
286# HARDWARE DEVICE CONFIGURATION
287
288# PC98 keyboard
289device		pckbd
290hint.pckbd.0.at="isa"
291hint.pckbd.0.port="0x041"
292hint.pckbd.0.irq="1"
293
294# These options are valid for other keyboard drivers as well.
295options 	KBD_DISABLE_KEYMAP_LOAD	# refuse to load a keymap
296options 	KBD_INSTALL_CDEV	# install a CDEV entry in /dev
297
298# GDC screen
299device		gdc
300hint.gdc.0.at="isa"
301options 	LINE30
302
303#
304# The Numeric Processing eXtension driver.  This is non-optional.
305device		npx
306
307#
308# `flags' for npx0:
309#	0x01	don't use the npx registers to optimize bcopy.
310#	0x02	don't use the npx registers to optimize bzero.
311#	0x04	don't use the npx registers to optimize copyin or copyout.
312# The npx registers are normally used to optimize copying and zeroing when
313# all of the following conditions are satisfied:
314#	I586_CPU is an option
315#	the cpu is an i586 (perhaps not a Pentium)
316#	the probe for npx0 succeeds
317#	INT 16 exception handling works.
318# Then copying and zeroing using the npx registers is normally 30-100% faster.
319# The flags can be used to control cases where it doesn't work or is slower.
320# Setting them at boot time using userconfig works right (the optimizations
321# are not used until later in the bootstrap when npx0 is attached).
322# Flag 0x08 automatically disables the i586 optimized routines.
323#
324
325#
326# Optional devices:
327#
328
329# 3Dfx Voodoo Graphics, Voodoo II /dev/3dfx CDEV support.  This will create
330# the /dev/3dfx0 device to work with glide implementations.  This should get
331# linked to /dev/3dfx and /dev/voodoo.  Note that this is not the same as
332# the tdfx DRI module from XFree86 and is completely unrelated.
333#
334# To enable Linuxulator support, one must also include COMPAT_LINUX in the
335# config as well, or you will not have the dependencies.  The other option
336# is to load both as modules.
337
338device		tdfx			# Enable 3Dfx Voodoo support
339options 	TDFX_LINUX		# Enable Linuxulator support
340
341# DRM options:
342# mgadrm:    AGP Matrox G200, G400, G450, G550
343# r128drm:   ATI Rage 128
344# radeondrm: ATI Radeon up to 9000/9100
345# sisdrm:    SiS 300/305,540,630
346# tdfxdrm:   3dfx Voodoo 3/4/5 and Banshee
347# DRM_DEBUG: include debug printfs, very slow
348#
349# mga requires AGP in the kernel, and it is recommended
350# for AGP r128 and radeon cards.
351
352device		mgadrm
353device		"r128drm"
354device		radeondrm
355device		sisdrm
356device		tdfxdrm
357
358options 	DRM_DEBUG
359
360#
361# Bus mouse
362#
363device		mse
364hint.mse.0.at="isa"
365hint.mse.0.port="0x7fd9"
366hint.mse.0.irq="13"
367
368#
369# Network interfaces:
370#
371
372# ar:   Arnet SYNC/570i hdlc sync 2/4 port V.35/X.21 serial driver
373#       (requires sppp)
374# cp:   Cronyx Tau-PCI sync single/dual/four port
375#       V.35/RS-232/RS-530/RS-449/X.21/G.703/E1/E3/T3/STS-1
376#       serial adaptor (requires sppp (default), or NETGRAPH if
377#       NETGRAPH_CRONYX is configured)
378# ed:   Western Digital and SMC 80xx; Novell NE1000 and NE2000; 3Com 3C503
379#       HP PC Lan+, various PC Card devices (refer to etc/defaults/pccard.conf)
380#       (requires miibus)
381# ie:   AT&T StarLAN 10 and EN100; 3Com 3C507; unknown NI5210;
382#       Intel EtherExpress
383# lnc:  Lance/PCnet cards (Isolan, Novell NE2100, NE32-VL, AMD Am7990 and
384#       Am79C960)
385# oltr: Olicom ISA token-ring adapters OC-3115, OC-3117, OC-3118 and OC-3133.
386#       Olicom PCI token-ring adapters OC-3136, OC-3137, OC-3139, OC-3140,
387#       OC-3141, OC-3540 and OC-3250.
388# sbni: Granch SBNI12-xx ISA and PCI adapters
389# sr:   RISCom/N2 hdlc sync 1/2 port V.35/X.21 serial driver (requires sppp)
390# wl:   Lucent Wavelan (ISA card only).
391
392# Order for ISA/EISA devices is important here
393
394device		ar
395device		cp
396device		ed
397#options 	ED_NO_MIIBUS		# Disable ed miibus support
398hint.ed.0.at="isa"
399hint.ed.0.port="0x280"
400hint.ed.0.irq="5"
401hint.ed.0.maddr="0xd8000"
402device		ie			# Hints only required for Starlan
403hint.ie.2.at="isa"
404hint.ie.2.port="0x300"
405hint.ie.2.irq="5"
406hint.ie.2.maddr="0xd0000"
407device		lnc
408hint.lnc.0.at="isa"
409hint.lnc.0.port="0x280"
410hint.lnc.0.irq="10"
411hint.lnc.0.drq="0"
412device		sbni
413hint.sbni.0.at="isa"
414hint.sbni.0.port="0x210"
415hint.sbni.0.irq="0xefdead"
416hint.sbni.0.flags="0"
417device		snc
418hint.snc.0.at="isa"
419hint.snc.0.port="0x888"
420hint.snc.0.irq="6"
421hint.snc.0.maddr="0xc0000"
422device		sr
423device		oltr
424device		wl
425hint.wl.0.at="isa"
426hint.wl.0.port="0x300"
427options 	WLCACHE		# enables the signal-strength cache
428options 	WLDEBUG		# enables verbose debugging output
429
430#
431# SCSI host adapters:
432#
433# ct: WD33C93[ABC] based SCSI host adapters.
434# ncv: NCR 53C500 based SCSI host adapters.
435# nsp: Workbit Ninja SCSI-3 based PC Card SCSI host adapters.
436# stg: TMC 18C30, 18C50 based SCSI host adapters.
437
438device		ct
439hint.ct.0.at="isa"
440device		ncv
441device		nsp
442device		stg
443
444#
445# SafeNet crypto driver: can be moved to the MI NOTES as soon as
446# it's tested on a big-endian machine
447#
448device		safe		# SafeNet 1141
449options		SAFE_DEBUG	# enable debugging support: hw.safe.debug
450options		SAFE_RNDTEST	# enable rndtest support
451
452#####################################################################
453
454#
455# Miscellaneous hardware:
456#
457# apm: Laptop Advanced Power Management (experimental)
458# pmtimer: Timer device driver for power management events (APM or ACPI)
459# cy: Cyclades serial driver
460# digi: Digiboard driver
461
462# Notes on APM
463#  The flags takes the following meaning for apm0:
464#    0x0020  Statclock is broken.
465
466device		apm
467hint.apm.0.flags="0x20"
468device		canbus
469device		canbepm
470device		cy
471options 	CY_PCI_FASTINTR		# Use with cy_pci unless irq is shared
472device		digi
473# BIOS & FEP/OS components of device digi.
474device		digi_CX
475device		digi_CX_PCI
476device		digi_EPCX
477device		digi_EPCX_PCI
478device		digi_Xe
479device		digi_Xem
480device		digi_Xr
481device		olpt
482hint.olpt.0.at="isa"
483hint.olpt.0.port="0x040"
484device		pmc
485hint.pmc.0.at="isa"
486hint.pmc.0.port="0x8f0"
487device		pmtimer			# Adjust system timer at wakeup time
488# sx device is i386 and pc98 only at the moment.
489device		sx
490options 	SX_DEBUG
491
492#
493# Laptop/Notebook options:
494#
495# See also:
496#  apm under `Miscellaneous hardware'
497# above.
498
499# For older notebooks that signal a powerfail condition (external
500# power supply dropped, or battery state low) by issuing an NMI:
501
502options 	POWERFAIL_NMI	# make it beep instead of panicing
503
504#
505# PC Card/PCMCIA
506# (OLDCARD)
507#
508# card: pccard slots
509# pcic: isa/pccard bridge
510device		pcic
511hint.pcic.0.at="isa"
512#hint.pcic.1.at="isa"
513device		card
514
515#---------------------------------------------------------------------------
516# ISDN4BSD
517#
518# See /usr/share/examples/isdn/ROADMAP for an introduction to isdn4bsd.
519#
520# i4b passive ISDN cards support contains the following hardware drivers:
521#
522#	isic  - Siemens/Infineon ISDN ISAC/HSCX/IPAC chipset driver
523#	iwic  - Winbond W6692 PCI bus ISDN S/T interface controller
524#	ifpi  - AVM Fritz!Card PCI driver
525#	ifpi2  - AVM Fritz!Card PCI version 2 driver
526#	ihfc  - Cologne Chip HFC ISA/ISA-PnP chipset driver
527#	ifpnp - AVM Fritz!Card PnP driver
528#	itjc  - Siemens ISAC / TJNet Tiger300/320 chipset
529#
530# i4b active ISDN cards support contains the following hardware drivers:
531#
532#	iavc  - AVM B1 PCI, AVM B1 ISA, AVM T1
533#
534# Note that the ``options'' (if given) and ``device'' lines must BOTH
535# be uncommented to enable support for a given card !
536#
537# In addition to a hardware driver (and probably an option) the mandatory
538# ISDN protocol stack devices and the mandatory support device must be
539# enabled as well as one or more devices from the optional devices section.
540#
541#---------------------------------------------------------------------------
542#	isic driver (Siemens/Infineon chipsets)
543#
544device	isic
545#
546# PCI bus Cards:
547# --------------
548#
549# ELSA MicroLink ISDN/PCI (same as ELSA QuickStep 1000pro PCI)
550options 	ELSA_QS1PCI
551#
552#---------------------------------------------------------------------------
553#	ifpnp driver for AVM Fritz!Card PnP
554#
555# AVM Fritz!Card PnP
556device		ifpnp
557#
558#---------------------------------------------------------------------------
559#	ihfc driver for Cologne Chip ISA chipsets (experimental!)
560#
561# Teles 16.3c ISA PnP
562# AcerISDN P10 ISA PnP
563# TELEINT ISDN SPEED No.1
564device		ihfc
565#
566#---------------------------------------------------------------------------
567#	ifpi driver for AVM Fritz!Card PCI
568#
569# AVM Fritz!Card PCI
570device		ifpi
571#
572#---------------------------------------------------------------------------
573#	ifpi2 driver for AVM Fritz!Card PCI version 2
574#
575# AVM Fritz!Card PCI version 2
576device		"ifpi2"
577#
578#---------------------------------------------------------------------------
579#	iwic driver for Winbond W6692 chipset
580#
581# ASUSCOM P-IN100-ST-D (and other Winbond W6692 based cards)
582device		iwic
583#
584#---------------------------------------------------------------------------
585#	itjc driver for Siemens ISAC / TJNet Tiger300/320 chipset
586#
587# Traverse Technologies NETjet-S
588# Teles PCI-TJ
589device		itjc
590#
591#---------------------------------------------------------------------------
592#	iavc driver (AVM active cards, needs i4bcapi driver!)
593#
594device		iavc
595#
596#---------------------------------------------------------------------------
597#	ISDN Protocol Stack - mandatory for all hardware drivers
598#
599# Q.921 / layer 2 - i4b passive cards D channel handling
600device		"i4bq921"
601#
602# Q.931 / layer 3 - i4b passive cards D channel handling
603device		"i4bq931"
604#
605# layer 4 - i4b common passive and active card handling
606device		"i4b"
607#
608#---------------------------------------------------------------------------
609#	ISDN devices - mandatory for all hardware drivers
610#
611# userland driver to do ISDN tracing (for passive cards only)
612device		"i4btrc"	4
613#
614# userland driver to control the whole thing
615device		"i4bctl"
616#
617#---------------------------------------------------------------------------
618#	ISDN devices - optional
619#
620# userland driver for access to raw B channel
621device		"i4brbch"	4
622#
623# userland driver for telephony
624device		"i4btel"	2
625#
626# network driver for IP over raw HDLC ISDN
627device		"i4bipr"	4
628# enable VJ header compression detection for ipr i/f
629options 	IPR_VJ
630# enable logging of the first n IP packets to isdnd (n=32 here)
631options 	IPR_LOG=32
632#
633# network driver for sync PPP over ISDN; requires an equivalent
634# number of sppp device to be configured
635device		"i4bisppp"	4
636#
637# B-channel interface to the netgraph subsystem
638device		"i4bing"	2
639#
640# CAPI driver needed for active ISDN cards (see iavc driver above)
641device		"i4bcapi"
642#
643#---------------------------------------------------------------------------
644
645#
646# Set the number of PV entries per process.  Increasing this can
647# stop panics related to heavy use of shared memory.  However, that can
648# (combined with large amounts of physical memory) cause panics at
649# boot time due the kernel running out of VM space.
650#
651# If you're tweaking this, you might also want to increase the sysctls
652# "vm.v_free_min", "vm.v_free_reserved", and "vm.v_free_target".
653#
654# The value below is the one more than the default.
655#
656options 	PMAP_SHPGPERPROC=201
657
658#
659# Change the size of the kernel virtual address space.  Due to
660# constraints in loader(8) on i386, this must be a multiple of 4.
661# 256 = 1 GB of kernel address space.  Increasing this also causes
662# a reduction of the address space in user processes.  512 splits
663# the 4GB cpu address space in half (2GB user, 2GB kernel).
664#
665options 	KVA_PAGES=260
666
667
668#####################################################################
669# ABI Emulation
670
671# Enable iBCS2 runtime support for SCO and ISC binaries
672options 	IBCS2
673
674# Emulate spx device for client side of SVR3 local X interface
675options 	SPX_HACK
676
677# Enable Linux ABI emulation
678options 	COMPAT_LINUX
679
680# Enable i386 a.out binary support
681options 	COMPAT_AOUT
682
683# Enable the linux-like proc filesystem support (requires COMPAT_LINUX
684# and PSEUDOFS)
685options 	LINPROCFS
686
687#
688# SysVR4 ABI emulation
689#
690# The svr4 ABI emulator can be statically compiled into the kernel or loaded as
691# a KLD module.
692# The STREAMS network emulation code can also be compiled statically or as a
693# module.  If loaded as a module, it must be loaded before the svr4 module
694# (the /usr/sbin/svr4 script does this for you).  If compiling statically,
695# the `streams' device must be configured into any kernel which also
696# specifies COMPAT_SVR4.  It is possible to have a statically-configured
697# STREAMS device and a dynamically loadable svr4 emulator;  the /usr/sbin/svr4
698# script understands that it doesn't need to load the `streams' module under
699# those circumstances.
700# Caveat:  At this time, `options KTRACE' is required for the svr4 emulator
701# (whether static or dynamic).
702#
703options 	COMPAT_SVR4	# build emulator statically
704options 	DEBUG_SVR4	# enable verbose debugging
705device		streams		# STREAMS network driver (required for svr4).
706
707
708#####################################################################
709# VM OPTIONS
710
711# Disable the 4 MByte page PSE CPU feature.  The PSE feature allows the
712# kernel to use 4 MByte pages to map the kernel instead of 4k pages.
713# This saves on the amount of memory needed for page tables needed to
714# map the kernel.  You should only disable this feature as a temporary
715# workaround if you are having problems with it enabled.
716#
717#options 	DISABLE_PSE
718
719# Disable the global pages PGE CPU feature.  The PGE feature allows pages
720# to be marked with the PG_G bit.  TLB entries for these pages are not
721# flushed from the cache when %cr3 is reloaded.  This can make context
722# switches less expensive.  You should only disable this feature as a
723# temporary workaround if you are having problems with it enabled.
724#
725#options 	DISABLE_PG_G
726
727# KSTACK_PAGES is the number of memory pages to assign to the kernel
728# stack of each thread.
729
730options 	KSTACK_PAGES=3
731
732#####################################################################
733
734# More undocumented options for linting.
735# Note that documenting these are not considered an affront.
736
737options 	FB_INSTALL_CDEV		# install a CDEV entry in /dev
738
739# PECOFF module (Win32 Execution Format)
740options 	PECOFF_SUPPORT
741options 	PECOFF_DEBUG
742
743options 	I4B_SMP_WORKAROUND
744options 	I586_PMC_GUPROF=0x70000
745options 	KBDIO_DEBUG=2
746options 	KBD_MAXRETRY=4
747options 	KBD_MAXWAIT=6
748options 	KBD_RESETDELAY=201
749
750options 	TIMER_FREQ=((14318182+6)/12)
751
752options 	VM_KMEM_SIZE
753options 	VM_KMEM_SIZE_MAX
754options 	VM_KMEM_SIZE_SCALE
755
756
757#####################################################################
758# Devices we don't want to deal with
759
760nodevice	atkbdc
761nodevice	atkbd
762nodevice	psm
763nodevice	vga
764nodevice	bt
765nodevice	adw
766nodevice	aha
767nodevice	ahb
768nodevice	ahd
769nodevice	mpt
770nodevice	trm
771nodevice	wds
772nodevice	asr
773nodevice	dpt
774nodevice	ciss
775nodevice	iir
776nodevice	mly
777nodevice	ida		# Compaq Smart RAID
778nodevice	mlx		# Mylex DAC960
779nodevice	amr		# AMI MegaRAID
780nodevice	twe		# 3ware ATA RAID
781nodevice	ataraid
782nodevice	cm
783nodevice	cs
784nodevice	ex
785nodevice	fea
786nodevice	cbb
787nodevice	pccard
788nodevice	cardbus
789nodevice	intpm
790nodevice	alpm
791nodevice	ichsmb
792nodevice	viapm
793nodevice	amdpm
794nodevice	nfpm
795
796
797#####################################################################
798# Options we don't want to deal with
799
800nooption	VGA_DEBUG
801nooption	VGA_WIDTH90
802nooption	VGA_SLOW_IOACCESS
803nooption	VGA_ALT_SEQACCESS
804nooption	PSM_RESETAFTERSUSPEND
805nooption	PSM_HOOKRESUME
806nooption	ATKBD_DFLT_KEYMAP
807nooption	AHD_DEBUG
808nooption	AHD_DEBUG_OPTS
809nooption	AHD_REG_PRETTY_PRINT
810nooption	ADW_ALLOW_MEMIO
811nooption	DPT_LOST_IRQ
812nooption	DPT_RESET_HBA
813nooption	DPT_TIMEOUT_FACTOR
814nooption	AAC_DEBUG
815nooption	ACPI_MAX_THREADS
816
817
818#####################################################################
819# Make options we don't want to deal with
820
821nomakeoption	ATKBD_DFLT_KEYMAP
822