1# $NetBSD: files.i386,v 1.224 2002/11/25 22:25:13 manu 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 11# APM options 12defflag opt_apm.h APM_DISABLE APM_FORCE_64K_SEGMENTS APM_NO_IDLE 13 APM_NO_STANDBY APM_V10_ONLY APM_NO_V12 APMDEBUG 14 APM_POWER_PRINT APM_ALLOW_BOGUS_SEGMENTS 15 APM_USE_KVM86 16defparam opt_apm.h APMDEBUG_VALUE APM_DISABLE_INTERRUPTS 17 18# Processor type options. 19defflag opt_cputype.h I386_CPU I486_CPU I586_CPU I686_CPU 20 21# delay before cpu_reset() for reboot. 22defparam CPURESET_DELAY 23 24# VM86 emulation 25defflag VM86 26defflag KVM86 27 28# Floating point emulation 29defflag MATH_EMULATE 30 31# User-settable LDT (used by WINE) 32defflag USER_LDT 33 34# Speed hack; make NOPs dummies (might break on some machines) 35defflag DUMMY_NOPS 36 37# MTRR support 38defflag MTRR 39 40# X server support in console drivers 41defflag opt_xserver.h XSERVER XSERVER_DDB 42 43# The REAL{BASE,EXT}MEM options 44defparam opt_realmem.h REALBASEMEM REALEXTMEM 45 46# understand boot device passed by pre-1.3 bootblocks 47defflag COMPAT_OLDBOOT 48 49defflag opt_mpbios.h MPVERBOSE MPDEBUG 50 51# PCI BIOS options 52defflag opt_pcibios.h PCIBIOS PCIBIOSVERBOSE 53 PCIBIOS_ADDR_FIXUP PCIBIOS_BUS_FIXUP 54 PCIBIOS_INTR_FIXUP PCIBIOS_INTR_FIXUP_FORCE 55 PCIBIOS_INTR_GUESS PCIINTR_DEBUG 56defparam opt_pcibios.h PCIBIOS_IRQS_HINT 57 58# Large page size 59defflag LARGEPAGES 60 61# No unmapped page below kernel stack 62defflag NOREDZONE 63 64# kernel stack debug 65defflag opt_kstack_dr0.h KSTACK_CHECK_DR0 66 67file arch/i386/i386/autoconf.c 68file arch/i386/i386/bus_machdep.c 69file arch/i386/i386/consinit.c 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/disksubr.c disk 76file arch/i386/i386/gdt.c 77file arch/i386/i386/i8259.c 78file arch/i386/i386/in_cksum.S inet | inet6 79file arch/i386/i386/intr.c 80file arch/i386/i386/ipkdb_glue.c ipkdb 81file arch/i386/i386/kgdb_machdep.c kgdb 82file arch/i386/i386/machdep.c 83file arch/i386/i386/math_emulate.c math_emulate 84file arch/i386/i386/mem.c 85file arch/i386/i386/microtime.S 86file arch/i386/i386/tsc_microtime.c i586_cpu | i686_cpu 87file arch/i386/i386/mtrr_i686.c mtrr 88file arch/i386/i386/mtrr_k6.c mtrr 89file netns/ns_cksum.c ns 90file arch/i386/i386/pmap.c 91file arch/i386/i386/process_machdep.c 92file arch/i386/i386/procfs_machdep.c procfs 93file arch/i386/i386/softintr.c 94file arch/i386/i386/sys_machdep.c 95file arch/i386/i386/syscall.c 96file arch/i386/i386/trap.c 97file arch/i386/i386/vm_machdep.c 98file dev/cons.c 99 100file arch/i386/i386/mptramp.S multiprocessor 101file arch/i386/i386/lock_machdep.c lockdebug 102file arch/i386/i386/ipifuncs.c multiprocessor 103 104file arch/i386/i386/pmc.c perfctrs 105 106file crypto/des/arch/i386/des_enc.S des 107file crypto/des/arch/i386/des_cbc.S des 108 109file crypto/blowfish/arch/i386/bf_enc.S blowfish 110file crypto/blowfish/arch/i386/bf_cbc.S blowfish 111 112# 113# Machine-independent SCSI drivers 114# 115 116include "dev/scsipi/files.scsipi" 117 118# 119# Machine-independent ATA drivers 120# 121 122include "dev/ata/files.ata" 123 124# Memory Disk for install floppy 125file dev/md_root.c memory_disk_hooks 126 127# 128# Machine-independent I2O drivers 129# 130 131include "dev/i2o/files.i2o" 132 133# attribute used to bring in BIOS trampoline code for real-mode probing 134# of certain devices/BIOS features 135define bioscall 136file arch/i386/i386/bioscall.S bioscall needs-flag 137 138# BIOS32 routines 139define bios32 140file arch/i386/i386/bios32.c bios32 needs-flag 141 142# 143# System bus types 144# 145 146define mainbus { [apid = -1] } 147# XXX BIOS32 only if something that uses it is configured! 148device mainbus: isabus, eisabus, mcabus, pcibus, mainbus, bios32, acpibus 149attach mainbus at root 150file arch/i386/i386/mainbus.c mainbus 151 152# 153# PCI-only drivers 154# XXX MUST BE INCLUDED BEFORE files.isa, as long as files.isa attaches 155# XXX devices to 'pci'. 156# 157 158include "dev/pci/files.pci" 159include "dev/pci/files.agp" 160file arch/i386/pci/pci_machdep.c pci 161file arch/i386/pci/agp_machdep.c agp 162file arch/i386/pci/pcibios.c pcibios 163file arch/i386/pci/pci_intr_fixup.c pcibios & pcibios_intr_fixup 164file arch/i386/pci/piix.c pcibios & pcibios_intr_fixup 165file arch/i386/pci/opti82c558.c pcibios & pcibios_intr_fixup 166file arch/i386/pci/opti82c700.c pcibios & pcibios_intr_fixup 167file arch/i386/pci/sis85c503.c pcibios & pcibios_intr_fixup 168file arch/i386/pci/via82c586.c pcibios & pcibios_intr_fixup 169file arch/i386/pci/amd756.c pcibios & pcibios_intr_fixup 170file arch/i386/pci/ali1543.c pcibios & pcibios_intr_fixup 171file arch/i386/pci/pci_bus_fixup.c pcibios & pcibios_bus_fixup 172file arch/i386/pci/pci_addr_fixup.c pcibios & pcibios_addr_fixup 173defparam PCI_CONF_MODE 174file arch/i386/pci/pciide_machdep.c pciide 175file arch/i386/pci/pcic_pci_machdep.c pcic_pci 176 177# PCI-Host bridge chipsets 178device pchb: pcibus, agpbus, agp_ali, agp_amd, agp_i810, agp_intel, agp_sis, 179 agp_via 180attach pchb at pci 181file arch/i386/pci/pchb.c pchb needs-flag 182file arch/i386/pci/pchb_rnd.c pchb & rnd 183 184# AMD Elan SC520 System Controller (PCI-Host bridge) 185device elansc: sysmon_wdog 186attach elansc at pci 187file arch/i386/pci/elan520.c elansc 188 189# PCI-EISA bridges 190device pceb: eisabus, isabus 191attach pceb at pci 192file arch/i386/pci/pceb.c pceb 193 194# PCI-ISA bridges 195device pcib: isabus 196attach pcib at pci 197file arch/i386/pci/pcib.c pcib 198 199# PCI-MCA bridges 200device pcmb: mcabus 201attach pcmb at pci 202file arch/i386/pci/pcmb.c pcmb 203 204device p64h2apic 205attach p64h2apic at pci 206file arch/i386/pci/p64h2apic.c p64h2apic 207 208 209 210# Game adapter (joystick) 211file arch/i386/isa/joy_timer.c joy 212 213# 214# ISA and mixed ISA+EISA or ISA+PCI drivers 215# 216 217include "dev/isa/files.isa" 218 219# XXX THE FOLLOWING BLOCK SHOULD GO INTO dev/pci/files.pci, BUT CANNOT 220# XXX BECAUSE NOT 'lpt' IS DEFINED IN files.isa, RATHER THAN files. 221# XXX (when the conf/files and files.isa bogons are fixed, this can 222# XXX be fixed as well.) 223 224attach lpt at puc with lpt_puc 225file dev/pci/lpt_puc.c lpt_puc 226 227file arch/i386/isa/isa_machdep.c isa 228 229# PC clock 230file arch/i386/isa/clock.c isa 231file dev/clock_subr.c isa 232 233# Numeric Processing Extension; Math Co-processor 234device npx 235file arch/i386/isa/npx.c npx needs-flag 236 237attach npx at isa with npx_isa 238file arch/i386/isa/npx_isa.c npx_isa 239 240# attribute used to represent the "keyboard controller" 241# XXX should be a real device 242define pckbcport { [irq = -1], [port = -1] } 243 244# PC console support a la "pccons" 245device pc: tty, pckbcport 246attach pc at isa 247device pcconskbd 248attach pcconskbd at pckbc 249file arch/i386/isa/pccons.c pc | pcconskbd needs-flag 250 251# PC Mice; Logitech-style, Microsoft-style, and PS/2-style 252device olms 253attach olms at isa 254file arch/i386/isa/olms.c olms needs-flag 255device lms: wsmousedev 256attach lms at isa 257file arch/i386/isa/lms.c lms 258device omms 259attach omms at isa 260file arch/i386/isa/omms.c omms needs-flag 261device mms: wsmousedev 262attach mms at isa 263file arch/i386/isa/mms.c mms 264 265include "dev/wscons/files.wscons" 266include "dev/wsfont/files.wsfont" 267 268include "dev/pckbc/files.pckbc" 269 270device sysbeep 271attach sysbeep at pcppi 272 273# Floppy disk controller 274device fdc {drive = -1}: isadma 275file dev/isa/fd.c fdc needs-flag 276 277attach fdc at isa with fdc_isa 278file dev/isa/fdc_isa.c fdc_isa 279 280device fd: disk 281attach fd at fdc 282 283# Adaptec AHA-284x VL SCSI controllers 284# device declaration in sys/conf/files 285attach ahc at isa with ahc_isa: ahc_aic77xx, smc93cx6 286file arch/i386/isa/ahc_isa.c ahc_isa 287 288# 289# EISA-only drivers 290# 291 292include "dev/eisa/files.eisa" 293file arch/i386/eisa/eisa_machdep.c eisa 294 295# 296# MCA-only drivers 297# 298 299device mca {[slot = -1]} : bioscall 300include "dev/mca/files.mca" 301file arch/i386/mca/mca_machdep.c mca 302 303# ISA Plug 'n Play devices 304file arch/i386/isa/isapnp_machdep.c isapnp 305 306# 307# VME support 308# 309include "dev/vme/files.vme" 310 311# 312# Other mainbus-attached devices 313# 314 315# Advanced Power Management support (APM) 316device apm: bioscall 317attach apm at mainbus 318file arch/i386/i386/apm.c apm needs-count 319file arch/i386/i386/apmcall.S apm 320 321# Intel SMP specification 1.4 322define mpbios 323file arch/i386/i386/mpbios.c mpbios needs-flag 324 325# CPUS 326 327define cpu { [apid = -1] } 328device cpu 329attach cpu at mainbus 330file arch/i386/i386/cpu.c cpu 331 332# Common APIC support routines 333file arch/i386/i386/apic.c ioapic | lapic 334 335# Local APIC (required for multiprocessor) 336define lapic 337file arch/i386/i386/lapic.c lapic needs-flag 338 339# I/O apics 340device ioapic: bioscall, mpbios, lapic 341attach ioapic at mainbus 342file arch/i386/i386/ioapic.c ioapic needs-flag 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 357 358# SVR4 binary compatibility (COMPAT_SVR4) 359include "compat/svr4/files.svr4" 360file arch/i386/i386/svr4_machdep.c compat_svr4 361file arch/i386/i386/svr4_sigcode.S compat_svr4 362file arch/i386/i386/svr4_syscall.c compat_svr4 363 364# MACH binary compatibility (COMPAT_MACH) 365include "compat/mach/files.mach" 366file arch/i386/i386/mach_machdep.c compat_mach | compat_darwin 367file arch/i386/i386/mach_sigcode.S compat_mach | compat_darwin 368file arch/i386/i386/mach_syscall.c compat_mach | compat_darwin 369file arch/i386/i386/macho_machdep.c exec_macho 370 371# DARWIN binary compatibility (COMPAT_DARWIN) 372include "compat/darwin/files.darwin" 373file arch/i386/i386/darwin_machdep.c compat_darwin 374 375# iBCS-2 binary compatibility (COMPAT_IBCS2) 376include "compat/ibcs2/files.ibcs2" 377file arch/i386/i386/ibcs2_machdep.c compat_ibcs2 378file arch/i386/i386/ibcs2_sigcode.S compat_ibcs2 379file arch/i386/i386/ibcs2_syscall.c compat_ibcs2 380 381# Linux binary compatibility (COMPAT_LINUX) 382include "compat/linux/files.linux" 383include "compat/linux/arch/i386/files.linux_i386" 384file arch/i386/i386/linux_sigcode.S compat_linux 385file arch/i386/i386/linux_syscall.c compat_linux 386file arch/i386/i386/linux_trap.c compat_linux 387 388# FreeBSD binary compatibility (COMPAT_FREEBSD) 389include "compat/freebsd/files.freebsd" 390file arch/i386/i386/freebsd_machdep.c compat_freebsd 391file arch/i386/i386/freebsd_sigcode.S compat_freebsd 392file arch/i386/i386/freebsd_syscall.c compat_freebsd 393 394# a.out binary compatibility (COMPAT_AOUT) 395include "compat/aout/files.aout" 396 397# Win32 binary compatibility (COMPAT_PECOFF) 398include "compat/pecoff/files.pecoff" 399 400# OSS audio driver compatibility 401include "compat/ossaudio/files.ossaudio" 402 403# 404# CARDBUS 405# 406include "dev/cardbus/files.cardbus" 407file arch/i386/i386/rbus_machdep.c cardbus 408 409# XXXX pcic here because it needs to be late. The catch: pcic needs 410# to be late, so devices which attach to it are attached late. But it 411# needs to be before its isa and pci attachments. This answer is 412# non-optimal, but I don't have a better answer right now. 413 414# PCIC pcmcia controller 415# XXX this needs to be done very late, so it's done here. This feels 416# like a kludge, but it might be for the best. 417 418defparam PCIC_ISA_ALLOC_IOBASE 419defparam PCIC_ISA_ALLOC_IOSIZE 420defparam PCIC_ISA_INTR_ALLOC_MASK 421 422device pcic: pcmciabus 423file dev/ic/i82365.c pcic 424 425# PCIC pcmcia controller on ISA bus. 426attach pcic at isa with pcic_isa 427file dev/isa/i82365_isa.c pcic_isa 428 429# PCIC pcmcia controller on PCI bus. 430attach pcic at pci with pcic_pci 431file dev/pci/i82365_pci.c pcic_pci 432 433# PCIC pcmcia controller on PnP board 434attach pcic at isapnp with pcic_isapnp 435file dev/isapnp/i82365_isapnp.c pcic_isapnp 436 437# Code common to ISA and ISAPnP attachments 438file dev/isa/i82365_isasubr.c pcic_isa | pcic_isapnp | pcic_pci 439 440# XXXX tcic here because it needs to be late. The catch: tcic needs 441# to be late, so devices which attach to it are attached late. But it 442# needs to be before its isa and pci attachments. This answer is 443# non-optimal, but I don't have a better answer right now. 444 445# TCIC pcmcia controller 446# XXX this needs to be done very late, so it's done here. This feels 447# like a kludge, but it might be for the best. 448 449defparam TCIC_ISA_ALLOC_IOBASE 450defparam TCIC_ISA_ALLOC_IOSIZE 451defparam TCIC_ISA_INTR_ALLOC_MASK 452 453device tcic: pcmciabus 454file dev/ic/tcic2.c tcic 455 456# TCIC pcmcia controller 457attach tcic at isa with tcic_isa 458file dev/isa/tcic2_isa.c tcic_isa 459 460# this wants to be probed as late as possible. 461# 462# Machine-independent PCMCIA drivers 463# 464include "dev/pcmcia/files.pcmcia" 465 466 467include "dev/usb/files.usb" 468 469include "dev/ieee1394/files.ieee1394" 470 471include "arch/i386/pnpbios/files.pnpbios" 472 473include "dev/acpi/files.acpi" 474file arch/i386/i386/acpi_machdep.c acpi 475file arch/i386/acpi/acpi_wakeup.c acpi 476 477# Toshiba VALD 478device vald 479attach vald at acpi with vald_acpi 480file arch/i386/acpi/vald_acpi.c vald_acpi 481 482# Sony SPIC (jog dial etc.) 483attach spic at acpi with spic_acpi 484file arch/i386/acpi/spic_acpi.c spic_acpi 485 486device vesabios {} 487attach vesabios at mainbus 488file arch/i386/bios/vesabios.c vesabios needs-flag 489defflag opt_vesabios.h VESABIOSVERBOSE 490 491include "dev/rasops/files.rasops" 492 493device vesarasterviii: rasops8 494attach vesarasterviii at vesabios 495file arch/i386/bios/vesa_raster8.c vesarasterviii 496 497device vesatext 498attach vesatext at vesabios 499file arch/i386/bios/vesa_text.c vesatext 500 501include "arch/i386/conf/majors.i386" 502