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