xref: /netbsd-src/sys/arch/i386/conf/files.i386 (revision c38e7cc395b1472a774ff828e46123de44c628e9)
1#	$NetBSD: files.i386,v 1.392 2018/04/07 19:38:06 mrg 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
21defflag			PMC
22defflag			KASLR
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# PCI BIOS options
37defflag	opt_pcibios.h	PCIBIOS PCIBIOSVERBOSE
38			PCIBIOS_INTR_GUESS PCIINTR_DEBUG
39defparam opt_pcibios.h	PCIBIOS_IRQS_HINT
40
41# splraise()/spllower() debug
42defflag	opt_spldebug.h			SPLDEBUG
43
44# Enable GCC spectre V2 mitigation options
45defflag opt_spectre.h	SPECTRE_V2_GCC_MITIGATION
46
47# Beep on halt
48defflag 	opt_beep.h		BEEP_ONHALT
49defparam 	opt_beep.h		BEEP_ONHALT_COUNT=3
50defparam 	opt_beep.h		BEEP_ONHALT_PITCH=1500
51defparam 	opt_beep.h		BEEP_ONHALT_PERIOD=250
52
53# Multiboot support
54defflag 	opt_multiboot.h		MULTIBOOT
55obsolete 	defparam		MULTIBOOT_SYMTAB_SPACE
56file 	arch/i386/i386/multiboot.c	multiboot
57
58file	arch/i386/i386/autoconf.c
59file	arch/i386/i386/aout_machdep.c	exec_aout
60file	arch/i386/i386/busfunc.S
61file	arch/i386/i386/cpufunc.S
62file	arch/i386/i386/cpu_in_cksum.S	(inet | inet6) & cpu_in_cksum
63file	arch/i386/i386/db_disasm.c	ddb
64file	arch/i386/i386/db_interface.c	ddb
65file	arch/i386/i386/db_machdep.c	ddb
66file	arch/i386/i386/dumpsys.c
67file	kern/subr_disk_mbr.c		disk
68file	kern/subr_spldebug.c		spldebug
69file	arch/i386/i386/gdt.c
70file	arch/i386/i386/i386func.S
71file	arch/i386/i386/kobj_machdep.c	modular
72file	arch/i386/i386/machdep.c
73file 	arch/i386/i386/longrun.c
74file	arch/i386/i386/mtrr_k6.c	mtrr
75file	arch/i386/i386/process_machdep.c
76file	arch/x86/x86/convert_xmm_s87.c
77file	arch/i386/i386/trap.c
78file	dev/cons.c
79file	arch/x86/x86/fpu.c
80file	arch/x86/x86/dbregs.c
81
82file	arch/i386/i386/mptramp.S	multiprocessor
83
84file	crypto/des/arch/i386/des_enc.S		des
85file	crypto/des/arch/i386/des_cbc.S		des
86
87file	crypto/blowfish/arch/i386/bf_enc.S	blowfish
88file	crypto/blowfish/arch/i386/bf_cbc.S	blowfish & !i386_cpu
89
90#
91# Stack-less Just-In-Time compiler
92#
93
94include	"external/bsd/sljit/conf/files.sljit"
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# i386 specific mainbus attributes
123define	apmbus {}
124define	pnpbiosbus {}
125
126#
127# System bus types
128#
129
130# XXX BIOS32 only if something that uses it is configured!
131device	mainbus: isabus, eisabus, mcabus, pcibus, bios32, acpibus,
132	cpubus, ioapicbus, apmbus, pnpbiosbus, ipmibus,
133	bioscall
134attach	mainbus at root
135file	arch/i386/i386/mainbus.c	mainbus
136
137#
138# PCI-only drivers
139# XXX MUST BE INCLUDED BEFORE files.isa, as long as files.isa attaches
140# XXX devices to 'pci'.
141#
142include	"dev/pci/files.pci"
143include "dev/pci/files.agp"
144file	arch/i386/pci/pcibios.c		pcibios
145file	arch/i386/pci/pci_intr_fixup.c	pcibios & pci_intr_fixup
146file	arch/i386/pci/piix.c		pcibios & pci_intr_fixup
147file	arch/i386/pci/opti82c558.c	pcibios & pci_intr_fixup
148file	arch/i386/pci/opti82c700.c	pcibios & pci_intr_fixup
149file	arch/i386/pci/sis85c503.c	pcibios & pci_intr_fixup
150file	arch/i386/pci/via82c586.c	pcibios & pci_intr_fixup
151file	arch/i386/pci/via8231.c		pcibios & pci_intr_fixup
152file	arch/i386/pci/amd756.c		pcibios & pci_intr_fixup
153file	arch/i386/pci/ali1543.c		pcibios & pci_intr_fixup
154defparam		PCI_CONF_MODE
155file	arch/i386/pci/pcic_pci_machdep.c	pcic_pci
156
157# x86 specific PCI hardware
158include "arch/x86/pci/files.pci"
159
160# AMD Elan SC520 System Controller (PCI-Host bridge)
161define elanparbus { }
162define elanpexbus { }
163device	elansc: sysmon_wdog, gpiobus, elanparbus, elanpexbus, pcibus
164attach	elansc at pcibus
165
166file	arch/i386/pci/elan520.c		elansc
167
168device elanpar
169attach elanpar at elanparbus
170
171device elanpex
172attach elanpex at elanpexbus
173
174# AMD Geode CS5535 Companion IDE controller
175device	gcscide: ata, ata_dma, ata_udma, pciide_common, wdc_common
176attach	gcscide at pci
177file	arch/i386/pci/gcscide.c 	gcscide
178
179# AMD Geode CS5536 Companion EHCI
180device	gcscehci: usbus
181attach	gcscehci at pci
182file	arch/i386/pci/gcscehci.c	gcscehci
183
184# AMD Geode SC1100 GCB area
185device  geodegcb {}
186attach	geodegcb at pci
187file	arch/i386/pci/geode.c		geodegcb
188
189# AMD Geode SC1100 Watchdog Timer
190device	geodewdog: sysmon_wdog, geodegcb
191attach	geodewdog at geodegcb
192file	arch/i386/pci/geodewdg.c	geodewdog
193
194# AMD Geode SC1100 high resolution counter
195device	geodecntr: geodegcb
196attach  geodecntr at geodegcb
197file	arch/i386/pci/geodecntr.c	geodecntr
198
199# PCI-EISA bridges
200device	pceb: eisabus, isabus
201attach	pceb at pci
202file	arch/i386/pci/pceb.c		pceb
203
204# PCI-ISA bridges
205device	gscpcib: isabus, gpiobus
206attach	gscpcib at pci
207file	arch/i386/pci/gscpcib.c		gscpcib
208
209# AMD Geode CS5535/CS5536 PCI-ISA bridge
210device	gcscpcib: isabus, sysmon_wdog, gpiobus
211attach	gcscpcib at pci with gcscpcib_pci
212file	arch/i386/pci/gcscpcib_pci.c	gcscpcib_pci
213file	dev/ic/gcscpcib.c		gcscpcib
214
215device	piixpcib: isabus, bioscall
216attach	piixpcib at pci
217file	arch/i386/pci/piixpcib.c	piixpcib
218
219device	viapcib: isabus, i2cbus
220attach	viapcib at pci
221file	arch/i386/pci/viapcib.c		viapcib
222
223# PCI-MCA bridges
224device	pcmb: mcabus
225attach	pcmb at pci
226file	arch/i386/pci/pcmb.c		pcmb
227
228device	p64h2apic
229attach	p64h2apic at pci
230file	arch/i386/pci/p64h2apic.c	p64h2apic
231
232
233#
234# ISA and mixed ISA+EISA or ISA+PCI drivers
235#
236
237include	"dev/isa/files.isa"
238
239# Protech PS3100 cash drawer
240device	ptcd: gpiobus
241attach	ptcd at isa
242file	dev/isa/ptcd.c			ptcd
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/pckbport/files.pckbport"
253
254device	sysbeep
255attach	sysbeep at pcppi
256
257# Floppy disk controller
258device	fdc {drive = -1}: isadma
259file	dev/isa/fd.c			fdc needs-flag
260
261attach	fdc at isa with fdc_isa
262file	dev/isa/fdc_isa.c		fdc_isa
263
264device	fd: disk
265attach	fd at fdc
266
267# Adaptec AHA-284x VL SCSI controllers
268# device declaration in sys/conf/files
269attach	ahc at isa with ahc_isa: ahc_aic77xx, smc93cx6
270file	arch/i386/isa/ahc_isa.c		ahc_isa
271
272#
273# EISA-only drivers
274#
275
276include	"dev/eisa/files.eisa"
277file	arch/i386/eisa/eisa_machdep.c	eisa
278
279#
280# MCA-only drivers
281#
282
283device	mca {[slot = -1]} : bioscall
284include	"dev/mca/files.mca"
285file	arch/i386/mca/mca_machdep.c	mca
286
287# ISA Plug 'n Play devices
288file	arch/i386/isa/isapnp_machdep.c	isapnp
289
290#
291# VME support
292#
293include	"dev/vme/files.vme"
294
295#
296# GPIB support
297#
298include "dev/gpib/files.gpib"
299
300#
301# CMOS RAM
302#
303defpseudo cmos
304file	arch/i386/isa/cmos.c		cmos needs-flag
305
306#
307# Other mainbus-attached devices
308#
309
310include "dev/apm/files.apm"
311
312#
313# Compatibility modules
314#
315
316# Binary compatibility with previous NetBSD releases (COMPAT_XX)
317file	arch/i386/i386/compat_13_machdep.c	compat_13
318file	arch/i386/i386/compat_16_machdep.c	compat_16
319
320# Linux binary compatibility (COMPAT_LINUX)
321include	"compat/linux/files.linux"
322include	"compat/linux/arch/i386/files.linux_i386"
323file	arch/i386/i386/linux_sigcode.S		compat_linux
324file	arch/i386/i386/linux_syscall.c		compat_linux
325file	arch/x86/x86/linux_trap.c		compat_linux
326
327# FreeBSD binary compatibility (COMPAT_FREEBSD)
328include	"compat/freebsd/files.freebsd"
329
330# NDIS compatibilty (COMPAT_NDIS)
331include "compat/ndis/files.ndis"
332
333# OSS audio driver compatibility
334include	"compat/ossaudio/files.ossaudio"
335
336#
337# CARDBUS
338#
339include	"dev/cardbus/files.cardbus"
340file	arch/i386/i386/rbus_machdep.c	cardbus
341
342# XXXX pcic here because it needs to be late.  The catch: pcic needs
343# to be late, so devices which attach to it are attached late.  But it
344# needs to be before its isa and pci attachments.  This answer is
345# non-optimal, but I don't have a better answer right now.
346
347# PCIC pcmcia controller
348# XXX this needs to be done very late, so it's done here.  This feels
349# like a kludge, but it might be for the best.
350
351defparam		PCIC_ISA_ALLOC_IOBASE
352defparam		PCIC_ISA_ALLOC_IOSIZE
353defparam		PCIC_ISA_INTR_ALLOC_MASK
354
355device	pcic: pcmciabus
356file	dev/ic/i82365.c			pcic
357
358# PCIC pcmcia controller on ISA bus.
359attach	pcic at isa with pcic_isa
360file	dev/isa/i82365_isa.c		pcic_isa
361
362# PCIC pcmcia controller on PCI bus.
363attach	pcic at pci with pcic_pci
364file	dev/pci/i82365_pci.c		pcic_pci
365
366# PCIC pcmcia controller on PnP board
367attach	pcic at isapnp with pcic_isapnp
368file	dev/isapnp/i82365_isapnp.c	pcic_isapnp
369
370# Code common to ISA and ISAPnP attachments
371file	dev/isa/i82365_isasubr.c	pcic_isa | pcic_isapnp | pcic_pci
372
373# XXXX tcic here because it needs to be late.  The catch: tcic needs
374# to be late, so devices which attach to it are attached late.  But it
375# needs to be before its isa and pci attachments.  This answer is
376# non-optimal, but I don't have a better answer right now.
377
378# TCIC pcmcia controller
379# XXX this needs to be done very late, so it's done here.  This feels
380# like a kludge, but it might be for the best.
381
382defparam		TCIC_ISA_ALLOC_IOBASE
383defparam		TCIC_ISA_ALLOC_IOSIZE
384defparam		TCIC_ISA_INTR_ALLOC_MASK
385
386device	tcic: pcmciabus
387file	dev/ic/tcic2.c			tcic
388
389# TCIC pcmcia controller
390attach	tcic at isa with tcic_isa
391file	dev/isa/tcic2_isa.c		tcic_isa
392
393# this wants to be probed as late as possible.
394#
395# Machine-independent PCMCIA drivers
396#
397include	"dev/pcmcia/files.pcmcia"
398
399
400include	"dev/usb/files.usb"
401
402include	"dev/bluetooth/files.bluetooth"
403
404include	"dev/sdmmc/files.sdmmc"
405
406include	"dev/ieee1394/files.ieee1394"
407
408include	"arch/i386/pnpbios/files.pnpbios"
409
410include "dev/acpi/files.acpi"
411file	arch/i386/acpi/acpi_wakeup_low.S	acpi
412
413# Obsolete vesabios/vesafb flags
414obsolete	defflag	opt_vesabios.h	VESABIOSVERBOSE
415obsolete	defparam opt_vesafb.h	VESAFB_WIDTH VESAFB_HEIGHT VESAFB_DEPTH
416obsolete	defflag	opt_vesafb.h	VESAFB_PM
417
418# AMD Geode LX Security Block
419device	glxsb: opencrypto
420attach	glxsb at pci
421file	arch/i386/pci/glxsb.c		glxsb
422
423include "arch/i386/conf/majors.i386"
424endif #xen
425