source: rtems/cpukit/include/rtems/pci.h @ 1b0c122b

4.104.115
Last change on this file since 1b0c122b was 1b0c122b, checked in by Joel Sherrill <joel.sherrill@…>, on 09/28/09 at 21:00:47

2009-09-28 Joel Sherrill <joel.sherrill@…>

  • include/rtems/pci.h: Revert extern inline patch.
  • Property mode set to 100644
File size: 53.4 KB
Line 
1/*
2 *
3 *  PCI defines and function prototypes
4 *  Copyright 1994, Drew Eckhardt
5 *  Copyright 1997, 1998 Martin Mares <mj@atrey.karlin.mff.cuni.cz>
6 *
7 *  For more information, please consult the following manuals (look at
8 *  http://www.pcisig.com/ for how to get them):
9 *
10 *  PCI BIOS Specification
11 *  PCI Local Bus Specification
12 *  PCI to PCI Bridge Specification
13 *  PCI System Design Guide
14 *
15 * $Id$
16 */
17
18#ifndef _RTEMS_PCI_H
19#define _RTEMS_PCI_H
20
21#include <stdint.h>
22
23#ifdef __cplusplus
24extern "C" {
25#endif
26
27/*
28 * Under PCI, each device has 256 bytes of configuration address space,
29 * of which the first 64 bytes are standardized as follows:
30 */
31#define PCI_VENDOR_ID      0x00  /* 16 bits */
32#define PCI_DEVICE_ID      0x02  /* 16 bits */
33
34#define PCI_COMMAND             0x04    /* 16 bits */
35#define PCI_COMMAND_IO          0x0001  /* Enable response in I/O space */
36#define PCI_COMMAND_MEMORY      0x0002  /* Enable response in Memory space */
37#define PCI_COMMAND_MASTER      0x0004  /* Enable bus mastering */
38#define PCI_COMMAND_SPECIAL     0x0008  /* Enable response to special cycles */
39#define PCI_COMMAND_INVALIDATE  0x0010  /* Use memory write and invalidate */
40#define PCI_COMMAND_VGA_PALETTE 0x0020  /* Enable palette snooping */
41#define PCI_COMMAND_PARITY      0x0040  /* Enable parity checking */
42#define PCI_COMMAND_WAIT        0x0080  /* Enable address/data stepping */
43#define PCI_COMMAND_SERR        0x0100  /* Enable SERR */
44#define PCI_COMMAND_FAST_BACK   0x0200  /* Enable back-to-back writes */
45
46#define PCI_STATUS                  0x06   /* 16 bits */
47#define PCI_STATUS_66MHZ            0x0020 /* Support 66 Mhz PCI 2.1 bus */
48#define PCI_STATUS_UDF              0x0040 /* Support User Definable Features */
49#define PCI_STATUS_FAST_BACK        0x0080 /* Accept fast-back to back */
50#define PCI_STATUS_PARITY           0x0100 /* Detected parity error */
51#define PCI_STATUS_DEVSEL_MASK      0x0600 /* DEVSEL timing */
52#define PCI_STATUS_DEVSEL_FAST      0x0000
53#define PCI_STATUS_DEVSEL_MEDIUM    0x0200
54#define PCI_STATUS_DEVSEL_SLOW      0x0400
55#define PCI_STATUS_SIG_TARGET_ABORT 0x0800 /* Set on target abort */
56#define PCI_STATUS_REC_TARGET_ABORT 0x1000 /* Master ack of " */
57#define PCI_STATUS_REC_MASTER_ABORT 0x2000 /* Set on master abort */
58#define PCI_STATUS_SIG_SYSTEM_ERROR 0x4000 /* Set when we drive SERR */
59#define PCI_STATUS_DETECTED_PARITY  0x8000 /* Set on parity error */
60
61#define PCI_CLASS_REVISION  0x08  /* High 24 bits are class, low 8 revision */
62#define PCI_REVISION_ID     0x08  /* Revision ID */
63#define PCI_CLASS_PROG      0x09  /* Reg. Level Programming Interface */
64#define PCI_CLASS_DEVICE    0x0a  /* Device class */
65#define PCI_CACHE_LINE_SIZE  0x0c /* 8 bits */
66#define PCI_LATENCY_TIMER    0x0d /* 8 bits */
67
68#define PCI_HEADER_TYPE         0x0e /* 8 bits */
69#define PCI_HEADER_TYPE_NORMAL  0
70#define PCI_HEADER_TYPE_BRIDGE  1
71#define PCI_HEADER_TYPE_CARDBUS 2
72
73#define PCI_BIST            0x0f  /* 8 bits */
74#define PCI_BIST_CODE_MASK  0x0f  /* Return result */
75#define PCI_BIST_START      0x40  /* 1 to start BIST, 2 secs or less */
76#define PCI_BIST_CAPABLE    0x80  /* 1 if BIST capable */
77
78/*
79 * Base addresses specify locations in memory or I/O space.
80 * Decoded size can be determined by writing a value of
81 * 0xffffffff to the register, and reading it back.  Only
82 * 1 bits are decoded.
83 */
84#define PCI_BASE_ADDRESS_0  0x10  /* 32 bits */
85#define PCI_BASE_ADDRESS_1  0x14  /* 32 bits [htype 0,1 only] */
86#define PCI_BASE_ADDRESS_2  0x18  /* 32 bits [htype 0 only] */
87#define PCI_BASE_ADDRESS_3  0x1c  /* 32 bits */
88#define PCI_BASE_ADDRESS_4  0x20  /* 32 bits */
89#define PCI_BASE_ADDRESS_5  0x24  /* 32 bits */
90#define PCI_BASE_ADDRESS_SPACE         0x01  /* 0 = memory, 1 = I/O */
91#define PCI_BASE_ADDRESS_SPACE_IO      0x01
92#define PCI_BASE_ADDRESS_SPACE_MEMORY  0x00
93#define PCI_BASE_ADDRESS_MEM_TYPE_MASK 0x06
94#define PCI_BASE_ADDRESS_MEM_TYPE_32   0x00  /* 32 bit address */
95#define PCI_BASE_ADDRESS_MEM_TYPE_1M   0x02  /* Below 1M */
96#define PCI_BASE_ADDRESS_MEM_TYPE_64   0x04  /* 64 bit address */
97#define PCI_BASE_ADDRESS_MEM_PREFETCH  0x08  /* prefetchable? */
98#define PCI_BASE_ADDRESS_MEM_MASK      (~0x0fUL)
99#define PCI_BASE_ADDRESS_IO_MASK      (~0x03UL)
100/* bit 1 is reserved if address_space = 1 */
101
102/* Header type 0 (normal devices) */
103#define PCI_CARDBUS_CIS         0x28
104#define PCI_SUBSYSTEM_VENDOR_ID 0x2c
105#define PCI_SUBSYSTEM_ID        0x2e
106#define PCI_ROM_ADDRESS         0x30/* Bits 31..11 address, 10..1 reserved */
107#define PCI_ROM_ADDRESS_ENABLE  0x01
108#define PCI_ROM_ADDRESS_MASK    (~0x7ffUL)
109
110/* 0x34-0x3b are reserved */
111#define PCI_INTERRUPT_LINE  0x3c  /* 8 bits */
112#define PCI_INTERRUPT_PIN   0x3d  /* 8 bits */
113#define PCI_MIN_GNT         0x3e  /* 8 bits */
114#define PCI_MAX_LAT         0x3f  /* 8 bits */
115
116/* Header type 1 (PCI-to-PCI bridges) */
117#define PCI_PRIMARY_BUS        0x18  /* Primary bus number */
118#define PCI_SECONDARY_BUS      0x19  /* Secondary bus number */
119#define PCI_SUBORDINATE_BUS    0x1a  /* Highest bus number behind the bridge */
120#define PCI_SEC_LATENCY_TIMER  0x1b  /* Latency timer for secondary interface */
121#define PCI_IO_BASE            0x1c  /* I/O range behind the bridge */
122#define PCI_IO_LIMIT           0x1d
123#define PCI_IO_RANGE_TYPE_MASK 0x0f  /* I/O bridging type */
124#define PCI_IO_RANGE_TYPE_16   0x00
125#define PCI_IO_RANGE_TYPE_32   0x01
126#define PCI_IO_RANGE_MASK      ~0x0f
127
128#define PCI_SEC_STATUS 0x1e  /* Secondary status register, only bit 14 used */
129
130#define PCI_MEMORY_BASE            0x20  /* Memory range behind */
131#define PCI_MEMORY_LIMIT           0x22
132#define PCI_MEMORY_RANGE_TYPE_MASK 0x0f
133#define PCI_MEMORY_RANGE_MASK      ~0x0f
134#define PCI_PREF_MEMORY_BASE       0x24  /* Prefetchable memory range behind */
135#define PCI_PREF_MEMORY_LIMIT      0x26
136#define PCI_PREF_RANGE_TYPE_MASK   0x0f
137#define PCI_PREF_RANGE_TYPE_32     0x00
138#define PCI_PREF_RANGE_TYPE_64     0x01
139#define PCI_PREF_RANGE_MASK        ~0x0f
140#define PCI_PREF_BASE_UPPER32      0x28 /* Upper half of prefetchable memory */
141#define PCI_PREF_LIMIT_UPPER32     0x2c
142#define PCI_IO_BASE_UPPER16        0x30  /* Upper half of I/O addresses */
143#define PCI_IO_LIMIT_UPPER16       0x32
144/* 0x34-0x3b is reserved */
145#define PCI_ROM_ADDRESS1  0x38  /* Same as PCI_ROM_ADDRESS, but for htype 1 */
146/* 0x3c-0x3d are same as for htype 0 */
147#define PCI_BRIDGE_CONTROL     0x3e
148#define PCI_BRIDGE_CTL_PARITY  0x01  /* Enable parity detection on secondary interface */
149#define PCI_BRIDGE_CTL_SERR         0x02  /* The same for SERR forwarding */
150#define PCI_BRIDGE_CTL_NO_ISA       0x04  /* Disable bridging of ISA ports */
151#define PCI_BRIDGE_CTL_VGA          0x08  /* Forward VGA addresses */
152#define PCI_BRIDGE_CTL_MASTER_ABORT 0x20  /* Report master aborts */
153#define PCI_BRIDGE_CTL_BUS_RESET    0x40  /* Secondary bus reset */
154#define PCI_BRIDGE_CTL_FAST_BACK    0x80  /* Fast Back2Back enabled */
155                                          /*     on secondary interface */
156
157/* Header type 2 (CardBus bridges) */
158/* 0x14-0x15 reserved */
159#define PCI_CB_SEC_STATUS             0x16  /* Secondary status */
160#define PCI_CB_PRIMARY_BUS            0x18  /* PCI bus number */
161#define PCI_CB_CARD_BUS               0x19  /* CardBus bus number */
162#define PCI_CB_SUBORDINATE_BUS        0x1a  /* Subordinate bus number */
163#define PCI_CB_LATENCY_TIMER          0x1b  /* CardBus latency timer */
164#define PCI_CB_MEMORY_BASE_0          0x1c
165#define PCI_CB_MEMORY_LIMIT_0         0x20
166#define PCI_CB_MEMORY_BASE_1          0x24
167#define PCI_CB_MEMORY_LIMIT_1         0x28
168#define PCI_CB_IO_BASE_0              0x2c
169#define PCI_CB_IO_BASE_0_HI           0x2e
170#define PCI_CB_IO_LIMIT_0             0x30
171#define PCI_CB_IO_LIMIT_0_HI          0x32
172#define PCI_CB_IO_BASE_1              0x34
173#define PCI_CB_IO_BASE_1_HI           0x36
174#define PCI_CB_IO_LIMIT_1             0x38
175#define PCI_CB_IO_LIMIT_1_HI          0x3a
176#define PCI_CB_IO_RANGE_MASK          ~0x03
177/* 0x3c-0x3d are same as for htype 0 */
178
179#define PCI_CB_BRIDGE_CONTROL           0x3e
180#define PCI_CB_BRIDGE_CTL_PARITY        0x01  /* Similar to standard bridge */
181                                              /*    control register */
182#define PCI_CB_BRIDGE_CTL_SERR          0x02
183#define PCI_CB_BRIDGE_CTL_ISA           0x04
184#define PCI_CB_BRIDGE_CTL_VGA           0x08
185#define PCI_CB_BRIDGE_CTL_MASTER_ABORT  0x20
186#define PCI_CB_BRIDGE_CTL_CB_RESET      0x40  /* CardBus reset */
187#define PCI_CB_BRIDGE_CTL_16BIT_INT     0x80  /* Enable interrupt for */
188                                              /*    16-bit cards */
189#define PCI_CB_BRIDGE_CTL_PREFETCH_MEM0 0x100 /* Prefetch enable for */
190                                              /*    both memory regions */
191#define PCI_CB_BRIDGE_CTL_PREFETCH_MEM1 0x200
192#define PCI_CB_BRIDGE_CTL_POST_WRITES   0x400
193
194#define PCI_CB_SUBSYSTEM_VENDOR_ID      0x40
195#define PCI_CB_SUBSYSTEM_ID             0x42
196
197/* 16-bit PC Card legacy mode base address (ExCa) */
198#define PCI_CB_LEGACY_MODE_BASE  0x44
199
200/* 0x48-0x7f reserved */
201
202/* Device classes and subclasses */
203
204#define PCI_CLASS_NOT_DEFINED      0x0000
205#define PCI_CLASS_NOT_DEFINED_VGA  0x0001
206
207#define PCI_BASE_CLASS_STORAGE    0x01
208#define PCI_CLASS_STORAGE_SCSI    0x0100
209#define PCI_CLASS_STORAGE_IDE     0x0101
210#define PCI_CLASS_STORAGE_FLOPPY  0x0102
211#define PCI_CLASS_STORAGE_IPI     0x0103
212#define PCI_CLASS_STORAGE_RAID    0x0104
213#define PCI_CLASS_STORAGE_OTHER   0x0180
214
215#define PCI_BASE_CLASS_NETWORK        0x02
216#define PCI_CLASS_NETWORK_ETHERNET    0x0200
217#define PCI_CLASS_NETWORK_TOKEN_RING  0x0201
218#define PCI_CLASS_NETWORK_FDDI        0x0202
219#define PCI_CLASS_NETWORK_ATM         0x0203
220#define PCI_CLASS_NETWORK_OTHER       0x0280
221
222#define PCI_BASE_CLASS_DISPLAY    0x03
223#define PCI_CLASS_DISPLAY_VGA     0x0300
224#define PCI_CLASS_DISPLAY_XGA     0x0301
225#define PCI_CLASS_DISPLAY_OTHER   0x0380
226
227#define PCI_BASE_CLASS_MULTIMEDIA   0x04
228#define PCI_CLASS_MULTIMEDIA_VIDEO  0x0400
229#define PCI_CLASS_MULTIMEDIA_AUDIO  0x0401
230#define PCI_CLASS_MULTIMEDIA_OTHER  0x0480
231
232#define PCI_BASE_CLASS_MEMORY  0x05
233#define PCI_CLASS_MEMORY_RAM   0x0500
234#define PCI_CLASS_MEMORY_FLASH 0x0501
235#define PCI_CLASS_MEMORY_OTHER 0x0580
236
237#define PCI_BASE_CLASS_BRIDGE    0x06
238#define PCI_CLASS_BRIDGE_HOST    0x0600
239#define PCI_CLASS_BRIDGE_ISA     0x0601
240#define PCI_CLASS_BRIDGE_EISA    0x0602
241#define PCI_CLASS_BRIDGE_MC      0x0603
242#define PCI_CLASS_BRIDGE_PCI     0x0604
243#define PCI_CLASS_BRIDGE_PCMCIA  0x0605
244#define PCI_CLASS_BRIDGE_NUBUS   0x0606
245#define PCI_CLASS_BRIDGE_CARDBUS 0x0607
246#define PCI_CLASS_BRIDGE_OTHER   0x0680
247
248#define PCI_BASE_CLASS_COMMUNICATION     0x07
249#define PCI_CLASS_COMMUNICATION_SERIAL   0x0700
250#define PCI_CLASS_COMMUNICATION_PARALLEL 0x0701
251#define PCI_CLASS_COMMUNICATION_OTHER    0x0780
252
253#define PCI_BASE_CLASS_SYSTEM  0x08
254#define PCI_CLASS_SYSTEM_PIC   0x0800
255#define PCI_CLASS_SYSTEM_DMA   0x0801
256#define PCI_CLASS_SYSTEM_TIMER 0x0802
257#define PCI_CLASS_SYSTEM_RTC   0x0803
258#define PCI_CLASS_SYSTEM_OTHER 0x0880
259
260#define PCI_BASE_CLASS_INPUT     0x09
261#define PCI_CLASS_INPUT_KEYBOARD 0x0900
262#define PCI_CLASS_INPUT_PEN      0x0901
263#define PCI_CLASS_INPUT_MOUSE    0x0902
264#define PCI_CLASS_INPUT_OTHER    0x0980
265
266#define PCI_BASE_CLASS_DOCKING     0x0a
267#define PCI_CLASS_DOCKING_GENERIC  0x0a00
268#define PCI_CLASS_DOCKING_OTHER    0x0a01
269
270#define PCI_BASE_CLASS_PROCESSOR    0x0b
271#define PCI_CLASS_PROCESSOR_386     0x0b00
272#define PCI_CLASS_PROCESSOR_486     0x0b01
273#define PCI_CLASS_PROCESSOR_PENTIUM 0x0b02
274#define PCI_CLASS_PROCESSOR_ALPHA   0x0b10
275#define PCI_CLASS_PROCESSOR_POWERPC 0x0b20
276#define PCI_CLASS_PROCESSOR_CO      0x0b40
277
278#define PCI_BASE_CLASS_SERIAL     0x0c
279#define PCI_CLASS_SERIAL_FIREWIRE 0x0c00
280#define PCI_CLASS_SERIAL_ACCESS   0x0c01
281#define PCI_CLASS_SERIAL_SSA      0x0c02
282#define PCI_CLASS_SERIAL_USB      0x0c03
283#define PCI_CLASS_SERIAL_FIBER    0x0c04
284
285#define PCI_CLASS_OTHERS    0xff
286
287/*
288 * Vendor and card ID's: sort these numerically according to vendor
289 * (and according to card ID within vendor). Send all updates to
290 * <linux-pcisupport@cck.uni-kl.de>.
291 */
292#define PCI_VENDOR_ID_COMPAQ                       0x0e11
293#define PCI_DEVICE_ID_COMPAQ_1280                  0x3033
294#define PCI_DEVICE_ID_COMPAQ_TRIFLEX               0x4000
295#define PCI_DEVICE_ID_COMPAQ_SMART2P               0xae10
296#define PCI_DEVICE_ID_COMPAQ_NETEL100              0xae32
297#define PCI_DEVICE_ID_COMPAQ_NETEL10               0xae34
298#define PCI_DEVICE_ID_COMPAQ_NETFLEX3I             0xae35
299#define PCI_DEVICE_ID_COMPAQ_NETEL100D             0xae40
300#define PCI_DEVICE_ID_COMPAQ_NETEL100PI            0xae43
301#define PCI_DEVICE_ID_COMPAQ_NETEL100I             0xb011
302#define PCI_DEVICE_ID_COMPAQ_THUNDER               0xf130
303#define PCI_DEVICE_ID_COMPAQ_NETFLEX3B             0xf150
304
305#define PCI_VENDOR_ID_NCR                          0x1000
306#define PCI_DEVICE_ID_NCR_53C810                   0x0001
307#define PCI_DEVICE_ID_NCR_53C820                   0x0002
308#define PCI_DEVICE_ID_NCR_53C825                   0x0003
309#define PCI_DEVICE_ID_NCR_53C815                   0x0004
310#define PCI_DEVICE_ID_NCR_53C860                   0x0006
311#define PCI_DEVICE_ID_NCR_53C896                   0x000b
312#define PCI_DEVICE_ID_NCR_53C895                   0x000c
313#define PCI_DEVICE_ID_NCR_53C885                   0x000d
314#define PCI_DEVICE_ID_NCR_53C875                   0x000f
315#define PCI_DEVICE_ID_NCR_53C875J                  0x008f
316
317#define PCI_VENDOR_ID_ATI                          0x1002
318#define PCI_DEVICE_ID_ATI_68800                    0x4158
319#define PCI_DEVICE_ID_ATI_215CT222                 0x4354
320#define PCI_DEVICE_ID_ATI_210888CX                 0x4358
321#define PCI_DEVICE_ID_ATI_215GB                    0x4742
322#define PCI_DEVICE_ID_ATI_215GD                    0x4744
323#define PCI_DEVICE_ID_ATI_215GI                    0x4749
324#define PCI_DEVICE_ID_ATI_215GP                    0x4750
325#define PCI_DEVICE_ID_ATI_215GQ                    0x4751
326#define PCI_DEVICE_ID_ATI_215GT                    0x4754
327#define PCI_DEVICE_ID_ATI_215GTB                   0x4755
328#define PCI_DEVICE_ID_ATI_210888GX                 0x4758
329#define PCI_DEVICE_ID_ATI_215LG                    0x4c47
330#define PCI_DEVICE_ID_ATI_264LT                    0x4c54
331#define PCI_DEVICE_ID_ATI_264VT                    0x5654
332
333#define PCI_VENDOR_ID_VLSI                         0x1004
334#define PCI_DEVICE_ID_VLSI_82C592                  0x0005
335#define PCI_DEVICE_ID_VLSI_82C593                  0x0006
336#define PCI_DEVICE_ID_VLSI_82C594                  0x0007
337#define PCI_DEVICE_ID_VLSI_82C597                  0x0009
338#define PCI_DEVICE_ID_VLSI_82C541                  0x000c
339#define PCI_DEVICE_ID_VLSI_82C543                  0x000d
340#define PCI_DEVICE_ID_VLSI_82C532                  0x0101
341#define PCI_DEVICE_ID_VLSI_82C534                  0x0102
342#define PCI_DEVICE_ID_VLSI_82C535                  0x0104
343#define PCI_DEVICE_ID_VLSI_82C147                  0x0105
344#define PCI_DEVICE_ID_VLSI_VAS96011                0x0702
345
346#define PCI_VENDOR_ID_ADL                          0x1005
347#define PCI_DEVICE_ID_ADL_2301                     0x2301
348
349#define PCI_VENDOR_ID_NS                           0x100b
350#define PCI_DEVICE_ID_NS_87415                     0x0002
351#define PCI_DEVICE_ID_NS_87410                     0xd001
352
353#define PCI_VENDOR_ID_TSENG                        0x100c
354#define PCI_DEVICE_ID_TSENG_W32P_2                 0x3202
355#define PCI_DEVICE_ID_TSENG_W32P_b                 0x3205
356#define PCI_DEVICE_ID_TSENG_W32P_c                 0x3206
357#define PCI_DEVICE_ID_TSENG_W32P_d                 0x3207
358#define PCI_DEVICE_ID_TSENG_ET6000                 0x3208
359
360#define PCI_VENDOR_ID_WEITEK                       0x100e
361#define PCI_DEVICE_ID_WEITEK_P9000                 0x9001
362#define PCI_DEVICE_ID_WEITEK_P9100                 0x9100
363
364#define PCI_VENDOR_ID_DEC                          0x1011
365#define PCI_DEVICE_ID_DEC_BRD                      0x0001
366#define PCI_DEVICE_ID_DEC_TULIP                    0x0002
367#define PCI_DEVICE_ID_DEC_TGA                      0x0004
368#define PCI_DEVICE_ID_DEC_TULIP_FAST               0x0009
369#define PCI_DEVICE_ID_DEC_TGA2                     0x000D
370#define PCI_DEVICE_ID_DEC_FDDI                     0x000F
371#define PCI_DEVICE_ID_DEC_TULIP_PLUS               0x0014
372#define PCI_DEVICE_ID_DEC_21142                    0x0019
373#define PCI_DEVICE_ID_DEC_21052                    0x0021
374#define PCI_DEVICE_ID_DEC_21150                    0x0022
375#define PCI_DEVICE_ID_DEC_21152                    0x0024
376
377#define PCI_VENDOR_ID_CIRRUS                       0x1013
378#define PCI_DEVICE_ID_CIRRUS_7548                  0x0038
379#define PCI_DEVICE_ID_CIRRUS_5430                  0x00a0
380#define PCI_DEVICE_ID_CIRRUS_5434_4                0x00a4
381#define PCI_DEVICE_ID_CIRRUS_5434_8                0x00a8
382#define PCI_DEVICE_ID_CIRRUS_5436                  0x00ac
383#define PCI_DEVICE_ID_CIRRUS_5446                  0x00b8
384#define PCI_DEVICE_ID_CIRRUS_5480                  0x00bc
385#define PCI_DEVICE_ID_CIRRUS_5464                  0x00d4
386#define PCI_DEVICE_ID_CIRRUS_5465                  0x00d6
387#define PCI_DEVICE_ID_CIRRUS_6729                  0x1100
388#define PCI_DEVICE_ID_CIRRUS_6832                  0x1110
389#define PCI_DEVICE_ID_CIRRUS_7542                  0x1200
390#define PCI_DEVICE_ID_CIRRUS_7543                  0x1202
391#define PCI_DEVICE_ID_CIRRUS_7541                  0x1204
392
393#define PCI_VENDOR_ID_IBM                          0x1014
394#define PCI_DEVICE_ID_IBM_FIRE_CORAL               0x000a
395#define PCI_DEVICE_ID_IBM_TR                       0x0018
396#define PCI_DEVICE_ID_IBM_82G2675                  0x001d
397#define PCI_DEVICE_ID_IBM_MCA                      0x0020
398#define PCI_DEVICE_ID_IBM_82351                    0x0022
399#define PCI_DEVICE_ID_IBM_SERVERAID                0x002e
400#define PCI_DEVICE_ID_IBM_TR_WAKE                  0x003e
401#define PCI_DEVICE_ID_IBM_MPIC                     0x0046
402#define PCI_DEVICE_ID_IBM_3780IDSP                 0x007d
403#define PCI_DEVICE_ID_IBM_MPIC_2                   0xffff
404
405#define PCI_VENDOR_ID_WD                           0x101c
406#define PCI_DEVICE_ID_WD_7197                      0x3296
407
408#define PCI_VENDOR_ID_AMD                          0x1022
409#define PCI_DEVICE_ID_AMD_LANCE                    0x2000
410#define PCI_DEVICE_ID_AMD_SCSI                     0x2020
411
412#define PCI_VENDOR_ID_TRIDENT                      0x1023
413#define PCI_DEVICE_ID_TRIDENT_9397                 0x9397
414#define PCI_DEVICE_ID_TRIDENT_9420                 0x9420
415#define PCI_DEVICE_ID_TRIDENT_9440                 0x9440
416#define PCI_DEVICE_ID_TRIDENT_9660                 0x9660
417#define PCI_DEVICE_ID_TRIDENT_9750                 0x9750
418
419#define PCI_VENDOR_ID_AI                           0x1025
420#define PCI_DEVICE_ID_AI_M1435                     0x1435
421
422#define PCI_VENDOR_ID_MATROX                       0x102B
423#define PCI_DEVICE_ID_MATROX_MGA_2                 0x0518
424#define PCI_DEVICE_ID_MATROX_MIL                   0x0519
425#define PCI_DEVICE_ID_MATROX_MYS                   0x051A
426#define PCI_DEVICE_ID_MATROX_MIL_2                 0x051b
427#define PCI_DEVICE_ID_MATROX_MIL_2_AGP             0x051f
428#define PCI_DEVICE_ID_MATROX_MGA_IMP               0x0d10
429
430#define PCI_VENDOR_ID_CT                           0x102c
431#define PCI_DEVICE_ID_CT_65545                     0x00d8
432#define PCI_DEVICE_ID_CT_65548                     0x00dc
433#define PCI_DEVICE_ID_CT_65550                     0x00e0
434#define PCI_DEVICE_ID_CT_65554                     0x00e4
435#define PCI_DEVICE_ID_CT_65555                     0x00e5
436
437#define PCI_VENDOR_ID_MIRO                         0x1031
438#define PCI_DEVICE_ID_MIRO_36050                   0x5601
439
440#define PCI_VENDOR_ID_NEC                          0x1033
441#define PCI_DEVICE_ID_NEC_PCX2                     0x0046
442
443#define PCI_VENDOR_ID_FD                           0x1036
444#define PCI_DEVICE_ID_FD_36C70                     0x0000
445
446#define PCI_VENDOR_ID_SI                           0x1039
447#define PCI_DEVICE_ID_SI_5591_AGP                  0x0001
448#define PCI_DEVICE_ID_SI_6202                      0x0002
449#define PCI_DEVICE_ID_SI_503                       0x0008
450#define PCI_DEVICE_ID_SI_ACPI                      0x0009
451#define PCI_DEVICE_ID_SI_5597_VGA                  0x0200
452#define PCI_DEVICE_ID_SI_6205                      0x0205
453#define PCI_DEVICE_ID_SI_501                       0x0406
454#define PCI_DEVICE_ID_SI_496                       0x0496
455#define PCI_DEVICE_ID_SI_601                       0x0601
456#define PCI_DEVICE_ID_SI_5107                      0x5107
457#define PCI_DEVICE_ID_SI_5511                      0x5511
458#define PCI_DEVICE_ID_SI_5513                      0x5513
459#define PCI_DEVICE_ID_SI_5571                      0x5571
460#define PCI_DEVICE_ID_SI_5591                      0x5591
461#define PCI_DEVICE_ID_SI_5597                      0x5597
462#define PCI_DEVICE_ID_SI_7001                      0x7001
463
464#define PCI_VENDOR_ID_HP                           0x103c
465#define PCI_DEVICE_ID_HP_J2585A                    0x1030
466#define PCI_DEVICE_ID_HP_J2585B                    0x1031
467
468#define PCI_VENDOR_ID_PCTECH                       0x1042
469#define PCI_DEVICE_ID_PCTECH_RZ1000                0x1000
470#define PCI_DEVICE_ID_PCTECH_RZ1001                0x1001
471#define PCI_DEVICE_ID_PCTECH_SAMURAI_0             0x3000
472#define PCI_DEVICE_ID_PCTECH_SAMURAI_1             0x3010
473#define PCI_DEVICE_ID_PCTECH_SAMURAI_IDE           0x3020
474
475#define PCI_VENDOR_ID_DPT                          0x1044
476#define PCI_DEVICE_ID_DPT                          0xa400
477
478#define PCI_VENDOR_ID_OPTI                         0x1045
479#define PCI_DEVICE_ID_OPTI_92C178                  0xc178
480#define PCI_DEVICE_ID_OPTI_82C557                  0xc557
481#define PCI_DEVICE_ID_OPTI_82C558                  0xc558
482#define PCI_DEVICE_ID_OPTI_82C621                  0xc621
483#define PCI_DEVICE_ID_OPTI_82C700                  0xc700
484#define PCI_DEVICE_ID_OPTI_82C701                  0xc701
485#define PCI_DEVICE_ID_OPTI_82C814                  0xc814
486#define PCI_DEVICE_ID_OPTI_82C822                  0xc822
487#define PCI_DEVICE_ID_OPTI_82C825                  0xd568
488
489#define PCI_VENDOR_ID_SGS                          0x104a
490#define PCI_DEVICE_ID_SGS_2000                     0x0008
491#define PCI_DEVICE_ID_SGS_1764                     0x0009
492
493#define PCI_VENDOR_ID_BUSLOGIC                     0x104B
494#define PCI_DEVICE_ID_BUSLOGIC_MULTIMASTER_NC      0x0140
495#define PCI_DEVICE_ID_BUSLOGIC_MULTIMASTER         0x1040
496#define PCI_DEVICE_ID_BUSLOGIC_FLASHPOINT          0x8130
497
498#define PCI_VENDOR_ID_TI                           0x104c
499#define PCI_DEVICE_ID_TI_TVP4010                   0x3d04
500#define PCI_DEVICE_ID_TI_TVP4020                   0x3d07
501#define PCI_DEVICE_ID_TI_PCI1130                   0xac12
502#define PCI_DEVICE_ID_TI_PCI1031                   0xac13
503#define PCI_DEVICE_ID_TI_PCI1131                   0xac15
504#define PCI_DEVICE_ID_TI_PCI1250                   0xac16
505#define PCI_DEVICE_ID_TI_PCI1220                   0xac17
506
507#define PCI_VENDOR_ID_OAK                          0x104e
508#define PCI_DEVICE_ID_OAK_OTI107                   0x0107
509
510#define PCI_VENDOR_ID_WINBOND2                     0x1050
511#define PCI_DEVICE_ID_WINBOND2_89C940              0x0940
512
513#define PCI_VENDOR_ID_MOTOROLA                     0x1057
514#define PCI_DEVICE_ID_MOTOROLA_MPC105              0x0001
515#define PCI_DEVICE_ID_MOTOROLA_MPC106              0x0002
516#define PCI_DEVICE_ID_MOTOROLA_RAVEN               0x4801
517#define PCI_DEVICE_ID_MOTOROLA_HAWK                0x4803
518
519#define PCI_VENDOR_ID_PROMISE                      0x105a
520#define PCI_DEVICE_ID_PROMISE_20246                0x4d33
521#define PCI_DEVICE_ID_PROMISE_5300                 0x5300
522
523#define PCI_VENDOR_ID_N9                           0x105d
524#define PCI_DEVICE_ID_N9_I128                      0x2309
525#define PCI_DEVICE_ID_N9_I128_2                    0x2339
526#define PCI_DEVICE_ID_N9_I128_T2R                  0x493d
527
528#define PCI_VENDOR_ID_UMC                          0x1060
529#define PCI_DEVICE_ID_UMC_UM8673F                  0x0101
530#define PCI_DEVICE_ID_UMC_UM8891A                  0x0891
531#define PCI_DEVICE_ID_UMC_UM8886BF                 0x673a
532#define PCI_DEVICE_ID_UMC_UM8886A                  0x886a
533#define PCI_DEVICE_ID_UMC_UM8881F                  0x8881
534#define PCI_DEVICE_ID_UMC_UM8886F                  0x8886
535#define PCI_DEVICE_ID_UMC_UM9017F                  0x9017
536#define PCI_DEVICE_ID_UMC_UM8886N                  0xe886
537#define PCI_DEVICE_ID_UMC_UM8891N                  0xe891
538
539#define PCI_VENDOR_ID_X                            0x1061
540#define PCI_DEVICE_ID_X_AGX016                     0x0001
541
542#define PCI_VENDOR_ID_PICOP                        0x1066
543#define PCI_DEVICE_ID_PICOP_PT86C52X               0x0001
544#define PCI_DEVICE_ID_PICOP_PT80C524               0x8002
545
546#define PCI_VENDOR_ID_APPLE                        0x106b
547#define PCI_DEVICE_ID_APPLE_BANDIT                 0x0001
548#define PCI_DEVICE_ID_APPLE_GC                     0x0002
549#define PCI_DEVICE_ID_APPLE_HYDRA                  0x000e
550
551#define PCI_VENDOR_ID_NEXGEN                       0x1074
552#define PCI_DEVICE_ID_NEXGEN_82C501                0x4e78
553
554#define PCI_VENDOR_ID_QLOGIC                       0x1077
555#define PCI_DEVICE_ID_QLOGIC_ISP1020               0x1020
556#define PCI_DEVICE_ID_QLOGIC_ISP1022               0x1022
557
558#define PCI_VENDOR_ID_CYRIX                        0x1078
559#define PCI_DEVICE_ID_CYRIX_5510                   0x0000
560#define PCI_DEVICE_ID_CYRIX_PCI_MASTER             0x0001
561#define PCI_DEVICE_ID_CYRIX_5520                   0x0002
562#define PCI_DEVICE_ID_CYRIX_5530_LEGACY            0x0100
563#define PCI_DEVICE_ID_CYRIX_5530_SMI               0x0101
564#define PCI_DEVICE_ID_CYRIX_5530_IDE               0x0102
565#define PCI_DEVICE_ID_CYRIX_5530_AUDIO             0x0103
566#define PCI_DEVICE_ID_CYRIX_5530_VIDEO             0x0104
567
568#define PCI_VENDOR_ID_LEADTEK                      0x107d
569#define PCI_DEVICE_ID_LEADTEK_805                  0x0000
570
571#define PCI_VENDOR_ID_CONTAQ                       0x1080
572#define PCI_DEVICE_ID_CONTAQ_82C599                0x0600
573#define PCI_DEVICE_ID_CONTAQ_82C693                0xc693
574
575#define PCI_VENDOR_ID_FOREX                        0x1083
576
577#define PCI_VENDOR_ID_OLICOM                       0x108d
578#define PCI_DEVICE_ID_OLICOM_OC3136                0x0001
579#define PCI_DEVICE_ID_OLICOM_OC2315                0x0011
580#define PCI_DEVICE_ID_OLICOM_OC2325                0x0012
581#define PCI_DEVICE_ID_OLICOM_OC2183                0x0013
582#define PCI_DEVICE_ID_OLICOM_OC2326                0x0014
583#define PCI_DEVICE_ID_OLICOM_OC6151                0x0021
584
585#define PCI_VENDOR_ID_SUN                          0x108e
586#define PCI_DEVICE_ID_SUN_EBUS                     0x1000
587#define PCI_DEVICE_ID_SUN_HAPPYMEAL                0x1001
588#define PCI_DEVICE_ID_SUN_SIMBA                    0x5000
589#define PCI_DEVICE_ID_SUN_PBM                      0x8000
590#define PCI_DEVICE_ID_SUN_SABRE                    0xa000
591
592#define PCI_VENDOR_ID_CMD                          0x1095
593#define PCI_DEVICE_ID_CMD_640                      0x0640
594#define PCI_DEVICE_ID_CMD_643                      0x0643
595#define PCI_DEVICE_ID_CMD_646                      0x0646
596#define PCI_DEVICE_ID_CMD_647                      0x0647
597#define PCI_DEVICE_ID_CMD_670                      0x0670
598
599#define PCI_VENDOR_ID_VISION                       0x1098
600#define PCI_DEVICE_ID_VISION_QD8500                0x0001
601#define PCI_DEVICE_ID_VISION_QD8580                0x0002
602
603#define PCI_VENDOR_ID_BROOKTREE                    0x109e
604#define PCI_DEVICE_ID_BROOKTREE_848                0x0350
605#define PCI_DEVICE_ID_BROOKTREE_849A               0x0351
606#define PCI_DEVICE_ID_BROOKTREE_8474               0x8474
607
608#define PCI_VENDOR_ID_SIERRA                       0x10a8
609#define PCI_DEVICE_ID_SIERRA_STB                   0x0000
610
611#define PCI_VENDOR_ID_ACC                          0x10aa
612#define PCI_DEVICE_ID_ACC_2056                     0x0000
613
614#define PCI_VENDOR_ID_WINBOND                      0x10ad
615#define PCI_DEVICE_ID_WINBOND_83769                0x0001
616#define PCI_DEVICE_ID_WINBOND_82C105               0x0105
617#define PCI_DEVICE_ID_WINBOND_83C553               0x0565
618
619#define PCI_VENDOR_ID_DATABOOK                     0x10b3
620#define PCI_DEVICE_ID_DATABOOK_87144               0xb106
621
622#define PCI_VENDOR_ID_PLX                          0x10b5
623#define PCI_DEVICE_ID_PLX_9050                     0x9050
624#define PCI_DEVICE_ID_PLX_9060                     0x9060
625#define PCI_DEVICE_ID_PLX_9060ES                   0x906E
626#define PCI_DEVICE_ID_PLX_9060SD                   0x906D
627#define PCI_DEVICE_ID_PLX_9080                     0x9080
628
629#define PCI_VENDOR_ID_MADGE                        0x10b6
630#define PCI_DEVICE_ID_MADGE_MK2                    0x0002
631#define PCI_DEVICE_ID_MADGE_C155S                  0x1001
632
633#define PCI_VENDOR_ID_3COM                         0x10b7
634#define PCI_DEVICE_ID_3COM_3C339                   0x3390
635#define PCI_DEVICE_ID_3COM_3C590                   0x5900
636#define PCI_DEVICE_ID_3COM_3C595TX                 0x5950
637#define PCI_DEVICE_ID_3COM_3C595T4                 0x5951
638#define PCI_DEVICE_ID_3COM_3C595MII                0x5952
639#define PCI_DEVICE_ID_3COM_3C900TPO                0x9000
640#define PCI_DEVICE_ID_3COM_3C900COMBO              0x9001
641#define PCI_DEVICE_ID_3COM_3C905TX                 0x9050
642#define PCI_DEVICE_ID_3COM_3C905T4                 0x9051
643#define PCI_DEVICE_ID_3COM_3C905B_TX               0x9055
644
645#define PCI_VENDOR_ID_SMC                          0x10b8
646#define PCI_DEVICE_ID_SMC_EPIC100                  0x0005
647
648#define PCI_VENDOR_ID_AL                           0x10b9
649#define PCI_DEVICE_ID_AL_M1445                     0x1445
650#define PCI_DEVICE_ID_AL_M1449                     0x1449
651#define PCI_DEVICE_ID_AL_M1451                     0x1451
652#define PCI_DEVICE_ID_AL_M1461                     0x1461
653#define PCI_DEVICE_ID_AL_M1489                     0x1489
654#define PCI_DEVICE_ID_AL_M1511                     0x1511
655#define PCI_DEVICE_ID_AL_M1513                     0x1513
656#define PCI_DEVICE_ID_AL_M1521                     0x1521
657#define PCI_DEVICE_ID_AL_M1523                     0x1523
658#define PCI_DEVICE_ID_AL_M1531                     0x1531
659#define PCI_DEVICE_ID_AL_M1533                     0x1533
660#define PCI_DEVICE_ID_AL_M3307                     0x3307
661#define PCI_DEVICE_ID_AL_M4803                     0x5215
662#define PCI_DEVICE_ID_AL_M5219                     0x5219
663#define PCI_DEVICE_ID_AL_M5229                     0x5229
664#define PCI_DEVICE_ID_AL_M5237                     0x5237
665#define PCI_DEVICE_ID_AL_M7101                     0x7101
666
667#define PCI_VENDOR_ID_MITSUBISHI                   0x10ba
668
669#define PCI_VENDOR_ID_SURECOM                      0x10bd
670#define PCI_DEVICE_ID_SURECOM_NE34                 0x0e34
671
672#define PCI_VENDOR_ID_NEOMAGIC                     0x10c8
673#define PCI_DEVICE_ID_NEOMAGIC_MAGICGRAPH_NM2070   0x0001
674#define PCI_DEVICE_ID_NEOMAGIC_MAGICGRAPH_128V     0x0002
675#define PCI_DEVICE_ID_NEOMAGIC_MAGICGRAPH_128ZV    0x0003
676#define PCI_DEVICE_ID_NEOMAGIC_MAGICGRAPH_NM2160   0x0004
677
678#define PCI_VENDOR_ID_ASP                          0x10cd
679#define PCI_DEVICE_ID_ASP_ABP940                   0x1200
680#define PCI_DEVICE_ID_ASP_ABP940U                  0x1300
681#define PCI_DEVICE_ID_ASP_ABP940UW                 0x2300
682
683#define PCI_VENDOR_ID_MACRONIX                     0x10d9
684#define PCI_DEVICE_ID_MACRONIX_MX98713             0x0512
685#define PCI_DEVICE_ID_MACRONIX_MX987x5             0x0531
686
687#define PCI_VENDOR_ID_CERN                         0x10dc
688#define PCI_DEVICE_ID_CERN_SPSB_PMC                0x0001
689#define PCI_DEVICE_ID_CERN_SPSB_PCI                0x0002
690#define PCI_DEVICE_ID_CERN_HIPPI_DST               0x0021
691#define PCI_DEVICE_ID_CERN_HIPPI_SRC               0x0022
692
693#define PCI_VENDOR_ID_NVIDIA                       0x10de
694
695#define PCI_VENDOR_ID_IMS                          0x10e0
696#define PCI_DEVICE_ID_IMS_8849                     0x8849
697
698#define PCI_VENDOR_ID_TEKRAM2                      0x10e1
699#define PCI_DEVICE_ID_TEKRAM2_690c                 0x690c
700
701#define PCI_VENDOR_ID_TUNDRA                       0x10e3
702#define PCI_DEVICE_ID_TUNDRA_CA91C042              0x0000
703
704#define PCI_VENDOR_ID_AMCC                         0x10e8
705#define PCI_DEVICE_ID_AMCC_MYRINET                 0x8043
706#define PCI_DEVICE_ID_AMCC_PARASTATION             0x8062
707#define PCI_DEVICE_ID_AMCC_S5933                   0x807d
708#define PCI_DEVICE_ID_AMCC_S5933_HEPC3             0x809c
709
710#define PCI_VENDOR_ID_INTERG                       0x10ea
711#define PCI_DEVICE_ID_INTERG_1680                  0x1680
712#define PCI_DEVICE_ID_INTERG_1682                  0x1682
713
714#define PCI_VENDOR_ID_REALTEK                      0x10ec
715#define PCI_DEVICE_ID_REALTEK_8029                 0x8029
716#define PCI_DEVICE_ID_REALTEK_8129                 0x8129
717#define PCI_DEVICE_ID_REALTEK_8139                 0x8139
718
719#define PCI_VENDOR_ID_TRUEVISION                   0x10fa
720#define PCI_DEVICE_ID_TRUEVISION_T1000             0x000c
721
722#define PCI_VENDOR_ID_INIT                         0x1101
723#define PCI_DEVICE_ID_INIT_320P                    0x9100
724#define PCI_DEVICE_ID_INIT_360P                    0x9500
725
726#define PCI_VENDOR_ID_TTI                          0x1103
727#define PCI_DEVICE_ID_TTI_HPT343                   0x0003
728
729#define PCI_VENDOR_ID_VIA                          0x1106
730#define PCI_DEVICE_ID_VIA_82C505                   0x0505
731#define PCI_DEVICE_ID_VIA_82C561                   0x0561
732#define PCI_DEVICE_ID_VIA_82C586_1                 0x0571
733#define PCI_DEVICE_ID_VIA_82C576                   0x0576
734#define PCI_DEVICE_ID_VIA_82C585                   0x0585
735#define PCI_DEVICE_ID_VIA_82C586_0                 0x0586
736#define PCI_DEVICE_ID_VIA_82C595                   0x0595
737#define PCI_DEVICE_ID_VIA_82C597_0                 0x0597
738#define PCI_DEVICE_ID_VIA_82C926                   0x0926
739#define PCI_DEVICE_ID_VIA_82C416                   0x1571
740#define PCI_DEVICE_ID_VIA_82C595_97                0x1595
741#define PCI_DEVICE_ID_VIA_82C586_2                 0x3038
742#define PCI_DEVICE_ID_VIA_82C586_3                 0x3040
743#define PCI_DEVICE_ID_VIA_86C100A                  0x6100
744#define PCI_DEVICE_ID_VIA_82C597_1                 0x8597
745
746#define PCI_VENDOR_ID_VORTEX                       0x1119
747#define PCI_DEVICE_ID_VORTEX_GDT60x0               0x0000
748#define PCI_DEVICE_ID_VORTEX_GDT6000B              0x0001
749#define PCI_DEVICE_ID_VORTEX_GDT6x10               0x0002
750#define PCI_DEVICE_ID_VORTEX_GDT6x20               0x0003
751#define PCI_DEVICE_ID_VORTEX_GDT6530               0x0004
752#define PCI_DEVICE_ID_VORTEX_GDT6550               0x0005
753#define PCI_DEVICE_ID_VORTEX_GDT6x17               0x0006
754#define PCI_DEVICE_ID_VORTEX_GDT6x27               0x0007
755#define PCI_DEVICE_ID_VORTEX_GDT6537               0x0008
756#define PCI_DEVICE_ID_VORTEX_GDT6557               0x0009
757#define PCI_DEVICE_ID_VORTEX_GDT6x15               0x000a
758#define PCI_DEVICE_ID_VORTEX_GDT6x25               0x000b
759#define PCI_DEVICE_ID_VORTEX_GDT6535               0x000c
760#define PCI_DEVICE_ID_VORTEX_GDT6555               0x000d
761#define PCI_DEVICE_ID_VORTEX_GDT6x17RP             0x0100
762#define PCI_DEVICE_ID_VORTEX_GDT6x27RP             0x0101
763#define PCI_DEVICE_ID_VORTEX_GDT6537RP             0x0102
764#define PCI_DEVICE_ID_VORTEX_GDT6557RP             0x0103
765#define PCI_DEVICE_ID_VORTEX_GDT6x11RP             0x0104
766#define PCI_DEVICE_ID_VORTEX_GDT6x21RP             0x0105
767#define PCI_DEVICE_ID_VORTEX_GDT6x17RP1            0x0110
768#define PCI_DEVICE_ID_VORTEX_GDT6x27RP1            0x0111
769#define PCI_DEVICE_ID_VORTEX_GDT6537RP1            0x0112
770#define PCI_DEVICE_ID_VORTEX_GDT6557RP1            0x0113
771#define PCI_DEVICE_ID_VORTEX_GDT6x11RP1            0x0114
772#define PCI_DEVICE_ID_VORTEX_GDT6x21RP1            0x0115
773#define PCI_DEVICE_ID_VORTEX_GDT6x17RP2            0x0120
774#define PCI_DEVICE_ID_VORTEX_GDT6x27RP2            0x0121
775#define PCI_DEVICE_ID_VORTEX_GDT6537RP2            0x0122
776#define PCI_DEVICE_ID_VORTEX_GDT6557RP2            0x0123
777#define PCI_DEVICE_ID_VORTEX_GDT6x11RP2            0x0124
778#define PCI_DEVICE_ID_VORTEX_GDT6x21RP2            0x0125
779
780#define PCI_VENDOR_ID_EF                           0x111a
781#define PCI_DEVICE_ID_EF_ATM_FPGA                  0x0000
782#define PCI_DEVICE_ID_EF_ATM_ASIC                  0x0002
783
784#define PCI_VENDOR_ID_FORE                         0x1127
785#define PCI_DEVICE_ID_FORE_PCA200PC                0x0210
786#define PCI_DEVICE_ID_FORE_PCA200E                 0x0300
787
788#define PCI_VENDOR_ID_IMAGINGTECH                  0x112f
789#define PCI_DEVICE_ID_IMAGINGTECH_ICPCI            0x0000
790
791#define PCI_VENDOR_ID_PHILIPS                      0x1131
792#define PCI_DEVICE_ID_PHILIPS_SAA7145              0x7145
793#define PCI_DEVICE_ID_PHILIPS_SAA7146              0x7146
794
795#define PCI_VENDOR_ID_CYCLONE                      0x113c
796#define PCI_DEVICE_ID_CYCLONE_SDK                  0x0001
797
798#define PCI_VENDOR_ID_ALLIANCE                     0x1142
799#define PCI_DEVICE_ID_ALLIANCE_PROMOTIO            0x3210
800#define PCI_DEVICE_ID_ALLIANCE_PROVIDEO            0x6422
801#define PCI_DEVICE_ID_ALLIANCE_AT24                0x6424
802#define PCI_DEVICE_ID_ALLIANCE_AT3D                0x643d
803
804#define PCI_VENDOR_ID_SK                           0x1148
805#define PCI_DEVICE_ID_SK_FP                        0x4000
806#define PCI_DEVICE_ID_SK_TR                        0x4200
807#define PCI_DEVICE_ID_SK_GE                        0x4300
808
809#define PCI_VENDOR_ID_VMIC                         0x114a
810#define PCI_DEVICE_ID_VMIC_VME                     0x7587
811
812#define PCI_VENDOR_ID_DIGI                         0x114f
813#define PCI_DEVICE_ID_DIGI_EPC                     0x0002
814#define PCI_DEVICE_ID_DIGI_RIGHTSWITCH             0x0003
815#define PCI_DEVICE_ID_DIGI_XEM                     0x0004
816#define PCI_DEVICE_ID_DIGI_XR                      0x0005
817#define PCI_DEVICE_ID_DIGI_CX                      0x0006
818#define PCI_DEVICE_ID_DIGI_XRJ                     0x0009
819#define PCI_DEVICE_ID_DIGI_EPCJ                    0x000a
820#define PCI_DEVICE_ID_DIGI_XR_920                  0x0027
821
822#define PCI_VENDOR_ID_MUTECH                       0x1159
823#define PCI_DEVICE_ID_MUTECH_MV1000                0x0001
824
825#define PCI_VENDOR_ID_RENDITION                    0x1163
826#define PCI_DEVICE_ID_RENDITION_VERITE             0x0001
827#define PCI_DEVICE_ID_RENDITION_VERITE2100         0x2000
828
829#define PCI_VENDOR_ID_TOSHIBA                      0x1179
830#define PCI_DEVICE_ID_TOSHIBA_601                  0x0601
831#define PCI_DEVICE_ID_TOSHIBA_TOPIC95              0x060a
832#define PCI_DEVICE_ID_TOSHIBA_TOPIC97              0x060f
833
834#define PCI_VENDOR_ID_RICOH                        0x1180
835#define PCI_DEVICE_ID_RICOH_RL5C465                0x0465
836#define PCI_DEVICE_ID_RICOH_RL5C466                0x0466
837#define PCI_DEVICE_ID_RICOH_RL5C475                0x0475
838#define PCI_DEVICE_ID_RICOH_RL5C478                0x0478
839
840#define PCI_VENDOR_ID_ARTOP                        0x1191
841#define PCI_DEVICE_ID_ARTOP_ATP8400                0x0004
842#define PCI_DEVICE_ID_ARTOP_ATP850UF               0x0005
843
844#define PCI_VENDOR_ID_ZEITNET                      0x1193
845#define PCI_DEVICE_ID_ZEITNET_1221                 0x0001
846#define PCI_DEVICE_ID_ZEITNET_1225                 0x0002
847
848#define PCI_VENDOR_ID_OMEGA                        0x119b
849#define PCI_DEVICE_ID_OMEGA_82C092G                0x1221
850
851#define PCI_VENDOR_ID_LITEON                       0x11ad
852#define PCI_DEVICE_ID_LITEON_LNE100TX              0x0002
853
854#define PCI_VENDOR_ID_NP                           0x11bc
855#define PCI_DEVICE_ID_NP_PCI_FDDI                  0x0001
856
857#define PCI_VENDOR_ID_ATT                          0x11c1
858#define PCI_DEVICE_ID_ATT_L56XMF                   0x0440
859
860#define PCI_VENDOR_ID_SPECIALIX                    0x11cb
861#define PCI_DEVICE_ID_SPECIALIX_IO8                0x2000
862#define PCI_DEVICE_ID_SPECIALIX_XIO                0x4000
863#define PCI_DEVICE_ID_SPECIALIX_RIO                0x8000
864
865#define PCI_VENDOR_ID_AURAVISION                   0x11d1
866#define PCI_DEVICE_ID_AURAVISION_VXP524            0x01f7
867
868#define PCI_VENDOR_ID_IKON                         0x11d5
869#define PCI_DEVICE_ID_IKON_10115                   0x0115
870#define PCI_DEVICE_ID_IKON_10117                   0x0117
871
872#define PCI_VENDOR_ID_ZORAN                        0x11de
873#define PCI_DEVICE_ID_ZORAN_36057                  0x6057
874#define PCI_DEVICE_ID_ZORAN_36120                  0x6120
875
876#define PCI_VENDOR_ID_KINETIC                      0x11f4
877#define PCI_DEVICE_ID_KINETIC_2915                 0x2915
878
879#define PCI_VENDOR_ID_COMPEX                       0x11f6
880#define PCI_DEVICE_ID_COMPEX_ENET100VG4            0x0112
881#define PCI_DEVICE_ID_COMPEX_RL2000                0x1401
882
883#define PCI_VENDOR_ID_RP                           0x11fe
884#define PCI_DEVICE_ID_RP32INTF                     0x0001
885#define PCI_DEVICE_ID_RP8INTF                      0x0002
886#define PCI_DEVICE_ID_RP16INTF                     0x0003
887#define PCI_DEVICE_ID_RP4QUAD                      0x0004
888#define PCI_DEVICE_ID_RP8OCTA                      0x0005
889#define PCI_DEVICE_ID_RP8J                         0x0006
890#define PCI_DEVICE_ID_RPP4                         0x000A
891#define PCI_DEVICE_ID_RPP8                         0x000B
892#define PCI_DEVICE_ID_RP8M                         0x000C
893
894#define PCI_VENDOR_ID_CYCLADES                     0x120e
895#define PCI_DEVICE_ID_CYCLOM_Y_Lo                  0x0100
896#define PCI_DEVICE_ID_CYCLOM_Y_Hi                  0x0101
897#define PCI_DEVICE_ID_CYCLOM_Z_Lo                  0x0200
898#define PCI_DEVICE_ID_CYCLOM_Z_Hi                  0x0201
899
900#define PCI_VENDOR_ID_ESSENTIAL                    0x120f
901#define PCI_DEVICE_ID_ESSENTIAL_ROADRUNNER         0x0001
902
903#define PCI_VENDOR_ID_O2                           0x1217
904#define PCI_DEVICE_ID_O2_6729                      0x6729
905#define PCI_DEVICE_ID_O2_6730                      0x673a
906#define PCI_DEVICE_ID_O2_6832                      0x6832
907#define PCI_DEVICE_ID_O2_6836                      0x6836
908
909#define PCI_VENDOR_ID_3DFX                         0x121a
910#define PCI_DEVICE_ID_3DFX_VOODOO                  0x0001
911#define PCI_DEVICE_ID_3DFX_VOODOO2                 0x0002
912
913#define PCI_VENDOR_ID_SIGMADES                     0x1236
914#define PCI_DEVICE_ID_SIGMADES_6425                0x6401
915
916#define PCI_VENDOR_ID_CCUBE                        0x123f
917
918#define PCI_VENDOR_ID_DIPIX                        0x1246
919
920#define PCI_VENDOR_ID_STALLION                     0x124d
921#define PCI_DEVICE_ID_STALLION_ECHPCI832           0x0000
922#define PCI_DEVICE_ID_STALLION_ECHPCI864           0x0002
923#define PCI_DEVICE_ID_STALLION_EIOPCI              0x0003
924
925#define PCI_VENDOR_ID_OPTIBASE                     0x1255
926#define PCI_DEVICE_ID_OPTIBASE_FORGE               0x1110
927#define PCI_DEVICE_ID_OPTIBASE_FUSION              0x1210
928#define PCI_DEVICE_ID_OPTIBASE_VPLEX               0x2110
929#define PCI_DEVICE_ID_OPTIBASE_VPLEXCC             0x2120
930#define PCI_DEVICE_ID_OPTIBASE_VQUEST              0x2130
931
932#define PCI_VENDOR_ID_SATSAGEM                     0x1267
933#define PCI_DEVICE_ID_SATSAGEM_PCR2101             0x5352
934#define PCI_DEVICE_ID_SATSAGEM_TELSATTURBO         0x5a4b
935
936#define PCI_VENDOR_ID_HUGHES                       0x1273
937#define PCI_DEVICE_ID_HUGHES_DIRECPC               0x0002
938
939#define PCI_VENDOR_ID_ENSONIQ                      0x1274
940#define PCI_DEVICE_ID_ENSONIQ_AUDIOPCI             0x5000
941
942#define PCI_VENDOR_ID_ALTEON                       0x12ae
943#define PCI_DEVICE_ID_ALTEON_ACENIC                0x0001
944
945#define PCI_VENDOR_ID_PICTUREL                     0x12c5
946#define PCI_DEVICE_ID_PICTUREL_PCIVST              0x0081
947
948#define PCI_VENDOR_ID_NVIDIA_SGS                   0x12d2
949#define PCI_DEVICE_ID_NVIDIA_SGS_RIVA128           0x0018
950
951#define PCI_VENDOR_ID_CBOARDS                      0x1307
952#define PCI_DEVICE_ID_CBOARDS_DAS1602_16           0x0001
953
954#define PCI_VENDOR_ID_SYMPHONY                     0x1c1c
955#define PCI_DEVICE_ID_SYMPHONY_101                 0x0001
956
957#define PCI_VENDOR_ID_TEKRAM                       0x1de1
958#define PCI_DEVICE_ID_TEKRAM_DC290                 0xdc29
959
960#define PCI_VENDOR_ID_3DLABS                       0x3d3d
961#define PCI_DEVICE_ID_3DLABS_300SX                 0x0001
962#define PCI_DEVICE_ID_3DLABS_500TX                 0x0002
963#define PCI_DEVICE_ID_3DLABS_DELTA                 0x0003
964#define PCI_DEVICE_ID_3DLABS_PERMEDIA              0x0004
965#define PCI_DEVICE_ID_3DLABS_MX                    0x0006
966
967#define PCI_VENDOR_ID_AVANCE                       0x4005
968#define PCI_DEVICE_ID_AVANCE_ALG2064               0x2064
969#define PCI_DEVICE_ID_AVANCE_2302                  0x2302
970
971#define PCI_VENDOR_ID_NETVIN                       0x4a14
972#define PCI_DEVICE_ID_NETVIN_NV5000SC              0x5000
973
974#define PCI_VENDOR_ID_S3                           0x5333
975#define PCI_DEVICE_ID_S3_PLATO_PXS                 0x0551
976#define PCI_DEVICE_ID_S3_ViRGE                     0x5631
977#define PCI_DEVICE_ID_S3_TRIO                      0x8811
978#define PCI_DEVICE_ID_S3_AURORA64VP                0x8812
979#define PCI_DEVICE_ID_S3_TRIO64UVP                 0x8814
980#define PCI_DEVICE_ID_S3_ViRGE_VX                  0x883d
981#define PCI_DEVICE_ID_S3_868                       0x8880
982#define PCI_DEVICE_ID_S3_928                       0x88b0
983#define PCI_DEVICE_ID_S3_864_1                     0x88c0
984#define PCI_DEVICE_ID_S3_864_2                     0x88c1
985#define PCI_DEVICE_ID_S3_964_1                     0x88d0
986#define PCI_DEVICE_ID_S3_964_2                     0x88d1
987#define PCI_DEVICE_ID_S3_968                       0x88f0
988#define PCI_DEVICE_ID_S3_TRIO64V2                  0x8901
989#define PCI_DEVICE_ID_S3_PLATO_PXG                 0x8902
990#define PCI_DEVICE_ID_S3_ViRGE_DXGX                0x8a01
991#define PCI_DEVICE_ID_S3_ViRGE_GX2                 0x8a10
992#define PCI_DEVICE_ID_S3_ViRGE_MX                  0x8c01
993#define PCI_DEVICE_ID_S3_ViRGE_MXP                 0x8c02
994#define PCI_DEVICE_ID_S3_ViRGE_MXPMV               0x8c03
995#define PCI_DEVICE_ID_S3_SONICVIBES                0xca00
996
997#define PCI_VENDOR_ID_INTEL                        0x8086
998#define PCI_DEVICE_ID_INTEL_82375                  0x0482
999#define PCI_DEVICE_ID_INTEL_82424                  0x0483
1000#define PCI_DEVICE_ID_INTEL_82378                  0x0484
1001#define PCI_DEVICE_ID_INTEL_82430                  0x0486
1002#define PCI_DEVICE_ID_INTEL_82434                  0x04a3
1003#define PCI_DEVICE_ID_INTEL_82092AA_0              0x1221
1004#define PCI_DEVICE_ID_INTEL_82092AA_1              0x1222
1005#define PCI_DEVICE_ID_INTEL_7116                   0x1223
1006#define PCI_DEVICE_ID_INTEL_82596                  0x1226
1007#define PCI_DEVICE_ID_INTEL_82865                  0x1227
1008#define PCI_DEVICE_ID_INTEL_82557                  0x1229
1009#define PCI_DEVICE_ID_INTEL_82437                  0x122d
1010#define PCI_DEVICE_ID_INTEL_82371FB_0              0x122e
1011#define PCI_DEVICE_ID_INTEL_82371FB_1              0x1230
1012#define PCI_DEVICE_ID_INTEL_82371MX                0x1234
1013#define PCI_DEVICE_ID_INTEL_82437MX                0x1235
1014#define PCI_DEVICE_ID_INTEL_82441                  0x1237
1015#define PCI_DEVICE_ID_INTEL_82380FB                0x124b
1016#define PCI_DEVICE_ID_INTEL_82439                  0x1250
1017#define PCI_DEVICE_ID_INTEL_82371SB_0              0x7000
1018#define PCI_DEVICE_ID_INTEL_82371SB_1              0x7010
1019#define PCI_DEVICE_ID_INTEL_82371SB_2              0x7020
1020#define PCI_DEVICE_ID_INTEL_82437VX                0x7030
1021#define PCI_DEVICE_ID_INTEL_82439TX                0x7100
1022#define PCI_DEVICE_ID_INTEL_82371AB_0              0x7110
1023#define PCI_DEVICE_ID_INTEL_82371AB                0x7111
1024#define PCI_DEVICE_ID_INTEL_82371AB_2              0x7112
1025#define PCI_DEVICE_ID_INTEL_82371AB_3              0x7113
1026#define PCI_DEVICE_ID_INTEL_82443LX_0              0x7180
1027#define PCI_DEVICE_ID_INTEL_82443LX_1              0x7181
1028#define PCI_DEVICE_ID_INTEL_82443BX_0              0x7190
1029#define PCI_DEVICE_ID_INTEL_82443BX_1              0x7191
1030#define PCI_DEVICE_ID_INTEL_82443BX_2              0x7192
1031#define PCI_DEVICE_ID_INTEL_P6                     0x84c4
1032#define PCI_DEVICE_ID_INTEL_82450GX                0x84c5
1033
1034#define PCI_VENDOR_ID_KTI                          0x8e2e
1035#define PCI_DEVICE_ID_KTI_ET32P2                   0x3000
1036
1037#define PCI_VENDOR_ID_ADAPTEC                      0x9004
1038#define PCI_DEVICE_ID_ADAPTEC_7810                 0x1078
1039#define PCI_DEVICE_ID_ADAPTEC_7850                 0x5078
1040#define PCI_DEVICE_ID_ADAPTEC_7855                 0x5578
1041#define PCI_DEVICE_ID_ADAPTEC_5800                 0x5800
1042#define PCI_DEVICE_ID_ADAPTEC_1480A                0x6075
1043#define PCI_DEVICE_ID_ADAPTEC_7860                 0x6078
1044#define PCI_DEVICE_ID_ADAPTEC_7861                 0x6178
1045#define PCI_DEVICE_ID_ADAPTEC_7870                 0x7078
1046#define PCI_DEVICE_ID_ADAPTEC_7871                 0x7178
1047#define PCI_DEVICE_ID_ADAPTEC_7872                 0x7278
1048#define PCI_DEVICE_ID_ADAPTEC_7873                 0x7378
1049#define PCI_DEVICE_ID_ADAPTEC_7874                 0x7478
1050#define PCI_DEVICE_ID_ADAPTEC_7895                 0x7895
1051#define PCI_DEVICE_ID_ADAPTEC_7880                 0x8078
1052#define PCI_DEVICE_ID_ADAPTEC_7881                 0x8178
1053#define PCI_DEVICE_ID_ADAPTEC_7882                 0x8278
1054#define PCI_DEVICE_ID_ADAPTEC_7883                 0x8378
1055#define PCI_DEVICE_ID_ADAPTEC_7884                 0x8478
1056#define PCI_DEVICE_ID_ADAPTEC_1030                 0x8b78
1057
1058#define PCI_VENDOR_ID_ADAPTEC2                     0x9005
1059#define PCI_DEVICE_ID_ADAPTEC2_2940U2              0x0010
1060#define PCI_DEVICE_ID_ADAPTEC2_7890                0x001f
1061#define PCI_DEVICE_ID_ADAPTEC2_3940U2              0x0050
1062#define PCI_DEVICE_ID_ADAPTEC2_7896                0x005f
1063
1064#define PCI_VENDOR_ID_ATRONICS                     0x907f
1065#define PCI_DEVICE_ID_ATRONICS_2015                0x2015
1066
1067#define PCI_VENDOR_ID_HOLTEK                       0x9412
1068#define PCI_DEVICE_ID_HOLTEK_6565                  0x6565
1069
1070#define PCI_VENDOR_ID_TIGERJET                     0xe159
1071#define PCI_DEVICE_ID_TIGERJET_300                 0x0001
1072
1073#define PCI_VENDOR_ID_ARK                          0xedd8
1074#define PCI_DEVICE_ID_ARK_STING                    0xa091
1075#define PCI_DEVICE_ID_ARK_STINGARK                 0xa099
1076#define PCI_DEVICE_ID_ARK_2000MT                   0xa0a1
1077/*
1078 * The PCI interface treats multi-function devices as independent
1079 * devices.  The slot/function address of each device is encoded
1080 * in a single byte as follows:
1081 *
1082 *  7:3 = slot
1083 *  2:0 = function
1084 */
1085#define PCI_DEVFN(_slot,_func) ((((_slot) & 0x1f) << 3) | ((_func) & 0x07))
1086#define PCI_SLOT(_devfn)      (((_devfn) >> 3) & 0x1f)
1087#define PCI_FUNC(_devfn)      ((_devfn) & 0x07)
1088
1089/*
1090 * Error values that may be returned by the PCI bios.
1091 */
1092#define PCIBIOS_SUCCESSFUL          0x00
1093#define PCIBIOS_FUNC_NOT_SUPPORTED  0x81
1094#define PCIBIOS_BAD_VENDOR_ID       0x83
1095#define PCIBIOS_DEVICE_NOT_FOUND    0x86
1096#define PCIBIOS_BAD_REGISTER_NUMBER 0x87
1097#define PCIBIOS_SET_FAILED          0x88
1098#define PCIBIOS_BUFFER_TOO_SMALL    0x89
1099
1100/* T. Straumann, 7/31/2001: increased to 32 - PMC slots are not
1101 * scanned on mvme2306 otherwise
1102 */
1103#define PCI_MAX_DEVICES      32
1104#define PCI_MAX_FUNCTIONS    8
1105
1106typedef struct  {
1107  int (*read_config_byte)(unsigned char, unsigned char,  unsigned char,
1108                          unsigned char, uint8_t *);
1109  int (*read_config_word)(unsigned char, unsigned char,  unsigned char,
1110                          unsigned char, uint16_t *);
1111  int (*read_config_dword)(unsigned char, unsigned char,  unsigned char,
1112                           unsigned char, uint32_t *);
1113  int (*write_config_byte)(unsigned char, unsigned char,  unsigned char,
1114                           unsigned char, uint8_t);
1115  int (*write_config_word)(unsigned char, unsigned char,  unsigned char,
1116                           unsigned char, uint16_t);
1117  int (*write_config_dword)(unsigned char, unsigned char,  unsigned char,
1118                            unsigned char, uint32_t);
1119} pci_config_access_functions;
1120
1121/* Error codes for pci_initialize */
1122#define PCIB_ERR_SUCCESS       (0)
1123#define PCIB_ERR_UNINITIALIZED (-1)  /* PCI BIOS is not initilized */
1124#define PCIB_ERR_NOTPRESENT    (-2)  /* PCI BIOS not present */
1125#define PCIB_ERR_NOFUNC        (-3)  /* Function not supported */
1126#define PCIB_ERR_BADVENDOR     (-4)  /* Bad Vendor ID */
1127#define PCIB_ERR_DEVNOTFOUND   (-5)  /* Device not found */
1128#define PCIB_ERR_BADREG        (-6)  /* Bad register number */
1129
1130extern int pci_initialize();
1131
1132typedef struct {
1133  volatile unsigned char*            pci_config_addr;
1134  volatile unsigned char*            pci_config_data;
1135  const pci_config_access_functions* pci_functions;
1136} pci_config;
1137
1138extern pci_config BSP_pci_configuration;
1139
1140extern inline int
1141pci_read_config_byte(
1142  unsigned char bus,
1143  unsigned char slot,
1144  unsigned char function,
1145  unsigned char where,
1146  uint8_t      *val)
1147{
1148  return BSP_pci_configuration.pci_functions->read_config_byte(
1149            bus, slot, function, where, val);
1150}
1151
1152extern inline int
1153pci_read_config_word(
1154  unsigned char bus,
1155  unsigned char slot,
1156  unsigned char function,
1157  unsigned char where,
1158  uint16_t     *val)
1159{
1160  return BSP_pci_configuration.pci_functions->read_config_word(
1161             bus, slot, function, where, val);
1162}
1163
1164extern inline int
1165pci_read_config_dword(
1166  unsigned char bus,
1167  unsigned char slot,
1168  unsigned char function,
1169  unsigned char where,
1170  uint32_t     *val)
1171{
1172  return BSP_pci_configuration.pci_functions->read_config_dword(bus, slot, function, where, val);
1173}
1174
1175extern inline int
1176pci_write_config_byte(
1177  unsigned char bus,
1178  unsigned char slot,
1179  unsigned char function,
1180  unsigned char where,
1181  uint8_t       val)
1182{
1183  return BSP_pci_configuration.pci_functions->write_config_byte(
1184             bus, slot, function, where, val);
1185}
1186
1187extern inline int
1188pci_write_config_word(
1189  unsigned char bus,
1190  unsigned char slot,
1191  unsigned char function,
1192  unsigned char where,
1193  uint16_t      val)
1194{
1195  return BSP_pci_configuration.pci_functions->write_config_word(
1196              bus, slot, function, where, val);
1197}
1198
1199extern inline int
1200pci_write_config_dword(
1201  unsigned char bus,
1202  unsigned char slot,
1203  unsigned char function,
1204  unsigned char where,
1205  uint32_t      val)
1206{
1207  return BSP_pci_configuration.pci_functions->write_config_dword(
1208      bus, slot, function, where, val);
1209}
1210
1211/* scan for a specific device */
1212/* find a particular PCI device
1213 * (currently, only bus0 is scanned for device/fun0)
1214 *
1215 * RETURNS: zero on success, bus/dev/fun in *pbus / *pdev / *pfun
1216 */
1217int
1218pci_find_device(
1219  unsigned short vendorid,
1220  unsigned short deviceid,
1221  int instance,
1222  int *pbus,
1223  int *pdev,
1224  int *pfun
1225);
1226
1227/*
1228 * Return the number of PCI busses in the system
1229 */
1230extern unsigned char pci_bus_count();
1231
1232#ifdef __cplusplus
1233}
1234#endif
1235
1236#endif /* _RTEMS_PCI_H */
Note: See TracBrowser for help on using the repository browser.