files.i386 revision 1.370
1#	$NetBSD: files.i386,v 1.370 2012/12/25 10:51:03 mbalmer 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# Protech PS3100 cash drawer
253device	ptcd: gpiobus
254attach	ptcd at isa
255file	dev/isa/ptcd.c			ptcd
256
257# TSC support
258file	arch/x86/x86/tsc.c
259
260# Numeric Processing Extension; Math Co-processor
261device	npx
262file	arch/i386/isa/npx.c		npx needs-flag
263
264attach	npx at isa with npx_isa
265file	arch/i386/isa/npx_isa.c		npx_isa
266
267# PC Mice: Logitech-style and Microsoft-style
268device	lms: wsmousedev
269attach	lms at isa
270file	arch/i386/isa/lms.c		lms
271device	mms: wsmousedev
272attach	mms at isa
273file	arch/i386/isa/mms.c		mms
274
275include	"dev/pckbport/files.pckbport"
276
277device	sysbeep
278attach	sysbeep at pcppi
279
280# Floppy disk controller
281device	fdc {drive = -1}: isadma
282file	dev/isa/fd.c			fdc needs-flag
283
284attach	fdc at isa with fdc_isa
285file	dev/isa/fdc_isa.c		fdc_isa
286
287device	fd: disk
288attach	fd at fdc
289
290# Adaptec AHA-284x VL SCSI controllers
291# device declaration in sys/conf/files
292attach	ahc at isa with ahc_isa: ahc_aic77xx, smc93cx6
293file	arch/i386/isa/ahc_isa.c		ahc_isa
294
295#
296# EISA-only drivers
297#
298
299include	"dev/eisa/files.eisa"
300file	arch/i386/eisa/eisa_machdep.c	eisa
301
302#
303# MCA-only drivers
304#
305
306device	mca {[slot = -1]} : bioscall
307include	"dev/mca/files.mca"
308file	arch/i386/mca/mca_machdep.c	mca
309
310# ISA Plug 'n Play devices
311file	arch/i386/isa/isapnp_machdep.c	isapnp
312
313#
314# VME support
315#
316include	"dev/vme/files.vme"
317
318#
319# GPIB support
320#
321include "dev/gpib/files.gpib"
322
323#
324# CMOS RAM
325#
326defpseudo cmos
327file	arch/i386/isa/cmos.c		cmos needs-flag
328
329#
330# Other mainbus-attached devices
331#
332
333include "dev/apm/files.apm"
334
335#
336# Compatibility modules
337#
338
339# VM86 mode
340file	arch/i386/i386/vm86.c			vm86
341
342# Binary compatibility with previous NetBSD releases (COMPAT_XX)
343file	arch/i386/i386/compat_13_machdep.c	compat_13
344file	arch/i386/i386/compat_16_machdep.c	compat_16 | compat_ibcs2
345
346# SVR4 binary compatibility (COMPAT_SVR4)
347include	"compat/svr4/files.svr4"
348file	arch/i386/i386/svr4_machdep.c		compat_svr4
349file	arch/i386/i386/svr4_sigcode.S		compat_svr4
350file	arch/i386/i386/svr4_syscall.c		compat_svr4
351
352# iBCS-2 binary compatibility (COMPAT_IBCS2)
353include	"compat/ibcs2/files.ibcs2"
354file	arch/i386/i386/ibcs2_machdep.c		compat_ibcs2
355file	arch/i386/i386/ibcs2_sigcode.S		compat_ibcs2
356file	arch/i386/i386/ibcs2_syscall.c		compat_ibcs2
357
358# Linux binary compatibility (COMPAT_LINUX)
359include	"compat/linux/files.linux"
360include	"compat/linux/arch/i386/files.linux_i386"
361file	arch/i386/i386/linux_sigcode.S		compat_linux
362file	arch/i386/i386/linux_syscall.c		compat_linux
363file	arch/x86/x86/linux_trap.c		compat_linux
364
365# FreeBSD binary compatibility (COMPAT_FREEBSD)
366include	"compat/freebsd/files.freebsd"
367file	arch/i386/i386/freebsd_machdep.c	compat_freebsd
368file	arch/i386/i386/freebsd_sigcode.S	compat_freebsd
369file	arch/i386/i386/freebsd_syscall.c	compat_freebsd
370
371# NDIS compatibilty (COMPAT_NDIS)
372include "compat/ndis/files.ndis"
373
374# OSS audio driver compatibility
375include	"compat/ossaudio/files.ossaudio"
376
377#
378# CARDBUS
379#
380include	"dev/cardbus/files.cardbus"
381file	arch/i386/i386/rbus_machdep.c	cardbus
382
383# XXXX pcic here because it needs to be late.  The catch: pcic needs
384# to be late, so devices which attach to it are attached late.  But it
385# needs to be before its isa and pci attachments.  This answer is
386# non-optimal, but I don't have a better answer right now.
387
388# PCIC pcmcia controller
389# XXX this needs to be done very late, so it's done here.  This feels
390# like a kludge, but it might be for the best.
391
392defparam		PCIC_ISA_ALLOC_IOBASE
393defparam		PCIC_ISA_ALLOC_IOSIZE
394defparam		PCIC_ISA_INTR_ALLOC_MASK
395
396device	pcic: pcmciabus
397file	dev/ic/i82365.c			pcic
398
399# PCIC pcmcia controller on ISA bus.
400attach	pcic at isa with pcic_isa
401file	dev/isa/i82365_isa.c		pcic_isa
402
403# PCIC pcmcia controller on PCI bus.
404attach	pcic at pci with pcic_pci
405file	dev/pci/i82365_pci.c		pcic_pci
406
407# PCIC pcmcia controller on PnP board
408attach	pcic at isapnp with pcic_isapnp
409file	dev/isapnp/i82365_isapnp.c	pcic_isapnp
410
411# Code common to ISA and ISAPnP attachments
412file	dev/isa/i82365_isasubr.c	pcic_isa | pcic_isapnp | pcic_pci
413
414# XXXX tcic here because it needs to be late.  The catch: tcic needs
415# to be late, so devices which attach to it are attached late.  But it
416# needs to be before its isa and pci attachments.  This answer is
417# non-optimal, but I don't have a better answer right now.
418
419# TCIC pcmcia controller
420# XXX this needs to be done very late, so it's done here.  This feels
421# like a kludge, but it might be for the best.
422
423defparam		TCIC_ISA_ALLOC_IOBASE
424defparam		TCIC_ISA_ALLOC_IOSIZE
425defparam		TCIC_ISA_INTR_ALLOC_MASK
426
427device	tcic: pcmciabus
428file	dev/ic/tcic2.c			tcic
429
430# TCIC pcmcia controller
431attach	tcic at isa with tcic_isa
432file	dev/isa/tcic2_isa.c		tcic_isa
433
434# this wants to be probed as late as possible.
435#
436# Machine-independent PCMCIA drivers
437#
438include	"dev/pcmcia/files.pcmcia"
439
440
441include	"dev/usb/files.usb"
442
443include	"dev/bluetooth/files.bluetooth"
444
445include	"dev/sdmmc/files.sdmmc"
446
447include	"dev/ieee1394/files.ieee1394"
448
449include	"arch/i386/pnpbios/files.pnpbios"
450
451include "dev/acpi/files.acpi"
452file	arch/i386/acpi/acpi_wakeup_low.S	acpi
453
454# Numeric Processing Extension; Math Co-processor
455attach	npx at acpinodebus with npx_acpi
456file	arch/i386/acpi/npx_acpi.c		npx_acpi
457
458# Obsolete vesabios/vesafb flags
459obsolete	defflag	opt_vesabios.h	VESABIOSVERBOSE
460obsolete	defparam opt_vesafb.h	VESAFB_WIDTH VESAFB_HEIGHT VESAFB_DEPTH
461obsolete	defflag	opt_vesafb.h	VESAFB_PM
462
463# AMD Geode LX Security Block
464device	glxsb: opencrypto
465attach	glxsb at pci
466file	arch/i386/pci/glxsb.c		glxsb
467
468include "arch/i386/conf/majors.i386"
469endif #xen
470