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