files.i386 revision 1.366
1#	$NetBSD: files.i386,v 1.366 2012/09/30 20:19:51 dsl 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
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
62file	arch/i386/i386/autoconf.c
63file	arch/i386/i386/aout_machdep.c	exec_aout
64file	arch/i386/i386/busfunc.S
65file	arch/i386/i386/cpufunc.S
66file	arch/i386/i386/cpu_in_cksum.S	(inet | inet6) & cpu_in_cksum
67file	arch/i386/i386/db_dbgreg.S	ddb | kstack_check_dr0
68file	arch/i386/i386/db_disasm.c	ddb
69file	arch/i386/i386/db_interface.c	ddb
70file	arch/i386/i386/db_machdep.c	ddb
71file	arch/i386/i386/dumpsys.c
72file	kern/subr_disk_mbr.c		disk
73file	kern/subr_spldebug.c		spldebug
74file	arch/i386/i386/gdt.c
75file	arch/i386/i386/i386func.S
76file	arch/i386/i386/ipkdb_glue.c	ipkdb
77file	arch/i386/i386/kgdb_machdep.c	kgdb
78file	arch/i386/i386/kobj_machdep.c	modular
79file	arch/i386/i386/machdep.c
80file 	arch/i386/i386/longrun.c
81file	arch/i386/i386/mtrr_k6.c	mtrr
82file	arch/i386/i386/process_machdep.c
83file	arch/i386/i386/trap.c
84file	dev/cons.c
85
86file	arch/i386/i386/mptramp.S	multiprocessor
87
88file	arch/i386/i386/pmc.c		perfctrs
89
90file	crypto/des/arch/i386/des_enc.S		des
91file	crypto/des/arch/i386/des_cbc.S		des
92
93file	crypto/blowfish/arch/i386/bf_enc.S	blowfish
94file	crypto/blowfish/arch/i386/bf_cbc.S	blowfish & !i386_cpu
95
96#
97# Machine-independent SCSI drivers
98#
99
100include	"dev/scsipi/files.scsipi"
101
102#
103# Machine-independent ATA drivers
104#
105
106include	"dev/ata/files.ata"
107
108# Memory Disk for install floppy
109file	dev/md_root.c			memory_disk_hooks & md
110
111#
112# Machine-independent I2O drivers
113#
114
115include	"dev/i2o/files.i2o"
116
117# attribute used to bring in BIOS trampoline code for real-mode probing
118# of certain devices/BIOS features
119define	bioscall
120file	arch/i386/i386/bioscall.S	bioscall needs-flag
121
122# BIOS32 routines
123define	bios32
124file	arch/i386/i386/bios32.c		bios32 needs-flag
125
126# i386 specific mainbus attributes
127define	apmbus {}
128define	pnpbiosbus {}
129
130#
131# System bus types
132#
133
134# XXX BIOS32 only if something that uses it is configured!
135device	mainbus: isabus, eisabus, mcabus, pcibus, bios32, acpibus,
136	cpubus, ioapicbus, apmbus, pnpbiosbus, ipmibus,
137	bioscall
138attach	mainbus at root
139file	arch/i386/i386/mainbus.c	mainbus
140
141#
142# PCI-only drivers
143# XXX MUST BE INCLUDED BEFORE files.isa, as long as files.isa attaches
144# XXX devices to 'pci'.
145#
146include	"dev/pci/files.pci"
147include "dev/pci/files.agp"
148file	arch/i386/pci/pcibios.c		pcibios
149file	arch/i386/pci/pci_intr_fixup.c	pcibios & pci_intr_fixup
150file	arch/i386/pci/piix.c		pcibios & pci_intr_fixup
151file	arch/i386/pci/opti82c558.c	pcibios & pci_intr_fixup
152file	arch/i386/pci/opti82c700.c	pcibios & pci_intr_fixup
153file	arch/i386/pci/sis85c503.c	pcibios & pci_intr_fixup
154file	arch/i386/pci/via82c586.c	pcibios & pci_intr_fixup
155file	arch/i386/pci/via8231.c		pcibios & pci_intr_fixup
156file	arch/i386/pci/amd756.c		pcibios & pci_intr_fixup
157file	arch/i386/pci/ali1543.c		pcibios & pci_intr_fixup
158defparam		PCI_CONF_MODE
159file	arch/i386/pci/pcic_pci_machdep.c	pcic_pci
160
161# x86 specific PCI hardware
162include "arch/x86/pci/files.pci"
163
164# AMD Elan SC520 System Controller (PCI-Host bridge)
165define elanparbus { }
166define elanpexbus { }
167device	elansc: sysmon_wdog, gpiobus, elanparbus, elanpexbus, pcibus
168attach	elansc at pcibus
169
170file	arch/i386/pci/elan520.c		elansc
171
172device elanpar
173attach elanpar at elanparbus
174
175device elanpex
176attach elanpex at elanpexbus
177
178# AMD Geode CS5535 Companion IDE controller
179device	gcscide: ata, ata_dma, ata_udma, pciide_common, wdc_common
180attach	gcscide at pci
181file	arch/i386/pci/gcscide.c 	gcscide
182
183# AMD Geode CS5536 Companion EHCI
184device	gcscehci: usbus
185attach	gcscehci at pci
186file	arch/i386/pci/gcscehci.c	gcscehci
187
188# AMD Geode SC1100 GCB area
189device  geodegcb {}
190attach	geodegcb at pci
191file	arch/i386/pci/geode.c		geodegcb
192
193# AMD Geode SC1100 Watchdog Timer
194device	geodewdog: sysmon_wdog, geodegcb
195attach	geodewdog at geodegcb
196file	arch/i386/pci/geodewdg.c	geodewdog
197
198# AMD Geode SC1100 high resolution counter
199device	geodecntr: geodegcb
200attach  geodecntr at geodegcb
201file	arch/i386/pci/geodecntr.c	geodecntr
202
203# PCI-EISA bridges
204device	pceb: eisabus, isabus
205attach	pceb at pci
206file	arch/i386/pci/pceb.c		pceb
207
208# PCI-ISA bridges
209device	gscpcib: isabus, gpiobus
210attach	gscpcib at pci
211file	arch/i386/pci/gscpcib.c		gscpcib
212
213# AMD Geode CS5535/CS5536 PCI-ISA bridge
214device	gcscpcib: isabus, sysmon_wdog, gpiobus
215attach	gcscpcib at pci with gcscpcib_pci
216file	arch/i386/pci/gcscpcib_pci.c	gcscpcib_pci
217file	dev/ic/gcscpcib.c		gcscpcib
218
219device	piixpcib: isabus, bioscall
220attach	piixpcib at pci
221file	arch/i386/pci/piixpcib.c	piixpcib
222
223device	viapcib: isabus, i2cbus
224attach	viapcib at pci
225file	arch/i386/pci/viapcib.c		viapcib
226
227# PCI-MCA bridges
228device	pcmb: mcabus
229attach	pcmb at pci
230file	arch/i386/pci/pcmb.c		pcmb
231
232device	p64h2apic
233attach	p64h2apic at pci
234file	arch/i386/pci/p64h2apic.c	p64h2apic
235
236
237#
238# ISA and mixed ISA+EISA or ISA+PCI drivers
239#
240
241include	"dev/isa/files.isa"
242
243# PC clock
244file	arch/x86/isa/clock.c		isa
245file	arch/x86/isa/rtc.c		isa
246
247# TSC support
248file	arch/x86/x86/tsc.c
249
250# Numeric Processing Extension; Math Co-processor
251device	npx
252file	arch/i386/isa/npx.c		npx needs-flag
253
254attach	npx at isa with npx_isa
255file	arch/i386/isa/npx_isa.c		npx_isa
256
257# PC Mice: Logitech-style and Microsoft-style
258device	lms: wsmousedev
259attach	lms at isa
260file	arch/i386/isa/lms.c		lms
261device	mms: wsmousedev
262attach	mms at isa
263file	arch/i386/isa/mms.c		mms
264
265include	"dev/pckbport/files.pckbport"
266
267device	sysbeep
268attach	sysbeep at pcppi
269
270# Floppy disk controller
271device	fdc {drive = -1}: isadma
272file	dev/isa/fd.c			fdc needs-flag
273
274attach	fdc at isa with fdc_isa
275file	dev/isa/fdc_isa.c		fdc_isa
276
277device	fd: disk
278attach	fd at fdc
279
280# Adaptec AHA-284x VL SCSI controllers
281# device declaration in sys/conf/files
282attach	ahc at isa with ahc_isa: ahc_aic77xx, smc93cx6
283file	arch/i386/isa/ahc_isa.c		ahc_isa
284
285#
286# EISA-only drivers
287#
288
289include	"dev/eisa/files.eisa"
290file	arch/i386/eisa/eisa_machdep.c	eisa
291
292#
293# MCA-only drivers
294#
295
296device	mca {[slot = -1]} : bioscall
297include	"dev/mca/files.mca"
298file	arch/i386/mca/mca_machdep.c	mca
299
300# ISA Plug 'n Play devices
301file	arch/i386/isa/isapnp_machdep.c	isapnp
302
303#
304# VME support
305#
306include	"dev/vme/files.vme"
307
308#
309# GPIB support
310#
311include "dev/gpib/files.gpib"
312
313#
314# CMOS RAM
315#
316defpseudo cmos
317file	arch/i386/isa/cmos.c		cmos needs-flag
318
319#
320# Other mainbus-attached devices
321#
322
323include "dev/apm/files.apm"
324
325#
326# Compatibility modules
327#
328
329# VM86 mode
330file	arch/i386/i386/vm86.c			vm86
331
332# VM86 in kernel
333file	arch/i386/i386/kvm86.c			kvm86
334file	arch/i386/i386/kvm86call.S		kvm86
335
336# Binary compatibility with previous NetBSD releases (COMPAT_XX)
337file	arch/i386/i386/compat_13_machdep.c	compat_13
338file	arch/i386/i386/compat_16_machdep.c	compat_16 | compat_ibcs2
339
340# SVR4 binary compatibility (COMPAT_SVR4)
341include	"compat/svr4/files.svr4"
342file	arch/i386/i386/svr4_machdep.c		compat_svr4
343file	arch/i386/i386/svr4_sigcode.S		compat_svr4
344file	arch/i386/i386/svr4_syscall.c		compat_svr4
345
346# iBCS-2 binary compatibility (COMPAT_IBCS2)
347include	"compat/ibcs2/files.ibcs2"
348file	arch/i386/i386/ibcs2_machdep.c		compat_ibcs2
349file	arch/i386/i386/ibcs2_sigcode.S		compat_ibcs2
350file	arch/i386/i386/ibcs2_syscall.c		compat_ibcs2
351
352# Linux binary compatibility (COMPAT_LINUX)
353include	"compat/linux/files.linux"
354include	"compat/linux/arch/i386/files.linux_i386"
355file	arch/i386/i386/linux_sigcode.S		compat_linux
356file	arch/i386/i386/linux_syscall.c		compat_linux
357file	arch/x86/x86/linux_trap.c		compat_linux
358
359# FreeBSD binary compatibility (COMPAT_FREEBSD)
360include	"compat/freebsd/files.freebsd"
361file	arch/i386/i386/freebsd_machdep.c	compat_freebsd
362file	arch/i386/i386/freebsd_sigcode.S	compat_freebsd
363file	arch/i386/i386/freebsd_syscall.c	compat_freebsd
364
365# NDIS compatibilty (COMPAT_NDIS)
366include "compat/ndis/files.ndis"
367
368# OSS audio driver compatibility
369include	"compat/ossaudio/files.ossaudio"
370
371#
372# CARDBUS
373#
374include	"dev/cardbus/files.cardbus"
375file	arch/i386/i386/rbus_machdep.c	cardbus
376
377# XXXX pcic here because it needs to be late.  The catch: pcic needs
378# to be late, so devices which attach to it are attached late.  But it
379# needs to be before its isa and pci attachments.  This answer is
380# non-optimal, but I don't have a better answer right now.
381
382# PCIC pcmcia controller
383# XXX this needs to be done very late, so it's done here.  This feels
384# like a kludge, but it might be for the best.
385
386defparam		PCIC_ISA_ALLOC_IOBASE
387defparam		PCIC_ISA_ALLOC_IOSIZE
388defparam		PCIC_ISA_INTR_ALLOC_MASK
389
390device	pcic: pcmciabus
391file	dev/ic/i82365.c			pcic
392
393# PCIC pcmcia controller on ISA bus.
394attach	pcic at isa with pcic_isa
395file	dev/isa/i82365_isa.c		pcic_isa
396
397# PCIC pcmcia controller on PCI bus.
398attach	pcic at pci with pcic_pci
399file	dev/pci/i82365_pci.c		pcic_pci
400
401# PCIC pcmcia controller on PnP board
402attach	pcic at isapnp with pcic_isapnp
403file	dev/isapnp/i82365_isapnp.c	pcic_isapnp
404
405# Code common to ISA and ISAPnP attachments
406file	dev/isa/i82365_isasubr.c	pcic_isa | pcic_isapnp | pcic_pci
407
408# XXXX tcic here because it needs to be late.  The catch: tcic needs
409# to be late, so devices which attach to it are attached late.  But it
410# needs to be before its isa and pci attachments.  This answer is
411# non-optimal, but I don't have a better answer right now.
412
413# TCIC pcmcia controller
414# XXX this needs to be done very late, so it's done here.  This feels
415# like a kludge, but it might be for the best.
416
417defparam		TCIC_ISA_ALLOC_IOBASE
418defparam		TCIC_ISA_ALLOC_IOSIZE
419defparam		TCIC_ISA_INTR_ALLOC_MASK
420
421device	tcic: pcmciabus
422file	dev/ic/tcic2.c			tcic
423
424# TCIC pcmcia controller
425attach	tcic at isa with tcic_isa
426file	dev/isa/tcic2_isa.c		tcic_isa
427
428# this wants to be probed as late as possible.
429#
430# Machine-independent PCMCIA drivers
431#
432include	"dev/pcmcia/files.pcmcia"
433
434
435include	"dev/usb/files.usb"
436
437include	"dev/bluetooth/files.bluetooth"
438
439include	"dev/sdmmc/files.sdmmc"
440
441include	"dev/ieee1394/files.ieee1394"
442
443include	"arch/i386/pnpbios/files.pnpbios"
444
445include "dev/acpi/files.acpi"
446file	arch/i386/acpi/acpi_wakeup_low.S	acpi
447
448# Numeric Processing Extension; Math Co-processor
449attach	npx at acpinodebus with npx_acpi
450file	arch/i386/acpi/npx_acpi.c		npx_acpi
451
452# Obsolete vesabios/vesafb flags
453obsolete	defflag	opt_vesabios.h	VESABIOSVERBOSE
454obsolete	defparam opt_vesafb.h	VESAFB_WIDTH VESAFB_HEIGHT VESAFB_DEPTH
455obsolete	defflag	opt_vesafb.h	VESAFB_PM
456
457# AMD Geode LX Security Block
458device	glxsb: opencrypto
459attach	glxsb at pci    
460file	arch/i386/pci/glxsb.c		glxsb
461
462include "arch/i386/conf/majors.i386"
463endif #xen
464