1# $NetBSD: files.i386,v 1.293 2006/10/01 18:37:54 bouyer Exp $ 2# 3# new style config file for i386 architecture 4# 5 6# maxpartitions must be first item in files.${ARCH}.newconf 7maxpartitions 8 8 9maxusers 2 16 128 10 11defparam opt_kernbase.h KERNBASE 12 13# Processor type options. 14defflag opt_cputype.h I386_CPU I486_CPU I586_CPU I686_CPU 15 16# delay before cpu_reset() for reboot. 17defparam CPURESET_DELAY 18 19# VM86 emulation 20defflag VM86 21defflag KVM86 22 23# Floating point emulation 24defflag MATH_EMULATE 25 26# User-settable LDT (used by WINE) 27defflag USER_LDT 28 29# X server support in console drivers 30defflag opt_xserver.h XSERVER XSERVER_DDB 31 32# The REAL{BASE,EXT}MEM options 33defparam opt_realmem.h REALBASEMEM REALEXTMEM 34 35# understand boot device passed by pre-1.3 bootblocks 36defflag COMPAT_OLDBOOT 37 38# PCI BIOS options 39defflag opt_pcibios.h PCIBIOS PCIBIOSVERBOSE 40 PCIBIOS_INTR_GUESS PCIINTR_DEBUG 41defparam opt_pcibios.h PCIBIOS_IRQS_HINT 42 43# Large page size 44defflag LARGEPAGES 45 46# No unmapped page below kernel stack 47defflag NOREDZONE 48 49# kernel stack debug 50defflag opt_kstack_dr0.h KSTACK_CHECK_DR0 51 52# Beep on halt 53defflag opt_beep.h BEEP_ONHALT 54defparam opt_beep.h BEEP_ONHALT_COUNT 55defparam opt_beep.h BEEP_ONHALT_PITCH BEEP_ONHALT_PERIOD 56 57# Enhanced SpeedStep 58defflag ENHANCED_SPEEDSTEP 59 60# Multiboot support 61defflag opt_multiboot.h MULTIBOOT 62defparam opt_multiboot.h MULTIBOOT_SYMTAB_SPACE 63file arch/i386/i386/multiboot.c multiboot 64 65# PowerNow K7 66defflag POWERNOW_K7 67 68file arch/i386/i386/autoconf.c 69file arch/i386/i386/db_dbgreg.S ddb | kstack_check_dr0 70file arch/i386/i386/db_disasm.c ddb 71file arch/i386/i386/db_interface.c ddb 72file arch/i386/i386/db_memrw.c ddb | kgdb 73file arch/i386/i386/db_trace.c ddb 74file kern/subr_disk_mbr.c disk 75file arch/i386/i386/gdt.c 76file arch/i386/i386/in_cksum.S inet | inet6 77file arch/i386/i386/ipkdb_glue.c ipkdb 78file arch/i386/i386/kgdb_machdep.c kgdb 79file arch/i386/i386/machdep.c 80file arch/i386/i386/identcpu.c 81file arch/i386/i386/math_emulate.c math_emulate 82file arch/i386/i386/mem.c 83file arch/i386/i386/mtrr_k6.c mtrr 84file netns/ns_cksum.c ns 85file arch/i386/i386/pmap.c 86file arch/i386/i386/process_machdep.c 87file arch/i386/i386/procfs_machdep.c procfs 88file arch/i386/i386/sys_machdep.c 89file arch/i386/i386/syscall.c 90file arch/i386/i386/trap.c 91file arch/i386/i386/vm_machdep.c 92file dev/cons.c 93 94file arch/i386/i386/mptramp.S multiprocessor 95file arch/i386/i386/ipifuncs.c multiprocessor 96 97file arch/i386/i386/pmc.c perfctrs 98 99file crypto/des/arch/i386/des_enc.S des 100file crypto/des/arch/i386/des_cbc.S des 101 102file crypto/blowfish/arch/i386/bf_enc.S blowfish 103file crypto/blowfish/arch/i386/bf_cbc.S blowfish & !i386_cpu 104 105# 106# Machine-independent SCSI drivers 107# 108 109include "dev/scsipi/files.scsipi" 110 111# 112# Machine-independent ATA drivers 113# 114 115include "dev/ata/files.ata" 116 117# Memory Disk for install floppy 118file dev/md_root.c memory_disk_hooks 119 120# 121# Machine-independent I2O drivers 122# 123 124include "dev/i2o/files.i2o" 125 126# attribute used to bring in BIOS trampoline code for real-mode probing 127# of certain devices/BIOS features 128define bioscall 129file arch/i386/i386/bioscall.S bioscall needs-flag 130 131# BIOS32 routines 132define bios32 133file arch/i386/i386/bios32.c bios32 needs-flag 134 135# i386 specific mainbus attributes 136define apmbus {} 137define pnpbiosbus {} 138define vesabiosbus {} 139 140# 141# System bus types 142# 143 144# XXX BIOS32 only if something that uses it is configured! 145device mainbus: isabus, eisabus, mcabus, pcibus, bios32, acpibus, 146 cpubus, apmbus, pnpbiosbus, vesabiosbus, ipmibus 147attach mainbus at root 148file arch/i386/i386/mainbus.c mainbus 149 150# 151# PCI-only drivers 152# XXX MUST BE INCLUDED BEFORE files.isa, as long as files.isa attaches 153# XXX devices to 'pci'. 154# 155 156include "dev/pci/files.pci" 157include "dev/pci/files.agp" 158file arch/i386/pci/agp_machdep.c agp 159file arch/i386/pci/pcibios.c pcibios 160file arch/i386/pci/pci_intr_fixup.c pcibios & pci_intr_fixup 161file arch/i386/pci/piix.c pcibios & pci_intr_fixup 162file arch/i386/pci/opti82c558.c pcibios & pci_intr_fixup 163file arch/i386/pci/opti82c700.c pcibios & pci_intr_fixup 164file arch/i386/pci/sis85c503.c pcibios & pci_intr_fixup 165file arch/i386/pci/via82c586.c pcibios & pci_intr_fixup 166file arch/i386/pci/via8231.c pcibios & pci_intr_fixup 167file arch/i386/pci/amd756.c pcibios & pci_intr_fixup 168file arch/i386/pci/ali1543.c pcibios & pci_intr_fixup 169file arch/i386/pci/pci_bus_fixup.c pci_bus_fixup 170file arch/i386/pci/pci_addr_fixup.c pci_addr_fixup 171defparam PCI_CONF_MODE 172file arch/i386/pci/pcic_pci_machdep.c pcic_pci 173 174device aapic 175attach aapic at pci 176file arch/x86/pci/aapic.c aapic 177 178# PCI-Host bridge chipsets 179device pchb: pcibus, agpbus, agp_ali, agp_amd, agp_i810, agp_intel, agp_sis, 180 agp_via 181attach pchb at pci 182file arch/i386/pci/pchb.c pchb needs-flag 183file arch/x86/pci/pchb_rnd.c pchb & rnd 184 185# AMD Elan SC520 System Controller (PCI-Host bridge) 186device elansc: sysmon_wdog, gpiobus 187attach elansc at pci 188file arch/i386/pci/elan520.c elansc 189 190# AMD Geode SC1100 GCB area 191device geodegcb {} 192attach geodegcb at pci 193file arch/i386/pci/geode.c geodegcb 194 195# AMD Geode SC1100 Watchdog Timer 196device geodewdog: sysmon_wdog, geodegcb 197attach geodewdog at geodegcb 198file arch/i386/pci/geodewdg.c geodewdog 199 200# AMD Geode SC1100 high resolution counter 201device geodecntr: geodegcb 202attach geodecntr at geodegcb 203file arch/i386/pci/geodecntr.c geodecntr 204 205# PCI-EISA bridges 206device pceb: eisabus, isabus 207attach pceb at pci 208file arch/i386/pci/pceb.c pceb 209 210# PCI-ISA bridges 211device pcib: isabus 212attach pcib at pci 213file arch/i386/pci/pcib.c pcib | ichlpcib | gscpcib | piixpcib | viapcib 214 215# PCI-LPC bridges 216device ichlpcib: isabus, sysmon_wdog 217attach ichlpcib at pci 218file arch/i386/pci/ichlpcib.c ichlpcib 219 220device gscpcib: isabus, gpiobus 221attach gscpcib at pci 222file arch/i386/pci/gscpcib.c gscpcib 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 250 251# TSC support 252file arch/x86/x86/tsc.c i586_cpu | i686_cpu 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 console support a la "pccons" 262device pc: tty 263attach pc at isa 264device pcconskbd: pckbport_machdep_cnattach 265attach pcconskbd at pckbport 266file arch/i386/isa/pccons.c pc | pcconskbd needs-flag 267 268# PC Mice: Logitech-style and Microsoft-style 269device lms: wsmousedev 270attach lms at isa 271file arch/i386/isa/lms.c lms 272device mms: wsmousedev 273attach mms at isa 274file arch/i386/isa/mms.c mms 275 276include "dev/wscons/files.wscons" 277include "dev/wsfont/files.wsfont" 278 279include "dev/pckbport/files.pckbport" 280 281device sysbeep 282attach sysbeep at pcppi 283 284# Floppy disk controller 285device fdc {drive = -1}: isadma 286file dev/isa/fd.c fdc needs-flag 287 288attach fdc at isa with fdc_isa 289file dev/isa/fdc_isa.c fdc_isa 290 291device fd: disk 292attach fd at fdc 293 294# Adaptec AHA-284x VL SCSI controllers 295# device declaration in sys/conf/files 296attach ahc at isa with ahc_isa: ahc_aic77xx, smc93cx6 297file arch/i386/isa/ahc_isa.c ahc_isa 298 299# 300# EISA-only drivers 301# 302 303include "dev/eisa/files.eisa" 304file arch/i386/eisa/eisa_machdep.c eisa 305 306# 307# MCA-only drivers 308# 309 310device mca {[slot = -1]} : bioscall 311include "dev/mca/files.mca" 312file arch/i386/mca/mca_machdep.c mca 313 314# ISA Plug 'n Play devices 315file arch/i386/isa/isapnp_machdep.c isapnp 316 317# 318# VME support 319# 320include "dev/vme/files.vme" 321 322# 323# GPIB support 324# 325include "dev/gpib/files.gpib" 326 327# 328# Other mainbus-attached devices 329# 330 331include "dev/apm/files.apm" 332 333# Advanced Power Management support (APM) 334attach apm at apmbus with apmbios: bioscall 335file arch/i386/i386/apmbios.c apmbios needs-flag 336file arch/i386/i386/apmcall.S apmbios 337 338# CPUS 339 340device cpu 341attach cpu at cpubus 342file arch/i386/i386/cpu.c cpu 343 344# 345# Compatibility modules 346# 347 348# VM86 mode 349file arch/i386/i386/vm86.c vm86 350 351# VM86 in kernel 352file arch/i386/i386/kvm86.c kvm86 353file arch/i386/i386/kvm86call.S kvm86 354 355# Binary compatibility with previous NetBSD releases (COMPAT_XX) 356file arch/i386/i386/compat_13_machdep.c compat_13 | compat_aout 357file arch/i386/i386/compat_16_machdep.c compat_16 | compat_ibcs2 358 359# SVR4 binary compatibility (COMPAT_SVR4) 360include "compat/svr4/files.svr4" 361file arch/i386/i386/svr4_machdep.c compat_svr4 362file arch/i386/i386/svr4_sigcode.S compat_svr4 363file arch/i386/i386/svr4_syscall.c compat_svr4 364 365# MACH binary compatibility (COMPAT_MACH) 366include "compat/mach/files.mach" 367file arch/i386/i386/mach_machdep.c compat_mach | compat_darwin 368file arch/i386/i386/mach_sigcode.S compat_mach | compat_darwin 369file arch/i386/i386/mach_syscall.c compat_mach | compat_darwin 370file arch/i386/i386/darwin_commpage_machdep.S compat_darwin 371file arch/i386/i386/macho_machdep.c exec_macho 372 373# DARWIN binary compatibility (COMPAT_DARWIN) 374include "compat/darwin/files.darwin" 375file arch/i386/i386/darwin_machdep.c compat_darwin 376 377# iBCS-2 binary compatibility (COMPAT_IBCS2) 378include "compat/ibcs2/files.ibcs2" 379file arch/i386/i386/ibcs2_machdep.c compat_ibcs2 380file arch/i386/i386/ibcs2_sigcode.S compat_ibcs2 381file arch/i386/i386/ibcs2_syscall.c compat_ibcs2 382 383# Linux binary compatibility (COMPAT_LINUX) 384include "compat/linux/files.linux" 385include "compat/linux/arch/i386/files.linux_i386" 386file arch/i386/i386/linux_sigcode.S compat_linux 387file arch/i386/i386/linux_syscall.c compat_linux 388file arch/x86/x86/linux_trap.c compat_linux 389 390# FreeBSD binary compatibility (COMPAT_FREEBSD) 391include "compat/freebsd/files.freebsd" 392file arch/i386/i386/freebsd_machdep.c compat_freebsd 393file arch/i386/i386/freebsd_sigcode.S compat_freebsd 394file arch/i386/i386/freebsd_syscall.c compat_freebsd 395 396# NDIS compatibilty (COMPAT_NDIS) 397include "compat/ndis/files.ndis" 398 399# Win32 binary compatibility (COMPAT_PECOFF) 400include "compat/pecoff/files.pecoff" 401 402# OSS audio driver compatibility 403include "compat/ossaudio/files.ossaudio" 404 405# 406# CARDBUS 407# 408include "dev/cardbus/files.cardbus" 409file arch/i386/i386/rbus_machdep.c cardbus 410 411# XXXX pcic here because it needs to be late. The catch: pcic needs 412# to be late, so devices which attach to it are attached late. But it 413# needs to be before its isa and pci attachments. This answer is 414# non-optimal, but I don't have a better answer right now. 415 416# PCIC pcmcia controller 417# XXX this needs to be done very late, so it's done here. This feels 418# like a kludge, but it might be for the best. 419 420defparam PCIC_ISA_ALLOC_IOBASE 421defparam PCIC_ISA_ALLOC_IOSIZE 422defparam PCIC_ISA_INTR_ALLOC_MASK 423 424device pcic: pcmciabus 425file dev/ic/i82365.c pcic 426 427# PCIC pcmcia controller on ISA bus. 428attach pcic at isa with pcic_isa 429file dev/isa/i82365_isa.c pcic_isa 430 431# PCIC pcmcia controller on PCI bus. 432attach pcic at pci with pcic_pci 433file dev/pci/i82365_pci.c pcic_pci 434 435# PCIC pcmcia controller on PnP board 436attach pcic at isapnp with pcic_isapnp 437file dev/isapnp/i82365_isapnp.c pcic_isapnp 438 439# Code common to ISA and ISAPnP attachments 440file dev/isa/i82365_isasubr.c pcic_isa | pcic_isapnp | pcic_pci 441 442# XXXX tcic here because it needs to be late. The catch: tcic needs 443# to be late, so devices which attach to it are attached late. But it 444# needs to be before its isa and pci attachments. This answer is 445# non-optimal, but I don't have a better answer right now. 446 447# TCIC pcmcia controller 448# XXX this needs to be done very late, so it's done here. This feels 449# like a kludge, but it might be for the best. 450 451defparam TCIC_ISA_ALLOC_IOBASE 452defparam TCIC_ISA_ALLOC_IOSIZE 453defparam TCIC_ISA_INTR_ALLOC_MASK 454 455device tcic: pcmciabus 456file dev/ic/tcic2.c tcic 457 458# TCIC pcmcia controller 459attach tcic at isa with tcic_isa 460file dev/isa/tcic2_isa.c tcic_isa 461 462# this wants to be probed as late as possible. 463# 464# Machine-independent PCMCIA drivers 465# 466include "dev/pcmcia/files.pcmcia" 467 468 469include "dev/usb/files.usb" 470 471include "dev/bluetooth/files.bluetooth" 472 473include "dev/ieee1394/files.ieee1394" 474 475include "arch/i386/pnpbios/files.pnpbios" 476 477include "dev/acpi/files.acpi" 478file arch/i386/acpi/acpi_wakeup.c acpi 479 480# Toshiba VALD 481device vald 482attach vald at acpinodebus with vald_acpi 483file arch/i386/acpi/vald_acpi.c vald_acpi 484 485# Sony SPIC (jog dial etc.) 486attach spic at acpinodebus with spic_acpi 487file arch/i386/acpi/spic_acpi.c spic_acpi 488 489# Sony Misc (brightness etc.) 490device sony 491attach sony at acpinodebus with sony_acpi 492file arch/i386/acpi/sony_acpi.c sony_acpi 493 494# Numeric Processing Extension; Math Co-processor 495attach npx at acpinodebus with npx_acpi 496file arch/i386/acpi/npx_acpi.c npx_acpi 497 498device vesabios {} 499attach vesabios at vesabiosbus 500file arch/i386/bios/vesabios.c vesabios needs-flag 501defflag opt_vesabios.h VESABIOSVERBOSE 502 503include "dev/rasops/files.rasops" 504 505device vesafb: wsemuldisplaydev, vcons, rasops8, rasops16, rasops32, splash, bioscall 506attach vesafb at vesabios 507file arch/i386/bios/vesafb.c vesafb needs-flag 508defparam opt_vesafb.h VESAFB_WIDTH VESAFB_HEIGHT VESAFB_DEPTH 509defflag opt_vesafb.h VESAFB_PM 510 511device vesatext 512attach vesatext at vesabios 513file arch/i386/bios/vesa_text.c vesatext 514 515# Enhanced SpeedStep 516file arch/i386/i386/est.c enhanced_speedstep 517defflag opt_est.h EST_FREQ_USERWRITE 518 519# AMD PowerNow K7 520file arch/i386/i386/powernow_k7.c powernow_k7 521 522include "arch/i386/conf/majors.i386" 523