files.i386 revision 1.368
1#	$NetBSD: files.i386,v 1.368 2012/10/28 16:25:03 alnsn 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# Obsolete Xbox support
19obsolete defflag	XBOX
20
21# VM86 emulation
22defflag			VM86
23
24# User-settable LDT (used by WINE)
25defflag			USER_LDT
26
27# X server support in console drivers
28defflag	opt_xserver.h	XSERVER XSERVER_DDB
29
30# The REAL{BASE,EXT}MEM options
31defparam opt_realmem.h	REALBASEMEM REALEXTMEM
32
33# The PHYSMEM_MAX_{SIZE,ADDR} optionms
34defparam opt_physmem.h	PHYSMEM_MAX_ADDR PHYSMEM_MAX_SIZE
35
36# understand boot device passed by pre-1.3 bootblocks
37defflag			COMPAT_OLDBOOT
38
39# PCI BIOS options
40defflag	opt_pcibios.h	PCIBIOS PCIBIOSVERBOSE
41			PCIBIOS_INTR_GUESS PCIINTR_DEBUG
42defparam opt_pcibios.h	PCIBIOS_IRQS_HINT
43
44# kernel stack debug
45defflag	opt_kstack_dr0.h		KSTACK_CHECK_DR0
46
47# splraise()/spllower() debug
48defflag	opt_spldebug.h			SPLDEBUG
49
50# Beep on halt
51defflag 	opt_beep.h		BEEP_ONHALT
52defparam 	opt_beep.h		BEEP_ONHALT_COUNT=3
53defparam 	opt_beep.h		BEEP_ONHALT_PITCH=1500
54defparam 	opt_beep.h		BEEP_ONHALT_PERIOD=250
55
56# Multiboot support
57defflag 	opt_multiboot.h		MULTIBOOT
58obsolete 	defparam		MULTIBOOT_SYMTAB_SPACE
59file 	arch/i386/i386/multiboot.c	multiboot
60
61file	arch/i386/i386/autoconf.c
62file	arch/i386/i386/aout_machdep.c	exec_aout
63file	arch/i386/i386/busfunc.S
64file	arch/i386/i386/cpufunc.S
65file	arch/i386/i386/cpu_in_cksum.S	(inet | inet6) & cpu_in_cksum
66file	arch/i386/i386/db_dbgreg.S	ddb | kstack_check_dr0
67file	arch/i386/i386/db_disasm.c	ddb
68file	arch/i386/i386/db_interface.c	ddb
69file	arch/i386/i386/db_machdep.c	ddb
70file	arch/i386/i386/dumpsys.c
71file	kern/subr_disk_mbr.c		disk
72file	kern/subr_spldebug.c		spldebug
73file	arch/i386/i386/gdt.c
74file	arch/i386/i386/i386func.S
75file	arch/i386/i386/ipkdb_glue.c	ipkdb
76file	arch/i386/i386/kgdb_machdep.c	kgdb
77file	arch/i386/i386/kobj_machdep.c	modular
78file	arch/i386/i386/machdep.c
79file 	arch/i386/i386/longrun.c
80file	arch/i386/i386/mtrr_k6.c	mtrr
81file	arch/i386/i386/process_machdep.c
82file	arch/i386/i386/trap.c
83file	dev/cons.c
84
85file	arch/i386/i386/mptramp.S	multiprocessor
86
87file	arch/i386/i386/pmc.c		perfctrs
88
89file	crypto/des/arch/i386/des_enc.S		des
90file	crypto/des/arch/i386/des_cbc.S		des
91
92file	crypto/blowfish/arch/i386/bf_enc.S	blowfish
93file	crypto/blowfish/arch/i386/bf_cbc.S	blowfish & !i386_cpu
94
95#
96# Stack-less Just-In-Time compiler
97#
98
99include	"external/bsd/sljit/conf/files.sljit"
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 with gcscpcib_pci
221file	arch/i386/pci/gcscpcib_pci.c	gcscpcib_pci
222file	dev/ic/gcscpcib.c		gcscpcib
223
224device	piixpcib: isabus, bioscall
225attach	piixpcib at pci
226file	arch/i386/pci/piixpcib.c	piixpcib
227
228device	viapcib: isabus, i2cbus
229attach	viapcib at pci
230file	arch/i386/pci/viapcib.c		viapcib
231
232# PCI-MCA bridges
233device	pcmb: mcabus
234attach	pcmb at pci
235file	arch/i386/pci/pcmb.c		pcmb
236
237device	p64h2apic
238attach	p64h2apic at pci
239file	arch/i386/pci/p64h2apic.c	p64h2apic
240
241
242#
243# ISA and mixed ISA+EISA or ISA+PCI drivers
244#
245
246include	"dev/isa/files.isa"
247
248# PC clock
249file	arch/x86/isa/clock.c		isa
250file	arch/x86/isa/rtc.c		isa
251
252# TSC support
253file	arch/x86/x86/tsc.c
254
255# Numeric Processing Extension; Math Co-processor
256device	npx
257file	arch/i386/isa/npx.c		npx needs-flag
258
259attach	npx at isa with npx_isa
260file	arch/i386/isa/npx_isa.c		npx_isa
261
262# PC Mice: Logitech-style and Microsoft-style
263device	lms: wsmousedev
264attach	lms at isa
265file	arch/i386/isa/lms.c		lms
266device	mms: wsmousedev
267attach	mms at isa
268file	arch/i386/isa/mms.c		mms
269
270include	"dev/pckbport/files.pckbport"
271
272device	sysbeep
273attach	sysbeep at pcppi
274
275# Floppy disk controller
276device	fdc {drive = -1}: isadma
277file	dev/isa/fd.c			fdc needs-flag
278
279attach	fdc at isa with fdc_isa
280file	dev/isa/fdc_isa.c		fdc_isa
281
282device	fd: disk
283attach	fd at fdc
284
285# Adaptec AHA-284x VL SCSI controllers
286# device declaration in sys/conf/files
287attach	ahc at isa with ahc_isa: ahc_aic77xx, smc93cx6
288file	arch/i386/isa/ahc_isa.c		ahc_isa
289
290#
291# EISA-only drivers
292#
293
294include	"dev/eisa/files.eisa"
295file	arch/i386/eisa/eisa_machdep.c	eisa
296
297#
298# MCA-only drivers
299#
300
301device	mca {[slot = -1]} : bioscall
302include	"dev/mca/files.mca"
303file	arch/i386/mca/mca_machdep.c	mca
304
305# ISA Plug 'n Play devices
306file	arch/i386/isa/isapnp_machdep.c	isapnp
307
308#
309# VME support
310#
311include	"dev/vme/files.vme"
312
313#
314# GPIB support
315#
316include "dev/gpib/files.gpib"
317
318#
319# CMOS RAM
320#
321defpseudo cmos
322file	arch/i386/isa/cmos.c		cmos needs-flag
323
324#
325# Other mainbus-attached devices
326#
327
328include "dev/apm/files.apm"
329
330#
331# Compatibility modules
332#
333
334# VM86 mode
335file	arch/i386/i386/vm86.c			vm86
336
337# Binary compatibility with previous NetBSD releases (COMPAT_XX)
338file	arch/i386/i386/compat_13_machdep.c	compat_13
339file	arch/i386/i386/compat_16_machdep.c	compat_16 | compat_ibcs2
340
341# SVR4 binary compatibility (COMPAT_SVR4)
342include	"compat/svr4/files.svr4"
343file	arch/i386/i386/svr4_machdep.c		compat_svr4
344file	arch/i386/i386/svr4_sigcode.S		compat_svr4
345file	arch/i386/i386/svr4_syscall.c		compat_svr4
346
347# iBCS-2 binary compatibility (COMPAT_IBCS2)
348include	"compat/ibcs2/files.ibcs2"
349file	arch/i386/i386/ibcs2_machdep.c		compat_ibcs2
350file	arch/i386/i386/ibcs2_sigcode.S		compat_ibcs2
351file	arch/i386/i386/ibcs2_syscall.c		compat_ibcs2
352
353# Linux binary compatibility (COMPAT_LINUX)
354include	"compat/linux/files.linux"
355include	"compat/linux/arch/i386/files.linux_i386"
356file	arch/i386/i386/linux_sigcode.S		compat_linux
357file	arch/i386/i386/linux_syscall.c		compat_linux
358file	arch/x86/x86/linux_trap.c		compat_linux
359
360# FreeBSD binary compatibility (COMPAT_FREEBSD)
361include	"compat/freebsd/files.freebsd"
362file	arch/i386/i386/freebsd_machdep.c	compat_freebsd
363file	arch/i386/i386/freebsd_sigcode.S	compat_freebsd
364file	arch/i386/i386/freebsd_syscall.c	compat_freebsd
365
366# NDIS compatibilty (COMPAT_NDIS)
367include "compat/ndis/files.ndis"
368
369# OSS audio driver compatibility
370include	"compat/ossaudio/files.ossaudio"
371
372#
373# CARDBUS
374#
375include	"dev/cardbus/files.cardbus"
376file	arch/i386/i386/rbus_machdep.c	cardbus
377
378# XXXX pcic here because it needs to be late.  The catch: pcic needs
379# to be late, so devices which attach to it are attached late.  But it
380# needs to be before its isa and pci attachments.  This answer is
381# non-optimal, but I don't have a better answer right now.
382
383# PCIC pcmcia controller
384# XXX this needs to be done very late, so it's done here.  This feels
385# like a kludge, but it might be for the best.
386
387defparam		PCIC_ISA_ALLOC_IOBASE
388defparam		PCIC_ISA_ALLOC_IOSIZE
389defparam		PCIC_ISA_INTR_ALLOC_MASK
390
391device	pcic: pcmciabus
392file	dev/ic/i82365.c			pcic
393
394# PCIC pcmcia controller on ISA bus.
395attach	pcic at isa with pcic_isa
396file	dev/isa/i82365_isa.c		pcic_isa
397
398# PCIC pcmcia controller on PCI bus.
399attach	pcic at pci with pcic_pci
400file	dev/pci/i82365_pci.c		pcic_pci
401
402# PCIC pcmcia controller on PnP board
403attach	pcic at isapnp with pcic_isapnp
404file	dev/isapnp/i82365_isapnp.c	pcic_isapnp
405
406# Code common to ISA and ISAPnP attachments
407file	dev/isa/i82365_isasubr.c	pcic_isa | pcic_isapnp | pcic_pci
408
409# XXXX tcic here because it needs to be late.  The catch: tcic needs
410# to be late, so devices which attach to it are attached late.  But it
411# needs to be before its isa and pci attachments.  This answer is
412# non-optimal, but I don't have a better answer right now.
413
414# TCIC pcmcia controller
415# XXX this needs to be done very late, so it's done here.  This feels
416# like a kludge, but it might be for the best.
417
418defparam		TCIC_ISA_ALLOC_IOBASE
419defparam		TCIC_ISA_ALLOC_IOSIZE
420defparam		TCIC_ISA_INTR_ALLOC_MASK
421
422device	tcic: pcmciabus
423file	dev/ic/tcic2.c			tcic
424
425# TCIC pcmcia controller
426attach	tcic at isa with tcic_isa
427file	dev/isa/tcic2_isa.c		tcic_isa
428
429# this wants to be probed as late as possible.
430#
431# Machine-independent PCMCIA drivers
432#
433include	"dev/pcmcia/files.pcmcia"
434
435
436include	"dev/usb/files.usb"
437
438include	"dev/bluetooth/files.bluetooth"
439
440include	"dev/sdmmc/files.sdmmc"
441
442include	"dev/ieee1394/files.ieee1394"
443
444include	"arch/i386/pnpbios/files.pnpbios"
445
446include "dev/acpi/files.acpi"
447file	arch/i386/acpi/acpi_wakeup_low.S	acpi
448
449# Numeric Processing Extension; Math Co-processor
450attach	npx at acpinodebus with npx_acpi
451file	arch/i386/acpi/npx_acpi.c		npx_acpi
452
453# Obsolete vesabios/vesafb flags
454obsolete	defflag	opt_vesabios.h	VESABIOSVERBOSE
455obsolete	defparam opt_vesafb.h	VESAFB_WIDTH VESAFB_HEIGHT VESAFB_DEPTH
456obsolete	defflag	opt_vesafb.h	VESAFB_PM
457
458# AMD Geode LX Security Block
459device	glxsb: opencrypto
460attach	glxsb at pci    
461file	arch/i386/pci/glxsb.c		glxsb
462
463include "arch/i386/conf/majors.i386"
464endif #xen
465