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