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