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