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