2 * $Id: pci.h,v 1.51 1997/12/27 13:55:23 mj Exp $ 4 * PCI defines and function prototypes 5 * Copyright 1994, Drew Eckhardt 6 * Copyright 1997, Martin Mares <mj@atrey.karlin.mff.cuni.cz> 8 * For more information, please consult 10 * PCI BIOS Specification Revision 11 * PCI Local Bus Specification 12 * PCI System Design Guide 14 * PCI Special Interest Group 16 * 5200 N.E. Elam Young Parkway 17 * Hillsboro, Oregon 97124-6497 21 * Manuals are $25 each or $50 for all three, plus $7 shipping 22 * within the United States, $35 abroad. 29 * Under PCI, each device has 256 bytes of configuration address space, 30 * of which the first 64 bytes are standardized as follows: 32 #define PCI_VENDOR_ID 0x00/* 16 bits */ 33 #define PCI_DEVICE_ID 0x02/* 16 bits */ 34 #define PCI_COMMAND 0x04/* 16 bits */ 35 #define PCI_COMMAND_IO 0x1/* Enable response in I/O space */ 36 #define PCI_COMMAND_MEMORY 0x2/* Enable response in Memory space */ 37 #define PCI_COMMAND_MASTER 0x4/* Enable bus mastering */ 38 #define PCI_COMMAND_SPECIAL 0x8/* Enable response to special cycles */ 39 #define PCI_COMMAND_INVALIDATE 0x10/* Use memory write and invalidate */ 40 #define PCI_COMMAND_VGA_PALETTE 0x20/* Enable palette snooping */ 41 #define PCI_COMMAND_PARITY 0x40/* Enable parity checking */ 42 #define PCI_COMMAND_WAIT 0x80/* Enable address/data stepping */ 43 #define PCI_COMMAND_SERR 0x100/* Enable SERR */ 44 #define PCI_COMMAND_FAST_BACK 0x200/* Enable back-to-back writes */ 46 #define PCI_STATUS 0x06/* 16 bits */ 47 #define PCI_STATUS_66MHZ 0x20/* Support 66 Mhz PCI 2.1 bus */ 48 #define PCI_STATUS_UDF 0x40/* Support User Definable Features */ 50 #define PCI_STATUS_FAST_BACK 0x80/* Accept fast-back to back */ 51 #define PCI_STATUS_PARITY 0x100/* Detected parity error */ 52 #define PCI_STATUS_DEVSEL_MASK 0x600/* DEVSEL timing */ 53 #define PCI_STATUS_DEVSEL_FAST 0x000 54 #define PCI_STATUS_DEVSEL_MEDIUM 0x200 55 #define PCI_STATUS_DEVSEL_SLOW 0x400 56 #define PCI_STATUS_SIG_TARGET_ABORT 0x800/* Set on target abort */ 57 #define PCI_STATUS_REC_TARGET_ABORT 0x1000/* Master ack of " */ 58 #define PCI_STATUS_REC_MASTER_ABORT 0x2000/* Set on master abort */ 59 #define PCI_STATUS_SIG_SYSTEM_ERROR 0x4000/* Set when we drive SERR */ 60 #define PCI_STATUS_DETECTED_PARITY 0x8000/* Set on parity error */ 62 #define PCI_CLASS_REVISION 0x08/* High 24 bits are class, low 8 64 #define PCI_REVISION_ID 0x08/* Revision ID */ 65 #define PCI_CLASS_PROG 0x09/* Reg. Level Programming Interface */ 66 #define PCI_CLASS_DEVICE 0x0a/* Device class */ 68 #define PCI_CACHE_LINE_SIZE 0x0c/* 8 bits */ 69 #define PCI_LATENCY_TIMER 0x0d/* 8 bits */ 70 #define PCI_HEADER_TYPE 0x0e/* 8 bits */ 71 #define PCI_BIST 0x0f/* 8 bits */ 72 #define PCI_BIST_CODE_MASK 0x0f/* Return result */ 73 #define PCI_BIST_START 0x40/* 1 to start BIST, 2 secs or less */ 74 #define PCI_BIST_CAPABLE 0x80/* 1 if BIST capable */ 77 * Base addresses specify locations in memory or I/O space. 78 * Decoded size can be determined by writing a value of 79 * 0xffffffff to the register, and reading it back. Only 82 #define PCI_BASE_ADDRESS_0 0x10/* 32 bits */ 83 #define PCI_BASE_ADDRESS_1 0x14/* 32 bits */ 84 #define PCI_BASE_ADDRESS_2 0x18/* 32 bits [htype 0 only] */ 85 #define PCI_BASE_ADDRESS_3 0x1c/* 32 bits */ 86 #define PCI_BASE_ADDRESS_4 0x20/* 32 bits */ 87 #define PCI_BASE_ADDRESS_5 0x24/* 32 bits */ 88 #define PCI_BASE_ADDRESS_SPACE 0x01/* 0 = memory, 1 = I/O */ 89 #define PCI_BASE_ADDRESS_SPACE_IO 0x01 90 #define PCI_BASE_ADDRESS_SPACE_MEMORY 0x00 91 #define PCI_BASE_ADDRESS_MEM_TYPE_MASK 0x06 92 #define PCI_BASE_ADDRESS_MEM_TYPE_32 0x00/* 32 bit address */ 93 #define PCI_BASE_ADDRESS_MEM_TYPE_1M 0x02/* Below 1M */ 94 #define PCI_BASE_ADDRESS_MEM_TYPE_64 0x04/* 64 bit address */ 95 #define PCI_BASE_ADDRESS_MEM_PREFETCH 0x08/* prefetchable? */ 96 #define PCI_BASE_ADDRESS_MEM_MASK (~0x0fUL) 97 #define PCI_BASE_ADDRESS_IO_MASK (~0x03UL) 98 /* bit 1 is reserved if address_space = 1 */ 100 /* Header type 0 (normal devices) */ 101 #define PCI_CARDBUS_CIS 0x28 102 #define PCI_SUBSYSTEM_ID 0x2c 103 #define PCI_SUBSYSTEM_VENDOR_ID 0x2e 104 #define PCI_ROM_ADDRESS 0x30/* 32 bits */ 105 #define PCI_ROM_ADDRESS_ENABLE 0x01/* Write 1 to enable ROM, 106 bits 31..11 are address, 107 10..2 are reserved */ 108 /* 0x34-0x3b are reserved */ 109 #define PCI_INTERRUPT_LINE 0x3c/* 8 bits */ 110 #define PCI_INTERRUPT_PIN 0x3d/* 8 bits */ 111 #define PCI_MIN_GNT 0x3e/* 8 bits */ 112 #define PCI_MAX_LAT 0x3f/* 8 bits */ 114 /* Header type 1 (PCI-to-PCI bridges) */ 115 #define PCI_PRIMARY_BUS 0x18/* Primary bus number */ 116 #define PCI_SECONDARY_BUS 0x19/* Secondary bus number */ 117 #define PCI_SUBORDINATE_BUS 0x1a/* Highest bus number behind the bridge */ 118 #define PCI_SEC_LATENCY_TIMER 0x1b/* Latency timer for secondary interface */ 119 #define PCI_IO_BASE 0x1c/* I/O range behind the bridge */ 120 #define PCI_IO_LIMIT 0x1d 121 #define PCI_IO_RANGE_TYPE_MASK 0x0f/* I/O bridging type */ 122 #define PCI_IO_RANGE_TYPE_16 0x00 123 #define PCI_IO_RANGE_TYPE_32 0x01 124 #define PCI_IO_RANGE_MASK ~0x0f 125 #define PCI_SEC_STATUS 0x1e/* Secondary status register, only bit 14 used */ 126 #define PCI_MEMORY_BASE 0x20/* Memory range behind */ 127 #define PCI_MEMORY_LIMIT 0x22 128 #define PCI_MEMORY_RANGE_TYPE_MASK 0x0f 129 #define PCI_MEMORY_RANGE_MASK ~0x0f 130 #define PCI_PREF_MEMORY_BASE 0x24/* Prefetchable memory range behind */ 131 #define PCI_PREF_MEMORY_LIMIT 0x26 132 #define PCI_PREF_RANGE_TYPE_MASK 0x0f 133 #define PCI_PREF_RANGE_TYPE_32 0x00 134 #define PCI_PREF_RANGE_TYPE_64 0x01 135 #define PCI_PREF_RANGE_MASK ~0x0f 136 #define PCI_PREF_BASE_UPPER32 0x28/* Upper half of prefetchable memory range */ 137 #define PCI_PREF_LIMIT_UPPER32 0x2c 138 #define PCI_IO_BASE_UPPER16 0x30/* Upper half of I/O addresses */ 139 #define PCI_IO_LIMIT_UPPER16 0x32 140 /* 0x34-0x3b is reserved */ 141 #define PCI_ROM_ADDRESS1 0x38/* Same as PCI_ROM_ADDRESS, but for htype 1 */ 142 /* 0x3c-0x3d are same as for htype 0 */ 143 #define PCI_BRIDGE_CONTROL 0x3e 144 #define PCI_BRIDGE_CTL_PARITY 0x01/* Enable parity detection on secondary interface */ 145 #define PCI_BRIDGE_CTL_SERR 0x02/* The same for SERR forwarding */ 146 #define PCI_BRIDGE_CTL_NO_ISA 0x04/* Disable bridging of ISA ports */ 147 #define PCI_BRIDGE_CTL_VGA 0x08/* Forward VGA addresses */ 148 #define PCI_BRIDGE_CTL_MASTER_ABORT 0x20/* Report master aborts */ 149 #define PCI_BRIDGE_CTL_BUS_RESET 0x40/* Secondary bus reset */ 150 #define PCI_BRIDGE_CTL_FAST_BACK 0x80/* Fast Back2Back enabled on secondary interface */ 152 /* Device classes and subclasses */ 154 #define PCI_CLASS_NOT_DEFINED 0x0000 155 #define PCI_CLASS_NOT_DEFINED_VGA 0x0001 157 #define PCI_BASE_CLASS_STORAGE 0x01 158 #define PCI_CLASS_STORAGE_SCSI 0x0100 159 #define PCI_CLASS_STORAGE_IDE 0x0101 160 #define PCI_CLASS_STORAGE_FLOPPY 0x0102 161 #define PCI_CLASS_STORAGE_IPI 0x0103 162 #define PCI_CLASS_STORAGE_RAID 0x0104 163 #define PCI_CLASS_STORAGE_OTHER 0x0180 165 #define PCI_BASE_CLASS_NETWORK 0x02 166 #define PCI_CLASS_NETWORK_ETHERNET 0x0200 167 #define PCI_CLASS_NETWORK_TOKEN_RING 0x0201 168 #define PCI_CLASS_NETWORK_FDDI 0x0202 169 #define PCI_CLASS_NETWORK_ATM 0x0203 170 #define PCI_CLASS_NETWORK_OTHER 0x0280 172 #define PCI_BASE_CLASS_DISPLAY 0x03 173 #define PCI_CLASS_DISPLAY_VGA 0x0300 174 #define PCI_CLASS_DISPLAY_XGA 0x0301 175 #define PCI_CLASS_DISPLAY_OTHER 0x0380 177 #define PCI_BASE_CLASS_MULTIMEDIA 0x04 178 #define PCI_CLASS_MULTIMEDIA_VIDEO 0x0400 179 #define PCI_CLASS_MULTIMEDIA_AUDIO 0x0401 180 #define PCI_CLASS_MULTIMEDIA_OTHER 0x0480 182 #define PCI_BASE_CLASS_MEMORY 0x05 183 #define PCI_CLASS_MEMORY_RAM 0x0500 184 #define PCI_CLASS_MEMORY_FLASH 0x0501 185 #define PCI_CLASS_MEMORY_OTHER 0x0580 187 #define PCI_BASE_CLASS_BRIDGE 0x06 188 #define PCI_CLASS_BRIDGE_HOST 0x0600 189 #define PCI_CLASS_BRIDGE_ISA 0x0601 190 #define PCI_CLASS_BRIDGE_EISA 0x0602 191 #define PCI_CLASS_BRIDGE_MC 0x0603 192 #define PCI_CLASS_BRIDGE_PCI 0x0604 193 #define PCI_CLASS_BRIDGE_PCMCIA 0x0605 194 #define PCI_CLASS_BRIDGE_NUBUS 0x0606 195 #define PCI_CLASS_BRIDGE_CARDBUS 0x0607 196 #define PCI_CLASS_BRIDGE_OTHER 0x0680 198 #define PCI_BASE_CLASS_COMMUNICATION 0x07 199 #define PCI_CLASS_COMMUNICATION_SERIAL 0x0700 200 #define PCI_CLASS_COMMUNICATION_PARALLEL 0x0701 201 #define PCI_CLASS_COMMUNICATION_OTHER 0x0780 203 #define PCI_BASE_CLASS_SYSTEM 0x08 204 #define PCI_CLASS_SYSTEM_PIC 0x0800 205 #define PCI_CLASS_SYSTEM_DMA 0x0801 206 #define PCI_CLASS_SYSTEM_TIMER 0x0802 207 #define PCI_CLASS_SYSTEM_RTC 0x0803 208 #define PCI_CLASS_SYSTEM_OTHER 0x0880 210 #define PCI_BASE_CLASS_INPUT 0x09 211 #define PCI_CLASS_INPUT_KEYBOARD 0x0900 212 #define PCI_CLASS_INPUT_PEN 0x0901 213 #define PCI_CLASS_INPUT_MOUSE 0x0902 214 #define PCI_CLASS_INPUT_OTHER 0x0980 216 #define PCI_BASE_CLASS_DOCKING 0x0a 217 #define PCI_CLASS_DOCKING_GENERIC 0x0a00 218 #define PCI_CLASS_DOCKING_OTHER 0x0a01 220 #define PCI_BASE_CLASS_PROCESSOR 0x0b 221 #define PCI_CLASS_PROCESSOR_386 0x0b00 222 #define PCI_CLASS_PROCESSOR_486 0x0b01 223 #define PCI_CLASS_PROCESSOR_PENTIUM 0x0b02 224 #define PCI_CLASS_PROCESSOR_ALPHA 0x0b10 225 #define PCI_CLASS_PROCESSOR_POWERPC 0x0b20 226 #define PCI_CLASS_PROCESSOR_CO 0x0b40 228 #define PCI_BASE_CLASS_SERIAL 0x0c 229 #define PCI_CLASS_SERIAL_FIREWIRE 0x0c00 230 #define PCI_CLASS_SERIAL_ACCESS 0x0c01 231 #define PCI_CLASS_SERIAL_SSA 0x0c02 232 #define PCI_CLASS_SERIAL_USB 0x0c03 233 #define PCI_CLASS_SERIAL_FIBER 0x0c04 235 #define PCI_CLASS_OTHERS 0xff 238 * Vendor and card ID's: sort these numerically according to vendor 239 * (and according to card ID within vendor) 241 #define PCI_VENDOR_ID_COMPAQ 0x0e11 242 #define PCI_DEVICE_ID_COMPAQ_1280 0x3033 243 #define PCI_DEVICE_ID_COMPAQ_SMART2P 0xae10 244 #define PCI_DEVICE_ID_COMPAQ_NETEL100 0xae32 245 #define PCI_DEVICE_ID_COMPAQ_NETEL10 0xae34 246 #define PCI_DEVICE_ID_COMPAQ_NETFLEX3I 0xae35 247 #define PCI_DEVICE_ID_COMPAQ_NETEL100D 0xae40 248 #define PCI_DEVICE_ID_COMPAQ_NETEL100PI 0xae43 249 #define PCI_DEVICE_ID_COMPAQ_NETEL100I 0xb011 250 #define PCI_DEVICE_ID_COMPAQ_THUNDER 0xf130 251 #define PCI_DEVICE_ID_COMPAQ_NETFLEX3B 0xf150 253 #define PCI_VENDOR_ID_NCR 0x1000 254 #define PCI_DEVICE_ID_NCR_53C810 0x0001 255 #define PCI_DEVICE_ID_NCR_53C820 0x0002 256 #define PCI_DEVICE_ID_NCR_53C825 0x0003 257 #define PCI_DEVICE_ID_NCR_53C815 0x0004 258 #define PCI_DEVICE_ID_NCR_53C860 0x0006 259 #define PCI_DEVICE_ID_NCR_53C896 0x000b 260 #define PCI_DEVICE_ID_NCR_53C895 0x000c 261 #define PCI_DEVICE_ID_NCR_53C885 0x000d 262 #define PCI_DEVICE_ID_NCR_53C875 0x000f 263 #define PCI_DEVICE_ID_NCR_53C875J 0x008f 265 #define PCI_VENDOR_ID_ATI 0x1002 266 #define PCI_DEVICE_ID_ATI_68800 0x4158 267 #define PCI_DEVICE_ID_ATI_215CT222 0x4354 268 #define PCI_DEVICE_ID_ATI_210888CX 0x4358 269 #define PCI_DEVICE_ID_ATI_215GB 0x4742 270 #define PCI_DEVICE_ID_ATI_215GD 0x4744 271 #define PCI_DEVICE_ID_ATI_215GP 0x4750 272 #define PCI_DEVICE_ID_ATI_215GT 0x4754 273 #define PCI_DEVICE_ID_ATI_215GTB 0x4755 274 #define PCI_DEVICE_ID_ATI_210888GX 0x4758 275 #define PCI_DEVICE_ID_ATI_264VT 0x5654 277 #define PCI_VENDOR_ID_VLSI 0x1004 278 #define PCI_DEVICE_ID_VLSI_82C592 0x0005 279 #define PCI_DEVICE_ID_VLSI_82C593 0x0006 280 #define PCI_DEVICE_ID_VLSI_82C594 0x0007 281 #define PCI_DEVICE_ID_VLSI_82C597 0x0009 282 #define PCI_DEVICE_ID_VLSI_82C541 0x000c 283 #define PCI_DEVICE_ID_VLSI_82C543 0x000d 284 #define PCI_DEVICE_ID_VLSI_82C532 0x0101 285 #define PCI_DEVICE_ID_VLSI_82C534 0x0102 286 #define PCI_DEVICE_ID_VLSI_82C535 0x0104 287 #define PCI_DEVICE_ID_VLSI_82C147 0x0105 288 #define PCI_DEVICE_ID_VLSI_VAS96011 0x0702 290 #define PCI_VENDOR_ID_ADL 0x1005 291 #define PCI_DEVICE_ID_ADL_2301 0x2301 293 #define PCI_VENDOR_ID_NS 0x100b 294 #define PCI_DEVICE_ID_NS_87415 0x0002 295 #define PCI_DEVICE_ID_NS_87410 0xd001 297 #define PCI_VENDOR_ID_TSENG 0x100c 298 #define PCI_DEVICE_ID_TSENG_W32P_2 0x3202 299 #define PCI_DEVICE_ID_TSENG_W32P_b 0x3205 300 #define PCI_DEVICE_ID_TSENG_W32P_c 0x3206 301 #define PCI_DEVICE_ID_TSENG_W32P_d 0x3207 302 #define PCI_DEVICE_ID_TSENG_ET6000 0x3208 304 #define PCI_VENDOR_ID_WEITEK 0x100e 305 #define PCI_DEVICE_ID_WEITEK_P9000 0x9001 306 #define PCI_DEVICE_ID_WEITEK_P9100 0x9100 308 #define PCI_VENDOR_ID_DEC 0x1011 309 #define PCI_DEVICE_ID_DEC_BRD 0x0001 310 #define PCI_DEVICE_ID_DEC_TULIP 0x0002 311 #define PCI_DEVICE_ID_DEC_TGA 0x0004 312 #define PCI_DEVICE_ID_DEC_TULIP_FAST 0x0009 313 #define PCI_DEVICE_ID_DEC_TGA2 0x000D 314 #define PCI_DEVICE_ID_DEC_FDDI 0x000F 315 #define PCI_DEVICE_ID_DEC_TULIP_PLUS 0x0014 316 #define PCI_DEVICE_ID_DEC_21142 0x0019 317 #define PCI_DEVICE_ID_DEC_21052 0x0021 318 #define PCI_DEVICE_ID_DEC_21150 0x0022 319 #define PCI_DEVICE_ID_DEC_21152 0x0024 321 #define PCI_VENDOR_ID_CIRRUS 0x1013 322 #define PCI_DEVICE_ID_CIRRUS_7548 0x0038 323 #define PCI_DEVICE_ID_CIRRUS_5430 0x00a0 324 #define PCI_DEVICE_ID_CIRRUS_5434_4 0x00a4 325 #define PCI_DEVICE_ID_CIRRUS_5434_8 0x00a8 326 #define PCI_DEVICE_ID_CIRRUS_5436 0x00ac 327 #define PCI_DEVICE_ID_CIRRUS_5446 0x00b8 328 #define PCI_DEVICE_ID_CIRRUS_5480 0x00bc 329 #define PCI_DEVICE_ID_CIRRUS_5464 0x00d4 330 #define PCI_DEVICE_ID_CIRRUS_5465 0x00d6 331 #define PCI_DEVICE_ID_CIRRUS_6729 0x1100 332 #define PCI_DEVICE_ID_CIRRUS_6832 0x1110 333 #define PCI_DEVICE_ID_CIRRUS_7542 0x1200 334 #define PCI_DEVICE_ID_CIRRUS_7543 0x1202 335 #define PCI_DEVICE_ID_CIRRUS_7541 0x1204 337 #define PCI_VENDOR_ID_IBM 0x1014 338 #define PCI_DEVICE_ID_IBM_FIRE_CORAL 0x000a 339 #define PCI_DEVICE_ID_IBM_TR 0x0018 340 #define PCI_DEVICE_ID_IBM_82G2675 0x001d 341 #define PCI_DEVICE_ID_IBM_MCA 0x0020 342 #define PCI_DEVICE_ID_IBM_82351 0x0022 343 #define PCI_DEVICE_ID_IBM_SERVERAID 0x002e 344 #define PCI_DEVICE_ID_IBM_MPEG2 0x007d 346 #define PCI_VENDOR_ID_WD 0x101c 347 #define PCI_DEVICE_ID_WD_7197 0x3296 349 #define PCI_VENDOR_ID_AMD 0x1022 350 #define PCI_DEVICE_ID_AMD_LANCE 0x2000 351 #define PCI_DEVICE_ID_AMD_SCSI 0x2020 353 #define PCI_VENDOR_ID_TRIDENT 0x1023 354 #define PCI_DEVICE_ID_TRIDENT_9397 0x9397 355 #define PCI_DEVICE_ID_TRIDENT_9420 0x9420 356 #define PCI_DEVICE_ID_TRIDENT_9440 0x9440 357 #define PCI_DEVICE_ID_TRIDENT_9660 0x9660 358 #define PCI_DEVICE_ID_TRIDENT_9750 0x9750 360 #define PCI_VENDOR_ID_AI 0x1025 361 #define PCI_DEVICE_ID_AI_M1435 0x1435 363 #define PCI_VENDOR_ID_MATROX 0x102B 364 #define PCI_DEVICE_ID_MATROX_MGA_2 0x0518 365 #define PCI_DEVICE_ID_MATROX_MIL 0x0519 366 #define PCI_DEVICE_ID_MATROX_MYS 0x051A 367 #define PCI_DEVICE_ID_MATROX_MIL_2 0x051b 368 #define PCI_DEVICE_ID_MATROX_MIL_2_AGP 0x051f 369 #define PCI_DEVICE_ID_MATROX_MGA_IMP 0x0d10 371 #define PCI_VENDOR_ID_CT 0x102c 372 #define PCI_DEVICE_ID_CT_65545 0x00d8 373 #define PCI_DEVICE_ID_CT_65548 0x00dc 374 #define PCI_DEVICE_ID_CT_65550 0x00e0 375 #define PCI_DEVICE_ID_CT_65554 0x00e4 377 #define PCI_VENDOR_ID_MIRO 0x1031 378 #define PCI_DEVICE_ID_MIRO_36050 0x5601 380 #define PCI_VENDOR_ID_NEC 0x1033 381 #define PCI_DEVICE_ID_NEC_PCX2 0x0046 383 #define PCI_VENDOR_ID_FD 0x1036 384 #define PCI_DEVICE_ID_FD_36C70 0x0000 386 #define PCI_VENDOR_ID_SI 0x1039 387 #define PCI_DEVICE_ID_SI_6201 0x0001 388 #define PCI_DEVICE_ID_SI_6202 0x0002 389 #define PCI_DEVICE_ID_SI_503 0x0008 390 #define PCI_DEVICE_ID_SI_6205 0x0205 391 #define PCI_DEVICE_ID_SI_501 0x0406 392 #define PCI_DEVICE_ID_SI_496 0x0496 393 #define PCI_DEVICE_ID_SI_601 0x0601 394 #define PCI_DEVICE_ID_SI_5107 0x5107 395 #define PCI_DEVICE_ID_SI_5511 0x5511 396 #define PCI_DEVICE_ID_SI_5513 0x5513 397 #define PCI_DEVICE_ID_SI_5571 0x5571 398 #define PCI_DEVICE_ID_SI_5597 0x5597 399 #define PCI_DEVICE_ID_SI_7001 0x7001 401 #define PCI_VENDOR_ID_HP 0x103c 402 #define PCI_DEVICE_ID_HP_J2585A 0x1030 403 #define PCI_DEVICE_ID_HP_J2585B 0x1031 405 #define PCI_VENDOR_ID_PCTECH 0x1042 406 #define PCI_DEVICE_ID_PCTECH_RZ1000 0x1000 407 #define PCI_DEVICE_ID_PCTECH_RZ1001 0x1001 408 #define PCI_DEVICE_ID_PCTECH_SAMURAI_0 0x3000 409 #define PCI_DEVICE_ID_PCTECH_SAMURAI_1 0x3010 410 #define PCI_DEVICE_ID_PCTECH_SAMURAI_IDE 0x3020 412 #define PCI_VENDOR_ID_DPT 0x1044 413 #define PCI_DEVICE_ID_DPT 0xa400 415 #define PCI_VENDOR_ID_OPTI 0x1045 416 #define PCI_DEVICE_ID_OPTI_92C178 0xc178 417 #define PCI_DEVICE_ID_OPTI_82C557 0xc557 418 #define PCI_DEVICE_ID_OPTI_82C558 0xc558 419 #define PCI_DEVICE_ID_OPTI_82C621 0xc621 420 #define PCI_DEVICE_ID_OPTI_82C700 0xc700 421 #define PCI_DEVICE_ID_OPTI_82C701 0xc701 422 #define PCI_DEVICE_ID_OPTI_82C814 0xc814 423 #define PCI_DEVICE_ID_OPTI_82C822 0xc822 424 #define PCI_DEVICE_ID_OPTI_82C825 0xd568 426 #define PCI_VENDOR_ID_SGS 0x104a 427 #define PCI_DEVICE_ID_SGS_2000 0x0008 428 #define PCI_DEVICE_ID_SGS_1764 0x0009 430 #define PCI_VENDOR_ID_BUSLOGIC 0x104B 431 #define PCI_DEVICE_ID_BUSLOGIC_MULTIMASTER_NC 0x0140 432 #define PCI_DEVICE_ID_BUSLOGIC_MULTIMASTER 0x1040 433 #define PCI_DEVICE_ID_BUSLOGIC_FLASHPOINT 0x8130 435 #define PCI_VENDOR_ID_TI 0x104c 436 #define PCI_DEVICE_ID_TI_TVP4010 0x3d04 437 #define PCI_DEVICE_ID_TI_TVP4020 0x3d07 438 #define PCI_DEVICE_ID_TI_PCI1130 0xac12 439 #define PCI_DEVICE_ID_TI_PCI1131 0xac15 440 #define PCI_DEVICE_ID_TI_PCI1250 0xac16 442 #define PCI_VENDOR_ID_OAK 0x104e 443 #define PCI_DEVICE_ID_OAK_OTI107 0x0107 445 /* Winbond have two vendor IDs! See 0x10ad as well */ 446 #define PCI_VENDOR_ID_WINBOND2 0x1050 447 #define PCI_DEVICE_ID_WINBOND2_89C940 0x0940 449 #define PCI_VENDOR_ID_MOTOROLA 0x1057 450 #define PCI_DEVICE_ID_MOTOROLA_MPC105 0x0001 451 #define PCI_DEVICE_ID_MOTOROLA_MPC106 0x0002 452 #define PCI_DEVICE_ID_MOTOROLA_RAVEN 0x4801 454 #define PCI_VENDOR_ID_PROMISE 0x105a 455 #define PCI_DEVICE_ID_PROMISE_20246 0x4d33 456 #define PCI_DEVICE_ID_PROMISE_5300 0x5300 458 #define PCI_VENDOR_ID_N9 0x105d 459 #define PCI_DEVICE_ID_N9_I128 0x2309 460 #define PCI_DEVICE_ID_N9_I128_2 0x2339 462 #define PCI_VENDOR_ID_UMC 0x1060 463 #define PCI_DEVICE_ID_UMC_UM8673F 0x0101 464 #define PCI_DEVICE_ID_UMC_UM8891A 0x0891 465 #define PCI_DEVICE_ID_UMC_UM8886BF 0x673a 466 #define PCI_DEVICE_ID_UMC_UM8886A 0x886a 467 #define PCI_DEVICE_ID_UMC_UM8881F 0x8881 468 #define PCI_DEVICE_ID_UMC_UM8886F 0x8886 469 #define PCI_DEVICE_ID_UMC_UM9017F 0x9017 470 #define PCI_DEVICE_ID_UMC_UM8886N 0xe886 471 #define PCI_DEVICE_ID_UMC_UM8891N 0xe891 473 #define PCI_VENDOR_ID_X 0x1061 474 #define PCI_DEVICE_ID_X_AGX016 0x0001 476 #define PCI_VENDOR_ID_PICOP 0x1066 477 #define PCI_DEVICE_ID_PICOP_PT86C52X 0x0001 479 #define PCI_VENDOR_ID_APPLE 0x106b 480 #define PCI_DEVICE_ID_APPLE_BANDIT 0x0001 481 #define PCI_DEVICE_ID_APPLE_GC 0x0002 482 #define PCI_DEVICE_ID_APPLE_HYDRA 0x000e 484 #define PCI_VENDOR_ID_NEXGEN 0x1074 485 #define PCI_DEVICE_ID_NEXGEN_82C501 0x4e78 487 #define PCI_VENDOR_ID_QLOGIC 0x1077 488 #define PCI_DEVICE_ID_QLOGIC_ISP1020 0x1020 489 #define PCI_DEVICE_ID_QLOGIC_ISP1022 0x1022 491 #define PCI_VENDOR_ID_CYRIX 0x1078 492 #define PCI_DEVICE_ID_CYRIX_5510 0x0000 493 #define PCI_DEVICE_ID_CYRIX_PCI_MASTER 0x0001 494 #define PCI_DEVICE_ID_CYRIX_5520 0x0002 495 #define PCI_DEVICE_ID_CYRIX_5530_LEGACY 0x0100 496 #define PCI_DEVICE_ID_CYRIX_5530_SMI 0x0101 497 #define PCI_DEVICE_ID_CYRIX_5530_IDE 0x0102 498 #define PCI_DEVICE_ID_CYRIX_5530_AUDIO 0x0103 499 #define PCI_DEVICE_ID_CYRIX_5530_VIDEO 0x0104 501 #define PCI_VENDOR_ID_LEADTEK 0x107d 502 #define PCI_DEVICE_ID_LEADTEK_805 0x0000 504 #define PCI_VENDOR_ID_CONTAQ 0x1080 505 #define PCI_DEVICE_ID_CONTAQ_82C599 0x0600 506 #define PCI_DEVICE_ID_CONTAQ_82C693 0xC693 508 #define PCI_VENDOR_ID_FOREX 0x1083 510 #define PCI_VENDOR_ID_OLICOM 0x108d 511 #define PCI_DEVICE_ID_OLICOM_OC3136 0x0001 512 #define PCI_DEVICE_ID_OLICOM_OC2315 0x0011 513 #define PCI_DEVICE_ID_OLICOM_OC2325 0x0012 514 #define PCI_DEVICE_ID_OLICOM_OC2183 0x0013 515 #define PCI_DEVICE_ID_OLICOM_OC2326 0x0014 516 #define PCI_DEVICE_ID_OLICOM_OC6151 0x0021 518 #define PCI_VENDOR_ID_SUN 0x108e 519 #define PCI_DEVICE_ID_SUN_EBUS 0x1000 520 #define PCI_DEVICE_ID_SUN_HAPPYMEAL 0x1001 521 #define PCI_DEVICE_ID_SUN_PBM 0x8000 523 #define PCI_VENDOR_ID_CMD 0x1095 524 #define PCI_DEVICE_ID_CMD_640 0x0640 525 #define PCI_DEVICE_ID_CMD_643 0x0643 526 #define PCI_DEVICE_ID_CMD_646 0x0646 527 #define PCI_DEVICE_ID_CMD_670 0x0670 529 #define PCI_VENDOR_ID_VISION 0x1098 530 #define PCI_DEVICE_ID_VISION_QD8500 0x0001 531 #define PCI_DEVICE_ID_VISION_QD8580 0x0002 533 #define PCI_VENDOR_ID_BROOKTREE 0x109e 534 #define PCI_DEVICE_ID_BROOKTREE_848 0x0350 535 #define PCI_DEVICE_ID_BROOKTREE_849A 0x0351 536 #define PCI_DEVICE_ID_BROOKTREE_8474 0x8474 538 #define PCI_VENDOR_ID_SIERRA 0x10a8 539 #define PCI_DEVICE_ID_SIERRA_STB 0x0000 541 #define PCI_VENDOR_ID_ACC 0x10aa 542 #define PCI_DEVICE_ID_ACC_2056 0x0000 544 #define PCI_VENDOR_ID_WINBOND 0x10ad 545 #define PCI_DEVICE_ID_WINBOND_83769 0x0001 546 #define PCI_DEVICE_ID_WINBOND_82C105 0x0105 547 #define PCI_DEVICE_ID_WINBOND_83C553 0x0565 549 #define PCI_VENDOR_ID_DATABOOK 0x10b3 550 #define PCI_DEVICE_ID_DATABOOK_87144 0xb106 552 #define PCI_VENDOR_ID_PLX 0x10b5 553 #define PCI_DEVICE_ID_PLX_9080 0x9080 555 #define PCI_VENDOR_ID_3COM 0x10b7 556 #define PCI_DEVICE_ID_3COM_3C590 0x5900 557 #define PCI_DEVICE_ID_3COM_3C595TX 0x5950 558 #define PCI_DEVICE_ID_3COM_3C595T4 0x5951 559 #define PCI_DEVICE_ID_3COM_3C595MII 0x5952 560 #define PCI_DEVICE_ID_3COM_3C900TPO 0x9000 561 #define PCI_DEVICE_ID_3COM_3C900COMBO 0x9001 562 #define PCI_DEVICE_ID_3COM_3C905TX 0x9050 564 #define PCI_VENDOR_ID_SMC 0x10b8 565 #define PCI_DEVICE_ID_SMC_EPIC100 0x0005 567 #define PCI_VENDOR_ID_AL 0x10b9 568 #define PCI_DEVICE_ID_AL_M1445 0x1445 569 #define PCI_DEVICE_ID_AL_M1449 0x1449 570 #define PCI_DEVICE_ID_AL_M1451 0x1451 571 #define PCI_DEVICE_ID_AL_M1461 0x1461 572 #define PCI_DEVICE_ID_AL_M1489 0x1489 573 #define PCI_DEVICE_ID_AL_M1511 0x1511 574 #define PCI_DEVICE_ID_AL_M1513 0x1513 575 #define PCI_DEVICE_ID_AL_M1521 0x1521 576 #define PCI_DEVICE_ID_AL_M1523 0x1523 577 #define PCI_DEVICE_ID_AL_M1531 0x1531 578 #define PCI_DEVICE_ID_AL_M1533 0x1533 579 #define PCI_DEVICE_ID_AL_M3307 0x3307 580 #define PCI_DEVICE_ID_AL_M4803 0x5215 581 #define PCI_DEVICE_ID_AL_M5219 0x5219 582 #define PCI_DEVICE_ID_AL_M5229 0x5229 583 #define PCI_DEVICE_ID_AL_M5237 0x5237 585 #define PCI_VENDOR_ID_MITSUBISHI 0x10ba 587 #define PCI_VENDOR_ID_SURECOM 0x10bd 588 #define PCI_DEVICE_ID_SURECOM_NE34 0x0e34 590 #define PCI_VENDOR_ID_NEOMAGIC 0x10c8 591 #define PCI_DEVICE_ID_NEOMAGIC_MAGICGRAPH_NM2070 0x0001 592 #define PCI_DEVICE_ID_NEOMAGIC_MAGICGRAPH_128V 0x0002 593 #define PCI_DEVICE_ID_NEOMAGIC_MAGICGRAPH_128ZV 0x0003 594 #define PCI_DEVICE_ID_NEOMAGIC_MAGICGRAPH_NM2160 0x0004 596 #define PCI_VENDOR_ID_ASP 0x10cd 597 #define PCI_DEVICE_ID_ASP_ABP940 0x1200 598 #define PCI_DEVICE_ID_ASP_ABP940U 0x1300 599 #define PCI_DEVICE_ID_ASP_ABP940UW 0x2300 601 #define PCI_VENDOR_ID_CERN 0x10dc 602 #define PCI_DEVICE_ID_CERN_SPSB_PMC 0x0001 603 #define PCI_DEVICE_ID_CERN_SPSB_PCI 0x0002 605 #define PCI_VENDOR_ID_NVIDIA 0x10de 607 #define PCI_VENDOR_ID_IMS 0x10e0 608 #define PCI_DEVICE_ID_IMS_8849 0x8849 610 #define PCI_VENDOR_ID_TEKRAM2 0x10e1 611 #define PCI_DEVICE_ID_TEKRAM2_690c 0x690c 613 #define PCI_VENDOR_ID_TUNDRA 0x10e3 614 #define PCI_DEVICE_ID_TUNDRA_CA91C042 0x0000 616 #define PCI_VENDOR_ID_AMCC 0x10e8 617 #define PCI_DEVICE_ID_AMCC_MYRINET 0x8043 618 #define PCI_DEVICE_ID_AMCC_S5933 0x807d 619 #define PCI_DEVICE_ID_AMCC_S5933_HEPC3 0x809c 621 #define PCI_VENDOR_ID_INTERG 0x10ea 622 #define PCI_DEVICE_ID_INTERG_1680 0x1680 623 #define PCI_DEVICE_ID_INTERG_1682 0x1682 625 #define PCI_VENDOR_ID_REALTEK 0x10ec 626 #define PCI_DEVICE_ID_REALTEK_8029 0x8029 627 #define PCI_DEVICE_ID_REALTEK_8129 0x8129 629 #define PCI_VENDOR_ID_TRUEVISION 0x10fa 630 #define PCI_DEVICE_ID_TRUEVISION_T1000 0x000c 632 #define PCI_VENDOR_ID_INIT 0x1101 633 #define PCI_DEVICE_ID_INIT_320P 0x9100 634 #define PCI_DEVICE_ID_INIT_360P 0x9500 636 #define PCI_VENDOR_ID_VIA 0x1106 637 #define PCI_DEVICE_ID_VIA_82C505 0x0505 638 #define PCI_DEVICE_ID_VIA_82C561 0x0561 639 #define PCI_DEVICE_ID_VIA_82C586_1 0x0571 640 #define PCI_DEVICE_ID_VIA_82C576 0x0576 641 #define PCI_DEVICE_ID_VIA_82C585 0x0585 642 #define PCI_DEVICE_ID_VIA_82C586_0 0x0586 643 #define PCI_DEVICE_ID_VIA_82C595 0x0595 644 #define PCI_DEVICE_ID_VIA_82C597_0 0x0597 645 #define PCI_DEVICE_ID_VIA_82C926 0x0926 646 #define PCI_DEVICE_ID_VIA_82C416 0x1571 647 #define PCI_DEVICE_ID_VIA_82C595_97 0x1595 648 #define PCI_DEVICE_ID_VIA_82C586_2 0x3038 649 #define PCI_DEVICE_ID_VIA_82C586_3 0x3040 650 #define PCI_DEVICE_ID_VIA_82C597_1 0x8597 652 #define PCI_VENDOR_ID_VORTEX 0x1119 653 #define PCI_DEVICE_ID_VORTEX_GDT60x0 0x0000 654 #define PCI_DEVICE_ID_VORTEX_GDT6000B 0x0001 655 #define PCI_DEVICE_ID_VORTEX_GDT6x10 0x0002 656 #define PCI_DEVICE_ID_VORTEX_GDT6x20 0x0003 657 #define PCI_DEVICE_ID_VORTEX_GDT6530 0x0004 658 #define PCI_DEVICE_ID_VORTEX_GDT6550 0x0005 659 #define PCI_DEVICE_ID_VORTEX_GDT6x17 0x0006 660 #define PCI_DEVICE_ID_VORTEX_GDT6x27 0x0007 661 #define PCI_DEVICE_ID_VORTEX_GDT6537 0x0008 662 #define PCI_DEVICE_ID_VORTEX_GDT6557 0x0009 663 #define PCI_DEVICE_ID_VORTEX_GDT6x15 0x000a 664 #define PCI_DEVICE_ID_VORTEX_GDT6x25 0x000b 665 #define PCI_DEVICE_ID_VORTEX_GDT6535 0x000c 666 #define PCI_DEVICE_ID_VORTEX_GDT6555 0x000d 667 #define PCI_DEVICE_ID_VORTEX_GDT6x17RP 0x0100 668 #define PCI_DEVICE_ID_VORTEX_GDT6x27RP 0x0101 669 #define PCI_DEVICE_ID_VORTEX_GDT6537RP 0x0102 670 #define PCI_DEVICE_ID_VORTEX_GDT6557RP 0x0103 671 #define PCI_DEVICE_ID_VORTEX_GDT6x11RP 0x0104 672 #define PCI_DEVICE_ID_VORTEX_GDT6x21RP 0x0105 673 #define PCI_DEVICE_ID_VORTEX_GDT6x17RP1 0x0110 674 #define PCI_DEVICE_ID_VORTEX_GDT6x27RP1 0x0111 675 #define PCI_DEVICE_ID_VORTEX_GDT6537RP1 0x0112 676 #define PCI_DEVICE_ID_VORTEX_GDT6557RP1 0x0113 677 #define PCI_DEVICE_ID_VORTEX_GDT6x11RP1 0x0114 678 #define PCI_DEVICE_ID_VORTEX_GDT6x21RP1 0x0115 679 #define PCI_DEVICE_ID_VORTEX_GDT6x17RP2 0x0120 680 #define PCI_DEVICE_ID_VORTEX_GDT6x27RP2 0x0121 681 #define PCI_DEVICE_ID_VORTEX_GDT6537RP2 0x0122 682 #define PCI_DEVICE_ID_VORTEX_GDT6557RP2 0x0123 683 #define PCI_DEVICE_ID_VORTEX_GDT6x11RP2 0x0124 684 #define PCI_DEVICE_ID_VORTEX_GDT6x21RP2 0x0125 686 #define PCI_VENDOR_ID_EF 0x111a 687 #define PCI_DEVICE_ID_EF_ATM_FPGA 0x0000 688 #define PCI_DEVICE_ID_EF_ATM_ASIC 0x0002 690 #define PCI_VENDOR_ID_FORE 0x1127 691 #define PCI_DEVICE_ID_FORE_PCA200PC 0x0210 692 #define PCI_DEVICE_ID_FORE_PCA200E 0x0300 694 #define PCI_VENDOR_ID_IMAGINGTECH 0x112f 695 #define PCI_DEVICE_ID_IMAGINGTECH_ICPCI 0x0000 697 #define PCI_VENDOR_ID_PHILIPS 0x1131 698 #define PCI_DEVICE_ID_PHILIPS_SAA7146 0x7146 700 #define PCI_VENDOR_ID_CYCLONE 0x113c 701 #define PCI_DEVICE_ID_CYCLONE_SDK 0x0001 703 #define PCI_VENDOR_ID_ALLIANCE 0x1142 704 #define PCI_DEVICE_ID_ALLIANCE_PROMOTIO 0x3210 705 #define PCI_DEVICE_ID_ALLIANCE_PROVIDEO 0x6422 706 #define PCI_DEVICE_ID_ALLIANCE_AT24 0x6424 707 #define PCI_DEVICE_ID_ALLIANCE_AT3D 0x643d 709 #define PCI_VENDOR_ID_VMIC 0x114a 710 #define PCI_DEVICE_ID_VMIC_VME 0x7587 712 #define PCI_VENDOR_ID_DIGI 0x114f 713 #define PCI_DEVICE_ID_DIGI_EPC 0x0002 714 #define PCI_DEVICE_ID_DIGI_RIGHTSWITCH 0x0003 715 #define PCI_DEVICE_ID_DIGI_XEM 0x0004 716 #define PCI_DEVICE_ID_DIGI_XR 0x0005 717 #define PCI_DEVICE_ID_DIGI_CX 0x0006 718 #define PCI_DEVICE_ID_DIGI_XRJ 0x0009 719 #define PCI_DEVICE_ID_DIGI_EPCJ 0x000a 721 #define PCI_VENDOR_ID_MUTECH 0x1159 722 #define PCI_DEVICE_ID_MUTECH_MV1000 0x0001 724 #define PCI_VENDOR_ID_RENDITION 0x1163 725 #define PCI_DEVICE_ID_RENDITION_VERITE 0x0001 726 #define PCI_DEVICE_ID_RENDITION_VERITE2100 0x2000 728 #define PCI_VENDOR_ID_TOSHIBA 0x1179 729 #define PCI_DEVICE_ID_TOSHIBA_601 0x0601 730 #define PCI_DEVICE_ID_TOSHIBA_TOPIC95 0x060a 731 #define PCI_DEVICE_ID_TOSHIBA_TOPIC97 0x060f 733 #define PCI_VENDOR_ID_RICOH 0x1180 734 #define PCI_DEVICE_ID_RICOH_RL5C466 0x0466 736 #define PCI_VENDOR_ID_ARTOP 0x1191 737 #define PCI_DEVICE_ID_ARTOP_ATP850UF 0x0005 739 #define PCI_VENDOR_ID_ZEITNET 0x1193 740 #define PCI_DEVICE_ID_ZEITNET_1221 0x0001 741 #define PCI_DEVICE_ID_ZEITNET_1225 0x0002 743 #define PCI_VENDOR_ID_OMEGA 0x119b 744 #define PCI_DEVICE_ID_OMEGA_82C092G 0x1221 746 #define PCI_VENDOR_ID_LITEON 0x11ad 747 #define PCI_DEVICE_ID_LITEON_LNE100TX 0x0002 749 #define PCI_VENDOR_ID_NP 0x11bc 750 #define PCI_DEVICE_ID_NP_PCI_FDDI 0x0001 752 #define PCI_VENDOR_ID_ATT 0x11c1 753 #define PCI_DEVICE_ID_ATT_L56XMF 0x0440 755 #define PCI_VENDOR_ID_SPECIALIX 0x11cb 756 #define PCI_DEVICE_ID_SPECIALIX_XIO 0x4000 757 #define PCI_DEVICE_ID_SPECIALIX_RIO 0x8000 759 #define PCI_VENDOR_ID_AURAVISION 0x11d1 760 #define PCI_DEVICE_ID_AURAVISION_VXP524 0x01f7 762 #define PCI_VENDOR_ID_IKON 0x11d5 763 #define PCI_DEVICE_ID_IKON_10115 0x0115 764 #define PCI_DEVICE_ID_IKON_10117 0x0117 766 #define PCI_VENDOR_ID_ZORAN 0x11de 767 #define PCI_DEVICE_ID_ZORAN_36057 0x6057 768 #define PCI_DEVICE_ID_ZORAN_36120 0x6120 770 #define PCI_VENDOR_ID_COMPEX 0x11f6 771 #define PCI_DEVICE_ID_COMPEX_ENET100VG4 0x0112 772 #define PCI_DEVICE_ID_COMPEX_RL2000 0x1401 774 #define PCI_VENDOR_ID_RP 0x11fe 775 #define PCI_DEVICE_ID_RP8OCTA 0x0001 776 #define PCI_DEVICE_ID_RP8INTF 0x0002 777 #define PCI_DEVICE_ID_RP16INTF 0x0003 778 #define PCI_DEVICE_ID_RP32INTF 0x0004 780 #define PCI_VENDOR_ID_CYCLADES 0x120e 781 #define PCI_DEVICE_ID_CYCLOM_Y_Lo 0x0100 782 #define PCI_DEVICE_ID_CYCLOM_Y_Hi 0x0101 783 #define PCI_DEVICE_ID_CYCLOM_Z_Lo 0x0200 784 #define PCI_DEVICE_ID_CYCLOM_Z_Hi 0x0201 786 #define PCI_VENDOR_ID_O2 0x1217 787 #define PCI_DEVICE_ID_O2_6832 0x6832 789 #define PCI_VENDOR_ID_3DFX 0x121a 790 #define PCI_DEVICE_ID_3DFX_VOODOO 0x0001 791 #define PCI_DEVICE_ID_3DFX_VOODOO2 0x0002 793 #define PCI_VENDOR_ID_SIGMADES 0x1236 794 #define PCI_DEVICE_ID_SIGMADES_6425 0x6401 796 #define PCI_VENDOR_ID_STALLION 0x124d 797 #define PCI_DEVICE_ID_STALLION_ECHPCI832 0x0000 798 #define PCI_DEVICE_ID_STALLION_ECHPCI864 0x0002 799 #define PCI_DEVICE_ID_STALLION_EIOPCI 0x0003 801 #define PCI_VENDOR_ID_OPTIBASE 0x1255 802 #define PCI_DEVICE_ID_OPTIBASE_FORGE 0x1110 803 #define PCI_DEVICE_ID_OPTIBASE_FUSION 0x1210 804 #define PCI_DEVICE_ID_OPTIBASE_VPLEX 0x2110 805 #define PCI_DEVICE_ID_OPTIBASE_VPLEXCC 0x2120 806 #define PCI_DEVICE_ID_OPTIBASE_VQUEST 0x2130 808 #define PCI_VENDOR_ID_ENSONIQ 0x1274 809 #define PCI_DEVICE_ID_ENSONIQ_AUDIOPCI 0x5000 811 #define PCI_VENDOR_ID_PICTUREL 0x12c5 812 #define PCI_DEVICE_ID_PICTUREL_PCIVST 0x0081 814 #define PCI_VENDOR_ID_NVIDIA_SGS 0x12d2 815 #define PCI_DEVICE_ID_NVIDIA_SGS_RIVA128 0x0018 817 #define PCI_VENDOR_ID_SYMPHONY 0x1c1c 818 #define PCI_DEVICE_ID_SYMPHONY_101 0x0001 820 #define PCI_VENDOR_ID_TEKRAM 0x1de1 821 #define PCI_DEVICE_ID_TEKRAM_DC290 0xdc29 823 #define PCI_VENDOR_ID_3DLABS 0x3d3d 824 #define PCI_DEVICE_ID_3DLABS_300SX 0x0001 825 #define PCI_DEVICE_ID_3DLABS_500TX 0x0002 826 #define PCI_DEVICE_ID_3DLABS_DELTA 0x0003 827 #define PCI_DEVICE_ID_3DLABS_PERMEDIA 0x0004 829 #define PCI_VENDOR_ID_AVANCE 0x4005 830 #define PCI_DEVICE_ID_AVANCE_ALG2064 0x2064 831 #define PCI_DEVICE_ID_AVANCE_2302 0x2302 833 #define PCI_VENDOR_ID_NETVIN 0x4a14 834 #define PCI_DEVICE_ID_NETVIN_NV5000SC 0x5000 836 #define PCI_VENDOR_ID_S3 0x5333 837 #define PCI_DEVICE_ID_S3_PLATO_PXS 0x0551 838 #define PCI_DEVICE_ID_S3_ViRGE 0x5631 839 #define PCI_DEVICE_ID_S3_TRIO 0x8811 840 #define PCI_DEVICE_ID_S3_AURORA64VP 0x8812 841 #define PCI_DEVICE_ID_S3_TRIO64UVP 0x8814 842 #define PCI_DEVICE_ID_S3_ViRGE_VX 0x883d 843 #define PCI_DEVICE_ID_S3_868 0x8880 844 #define PCI_DEVICE_ID_S3_928 0x88b0 845 #define PCI_DEVICE_ID_S3_864_1 0x88c0 846 #define PCI_DEVICE_ID_S3_864_2 0x88c1 847 #define PCI_DEVICE_ID_S3_964_1 0x88d0 848 #define PCI_DEVICE_ID_S3_964_2 0x88d1 849 #define PCI_DEVICE_ID_S3_968 0x88f0 850 #define PCI_DEVICE_ID_S3_TRIO64V2 0x8901 851 #define PCI_DEVICE_ID_S3_PLATO_PXG 0x8902 852 #define PCI_DEVICE_ID_S3_ViRGE_DXGX 0x8a01 853 #define PCI_DEVICE_ID_S3_ViRGE_GX2 0x8a10 854 #define PCI_DEVICE_ID_S3_ViRGE_MX 0x8c01 855 #define PCI_DEVICE_ID_S3_ViRGE_MXP 0x8c02 856 #define PCI_DEVICE_ID_S3_ViRGE_MXPMV 0x8c03 857 #define PCI_DEVICE_ID_S3_SONICVIBES 0xca00 859 #define PCI_VENDOR_ID_INTEL 0x8086 860 #define PCI_DEVICE_ID_INTEL_82375 0x0482 861 #define PCI_DEVICE_ID_INTEL_82424 0x0483 862 #define PCI_DEVICE_ID_INTEL_82378 0x0484 863 #define PCI_DEVICE_ID_INTEL_82430 0x0486 864 #define PCI_DEVICE_ID_INTEL_82434 0x04a3 865 #define PCI_DEVICE_ID_INTEL_82092AA_0 0x1221 866 #define PCI_DEVICE_ID_INTEL_82092AA_1 0x1222 867 #define PCI_DEVICE_ID_INTEL_7116 0x1223 868 #define PCI_DEVICE_ID_INTEL_82596 0x1226 869 #define PCI_DEVICE_ID_INTEL_82865 0x1227 870 #define PCI_DEVICE_ID_INTEL_82557 0x1229 871 #define PCI_DEVICE_ID_INTEL_82437 0x122d 872 #define PCI_DEVICE_ID_INTEL_82371FB_0 0x122e 873 #define PCI_DEVICE_ID_INTEL_82371FB_1 0x1230 874 #define PCI_DEVICE_ID_INTEL_82371MX 0x1234 875 #define PCI_DEVICE_ID_INTEL_82437MX 0x1235 876 #define PCI_DEVICE_ID_INTEL_82441 0x1237 877 #define PCI_DEVICE_ID_INTEL_82439 0x1250 878 #define PCI_DEVICE_ID_INTEL_82371SB_0 0x7000 879 #define PCI_DEVICE_ID_INTEL_82371SB_1 0x7010 880 #define PCI_DEVICE_ID_INTEL_82371SB_2 0x7020 881 #define PCI_DEVICE_ID_INTEL_82437VX 0x7030 882 #define PCI_DEVICE_ID_INTEL_82439TX 0x7100 883 #define PCI_DEVICE_ID_INTEL_82371AB_0 0x7110 884 #define PCI_DEVICE_ID_INTEL_82371AB 0x7111 885 #define PCI_DEVICE_ID_INTEL_82371AB_2 0x7112 886 #define PCI_DEVICE_ID_INTEL_82371AB_3 0x7113 887 #define PCI_DEVICE_ID_INTEL_82443LX_0 0x7180 888 #define PCI_DEVICE_ID_INTEL_82443LX_1 0x7181 889 #define PCI_DEVICE_ID_INTEL_P6 0x84c4 890 #define PCI_DEVICE_ID_INTEL_82450GX 0x84c5 892 #define PCI_VENDOR_ID_KTI 0x8e2e 893 #define PCI_DEVICE_ID_KTI_ET32P2 0x3000 895 #define PCI_VENDOR_ID_ADAPTEC 0x9004 896 #define PCI_DEVICE_ID_ADAPTEC_7850 0x5078 897 #define PCI_DEVICE_ID_ADAPTEC_7855 0x5578 898 #define PCI_DEVICE_ID_ADAPTEC_5800 0x5800 899 #define PCI_DEVICE_ID_ADAPTEC_7860 0x6078 900 #define PCI_DEVICE_ID_ADAPTEC_7861 0x6178 901 #define PCI_DEVICE_ID_ADAPTEC_7870 0x7078 902 #define PCI_DEVICE_ID_ADAPTEC_7871 0x7178 903 #define PCI_DEVICE_ID_ADAPTEC_7872 0x7278 904 #define PCI_DEVICE_ID_ADAPTEC_7873 0x7378 905 #define PCI_DEVICE_ID_ADAPTEC_7874 0x7478 906 #define PCI_DEVICE_ID_ADAPTEC_7895 0x7895 907 #define PCI_DEVICE_ID_ADAPTEC_7880 0x8078 908 #define PCI_DEVICE_ID_ADAPTEC_7881 0x8178 909 #define PCI_DEVICE_ID_ADAPTEC_7882 0x8278 910 #define PCI_DEVICE_ID_ADAPTEC_7883 0x8378 911 #define PCI_DEVICE_ID_ADAPTEC_7884 0x8478 913 #define PCI_VENDOR_ID_ATRONICS 0x907f 914 #define PCI_DEVICE_ID_ATRONICS_2015 0x2015 916 #define PCI_VENDOR_ID_HOLTEK 0x9412 917 #define PCI_DEVICE_ID_HOLTEK_6565 0x6565 919 #define PCI_VENDOR_ID_ARK 0xedd8 920 #define PCI_DEVICE_ID_ARK_STING 0xa091 921 #define PCI_DEVICE_ID_ARK_STINGARK 0xa099 922 #define PCI_DEVICE_ID_ARK_2000MT 0xa0a1 925 * The PCI interface treats multi-function devices as independent 926 * devices. The slot/function address of each device is encoded 927 * in a single byte as follows: 932 #define PCI_DEVFN(slot,func) ((((slot) & 0x1f) << 3) | ((func) & 0x07)) 933 #define PCI_SLOT(devfn) (((devfn) >> 3) & 0x1f) 934 #define PCI_FUNC(devfn) ((devfn) & 0x07) 936 /* create an index into the pci_dev base_address[] array from an offset */ 937 #define PCI_BASE_INDEX(o) (((o)-PCI_BASE_ADDRESS_0)>>2) 941 * There is one pci_dev structure for each slot-number/function-number 945 struct pci_bus
*bus
;/* bus this device is on */ 946 struct pci_dev
*sibling
;/* next device on this bus */ 947 struct pci_dev
*next
;/* chain of all devices */ 949 void*sysdata
;/* hook for sys-specific extension */ 951 unsigned int devfn
;/* encoded device & function index */ 952 unsigned short vendor
; 953 unsigned short device
; 954 unsigned intclass;/* 3 bytes: (base,sub,prog-if) */ 955 unsigned int master
:1;/* set if device is master capable */ 957 * In theory, the irq level can be read from configuration 958 * space and all would be fine. However, old PCI chips don't 959 * support these registers and return 0 instead. For example, 960 * the Vision864-P rev 0 chip can uses INTA, but returns 0 in 961 * the interrupt line and pin registers. pci_init() 962 * initializes this field with the value at PCI_INTERRUPT_LINE 963 * and it is the job of pcibios_fixup() to change it if 964 * necessary. The field must not be 0 unless the device 965 * cannot generate interrupts at all. 967 unsigned int irq
;/* irq generated by this device */ 969 /* Base registers for this device, can be adjusted by 970 * pcibios_fixup() as necessary. 972 unsigned long base_address
[6]; 976 struct pci_bus
*parent
;/* parent bus this bridge is on */ 977 struct pci_bus
*children
;/* chain of P2P bridges on this bus */ 978 struct pci_bus
*next
;/* chain of all PCI buses */ 980 struct pci_dev
*self
;/* bridge device as seen by parent */ 981 struct pci_dev
*devices
;/* devices behind this bridge */ 983 void*sysdata
;/* hook for sys-specific extension */ 985 unsigned char number
;/* bus number */ 986 unsigned char primary
;/* number of primary bridge */ 987 unsigned char secondary
;/* number of secondary bridge */ 988 unsigned char subordinate
;/* max number of subordinate buses */ 991 externstruct pci_bus pci_root
;/* root bus */ 992 externstruct pci_dev
*pci_devices
;/* list of all devices */ 993 externstruct pci_dev
*pci_find_dev(unsigned char bus
,unsigned char devfn
); 995 externunsigned longpci_init(unsigned long mem_start
,unsigned long mem_end
); 997 externunsigned intpci_scan_bus(struct pci_bus
*bus
,unsigned long*mem_startp
); 999 externintget_pci_list(char*buf
); 1001 externvoidpci_quirks_init(void); 1003 #endif/* __KERNEL__ */ 1004 #endif/* LINUX_PCI_H */