files.i386 revision 1.295
1#	$NetBSD: files.i386,v 1.295 2006/10/25 13:56:15 jmmv Exp $
2#
3# new style config file for i386 architecture
4#
5
6# maxpartitions must be first item in files.${ARCH}.newconf
7maxpartitions 8
8
9maxusers 2 16 128
10
11defparam opt_kernbase.h	KERNBASE
12
13# Processor type options.
14defflag	opt_cputype.h	I386_CPU I486_CPU I586_CPU I686_CPU
15
16# delay before cpu_reset() for reboot.
17defparam		CPURESET_DELAY
18
19# VM86 emulation
20defflag			VM86
21defflag			KVM86
22
23# Floating point emulation
24defflag			MATH_EMULATE
25
26# User-settable LDT (used by WINE)
27defflag			USER_LDT
28
29# X server support in console drivers
30defflag	opt_xserver.h	XSERVER XSERVER_DDB
31
32# The REAL{BASE,EXT}MEM options
33defparam opt_realmem.h	REALBASEMEM REALEXTMEM
34
35# understand boot device passed by pre-1.3 bootblocks
36defflag			COMPAT_OLDBOOT
37
38# PCI BIOS options
39defflag	opt_pcibios.h	PCIBIOS PCIBIOSVERBOSE
40			PCIBIOS_INTR_GUESS PCIINTR_DEBUG
41defparam opt_pcibios.h	PCIBIOS_IRQS_HINT
42
43# Large page size
44defflag			LARGEPAGES
45
46# No unmapped page below kernel stack
47defflag			NOREDZONE
48
49# kernel stack debug
50defflag	opt_kstack_dr0.h		KSTACK_CHECK_DR0
51
52# Beep on halt
53defflag opt_beep.h		BEEP_ONHALT
54defparam opt_beep.h		BEEP_ONHALT_COUNT
55defparam opt_beep.h		BEEP_ONHALT_PITCH BEEP_ONHALT_PERIOD
56
57# Enhanced SpeedStep
58defflag			ENHANCED_SPEEDSTEP
59
60# Multiboot support
61defflag opt_multiboot.h		MULTIBOOT
62file	arch/i386/i386/multiboot.c	multiboot
63
64# PowerNow K7
65defflag			POWERNOW_K7
66
67file	arch/i386/i386/autoconf.c
68file	arch/i386/i386/db_dbgreg.S	ddb | kstack_check_dr0
69file	arch/i386/i386/db_disasm.c	ddb
70file	arch/i386/i386/db_interface.c	ddb
71file	arch/i386/i386/db_memrw.c	ddb | kgdb
72file	arch/i386/i386/db_trace.c	ddb
73file	kern/subr_disk_mbr.c		disk
74file	arch/i386/i386/gdt.c
75file	arch/i386/i386/in_cksum.S	inet | inet6
76file	arch/i386/i386/ipkdb_glue.c	ipkdb
77file	arch/i386/i386/kgdb_machdep.c	kgdb
78file	arch/i386/i386/machdep.c
79file	arch/i386/i386/identcpu.c
80file	arch/i386/i386/math_emulate.c	math_emulate
81file	arch/i386/i386/mem.c
82file	arch/i386/i386/mtrr_k6.c	mtrr
83file	netns/ns_cksum.c		ns
84file	arch/i386/i386/pmap.c
85file	arch/i386/i386/process_machdep.c
86file	arch/i386/i386/procfs_machdep.c	procfs
87file	arch/i386/i386/sys_machdep.c
88file	arch/i386/i386/syscall.c
89file	arch/i386/i386/trap.c
90file	arch/i386/i386/vm_machdep.c
91file	dev/cons.c
92
93file	arch/i386/i386/mptramp.S  	multiprocessor
94file    arch/i386/i386/ipifuncs.c       multiprocessor
95
96file	arch/i386/i386/pmc.c		perfctrs
97
98file	crypto/des/arch/i386/des_enc.S		des
99file	crypto/des/arch/i386/des_cbc.S		des
100
101file	crypto/blowfish/arch/i386/bf_enc.S	blowfish
102file	crypto/blowfish/arch/i386/bf_cbc.S	blowfish & !i386_cpu
103
104#
105# Machine-independent SCSI drivers
106#
107
108include	"dev/scsipi/files.scsipi"
109
110#
111# Machine-independent ATA drivers
112#
113
114include	"dev/ata/files.ata"
115
116# Memory Disk for install floppy
117file	dev/md_root.c			memory_disk_hooks
118
119#
120# Machine-independent I2O drivers
121#
122
123include	"dev/i2o/files.i2o"
124
125# attribute used to bring in BIOS trampoline code for real-mode probing
126# of certain devices/BIOS features
127define	bioscall
128file	arch/i386/i386/bioscall.S	bioscall needs-flag
129
130# BIOS32 routines
131define	bios32
132file	arch/i386/i386/bios32.c		bios32 needs-flag
133
134# i386 specific mainbus attributes
135define apmbus {}
136define pnpbiosbus {}
137define vesabiosbus {}
138
139#
140# System bus types
141#
142
143# XXX BIOS32 only if something that uses it is configured!
144device	mainbus: isabus, eisabus, mcabus, pcibus, bios32, acpibus,
145	cpubus, apmbus, pnpbiosbus, vesabiosbus, ipmibus
146attach	mainbus at root
147file	arch/i386/i386/mainbus.c	mainbus
148
149#
150# PCI-only drivers
151# XXX MUST BE INCLUDED BEFORE files.isa, as long as files.isa attaches
152# XXX devices to 'pci'.
153#
154
155include	"dev/pci/files.pci"
156include "dev/pci/files.agp"
157file 	arch/i386/pci/agp_machdep.c	agp
158file	arch/i386/pci/pcibios.c		pcibios
159file	arch/i386/pci/pci_intr_fixup.c	pcibios & pci_intr_fixup
160file	arch/i386/pci/piix.c		pcibios & pci_intr_fixup
161file	arch/i386/pci/opti82c558.c	pcibios & pci_intr_fixup
162file	arch/i386/pci/opti82c700.c	pcibios & pci_intr_fixup
163file	arch/i386/pci/sis85c503.c	pcibios & pci_intr_fixup
164file	arch/i386/pci/via82c586.c	pcibios & pci_intr_fixup
165file	arch/i386/pci/via8231.c		pcibios & pci_intr_fixup
166file	arch/i386/pci/amd756.c		pcibios & pci_intr_fixup
167file	arch/i386/pci/ali1543.c		pcibios & pci_intr_fixup
168file	arch/i386/pci/pci_bus_fixup.c	pci_bus_fixup
169file	arch/i386/pci/pci_addr_fixup.c	pci_addr_fixup
170defparam		PCI_CONF_MODE
171file	arch/i386/pci/pcic_pci_machdep.c	pcic_pci
172
173device 	aapic
174attach 	aapic at pci
175file 	arch/x86/pci/aapic.c			aapic
176
177# PCI-Host bridge chipsets
178device	pchb: pcibus, agpbus, agp_ali, agp_amd, agp_i810, agp_intel, agp_sis,
179	      agp_via
180attach	pchb at pci
181file	arch/i386/pci/pchb.c		pchb			needs-flag
182file	arch/x86/pci/pchb_rnd.c		pchb & rnd
183
184# AMD Elan SC520 System Controller (PCI-Host bridge)
185device	elansc: sysmon_wdog, gpiobus
186attach	elansc at pci
187file	arch/i386/pci/elan520.c		elansc
188
189# AMD Geode SC1100 GCB area
190device  geodegcb {}
191attach	geodegcb at pci
192file	arch/i386/pci/geode.c		geodegcb
193
194# AMD Geode SC1100 Watchdog Timer
195device	geodewdog: sysmon_wdog, geodegcb
196attach	geodewdog at geodegcb
197file	arch/i386/pci/geodewdg.c	geodewdog
198
199# AMD Geode SC1100 high resolution counter
200device	geodecntr: geodegcb
201attach  geodecntr at geodegcb
202file	arch/i386/pci/geodecntr.c	geodecntr
203
204# PCI-EISA bridges
205device	pceb: eisabus, isabus
206attach	pceb at pci
207file	arch/i386/pci/pceb.c		pceb
208
209# PCI-ISA bridges
210device	pcib: isabus
211attach	pcib at pci
212file	arch/i386/pci/pcib.c		pcib | ichlpcib | gscpcib | piixpcib | viapcib
213
214# PCI-LPC bridges
215device	ichlpcib: isabus, sysmon_wdog
216attach	ichlpcib at pci
217file	arch/i386/pci/ichlpcib.c	ichlpcib
218
219device	gscpcib: isabus, gpiobus
220attach	gscpcib at pci
221file	arch/i386/pci/gscpcib.c		gscpcib
222
223device	piixpcib: isabus, bioscall
224attach	piixpcib at pci
225file	arch/i386/pci/piixpcib.c	piixpcib
226
227device	viapcib: isabus, i2cbus
228attach	viapcib at pci
229file	arch/i386/pci/viapcib.c		viapcib
230
231# PCI-MCA bridges
232device	pcmb: mcabus
233attach	pcmb at pci
234file	arch/i386/pci/pcmb.c		pcmb
235
236device	p64h2apic
237attach	p64h2apic at pci
238file	arch/i386/pci/p64h2apic.c	p64h2apic
239
240
241#
242# ISA and mixed ISA+EISA or ISA+PCI drivers
243#
244
245include	"dev/isa/files.isa"
246
247# PC clock
248file	arch/x86/isa/clock.c		isa
249
250# TSC support
251file	arch/x86/x86/tsc.c		i586_cpu | i686_cpu
252
253# Numeric Processing Extension; Math Co-processor
254device	npx
255file	arch/i386/isa/npx.c		npx needs-flag
256
257attach	npx at isa with npx_isa
258file	arch/i386/isa/npx_isa.c		npx_isa
259
260# PC console support a la "pccons"
261device	pc: tty
262attach	pc at isa
263device	pcconskbd: pckbport_machdep_cnattach
264attach	pcconskbd at pckbport
265file	arch/i386/isa/pccons.c		pc | pcconskbd needs-flag
266
267# PC Mice: Logitech-style and Microsoft-style
268device	lms: wsmousedev
269attach	lms at isa
270file	arch/i386/isa/lms.c		lms
271device	mms: wsmousedev
272attach	mms at isa
273file	arch/i386/isa/mms.c		mms
274
275include	"dev/wscons/files.wscons"
276include	"dev/wsfont/files.wsfont"
277
278include	"dev/pckbport/files.pckbport"
279
280device	sysbeep
281attach	sysbeep at pcppi
282
283# Floppy disk controller
284device	fdc {drive = -1}: isadma
285file	dev/isa/fd.c			fdc needs-flag
286
287attach	fdc at isa with fdc_isa
288file	dev/isa/fdc_isa.c		fdc_isa
289
290device	fd: disk
291attach	fd at fdc
292
293# Adaptec AHA-284x VL SCSI controllers
294# device declaration in sys/conf/files
295attach	ahc at isa with ahc_isa: ahc_aic77xx, smc93cx6
296file	arch/i386/isa/ahc_isa.c		ahc_isa
297
298#
299# EISA-only drivers
300#
301
302include	"dev/eisa/files.eisa"
303file	arch/i386/eisa/eisa_machdep.c	eisa
304
305#
306# MCA-only drivers
307#
308
309device	mca {[slot = -1]} : bioscall
310include	"dev/mca/files.mca"
311file	arch/i386/mca/mca_machdep.c	mca
312
313# ISA Plug 'n Play devices
314file	arch/i386/isa/isapnp_machdep.c	isapnp
315
316#
317# VME support
318#
319include	"dev/vme/files.vme"
320
321#
322# GPIB support
323#
324include "dev/gpib/files.gpib"
325
326#
327# Other mainbus-attached devices
328#
329
330include "dev/apm/files.apm"
331
332# Advanced Power Management support (APM)
333attach	apm at apmbus with apmbios: bioscall
334file	arch/i386/i386/apmbios.c	apmbios	needs-flag
335file	arch/i386/i386/apmcall.S	apmbios
336
337# CPUS
338
339device cpu
340attach cpu at cpubus
341file	arch/i386/i386/cpu.c		cpu
342
343#
344# Compatibility modules
345#
346
347# VM86 mode
348file	arch/i386/i386/vm86.c			vm86
349
350# VM86 in kernel
351file	arch/i386/i386/kvm86.c			kvm86
352file	arch/i386/i386/kvm86call.S		kvm86
353
354# Binary compatibility with previous NetBSD releases (COMPAT_XX)
355file	arch/i386/i386/compat_13_machdep.c	compat_13
356file	arch/i386/i386/compat_16_machdep.c	compat_16 | compat_ibcs2
357
358# SVR4 binary compatibility (COMPAT_SVR4)
359include	"compat/svr4/files.svr4"
360file	arch/i386/i386/svr4_machdep.c		compat_svr4
361file	arch/i386/i386/svr4_sigcode.S		compat_svr4
362file	arch/i386/i386/svr4_syscall.c		compat_svr4
363
364# MACH binary compatibility (COMPAT_MACH)
365include	"compat/mach/files.mach"
366file	arch/i386/i386/mach_machdep.c		compat_mach | compat_darwin
367file	arch/i386/i386/mach_sigcode.S		compat_mach | compat_darwin
368file	arch/i386/i386/mach_syscall.c		compat_mach | compat_darwin
369file	arch/i386/i386/darwin_commpage_machdep.S compat_darwin
370file	arch/i386/i386/macho_machdep.c		exec_macho
371
372# DARWIN binary compatibility (COMPAT_DARWIN)
373include	"compat/darwin/files.darwin"
374file	arch/i386/i386/darwin_machdep.c		compat_darwin
375
376# iBCS-2 binary compatibility (COMPAT_IBCS2)
377include	"compat/ibcs2/files.ibcs2"
378file	arch/i386/i386/ibcs2_machdep.c		compat_ibcs2
379file	arch/i386/i386/ibcs2_sigcode.S		compat_ibcs2
380file	arch/i386/i386/ibcs2_syscall.c		compat_ibcs2
381
382# Linux binary compatibility (COMPAT_LINUX)
383include	"compat/linux/files.linux"
384include	"compat/linux/arch/i386/files.linux_i386"
385file	arch/i386/i386/linux_sigcode.S		compat_linux
386file	arch/i386/i386/linux_syscall.c		compat_linux
387file	arch/x86/x86/linux_trap.c		compat_linux
388
389# FreeBSD binary compatibility (COMPAT_FREEBSD)
390include	"compat/freebsd/files.freebsd"
391file	arch/i386/i386/freebsd_machdep.c	compat_freebsd
392file	arch/i386/i386/freebsd_sigcode.S	compat_freebsd
393file	arch/i386/i386/freebsd_syscall.c	compat_freebsd
394
395# NDIS compatibilty (COMPAT_NDIS)
396include "compat/ndis/files.ndis"
397
398# Win32 binary compatibility (COMPAT_PECOFF)
399include	"compat/pecoff/files.pecoff"
400
401# OSS audio driver compatibility
402include	"compat/ossaudio/files.ossaudio"
403
404#
405# CARDBUS
406#
407include	"dev/cardbus/files.cardbus"
408file	arch/i386/i386/rbus_machdep.c	cardbus
409
410# XXXX pcic here because it needs to be late.  The catch: pcic needs
411# to be late, so devices which attach to it are attached late.  But it
412# needs to be before its isa and pci attachments.  This answer is
413# non-optimal, but I don't have a better answer right now.
414
415# PCIC pcmcia controller
416# XXX this needs to be done very late, so it's done here.  This feels
417# like a kludge, but it might be for the best.
418
419defparam		PCIC_ISA_ALLOC_IOBASE
420defparam		PCIC_ISA_ALLOC_IOSIZE
421defparam		PCIC_ISA_INTR_ALLOC_MASK
422
423device	pcic: pcmciabus
424file	dev/ic/i82365.c			pcic
425
426# PCIC pcmcia controller on ISA bus.
427attach	pcic at isa with pcic_isa
428file	dev/isa/i82365_isa.c		pcic_isa
429
430# PCIC pcmcia controller on PCI bus.
431attach	pcic at pci with pcic_pci
432file	dev/pci/i82365_pci.c		pcic_pci
433
434# PCIC pcmcia controller on PnP board
435attach	pcic at isapnp with pcic_isapnp
436file	dev/isapnp/i82365_isapnp.c	pcic_isapnp
437
438# Code common to ISA and ISAPnP attachments
439file	dev/isa/i82365_isasubr.c	pcic_isa | pcic_isapnp | pcic_pci
440
441# XXXX tcic here because it needs to be late.  The catch: tcic needs
442# to be late, so devices which attach to it are attached late.  But it
443# needs to be before its isa and pci attachments.  This answer is
444# non-optimal, but I don't have a better answer right now.
445
446# TCIC pcmcia controller
447# XXX this needs to be done very late, so it's done here.  This feels
448# like a kludge, but it might be for the best.
449
450defparam		TCIC_ISA_ALLOC_IOBASE
451defparam		TCIC_ISA_ALLOC_IOSIZE
452defparam		TCIC_ISA_INTR_ALLOC_MASK
453
454device	tcic: pcmciabus
455file	dev/ic/tcic2.c			tcic
456
457# TCIC pcmcia controller
458attach	tcic at isa with tcic_isa
459file	dev/isa/tcic2_isa.c		tcic_isa
460
461# this wants to be probed as late as possible.
462#
463# Machine-independent PCMCIA drivers
464#
465include	"dev/pcmcia/files.pcmcia"
466
467
468include	"dev/usb/files.usb"
469
470include	"dev/bluetooth/files.bluetooth"
471
472include	"dev/ieee1394/files.ieee1394"
473
474include	"arch/i386/pnpbios/files.pnpbios"
475
476include "dev/acpi/files.acpi"
477file	arch/i386/acpi/acpi_wakeup.c	acpi
478
479# Toshiba VALD 
480device	vald
481attach	vald at acpinodebus with vald_acpi
482file	arch/i386/acpi/vald_acpi.c		vald_acpi
483
484# Sony SPIC (jog dial etc.)
485attach	spic at acpinodebus with spic_acpi
486file	arch/i386/acpi/spic_acpi.c		spic_acpi
487
488# Sony Misc (brightness etc.)
489device	sony
490attach	sony at acpinodebus with sony_acpi
491file	arch/i386/acpi/sony_acpi.c		sony_acpi
492
493# Numeric Processing Extension; Math Co-processor
494attach	npx at acpinodebus with npx_acpi
495file	arch/i386/acpi/npx_acpi.c		npx_acpi
496
497device	vesabios {}
498attach vesabios at vesabiosbus
499file	arch/i386/bios/vesabios.c		vesabios needs-flag
500defflag	opt_vesabios.h	VESABIOSVERBOSE
501
502include	"dev/rasops/files.rasops"
503
504device vesafb: wsemuldisplaydev, vcons, rasops8, rasops16, rasops32, splash, bioscall
505attach vesafb at vesabios
506file	arch/i386/bios/vesafb.c		vesafb needs-flag
507defparam opt_vesafb.h	VESAFB_WIDTH VESAFB_HEIGHT VESAFB_DEPTH
508defflag opt_vesafb.h	VESAFB_PM
509
510device vesatext
511attach vesatext at vesabios
512file	arch/i386/bios/vesa_text.c	vesatext
513
514# Enhanced SpeedStep
515file	arch/i386/i386/est.c		enhanced_speedstep
516defflag	opt_est.h	EST_FREQ_USERWRITE
517
518# AMD PowerNow K7
519file   arch/i386/i386/powernow_k7.c	powernow_k7
520
521include "arch/i386/conf/majors.i386"
522