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