Import 2.1.92pre2
[davej-history.git] / include / linux / pci.h
blobb70e74ee7d44370c82d7b1847238050078590c30
1 /*
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
9 *
10 * PCI BIOS Specification Revision
11 * PCI Local Bus Specification
12 * PCI System Design Guide
14 * PCI Special Interest Group
15 * M/S HF3-15A
16 * 5200 N.E. Elam Young Parkway
17 * Hillsboro, Oregon 97124-6497
18 * +1 (503) 696-2000
19 * +1 (800) 433-5177
21 * Manuals are $25 each or $50 for all three, plus $7 shipping
22 * within the United States, $35 abroad.
25 #ifndef LINUX_PCI_H
26 #define LINUX_PCI_H
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
63 revision */
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
80 * 1 bits are decoded.
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:
929 * 7:3 = slot
930 * 2:0 = function
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)
939 #ifdef __KERNEL__
941 * There is one pci_dev structure for each slot-number/function-number
942 * combination:
944 struct pci_dev {
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];
975 struct pci_bus {
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 */
close