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