files.i386 revision 1.272
1#	$NetBSD: files.i386,v 1.272 2005/10/07 15:59:49 riz 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
11# APM options
12defflag	opt_apm.h	APM_DISABLE APM_FORCE_64K_SEGMENTS APM_NO_IDLE
13			APM_NO_STANDBY APM_V10_ONLY APM_NO_V12 APMDEBUG
14			APM_POWER_PRINT APM_ALLOW_BOGUS_SEGMENTS
15			APM_USE_KVM86
16defparam opt_apm.h	APMDEBUG_VALUE APM_DISABLE_INTERRUPTS
17
18# Processor type options.
19defflag	opt_cputype.h	I386_CPU I486_CPU I586_CPU I686_CPU
20
21# delay before cpu_reset() for reboot.
22defparam		CPURESET_DELAY
23
24# VM86 emulation
25defflag			VM86
26defflag			KVM86
27
28# Floating point emulation
29defflag			MATH_EMULATE
30
31# User-settable LDT (used by WINE)
32defflag			USER_LDT
33
34# X server support in console drivers
35defflag	opt_xserver.h	XSERVER XSERVER_DDB
36
37# The REAL{BASE,EXT}MEM options
38defparam opt_realmem.h	REALBASEMEM REALEXTMEM
39
40# understand boot device passed by pre-1.3 bootblocks
41defflag			COMPAT_OLDBOOT
42
43# PCI BIOS options
44defflag	opt_pcibios.h	PCIBIOS PCIBIOSVERBOSE
45			PCIBIOS_INTR_GUESS PCIINTR_DEBUG
46defparam opt_pcibios.h	PCIBIOS_IRQS_HINT
47
48# Large page size
49defflag			LARGEPAGES
50
51# No unmapped page below kernel stack
52defflag			NOREDZONE
53
54# kernel stack debug
55defflag	opt_kstack_dr0.h		KSTACK_CHECK_DR0
56
57# Beep on halt
58defflag opt_beep.h		BEEP_ONHALT
59defparam opt_beep.h		BEEP_ONHALT_COUNT
60defparam opt_beep.h		BEEP_ONHALT_PITCH BEEP_ONHALT_PERIOD
61
62# Enhanced SpeedStep
63defflag			ENHANCED_SPEEDSTEP
64
65file	arch/i386/i386/autoconf.c
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_memrw.c	ddb | kgdb
70file	arch/i386/i386/db_trace.c	ddb
71file	kern/subr_disk_mbr.c		disk
72file	arch/i386/i386/gdt.c
73file	arch/i386/i386/in_cksum.S	inet | inet6
74file	arch/i386/i386/ipkdb_glue.c	ipkdb
75file	arch/i386/i386/kgdb_machdep.c	kgdb
76file	arch/i386/i386/machdep.c
77file	arch/i386/i386/identcpu.c
78file	arch/i386/i386/math_emulate.c	math_emulate
79file	arch/i386/i386/mem.c
80file	kern/kern_microtime.c		i586_cpu | i686_cpu
81file	arch/i386/i386/mtrr_k6.c	mtrr
82file	netns/ns_cksum.c		ns
83file	arch/i386/i386/pmap.c
84file	arch/i386/i386/process_machdep.c
85file	arch/i386/i386/procfs_machdep.c	procfs
86file	arch/i386/i386/sys_machdep.c
87file	arch/i386/i386/syscall.c
88file	arch/i386/i386/trap.c
89file	arch/i386/i386/vm_machdep.c
90file	dev/cons.c
91
92file	arch/i386/i386/mptramp.S  	multiprocessor
93file    arch/i386/i386/ipifuncs.c       multiprocessor
94
95file	arch/i386/i386/pmc.c		perfctrs
96
97file	crypto/des/arch/i386/des_enc.S		des
98file	crypto/des/arch/i386/des_cbc.S		des
99
100file	crypto/blowfish/arch/i386/bf_enc.S	blowfish
101file	crypto/blowfish/arch/i386/bf_cbc.S	blowfish & !i386_cpu
102
103#
104# Machine-independent SCSI drivers
105#
106
107include	"dev/scsipi/files.scsipi"
108
109#
110# Machine-independent ATA drivers
111#
112
113include	"dev/ata/files.ata"
114
115# Memory Disk for install floppy
116file	dev/md_root.c			memory_disk_hooks
117
118#
119# Machine-independent I2O drivers
120#
121
122include	"dev/i2o/files.i2o"
123
124# attribute used to bring in BIOS trampoline code for real-mode probing
125# of certain devices/BIOS features
126define	bioscall
127file	arch/i386/i386/bioscall.S	bioscall needs-flag
128
129# BIOS32 routines
130define	bios32
131file	arch/i386/i386/bios32.c		bios32 needs-flag
132
133# i386 specific mainbus attributes
134define apmbus {}
135define pnpbiosbus {}
136define vesabiosbus {}
137
138#
139# System bus types
140#
141
142# XXX BIOS32 only if something that uses it is configured!
143device	mainbus: isabus, eisabus, mcabus, pcibus, bios32, acpibus,
144	cpubus, apmbus, pnpbiosbus, vesabiosbus
145attach	mainbus at root
146file	arch/i386/i386/mainbus.c	mainbus
147
148#
149# PCI-only drivers
150# XXX MUST BE INCLUDED BEFORE files.isa, as long as files.isa attaches
151# XXX devices to 'pci'.
152#
153
154include	"dev/pci/files.pci"
155include "dev/pci/files.agp"
156file 	arch/i386/pci/agp_machdep.c	agp
157file	arch/i386/pci/pcibios.c		pcibios
158file	arch/i386/pci/pci_intr_fixup.c	pcibios & pci_intr_fixup
159file	arch/i386/pci/piix.c		pcibios & pci_intr_fixup
160file	arch/i386/pci/opti82c558.c	pcibios & pci_intr_fixup
161file	arch/i386/pci/opti82c700.c	pcibios & pci_intr_fixup
162file	arch/i386/pci/sis85c503.c	pcibios & pci_intr_fixup
163file	arch/i386/pci/via82c586.c	pcibios & pci_intr_fixup
164file	arch/i386/pci/amd756.c		pcibios & pci_intr_fixup
165file	arch/i386/pci/ali1543.c		pcibios & pci_intr_fixup
166file	arch/i386/pci/pci_bus_fixup.c	pci_bus_fixup
167file	arch/i386/pci/pci_addr_fixup.c	pci_addr_fixup
168defparam		PCI_CONF_MODE
169file	arch/i386/pci/pcic_pci_machdep.c	pcic_pci
170
171device 	aapic
172attach 	aapic at pci
173file 	arch/x86/pci/aapic.c			aapic
174
175# PCI-Host bridge chipsets
176device	pchb: pcibus, agpbus, agp_ali, agp_amd, agp_i810, agp_intel, agp_sis,
177	      agp_via
178attach	pchb at pci
179file	arch/i386/pci/pchb.c		pchb			needs-flag
180file	arch/i386/pci/pchb_rnd.c	pchb & rnd
181
182# AMD Elan SC520 System Controller (PCI-Host bridge)
183device	elansc: sysmon_wdog, gpiobus
184attach	elansc at pci
185file	arch/i386/pci/elan520.c		elansc
186
187# AMD Geode SC1100 Watchdog Timer
188device	geodewdog: sysmon_wdog
189attach	geodewdog at pci
190file	arch/i386/pci/geode.c		geodewdog
191
192# PCI-EISA bridges
193device	pceb: eisabus, isabus
194attach	pceb at pci
195file	arch/i386/pci/pceb.c		pceb
196
197# PCI-ISA bridges
198device	pcib: isabus
199attach	pcib at pci
200file	arch/i386/pci/pcib.c		pcib | ichlpcib | gscpcib
201
202# PCI-LPC bridges
203device	ichlpcib: isabus, sysmon_wdog
204attach	ichlpcib at pci
205file	arch/i386/pci/ichlpcib.c	ichlpcib
206
207device	gscpcib: isabus, gpiobus
208attach	gscpcib at pci
209file	arch/i386/pci/gscpcib.c		gscpcib
210
211# PCI-MCA bridges
212device	pcmb: mcabus
213attach	pcmb at pci
214file	arch/i386/pci/pcmb.c		pcmb
215
216device	p64h2apic
217attach	p64h2apic at pci
218file	arch/i386/pci/p64h2apic.c	p64h2apic
219
220
221#
222# ISA and mixed ISA+EISA or ISA+PCI drivers
223#
224
225include	"dev/isa/files.isa"
226
227# PC clock
228file	arch/i386/isa/clock.c		isa
229
230# Numeric Processing Extension; Math Co-processor
231device	npx
232file	arch/i386/isa/npx.c		npx needs-flag
233
234attach	npx at isa with npx_isa
235file	arch/i386/isa/npx_isa.c		npx_isa
236
237# PC console support a la "pccons"
238device	pc: tty
239attach	pc at isa
240device	pcconskbd: pckbport_machdep_cnattach
241attach	pcconskbd at pckbport
242file	arch/i386/isa/pccons.c		pc | pcconskbd needs-flag
243
244# PC Mice: Logitech-style and Microsoft-style
245device	lms: wsmousedev
246attach	lms at isa
247file	arch/i386/isa/lms.c		lms
248device	mms: wsmousedev
249attach	mms at isa
250file	arch/i386/isa/mms.c		mms
251
252include	"dev/wscons/files.wscons"
253include	"dev/wsfont/files.wsfont"
254
255include	"dev/pckbport/files.pckbport"
256
257device	sysbeep
258attach	sysbeep at pcppi
259
260# Floppy disk controller
261device	fdc {drive = -1}: isadma
262file	dev/isa/fd.c			fdc needs-flag
263
264attach	fdc at isa with fdc_isa
265file	dev/isa/fdc_isa.c		fdc_isa
266
267device	fd: disk
268attach	fd at fdc
269
270# Adaptec AHA-284x VL SCSI controllers
271# device declaration in sys/conf/files
272attach	ahc at isa with ahc_isa: ahc_aic77xx, smc93cx6
273file	arch/i386/isa/ahc_isa.c		ahc_isa
274
275#
276# EISA-only drivers
277#
278
279include	"dev/eisa/files.eisa"
280file	arch/i386/eisa/eisa_machdep.c	eisa
281
282#
283# MCA-only drivers
284#
285
286device	mca {[slot = -1]} : bioscall
287include	"dev/mca/files.mca"
288file	arch/i386/mca/mca_machdep.c	mca
289
290# ISA Plug 'n Play devices
291file	arch/i386/isa/isapnp_machdep.c	isapnp
292
293#
294# VME support
295#
296include	"dev/vme/files.vme"
297
298#
299# GPIB support
300#
301include "dev/gpib/files.gpib"
302
303#
304# Other mainbus-attached devices
305#
306
307# Advanced Power Management support (APM)
308device	apm: bioscall
309attach	apm at apmbus
310file	arch/i386/i386/apm.c		apm needs-count
311file	arch/i386/i386/apmcall.S	apm
312
313# CPUS
314
315device cpu
316attach cpu at cpubus
317file	arch/i386/i386/cpu.c		cpu
318
319#
320# Compatibility modules
321#
322
323# VM86 mode
324file	arch/i386/i386/vm86.c			vm86
325
326# VM86 in kernel
327file	arch/i386/i386/kvm86.c			kvm86
328file	arch/i386/i386/kvm86call.S		kvm86
329
330# Binary compatibility with previous NetBSD releases (COMPAT_XX)
331file	arch/i386/i386/compat_13_machdep.c	compat_13 | compat_aout
332file	arch/i386/i386/compat_16_machdep.c	compat_16 | compat_ibcs2
333
334# SVR4 binary compatibility (COMPAT_SVR4)
335include	"compat/svr4/files.svr4"
336file	arch/i386/i386/svr4_machdep.c		compat_svr4
337file	arch/i386/i386/svr4_sigcode.S		compat_svr4
338file	arch/i386/i386/svr4_syscall.c		compat_svr4
339
340# MACH binary compatibility (COMPAT_MACH)
341include	"compat/mach/files.mach"
342file	arch/i386/i386/mach_machdep.c		compat_mach | compat_darwin
343file	arch/i386/i386/mach_sigcode.S		compat_mach | compat_darwin
344file	arch/i386/i386/mach_syscall.c		compat_mach | compat_darwin
345file	arch/i386/i386/darwin_commpage_machdep.S compat_darwin
346file	arch/i386/i386/macho_machdep.c		exec_macho
347
348# DARWIN binary compatibility (COMPAT_DARWIN)
349include	"compat/darwin/files.darwin"
350file	arch/i386/i386/darwin_machdep.c		compat_darwin
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# Win32 binary compatibility (COMPAT_PECOFF)
372include	"compat/pecoff/files.pecoff"
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/ieee1394/files.ieee1394"
444
445include	"arch/i386/pnpbios/files.pnpbios"
446
447include "dev/acpi/files.acpi"
448file	arch/i386/acpi/acpi_wakeup.c	acpi
449
450# Toshiba VALD 
451device	vald
452attach	vald at acpi with vald_acpi
453file	arch/i386/acpi/vald_acpi.c		vald_acpi
454
455# Sony SPIC (jog dial etc.)
456attach	spic at acpi with spic_acpi
457file	arch/i386/acpi/spic_acpi.c		spic_acpi
458
459# Numeric Processing Extension; Math Co-processor
460attach	npx at acpi with npx_acpi
461file	arch/i386/acpi/npx_acpi.c		npx_acpi
462
463device	vesabios {}
464attach vesabios at vesabiosbus
465file	arch/i386/bios/vesabios.c		vesabios needs-flag
466defflag	opt_vesabios.h	VESABIOSVERBOSE
467
468include	"dev/rasops/files.rasops"
469
470device vesarasterviii: rasops8
471attach vesarasterviii at vesabios
472file	arch/i386/bios/vesa_raster8.c	vesarasterviii
473
474device vesatext
475attach vesatext at vesabios
476file	arch/i386/bios/vesa_text.c	vesatext
477
478# Enhanced SpeedStep
479file	arch/i386/i386/est.c		enhanced_speedstep
480defflag	opt_est.h	EST_FREQ_USERWRITE
481
482# Atheros 5210/5211/5212 Hardware Abstraction Layer (HAL)
483object	/athhal-i386-elf.hal.o	ath
484
485include "arch/i386/conf/majors.i386"
486