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