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