1# $NetBSD: files.i386,v 1.338 2008/06/13 17:26:33 christos Exp $ 2# 3# new style config file for i386 architecture 4# 5 6version 20071109 7 8ifndef xen 9 10# maxpartitions must be first item in files.${ARCH}.newconf 11maxpartitions 8 12 13maxusers 2 16 128 14 15defparam opt_kernbase.h KERNBASE 16 17# delay before cpu_reset() for reboot. 18defparam CPURESET_DELAY 19 20# Xbox support 21defflag XBOX 22 23# VM86 emulation 24defflag VM86 25defflag KVM86 26 27# User-settable LDT (used by WINE) 28defflag USER_LDT 29 30# X server support in console drivers 31defflag opt_xserver.h XSERVER XSERVER_DDB 32 33# The REAL{BASE,EXT}MEM options 34defparam opt_realmem.h REALBASEMEM REALEXTMEM 35 36# The PHYSMEM_MAX_{SIZE,ADDR} optionms 37defparam opt_physmem.h PHYSMEM_MAX_ADDR PHYSMEM_MAX_SIZE 38 39# understand boot device passed by pre-1.3 bootblocks 40defflag COMPAT_OLDBOOT 41 42# PCI BIOS options 43defflag opt_pcibios.h PCIBIOS PCIBIOSVERBOSE 44 PCIBIOS_INTR_GUESS PCIINTR_DEBUG 45defparam opt_pcibios.h PCIBIOS_IRQS_HINT 46 47# No unmapped page below kernel stack 48defflag NOREDZONE 49 50# kernel stack debug 51defflag opt_kstack_dr0.h KSTACK_CHECK_DR0 52 53# Beep on halt 54defflag opt_beep.h BEEP_ONHALT 55defparam opt_beep.h BEEP_ONHALT_COUNT=3 56defparam opt_beep.h BEEP_ONHALT_PITCH=1500 57defparam opt_beep.h BEEP_ONHALT_PERIOD=250 58 59# Multiboot support 60defflag opt_multiboot.h MULTIBOOT 61obsolete defparam MULTIBOOT_SYMTAB_SPACE 62file arch/i386/i386/multiboot.c multiboot 63 64# PowerNow K7 65defflag POWERNOW_K7 66 67file arch/i386/i386/autoconf.c 68file arch/i386/i386/busfunc.S 69file arch/i386/i386/cpufunc.S 70file arch/i386/i386/cpu_in_cksum.S (inet | inet6) & cpu_in_cksum 71file arch/i386/i386/db_dbgreg.S ddb | kstack_check_dr0 72file arch/i386/i386/db_disasm.c ddb 73file arch/i386/i386/db_interface.c ddb 74file arch/i386/i386/db_memrw.c ddb | kgdb 75file arch/i386/i386/db_trace.c ddb 76file arch/i386/i386/dumpsys.c 77file kern/subr_disk_mbr.c disk 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/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 & md 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, ioapicbus, apmbus, pnpbiosbus, vesabiosbus, ipmibus, 147 bioscall 148attach mainbus at root 149file arch/i386/i386/mainbus.c mainbus 150 151# 152# PCI-only drivers 153# XXX MUST BE INCLUDED BEFORE files.isa, as long as files.isa attaches 154# XXX devices to 'pci'. 155# 156include "dev/pci/files.pci" 157include "dev/pci/files.agp" 158file arch/i386/pci/pcibios.c pcibios 159file arch/i386/pci/pci_intr_fixup.c pcibios & pci_intr_fixup 160file arch/i386/pci/piix.c pcibios & pci_intr_fixup 161file arch/i386/pci/opti82c558.c pcibios & pci_intr_fixup 162file arch/i386/pci/opti82c700.c pcibios & pci_intr_fixup 163file arch/i386/pci/sis85c503.c pcibios & pci_intr_fixup 164file arch/i386/pci/via82c586.c pcibios & pci_intr_fixup 165file arch/i386/pci/via8231.c pcibios & pci_intr_fixup 166file arch/i386/pci/amd756.c pcibios & pci_intr_fixup 167file arch/i386/pci/ali1543.c pcibios & pci_intr_fixup 168defparam PCI_CONF_MODE 169file arch/i386/pci/pcic_pci_machdep.c pcic_pci 170 171# x86 specific PCI hardware 172include "arch/x86/pci/files.pci" 173 174# AMD Elan SC520 System Controller (PCI-Host bridge) 175define elanparbus { } 176define elanpexbus { } 177device elansc: sysmon_wdog, gpiobus, elanparbus, elanpexbus, pcibus 178attach elansc at pcibus 179 180file arch/i386/pci/elan520.c elansc 181 182device elanpar 183attach elanpar at elanparbus 184 185device elanpex 186attach elanpex at elanpexbus 187 188# AMD Geode CS5535 Companion IDE controller 189device gcscide: ata, ata_dma, ata_udma, pciide_common, wdc_common 190attach gcscide at pci 191file arch/i386/pci/gcscide.c gcscide 192 193# AMD Geode CS5536 Companion EHCI 194device gcscehci: usbus 195attach gcscehci at pci 196file arch/i386/pci/gcscehci.c gcscehci 197 198# AMD Geode SC1100 GCB area 199device geodegcb {} 200attach geodegcb at pci 201file arch/i386/pci/geode.c geodegcb 202 203# AMD Geode SC1100 Watchdog Timer 204device geodewdog: sysmon_wdog, geodegcb 205attach geodewdog at geodegcb 206file arch/i386/pci/geodewdg.c geodewdog 207 208# AMD Geode SC1100 high resolution counter 209device geodecntr: geodegcb 210attach geodecntr at geodegcb 211file arch/i386/pci/geodecntr.c geodecntr 212 213# PCI-EISA bridges 214device pceb: eisabus, isabus 215attach pceb at pci 216file arch/i386/pci/pceb.c pceb 217 218# PCI-ISA bridges 219device gscpcib: isabus, gpiobus 220attach gscpcib at pci 221file arch/i386/pci/gscpcib.c gscpcib 222 223# AMD Geode CS5535/CS5536 PCI-ISA bridge 224device gcscpcib: isabus, sysmon_wdog, gpiobus 225attach gcscpcib at pci 226file arch/i386/pci/gcscpcib.c gcscpcib 227 228device piixpcib: isabus, bioscall 229attach piixpcib at pci 230file arch/i386/pci/piixpcib.c piixpcib 231 232device viapcib: isabus, i2cbus 233attach viapcib at pci 234file arch/i386/pci/viapcib.c viapcib 235 236# PCI-MCA bridges 237device pcmb: mcabus 238attach pcmb at pci 239file arch/i386/pci/pcmb.c pcmb 240 241device p64h2apic 242attach p64h2apic at pci 243file arch/i386/pci/p64h2apic.c p64h2apic 244 245 246# 247# ISA and mixed ISA+EISA or ISA+PCI drivers 248# 249 250include "dev/isa/files.isa" 251 252# PC clock 253file arch/x86/isa/clock.c isa 254 255# TSC support 256file arch/x86/x86/tsc.c 257 258# Numeric Processing Extension; Math Co-processor 259device npx 260file arch/i386/isa/npx.c npx needs-flag 261 262attach npx at isa with npx_isa 263file arch/i386/isa/npx_isa.c npx_isa 264 265# PC Mice: Logitech-style and Microsoft-style 266device lms: wsmousedev 267attach lms at isa 268file arch/i386/isa/lms.c lms 269device mms: wsmousedev 270attach mms at isa 271file arch/i386/isa/mms.c mms 272 273include "dev/pckbport/files.pckbport" 274 275device sysbeep 276attach sysbeep at pcppi 277 278# Floppy disk controller 279device fdc {drive = -1}: isadma 280file dev/isa/fd.c fdc needs-flag 281 282attach fdc at isa with fdc_isa 283file dev/isa/fdc_isa.c fdc_isa 284 285device fd: disk 286attach fd at fdc 287 288# Adaptec AHA-284x VL SCSI controllers 289# device declaration in sys/conf/files 290attach ahc at isa with ahc_isa: ahc_aic77xx, smc93cx6 291file arch/i386/isa/ahc_isa.c ahc_isa 292 293# 294# EISA-only drivers 295# 296 297include "dev/eisa/files.eisa" 298file arch/i386/eisa/eisa_machdep.c eisa 299 300# 301# MCA-only drivers 302# 303 304device mca {[slot = -1]} : bioscall 305include "dev/mca/files.mca" 306file arch/i386/mca/mca_machdep.c mca 307 308# ISA Plug 'n Play devices 309file arch/i386/isa/isapnp_machdep.c isapnp 310 311# 312# VME support 313# 314include "dev/vme/files.vme" 315 316# 317# GPIB support 318# 319include "dev/gpib/files.gpib" 320 321# 322# CMOS RAM 323# 324defpseudo cmos 325file arch/i386/isa/cmos.c cmos needs-flag 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# XBox LED & system support 339file arch/i386/xbox/xbox.c xbox 340 341# XBox X3LCD support (*very* rudimentary) 342file arch/i386/xbox/xboxlcd.c xbox 343 344# XBox framebuffer support 345device xboxfb: wsemuldisplaydev, rasops32, vcons 346attach xboxfb at pci 347file arch/i386/xbox/xboxfb.c xboxfb needs-flag 348 349# 350# Compatibility modules 351# 352 353# VM86 mode 354file arch/i386/i386/vm86.c vm86 355 356# VM86 in kernel 357file arch/i386/i386/kvm86.c kvm86 358file arch/i386/i386/kvm86call.S kvm86 359 360# Binary compatibility with previous NetBSD releases (COMPAT_XX) 361file arch/i386/i386/compat_13_machdep.c compat_13 362file arch/i386/i386/compat_16_machdep.c compat_16 | compat_ibcs2 363 364# SVR4 binary compatibility (COMPAT_SVR4) 365include "compat/svr4/files.svr4" 366file arch/i386/i386/svr4_machdep.c compat_svr4 367file arch/i386/i386/svr4_sigcode.S compat_svr4 368file arch/i386/i386/svr4_syscall.c compat_svr4 369 370# MACH binary compatibility (COMPAT_MACH) 371include "compat/mach/files.mach" 372file arch/i386/i386/mach_machdep.c compat_mach | compat_darwin 373file arch/i386/i386/mach_sigcode.S compat_mach | compat_darwin 374file arch/i386/i386/mach_syscall.c compat_mach | compat_darwin 375file arch/i386/i386/darwin_commpage_machdep.S compat_darwin 376file arch/i386/i386/macho_machdep.c exec_macho 377 378# DARWIN binary compatibility (COMPAT_DARWIN) 379include "compat/darwin/files.darwin" 380file arch/i386/i386/darwin_machdep.c compat_darwin 381 382# iBCS-2 binary compatibility (COMPAT_IBCS2) 383include "compat/ibcs2/files.ibcs2" 384file arch/i386/i386/ibcs2_machdep.c compat_ibcs2 385file arch/i386/i386/ibcs2_sigcode.S compat_ibcs2 386file arch/i386/i386/ibcs2_syscall.c compat_ibcs2 387 388# Linux binary compatibility (COMPAT_LINUX) 389include "compat/linux/files.linux" 390include "compat/linux/arch/i386/files.linux_i386" 391file arch/i386/i386/linux_sigcode.S compat_linux 392file arch/i386/i386/linux_syscall.c compat_linux 393file arch/x86/x86/linux_trap.c compat_linux 394 395# FreeBSD binary compatibility (COMPAT_FREEBSD) 396include "compat/freebsd/files.freebsd" 397file arch/i386/i386/freebsd_machdep.c compat_freebsd 398file arch/i386/i386/freebsd_sigcode.S compat_freebsd 399file arch/i386/i386/freebsd_syscall.c compat_freebsd 400 401# NDIS compatibilty (COMPAT_NDIS) 402include "compat/ndis/files.ndis" 403 404# Win32 binary compatibility (COMPAT_PECOFF) 405include "compat/pecoff/files.pecoff" 406 407# OSS audio driver compatibility 408include "compat/ossaudio/files.ossaudio" 409 410# 411# CARDBUS 412# 413include "dev/cardbus/files.cardbus" 414file arch/i386/i386/rbus_machdep.c cardbus 415 416# XXXX pcic here because it needs to be late. The catch: pcic needs 417# to be late, so devices which attach to it are attached late. But it 418# needs to be before its isa and pci attachments. This answer is 419# non-optimal, but I don't have a better answer right now. 420 421# PCIC pcmcia controller 422# XXX this needs to be done very late, so it's done here. This feels 423# like a kludge, but it might be for the best. 424 425defparam PCIC_ISA_ALLOC_IOBASE 426defparam PCIC_ISA_ALLOC_IOSIZE 427defparam PCIC_ISA_INTR_ALLOC_MASK 428 429device pcic: pcmciabus 430file dev/ic/i82365.c pcic 431 432# PCIC pcmcia controller on ISA bus. 433attach pcic at isa with pcic_isa 434file dev/isa/i82365_isa.c pcic_isa 435 436# PCIC pcmcia controller on PCI bus. 437attach pcic at pci with pcic_pci 438file dev/pci/i82365_pci.c pcic_pci 439 440# PCIC pcmcia controller on PnP board 441attach pcic at isapnp with pcic_isapnp 442file dev/isapnp/i82365_isapnp.c pcic_isapnp 443 444# Code common to ISA and ISAPnP attachments 445file dev/isa/i82365_isasubr.c pcic_isa | pcic_isapnp | pcic_pci 446 447# XXXX tcic here because it needs to be late. The catch: tcic needs 448# to be late, so devices which attach to it are attached late. But it 449# needs to be before its isa and pci attachments. This answer is 450# non-optimal, but I don't have a better answer right now. 451 452# TCIC pcmcia controller 453# XXX this needs to be done very late, so it's done here. This feels 454# like a kludge, but it might be for the best. 455 456defparam TCIC_ISA_ALLOC_IOBASE 457defparam TCIC_ISA_ALLOC_IOSIZE 458defparam TCIC_ISA_INTR_ALLOC_MASK 459 460device tcic: pcmciabus 461file dev/ic/tcic2.c tcic 462 463# TCIC pcmcia controller 464attach tcic at isa with tcic_isa 465file dev/isa/tcic2_isa.c tcic_isa 466 467# this wants to be probed as late as possible. 468# 469# Machine-independent PCMCIA drivers 470# 471include "dev/pcmcia/files.pcmcia" 472 473 474include "dev/usb/files.usb" 475 476include "dev/bluetooth/files.bluetooth" 477 478include "dev/ieee1394/files.ieee1394" 479 480include "arch/i386/pnpbios/files.pnpbios" 481 482include "dev/acpi/files.acpi" 483file arch/i386/acpi/acpi_wakeup_low.S acpi 484 485# Toshiba VALD 486device vald 487attach vald at acpinodebus with vald_acpi 488file arch/i386/acpi/vald_acpi.c vald_acpi 489 490# Sony SPIC (jog dial etc.) 491attach spic at acpinodebus with spic_acpi 492file arch/i386/acpi/spic_acpi.c spic_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 503device vesafb: displaydev, wsemuldisplaydev, vcons, rasops8, rasops16, rasops32, splash, bioscall 504attach vesafb at vesabios 505file arch/i386/bios/vesafb.c vesafb needs-flag 506defparam opt_vesafb.h VESAFB_WIDTH VESAFB_HEIGHT VESAFB_DEPTH 507defflag opt_vesafb.h VESAFB_PM 508 509device vesatext 510attach vesatext at vesabios 511file arch/i386/bios/vesa_text.c vesatext 512 513# AMD PowerNow K7 514file arch/i386/i386/powernow_k7.c powernow_k7 515 516# AMD Geode LX Security Block 517device glxsb: opencrypto 518attach glxsb at pci 519file arch/i386/pci/glxsb.c glxsb 520 521include "arch/i386/conf/majors.i386" 522endif #xen 523