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