xref: /netbsd-src/sys/arch/i386/conf/files.i386 (revision e6c7e151de239c49d2e38720a061ed9d1fa99309)
1#	$NetBSD: files.i386,v 1.401 2019/10/18 01:38:28 manu 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# User-settable LDT (used by WINE)
22defflag			USER_LDT
23
24# X server support in console drivers
25defflag	opt_xserver.h	XSERVER XSERVER_DDB
26
27# The REAL{BASE,EXT}MEM options
28defparam opt_realmem.h	REALBASEMEM REALEXTMEM
29
30# The PHYSMEM_MAX_{SIZE,ADDR} optionms
31defparam opt_physmem.h	PHYSMEM_MAX_ADDR PHYSMEM_MAX_SIZE
32
33# PCI BIOS options
34defflag	opt_pcibios.h	PCIBIOS PCIBIOSVERBOSE
35			PCIBIOS_INTR_GUESS PCIINTR_DEBUG
36defparam opt_pcibios.h	PCIBIOS_IRQS_HINT
37
38# splraise()/spllower() debug
39defflag	opt_spldebug.h			SPLDEBUG
40
41# Enable GCC spectre V2 mitigation options
42defflag opt_spectre.h	SPECTRE_V2_GCC_MITIGATION
43
44# Beep on halt
45defflag 	opt_beep.h		BEEP_ONHALT
46defparam 	opt_beep.h		BEEP_ONHALT_COUNT=3
47defparam 	opt_beep.h		BEEP_ONHALT_PITCH=1500
48defparam 	opt_beep.h		BEEP_ONHALT_PERIOD=250
49
50# Multiboot support
51defflag 	opt_multiboot.h		MULTIBOOT
52obsolete 	defparam		MULTIBOOT_SYMTAB_SPACE
53file 	arch/i386/i386/multiboot.c	multiboot
54file 	arch/x86/x86/multiboot2.c	multiboot
55
56file	arch/i386/i386/autoconf.c
57file	arch/i386/i386/aout_machdep.c	exec_aout
58file	arch/i386/i386/busfunc.S
59file	arch/i386/i386/cpufunc.S
60file	arch/i386/i386/cpu_in_cksum.S	(inet | inet6) & cpu_in_cksum
61file	arch/i386/i386/db_disasm.c	ddb
62file	arch/i386/i386/db_interface.c	ddb
63file	arch/i386/i386/db_machdep.c	ddb
64file	arch/i386/i386/dumpsys.c
65file	kern/subr_disk_mbr.c		disk
66file	kern/subr_spldebug.c		spldebug
67file	arch/i386/i386/gdt.c
68file	arch/i386/i386/i386func.S
69file	arch/i386/i386/kobj_machdep.c	modular
70file	arch/i386/i386/machdep.c
71file 	arch/i386/i386/longrun.c
72file	arch/i386/i386/mtrr_k6.c	mtrr
73file	arch/i386/i386/process_machdep.c
74file	arch/i386/i386/trap.c
75file	dev/cons.c
76file	arch/x86/x86/fpu.c
77file	arch/x86/x86/dbregs.c
78file	arch/x86/x86/spectre.c
79
80file	arch/i386/i386/mptramp.S	multiprocessor
81
82file	crypto/des/arch/i386/des_enc.S		des
83file	crypto/des/arch/i386/des_cbc.S		des
84
85file	crypto/blowfish/arch/i386/bf_enc.S	blowfish
86file	crypto/blowfish/arch/i386/bf_cbc.S	blowfish & !i386_cpu
87
88#
89# Stack-less Just-In-Time compiler
90#
91
92include	"external/bsd/sljit/conf/files.sljit"
93
94#
95# Machine-independent SCSI drivers
96#
97
98include	"dev/scsipi/files.scsipi"
99
100#
101# Machine-independent ATA drivers
102#
103
104include	"dev/ata/files.ata"
105
106# Memory Disk for install floppy
107file	dev/md_root.c			memory_disk_hooks & md
108
109#
110# Machine-independent I2O drivers
111#
112
113include	"dev/i2o/files.i2o"
114
115# attribute used to bring in BIOS trampoline code for real-mode probing
116# of certain devices/BIOS features
117define	bioscall
118file	arch/i386/i386/bioscall.S	bioscall needs-flag
119
120# i386 specific mainbus attributes
121define	apmbus {}
122define	pnpbiosbus {}
123
124#
125# System bus types
126#
127
128# XXX BIOS32 only if something that uses it is configured!
129device	mainbus: isabus, eisabus, mcabus, pcibus, bios32, acpibus,
130	cpubus, ioapicbus, apmbus, pnpbiosbus, ipmibus,
131	bioscall
132attach	mainbus at root
133file	arch/i386/i386/i386_mainbus.c	mainbus
134file	arch/x86/x86/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# OSS audio driver compatibility
330include	"compat/ossaudio/files.ossaudio"
331
332#
333# CARDBUS
334#
335include	"dev/cardbus/files.cardbus"
336file	arch/i386/i386/rbus_machdep.c	cardbus
337
338# XXXX pcic here because it needs to be late.  The catch: pcic needs
339# to be late, so devices which attach to it are attached late.  But it
340# needs to be before its isa and pci attachments.  This answer is
341# non-optimal, but I don't have a better answer right now.
342
343# PCIC pcmcia controller
344# XXX this needs to be done very late, so it's done here.  This feels
345# like a kludge, but it might be for the best.
346
347defparam		PCIC_ISA_ALLOC_IOBASE
348defparam		PCIC_ISA_ALLOC_IOSIZE
349defparam		PCIC_ISA_INTR_ALLOC_MASK
350
351device	pcic: pcmciabus
352file	dev/ic/i82365.c			pcic
353
354# PCIC pcmcia controller on ISA bus.
355attach	pcic at isa with pcic_isa
356file	dev/isa/i82365_isa.c		pcic_isa
357
358# PCIC pcmcia controller on PCI bus.
359attach	pcic at pci with pcic_pci
360file	dev/pci/i82365_pci.c		pcic_pci
361
362# PCIC pcmcia controller on PnP board
363attach	pcic at isapnp with pcic_isapnp
364file	dev/isapnp/i82365_isapnp.c	pcic_isapnp
365
366# Code common to ISA and ISAPnP attachments
367file	dev/isa/i82365_isasubr.c	pcic_isa | pcic_isapnp | pcic_pci
368
369# XXXX tcic here because it needs to be late.  The catch: tcic needs
370# to be late, so devices which attach to it are attached late.  But it
371# needs to be before its isa and pci attachments.  This answer is
372# non-optimal, but I don't have a better answer right now.
373
374# TCIC pcmcia controller
375# XXX this needs to be done very late, so it's done here.  This feels
376# like a kludge, but it might be for the best.
377
378defparam		TCIC_ISA_ALLOC_IOBASE
379defparam		TCIC_ISA_ALLOC_IOSIZE
380defparam		TCIC_ISA_INTR_ALLOC_MASK
381
382device	tcic: pcmciabus
383file	dev/ic/tcic2.c			tcic
384
385# TCIC pcmcia controller
386attach	tcic at isa with tcic_isa
387file	dev/isa/tcic2_isa.c		tcic_isa
388
389# this wants to be probed as late as possible.
390#
391# Machine-independent PCMCIA drivers
392#
393include	"dev/pcmcia/files.pcmcia"
394
395
396include	"dev/usb/files.usb"
397
398include	"dev/bluetooth/files.bluetooth"
399
400include	"dev/sdmmc/files.sdmmc"
401
402include	"dev/ieee1394/files.ieee1394"
403
404include	"arch/i386/pnpbios/files.pnpbios"
405
406include "dev/acpi/files.acpi"
407file	arch/i386/acpi/acpi_wakeup_low.S	acpi
408
409# Microsoft Hyper-V
410include "dev/hyperv/files.hyperv"
411
412attach	vmbus at acpinodebus with vmbus_acpi
413file	dev/acpi/vmbus_acpi.c			vmbus_acpi
414
415# Obsolete vesabios/vesafb flags
416obsolete	defflag	opt_vesabios.h	VESABIOSVERBOSE
417obsolete	defparam opt_vesafb.h	VESAFB_WIDTH VESAFB_HEIGHT VESAFB_DEPTH
418obsolete	defflag	opt_vesafb.h	VESAFB_PM
419
420# AMD Geode LX Security Block
421device	glxsb: opencrypto
422attach	glxsb at pci
423file	arch/i386/pci/glxsb.c		glxsb
424
425include "arch/i386/conf/majors.i386"
426endif #xen
427