1# $NetBSD: files.i386,v 1.353 2010/01/03 04:06:31 dholland 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# Xbox support 19defflag XBOX 20 21# VM86 emulation 22defflag VM86 23defflag KVM86 24 25# User-settable LDT (used by WINE) 26defflag USER_LDT 27 28# X server support in console drivers 29defflag opt_xserver.h XSERVER XSERVER_DDB 30 31# The REAL{BASE,EXT}MEM options 32defparam opt_realmem.h REALBASEMEM REALEXTMEM 33 34# The PHYSMEM_MAX_{SIZE,ADDR} optionms 35defparam opt_physmem.h PHYSMEM_MAX_ADDR PHYSMEM_MAX_SIZE 36 37# understand boot device passed by pre-1.3 bootblocks 38defflag COMPAT_OLDBOOT 39 40# PCI BIOS options 41defflag opt_pcibios.h PCIBIOS PCIBIOSVERBOSE 42 PCIBIOS_INTR_GUESS PCIINTR_DEBUG 43defparam opt_pcibios.h PCIBIOS_IRQS_HINT 44 45# kernel stack debug 46defflag opt_kstack_dr0.h KSTACK_CHECK_DR0 47 48# splraise()/spllower() debug 49defflag opt_spldebug.h SPLDEBUG 50 51# Beep on halt 52defflag opt_beep.h BEEP_ONHALT 53defparam opt_beep.h BEEP_ONHALT_COUNT=3 54defparam opt_beep.h BEEP_ONHALT_PITCH=1500 55defparam opt_beep.h BEEP_ONHALT_PERIOD=250 56 57# Multiboot support 58defflag opt_multiboot.h MULTIBOOT 59obsolete defparam MULTIBOOT_SYMTAB_SPACE 60file arch/i386/i386/multiboot.c multiboot 61 62# PowerNow K7 63defflag POWERNOW_K7 64 65file arch/i386/i386/autoconf.c 66file arch/i386/i386/aout_machdep.c exec_aout 67file arch/i386/i386/busfunc.S 68file arch/i386/i386/cpufunc.S 69file arch/i386/i386/cpu_in_cksum.S (inet | inet6) & cpu_in_cksum 70file arch/i386/i386/db_dbgreg.S ddb | kstack_check_dr0 71file arch/i386/i386/db_disasm.c ddb 72file arch/i386/i386/db_interface.c ddb 73file arch/i386/i386/db_memrw.c ddb | kgdb 74file arch/i386/i386/db_trace.c ddb 75file arch/i386/i386/dumpsys.c 76file kern/subr_disk_mbr.c disk 77file kern/subr_spldebug.c spldebug 78file arch/i386/i386/gdt.c 79file arch/i386/i386/i386func.S 80file arch/i386/i386/ipkdb_glue.c ipkdb 81file arch/i386/i386/kgdb_machdep.c kgdb 82file arch/i386/i386/kobj_machdep.c modular 83file arch/i386/i386/machdep.c 84file arch/i386/i386/longrun.c 85file arch/i386/i386/mem.c 86file arch/i386/i386/mtrr_k6.c mtrr 87file arch/i386/i386/process_machdep.c 88file arch/i386/i386/procfs_machdep.c procfs 89file arch/i386/i386/trap.c 90file dev/cons.c 91 92file arch/i386/i386/mptramp.S multiprocessor 93 94file arch/i386/i386/pmc.c perfctrs 95 96file crypto/des/arch/i386/des_enc.S des 97file crypto/des/arch/i386/des_cbc.S des 98 99file crypto/blowfish/arch/i386/bf_enc.S blowfish 100file crypto/blowfish/arch/i386/bf_cbc.S blowfish & !i386_cpu 101 102# 103# Machine-independent SCSI drivers 104# 105 106include "dev/scsipi/files.scsipi" 107 108# 109# Machine-independent ATA drivers 110# 111 112include "dev/ata/files.ata" 113 114# Memory Disk for install floppy 115file dev/md_root.c memory_disk_hooks & md 116 117# 118# Machine-independent I2O drivers 119# 120 121include "dev/i2o/files.i2o" 122 123# attribute used to bring in BIOS trampoline code for real-mode probing 124# of certain devices/BIOS features 125define bioscall 126file arch/i386/i386/bioscall.S bioscall needs-flag 127 128# BIOS32 routines 129define bios32 130file arch/i386/i386/bios32.c bios32 needs-flag 131 132# i386 specific mainbus attributes 133define apmbus {} 134define pnpbiosbus {} 135 136# 137# System bus types 138# 139 140# XXX BIOS32 only if something that uses it is configured! 141device mainbus: isabus, eisabus, mcabus, pcibus, bios32, acpibus, 142 cpubus, ioapicbus, apmbus, pnpbiosbus, ipmibus, 143 bioscall 144attach mainbus at root 145file arch/i386/i386/mainbus.c mainbus 146 147# 148# PCI-only drivers 149# XXX MUST BE INCLUDED BEFORE files.isa, as long as files.isa attaches 150# XXX devices to 'pci'. 151# 152include "dev/pci/files.pci" 153include "dev/pci/files.agp" 154file arch/i386/pci/pcibios.c pcibios 155file arch/i386/pci/pci_intr_fixup.c pcibios & pci_intr_fixup 156file arch/i386/pci/piix.c pcibios & pci_intr_fixup 157file arch/i386/pci/opti82c558.c pcibios & pci_intr_fixup 158file arch/i386/pci/opti82c700.c pcibios & pci_intr_fixup 159file arch/i386/pci/sis85c503.c pcibios & pci_intr_fixup 160file arch/i386/pci/via82c586.c pcibios & pci_intr_fixup 161file arch/i386/pci/via8231.c pcibios & pci_intr_fixup 162file arch/i386/pci/amd756.c pcibios & pci_intr_fixup 163file arch/i386/pci/ali1543.c pcibios & pci_intr_fixup 164defparam PCI_CONF_MODE 165file arch/i386/pci/pcic_pci_machdep.c pcic_pci 166 167# x86 specific PCI hardware 168include "arch/x86/pci/files.pci" 169 170# AMD Elan SC520 System Controller (PCI-Host bridge) 171define elanparbus { } 172define elanpexbus { } 173device elansc: sysmon_wdog, gpiobus, elanparbus, elanpexbus, pcibus 174attach elansc at pcibus 175 176file arch/i386/pci/elan520.c elansc 177 178device elanpar 179attach elanpar at elanparbus 180 181device elanpex 182attach elanpex at elanpexbus 183 184# AMD Geode CS5535 Companion IDE controller 185device gcscide: ata, ata_dma, ata_udma, pciide_common, wdc_common 186attach gcscide at pci 187file arch/i386/pci/gcscide.c gcscide 188 189# AMD Geode CS5536 Companion EHCI 190device gcscehci: usbus 191attach gcscehci at pci 192file arch/i386/pci/gcscehci.c gcscehci 193 194# AMD Geode SC1100 GCB area 195device geodegcb {} 196attach geodegcb at pci 197file arch/i386/pci/geode.c geodegcb 198 199# AMD Geode SC1100 Watchdog Timer 200device geodewdog: sysmon_wdog, geodegcb 201attach geodewdog at geodegcb 202file arch/i386/pci/geodewdg.c geodewdog 203 204# AMD Geode SC1100 high resolution counter 205device geodecntr: geodegcb 206attach geodecntr at geodegcb 207file arch/i386/pci/geodecntr.c geodecntr 208 209# PCI-EISA bridges 210device pceb: eisabus, isabus 211attach pceb at pci 212file arch/i386/pci/pceb.c pceb 213 214# PCI-ISA bridges 215device gscpcib: isabus, gpiobus 216attach gscpcib at pci 217file arch/i386/pci/gscpcib.c gscpcib 218 219# AMD Geode CS5535/CS5536 PCI-ISA bridge 220device gcscpcib: isabus, sysmon_wdog, gpiobus 221attach gcscpcib at pci 222file arch/i386/pci/gcscpcib.c gcscpcib 223 224device piixpcib: isabus, bioscall 225attach piixpcib at pci 226file arch/i386/pci/piixpcib.c piixpcib 227 228device viapcib: isabus, i2cbus 229attach viapcib at pci 230file arch/i386/pci/viapcib.c viapcib 231 232# PCI-MCA bridges 233device pcmb: mcabus 234attach pcmb at pci 235file arch/i386/pci/pcmb.c pcmb 236 237device p64h2apic 238attach p64h2apic at pci 239file arch/i386/pci/p64h2apic.c p64h2apic 240 241 242# 243# ISA and mixed ISA+EISA or ISA+PCI drivers 244# 245 246include "dev/isa/files.isa" 247 248# PC clock 249file arch/x86/isa/clock.c isa 250file arch/x86/isa/rtc.c isa 251 252# TSC support 253file arch/x86/x86/tsc.c 254 255# Numeric Processing Extension; Math Co-processor 256device npx 257file arch/i386/isa/npx.c npx needs-flag 258 259attach npx at isa with npx_isa 260file arch/i386/isa/npx_isa.c npx_isa 261 262# PC Mice: Logitech-style and Microsoft-style 263device lms: wsmousedev 264attach lms at isa 265file arch/i386/isa/lms.c lms 266device mms: wsmousedev 267attach mms at isa 268file arch/i386/isa/mms.c mms 269 270include "dev/pckbport/files.pckbport" 271 272device sysbeep 273attach sysbeep at pcppi 274 275# Floppy disk controller 276device fdc {drive = -1}: isadma 277file dev/isa/fd.c fdc needs-flag 278 279attach fdc at isa with fdc_isa 280file dev/isa/fdc_isa.c fdc_isa 281 282device fd: disk 283attach fd at fdc 284 285# Adaptec AHA-284x VL SCSI controllers 286# device declaration in sys/conf/files 287attach ahc at isa with ahc_isa: ahc_aic77xx, smc93cx6 288file arch/i386/isa/ahc_isa.c ahc_isa 289 290# 291# EISA-only drivers 292# 293 294include "dev/eisa/files.eisa" 295file arch/i386/eisa/eisa_machdep.c eisa 296 297# 298# MCA-only drivers 299# 300 301device mca {[slot = -1]} : bioscall 302include "dev/mca/files.mca" 303file arch/i386/mca/mca_machdep.c mca 304 305# ISA Plug 'n Play devices 306file arch/i386/isa/isapnp_machdep.c isapnp 307 308# 309# VME support 310# 311include "dev/vme/files.vme" 312 313# 314# GPIB support 315# 316include "dev/gpib/files.gpib" 317 318# 319# CMOS RAM 320# 321defpseudo cmos 322file arch/i386/isa/cmos.c cmos needs-flag 323 324# 325# Other mainbus-attached devices 326# 327 328include "dev/apm/files.apm" 329 330# Advanced Power Management support (APM) 331attach apm at apmbus with apmbios: bioscall 332file arch/i386/i386/apmbios.c apmbios needs-flag 333file arch/i386/i386/apmcall.S apmbios 334 335# XBox LED & system support 336file arch/i386/xbox/xbox.c xbox 337 338# XBox X3LCD support (*very* rudimentary) 339file arch/i386/xbox/xboxlcd.c xbox 340 341# XBox framebuffer support 342device xboxfb: wsemuldisplaydev, rasops32, vcons 343attach xboxfb at pci 344file arch/i386/xbox/xboxfb.c xboxfb needs-flag 345 346# 347# Compatibility modules 348# 349 350# VM86 mode 351file arch/i386/i386/vm86.c vm86 352 353# VM86 in kernel 354file arch/i386/i386/kvm86.c kvm86 355file arch/i386/i386/kvm86call.S kvm86 356 357# Binary compatibility with previous NetBSD releases (COMPAT_XX) 358file arch/i386/i386/compat_13_machdep.c compat_13 359file arch/i386/i386/compat_16_machdep.c compat_16 | compat_ibcs2 360 361# SVR4 binary compatibility (COMPAT_SVR4) 362include "compat/svr4/files.svr4" 363file arch/i386/i386/svr4_machdep.c compat_svr4 364file arch/i386/i386/svr4_sigcode.S compat_svr4 365file arch/i386/i386/svr4_syscall.c compat_svr4 366 367# MACH binary compatibility (COMPAT_MACH) 368include "compat/mach/files.mach" 369file arch/i386/i386/mach_machdep.c compat_mach | compat_darwin 370file arch/i386/i386/mach_sigcode.S compat_mach | compat_darwin 371file arch/i386/i386/mach_syscall.c compat_mach | compat_darwin 372file arch/i386/i386/darwin_commpage_machdep.S compat_darwin 373file arch/i386/i386/macho_machdep.c exec_macho 374 375# DARWIN binary compatibility (COMPAT_DARWIN) 376include "compat/darwin/files.darwin" 377file arch/i386/i386/darwin_machdep.c compat_darwin 378 379# iBCS-2 binary compatibility (COMPAT_IBCS2) 380include "compat/ibcs2/files.ibcs2" 381file arch/i386/i386/ibcs2_machdep.c compat_ibcs2 382file arch/i386/i386/ibcs2_sigcode.S compat_ibcs2 383file arch/i386/i386/ibcs2_syscall.c compat_ibcs2 384 385# Linux binary compatibility (COMPAT_LINUX) 386include "compat/linux/files.linux" 387include "compat/linux/arch/i386/files.linux_i386" 388file arch/i386/i386/linux_sigcode.S compat_linux 389file arch/i386/i386/linux_syscall.c compat_linux 390file arch/x86/x86/linux_trap.c compat_linux 391 392# FreeBSD binary compatibility (COMPAT_FREEBSD) 393include "compat/freebsd/files.freebsd" 394file arch/i386/i386/freebsd_machdep.c compat_freebsd 395file arch/i386/i386/freebsd_sigcode.S compat_freebsd 396file arch/i386/i386/freebsd_syscall.c compat_freebsd 397 398# NDIS compatibilty (COMPAT_NDIS) 399include "compat/ndis/files.ndis" 400 401# Win32 binary compatibility (COMPAT_PECOFF) 402include "compat/pecoff/files.pecoff" 403 404# OSS audio driver compatibility 405include "compat/ossaudio/files.ossaudio" 406 407# 408# CARDBUS 409# 410include "dev/cardbus/files.cardbus" 411file arch/i386/i386/rbus_machdep.c cardbus 412 413# XXXX pcic here because it needs to be late. The catch: pcic needs 414# to be late, so devices which attach to it are attached late. But it 415# needs to be before its isa and pci attachments. This answer is 416# non-optimal, but I don't have a better answer right now. 417 418# PCIC pcmcia controller 419# XXX this needs to be done very late, so it's done here. This feels 420# like a kludge, but it might be for the best. 421 422defparam PCIC_ISA_ALLOC_IOBASE 423defparam PCIC_ISA_ALLOC_IOSIZE 424defparam PCIC_ISA_INTR_ALLOC_MASK 425 426device pcic: pcmciabus 427file dev/ic/i82365.c pcic 428 429# PCIC pcmcia controller on ISA bus. 430attach pcic at isa with pcic_isa 431file dev/isa/i82365_isa.c pcic_isa 432 433# PCIC pcmcia controller on PCI bus. 434attach pcic at pci with pcic_pci 435file dev/pci/i82365_pci.c pcic_pci 436 437# PCIC pcmcia controller on PnP board 438attach pcic at isapnp with pcic_isapnp 439file dev/isapnp/i82365_isapnp.c pcic_isapnp 440 441# Code common to ISA and ISAPnP attachments 442file dev/isa/i82365_isasubr.c pcic_isa | pcic_isapnp | pcic_pci 443 444# XXXX tcic here because it needs to be late. The catch: tcic needs 445# to be late, so devices which attach to it are attached late. But it 446# needs to be before its isa and pci attachments. This answer is 447# non-optimal, but I don't have a better answer right now. 448 449# TCIC pcmcia controller 450# XXX this needs to be done very late, so it's done here. This feels 451# like a kludge, but it might be for the best. 452 453defparam TCIC_ISA_ALLOC_IOBASE 454defparam TCIC_ISA_ALLOC_IOSIZE 455defparam TCIC_ISA_INTR_ALLOC_MASK 456 457device tcic: pcmciabus 458file dev/ic/tcic2.c tcic 459 460# TCIC pcmcia controller 461attach tcic at isa with tcic_isa 462file dev/isa/tcic2_isa.c tcic_isa 463 464# this wants to be probed as late as possible. 465# 466# Machine-independent PCMCIA drivers 467# 468include "dev/pcmcia/files.pcmcia" 469 470 471include "dev/usb/files.usb" 472 473include "dev/bluetooth/files.bluetooth" 474 475include "dev/sdmmc/files.sdmmc" 476 477include "dev/ieee1394/files.ieee1394" 478 479include "arch/i386/pnpbios/files.pnpbios" 480 481include "dev/acpi/files.acpi" 482file arch/i386/acpi/acpi_wakeup_low.S acpi 483 484# Toshiba VALD 485device vald 486attach vald at acpinodebus with vald_acpi 487file arch/i386/acpi/vald_acpi.c vald_acpi 488 489# Numeric Processing Extension; Math Co-processor 490attach npx at acpinodebus with npx_acpi 491file arch/i386/acpi/npx_acpi.c npx_acpi 492 493# Obsolete vesabios/vesafb flags 494obsolete defflag opt_vesabios.h VESABIOSVERBOSE 495obsolete defparam opt_vesafb.h VESAFB_WIDTH VESAFB_HEIGHT VESAFB_DEPTH 496obsolete defflag opt_vesafb.h VESAFB_PM 497 498# AMD PowerNow K7 499file arch/i386/i386/powernow_k7.c powernow_k7 500 501# AMD Geode LX Security Block 502device glxsb: opencrypto 503attach glxsb at pci 504file arch/i386/pci/glxsb.c glxsb 505 506include "arch/i386/conf/majors.i386" 507endif #xen 508