1/*
2 * Copyright 2017, Data61
3 * Commonwealth Scientific and Industrial Research Organisation (CSIRO)
4 * ABN 41 687 119 230.
5 *
6 * This software may be distributed and modified according to the terms of
7 * the BSD 2-Clause license. Note that NO WARRANTY is provided.
8 * See "LICENSE_BSD2.txt" for details.
9 *
10 * @TAG(DATA61_BSD)
11 */
12#pragma once
13
14#include <stdio.h>
15#include <stdint.h>
16
17/*
18 * Under PCI, each device has 256 bytes of configuration address space,
19 * of which the first 64 bytes are standardized as follows:
20 */
21#define PCI_STD_HEADER_SIZEOF   64
22#define PCI_VENDOR_ID           0x00    /* 16 bits */
23#define PCI_DEVICE_ID           0x02    /* 16 bits */
24#define PCI_COMMAND             0x04    /* 16 bits */
25#define  PCI_COMMAND_IO         0x1     /* Enable response in I/O space */
26#define  PCI_COMMAND_MEMORY     0x2     /* Enable response in Memory space */
27#define  PCI_COMMAND_MASTER     0x4     /* Enable bus mastering */
28#define  PCI_COMMAND_SPECIAL    0x8     /* Enable response to special cycles */
29#define  PCI_COMMAND_INVALIDATE 0x10    /* Use memory write and invalidate */
30#define  PCI_COMMAND_VGA_PALETTE 0x20   /* Enable palette snooping */
31#define  PCI_COMMAND_PARITY     0x40    /* Enable parity checking */
32#define  PCI_COMMAND_WAIT       0x80    /* Enable address/data stepping */
33#define  PCI_COMMAND_SERR       0x100   /* Enable SERR */
34#define  PCI_COMMAND_FAST_BACK  0x200   /* Enable back-to-back writes */
35#define  PCI_COMMAND_INTX_DISABLE 0x400 /* INTx Emulation Disable */
36
37#define PCI_STATUS              0x06    /* 16 bits */
38#define  PCI_STATUS_INTERRUPT   0x08    /* Interrupt status */
39#define  PCI_STATUS_CAP_LIST    0x10    /* Support Capability List */
40#define  PCI_STATUS_66MHZ       0x20    /* Support 66 Mhz PCI 2.1 bus */
41#define  PCI_STATUS_UDF         0x40    /* Support User Definable Features [obsolete] */
42#define  PCI_STATUS_FAST_BACK   0x80    /* Accept fast-back to back */
43#define  PCI_STATUS_PARITY      0x100   /* Detected parity error */
44#define  PCI_STATUS_DEVSEL_MASK 0x600   /* DEVSEL timing */
45#define  PCI_STATUS_DEVSEL_FAST         0x000
46#define  PCI_STATUS_DEVSEL_MEDIUM       0x200
47#define  PCI_STATUS_DEVSEL_SLOW         0x400
48#define  PCI_STATUS_SIG_TARGET_ABORT    0x800 /* Set on target abort */
49#define  PCI_STATUS_REC_TARGET_ABORT    0x1000 /* Master ack of " */
50#define  PCI_STATUS_REC_MASTER_ABORT    0x2000 /* Set on master abort */
51#define  PCI_STATUS_SIG_SYSTEM_ERROR    0x4000 /* Set when we drive SERR */
52#define  PCI_STATUS_DETECTED_PARITY     0x8000 /* Set on parity error */
53
54#define PCI_CLASS_REVISION      0x08    /* High 24 bits are class, low 8 revision */
55#define PCI_REVISION_ID         0x08    /* Revision ID */
56#define PCI_CLASS_PROG          0x09    /* Reg. Level Programming Interface */
57#define PCI_CLASS_DEVICE        0x0a    /* Device class */
58
59#define PCI_CACHE_LINE_SIZE     0x0c    /* 8 bits */
60#define PCI_LATENCY_TIMER       0x0d    /* 8 bits */
61#define PCI_HEADER_TYPE         0x0e    /* 8 bits */
62#define  PCI_HEADER_TYPE_NORMAL         0
63#define  PCI_HEADER_TYPE_BRIDGE         1
64#define  PCI_HEADER_TYPE_CARDBUS        2
65
66#define PCI_BIST                0x0f    /* 8 bits */
67#define  PCI_BIST_CODE_MASK     0x0f    /* Return result */
68#define  PCI_BIST_START         0x40    /* 1 to start BIST, 2 secs or less */
69#define  PCI_BIST_CAPABLE       0x80    /* 1 if BIST capable */
70
71/*
72 * Base addresses specify locations in memory or I/O space.
73 * Decoded size can be determined by writing a value of
74 * 0xffffffff to the register, and reading it back.  Only
75 * 1 bits are decoded.
76 */
77#define PCI_BASE_ADDRESS_0      0x10    /* 32 bits */
78#define PCI_BASE_ADDRESS_1      0x14    /* 32 bits [htype 0,1 only] */
79#define PCI_BASE_ADDRESS_2      0x18    /* 32 bits [htype 0 only] */
80#define PCI_BASE_ADDRESS_3      0x1c    /* 32 bits */
81#define PCI_BASE_ADDRESS_4      0x20    /* 32 bits */
82#define PCI_BASE_ADDRESS_5      0x24    /* 32 bits */
83#define  PCI_BASE_ADDRESS_SPACE         0x01    /* 0 = memory, 1 = I/O */
84#define  PCI_BASE_ADDRESS_SPACE_IO      0x01
85#define  PCI_BASE_ADDRESS_SPACE_MEMORY  0x00
86#define  PCI_BASE_ADDRESS_MEM_TYPE_MASK 0x06
87#define  PCI_BASE_ADDRESS_MEM_TYPE_32   0x00    /* 32 bit address */
88#define  PCI_BASE_ADDRESS_MEM_TYPE_1M   0x02    /* Below 1M [obsolete] */
89#define  PCI_BASE_ADDRESS_MEM_TYPE_64   0x04    /* 64 bit address */
90#define  PCI_BASE_ADDRESS_MEM_PREFETCH  0x08    /* prefetchable? */
91#define  PCI_BASE_ADDRESS_MEM_MASK      (~0x0fUL)
92#define  PCI_BASE_ADDRESS_IO_MASK       (~0x03UL)
93/* bit 1 is reserved if address_space = 1 */
94
95/* Header type 0 (normal devices) */
96#define PCI_CARDBUS_CIS         0x28
97#define PCI_SUBSYSTEM_VENDOR_ID 0x2c
98#define PCI_SUBSYSTEM_ID        0x2e
99#define PCI_ROM_ADDRESS         0x30    /* Bits 31..11 are address, 10..1 reserved */
100#define  PCI_ROM_ADDRESS_ENABLE 0x01
101#define PCI_ROM_ADDRESS_MASK    (~0x7ffUL)
102
103#define PCI_CAPABILITY_LIST     0x34    /* Offset of first capability list entry */
104
105/* 0x35-0x3b are reserved */
106#define PCI_INTERRUPT_LINE      0x3c    /* 8 bits */
107#define PCI_INTERRUPT_PIN       0x3d    /* 8 bits */
108#define PCI_MIN_GNT             0x3e    /* 8 bits */
109#define PCI_MAX_LAT             0x3f    /* 8 bits */
110
111/* Header type 1 (PCI-to-PCI bridges) */
112#define PCI_PRIMARY_BUS         0x18    /* Primary bus number */
113#define PCI_SECONDARY_BUS       0x19    /* Secondary bus number */
114#define PCI_SUBORDINATE_BUS     0x1a    /* Highest bus number behind the bridge */
115#define PCI_SEC_LATENCY_TIMER   0x1b    /* Latency timer for secondary interface */
116#define PCI_IO_BASE             0x1c    /* I/O range behind the bridge */
117#define PCI_IO_LIMIT            0x1d
118#define  PCI_IO_RANGE_TYPE_MASK 0x0fUL  /* I/O bridging type */
119#define  PCI_IO_RANGE_TYPE_16   0x00
120#define  PCI_IO_RANGE_TYPE_32   0x01
121#define  PCI_IO_RANGE_MASK      (~0x0fUL) /* Standard 4K I/O windows */
122#define  PCI_IO_1K_RANGE_MASK   (~0x03UL) /* Intel 1K I/O windows */
123#define PCI_SEC_STATUS          0x1e    /* Secondary status register, only bit 14 used */
124#define PCI_MEMORY_BASE         0x20    /* Memory range behind */
125#define PCI_MEMORY_LIMIT        0x22
126#define  PCI_MEMORY_RANGE_TYPE_MASK 0x0fUL
127#define  PCI_MEMORY_RANGE_MASK  (~0x0fUL)
128#define PCI_PREF_MEMORY_BASE    0x24    /* Prefetchable memory range behind */
129#define PCI_PREF_MEMORY_LIMIT   0x26
130#define  PCI_PREF_RANGE_TYPE_MASK 0x0fUL
131#define  PCI_PREF_RANGE_TYPE_32 0x00
132#define  PCI_PREF_RANGE_TYPE_64 0x01
133#define  PCI_PREF_RANGE_MASK    (~0x0fUL)
134#define PCI_PREF_BASE_UPPER32   0x28    /* Upper half of prefetchable memory range */
135#define PCI_PREF_LIMIT_UPPER32  0x2c
136#define PCI_IO_BASE_UPPER16     0x30    /* Upper half of I/O addresses */
137#define PCI_IO_LIMIT_UPPER16    0x32
138/* 0x34 same as for htype 0 */
139/* 0x35-0x3b is reserved */
140#define PCI_ROM_ADDRESS1        0x38    /* Same as PCI_ROM_ADDRESS, but for htype 1 */
141/* 0x3c-0x3d are same as for htype 0 */
142#define PCI_BRIDGE_CONTROL      0x3e
143#define  PCI_BRIDGE_CTL_PARITY  0x01    /* Enable parity detection on secondary interface */
144#define  PCI_BRIDGE_CTL_SERR    0x02    /* The same for SERR forwarding */
145#define  PCI_BRIDGE_CTL_ISA     0x04    /* Enable ISA mode */
146#define  PCI_BRIDGE_CTL_VGA     0x08    /* Forward VGA addresses */
147#define  PCI_BRIDGE_CTL_MASTER_ABORT    0x20  /* Report master aborts */
148#define  PCI_BRIDGE_CTL_BUS_RESET       0x40    /* Secondary bus reset */
149#define  PCI_BRIDGE_CTL_FAST_BACK       0x80    /* Fast Back2Back enabled on secondary interface */
150
151/* Header type 2 (CardBus bridges) */
152#define PCI_CB_CAPABILITY_LIST  0x14
153/* 0x15 reserved */
154#define PCI_CB_SEC_STATUS       0x16    /* Secondary status */
155#define PCI_CB_PRIMARY_BUS      0x18    /* PCI bus number */
156#define PCI_CB_CARD_BUS         0x19    /* CardBus bus number */
157#define PCI_CB_SUBORDINATE_BUS  0x1a    /* Subordinate bus number */
158#define PCI_CB_LATENCY_TIMER    0x1b    /* CardBus latency timer */
159#define PCI_CB_MEMORY_BASE_0    0x1c
160#define PCI_CB_MEMORY_LIMIT_0   0x20
161#define PCI_CB_MEMORY_BASE_1    0x24
162#define PCI_CB_MEMORY_LIMIT_1   0x28
163#define PCI_CB_IO_BASE_0        0x2c
164#define PCI_CB_IO_BASE_0_HI     0x2e
165#define PCI_CB_IO_LIMIT_0       0x30
166#define PCI_CB_IO_LIMIT_0_HI    0x32
167#define PCI_CB_IO_BASE_1        0x34
168#define PCI_CB_IO_BASE_1_HI     0x36
169#define PCI_CB_IO_LIMIT_1       0x38
170#define PCI_CB_IO_LIMIT_1_HI    0x3a
171#define  PCI_CB_IO_RANGE_MASK   (~0x03UL)
172/* 0x3c-0x3d are same as for htype 0 */
173#define PCI_CB_BRIDGE_CONTROL   0x3e
174#define  PCI_CB_BRIDGE_CTL_PARITY       0x01    /* Similar to standard bridge control register */
175#define  PCI_CB_BRIDGE_CTL_SERR         0x02
176#define  PCI_CB_BRIDGE_CTL_ISA          0x04
177#define  PCI_CB_BRIDGE_CTL_VGA          0x08
178#define  PCI_CB_BRIDGE_CTL_MASTER_ABORT 0x20
179#define  PCI_CB_BRIDGE_CTL_CB_RESET     0x40    /* CardBus reset */
180#define  PCI_CB_BRIDGE_CTL_16BIT_INT    0x80    /* Enable interrupt for 16-bit cards */
181#define  PCI_CB_BRIDGE_CTL_PREFETCH_MEM0 0x100  /* Prefetch enable for both memory regions */
182#define  PCI_CB_BRIDGE_CTL_PREFETCH_MEM1 0x200
183#define  PCI_CB_BRIDGE_CTL_POST_WRITES  0x400
184#define PCI_CB_SUBSYSTEM_VENDOR_ID      0x40
185#define PCI_CB_SUBSYSTEM_ID             0x42
186#define PCI_CB_LEGACY_MODE_BASE         0x44    /* 16-bit PC Card legacy mode base address (ExCa) */
187/* 0x48-0x7f reserved */
188
189/* Capability lists */
190
191#define PCI_CAP_LIST_ID         0       /* Capability ID */
192#define  PCI_CAP_ID_PM          0x01    /* Power Management */
193#define  PCI_CAP_ID_AGP         0x02    /* Accelerated Graphics Port */
194#define  PCI_CAP_ID_VPD         0x03    /* Vital Product Data */
195#define  PCI_CAP_ID_SLOTID      0x04    /* Slot Identification */
196#define  PCI_CAP_ID_MSI         0x05    /* Message Signalled Interrupts */
197#define  PCI_CAP_ID_CHSWP       0x06    /* CompactPCI HotSwap */
198#define  PCI_CAP_ID_PCIX        0x07    /* PCI-X */
199#define  PCI_CAP_ID_HT          0x08    /* HyperTransport */
200#define  PCI_CAP_ID_VNDR        0x09    /* Vendor specific */
201#define  PCI_CAP_ID_DBG         0x0A    /* Debug port */
202#define  PCI_CAP_ID_CCRC        0x0B    /* CompactPCI Central Resource Control */
203#define  PCI_CAP_ID_SHPC        0x0C    /* PCI Standard Hot-Plug Controller */
204#define  PCI_CAP_ID_SSVID       0x0D    /* Bridge subsystem vendor/device ID */
205#define  PCI_CAP_ID_AGP3        0x0E    /* AGP Target PCI-PCI bridge */
206#define  PCI_CAP_ID_SECDEV      0x0F    /* Secure Device */
207#define  PCI_CAP_ID_EXP         0x10    /* PCI Express */
208#define  PCI_CAP_ID_MSIX        0x11    /* MSI-X */
209#define  PCI_CAP_ID_SATA        0x12    /* SATA Data/Index Conf. */
210#define  PCI_CAP_ID_AF          0x13    /* PCI Advanced Features */
211#define  PCI_CAP_ID_MAX         PCI_CAP_ID_AF
212#define PCI_CAP_LIST_NEXT       1       /* Next capability in the list */
213#define PCI_CAP_FLAGS           2       /* Capability defined flags (16 bits) */
214#define PCI_CAP_SIZEOF          4
215
216/* Power Management Registers */
217
218#define PCI_PM_PMC              2       /* PM Capabilities Register */
219#define  PCI_PM_CAP_VER_MASK    0x0007  /* Version */
220#define  PCI_PM_CAP_PME_CLOCK   0x0008  /* PME clock required */
221#define  PCI_PM_CAP_RESERVED    0x0010  /* Reserved field */
222#define  PCI_PM_CAP_DSI         0x0020  /* Device specific initialization */
223#define  PCI_PM_CAP_AUX_POWER   0x01C0  /* Auxiliary power support mask */
224#define  PCI_PM_CAP_D1          0x0200  /* D1 power state support */
225#define  PCI_PM_CAP_D2          0x0400  /* D2 power state support */
226#define  PCI_PM_CAP_PME         0x0800  /* PME pin supported */
227#define  PCI_PM_CAP_PME_MASK    0xF800  /* PME Mask of all supported states */
228#define  PCI_PM_CAP_PME_D0      0x0800  /* PME# from D0 */
229#define  PCI_PM_CAP_PME_D1      0x1000  /* PME# from D1 */
230#define  PCI_PM_CAP_PME_D2      0x2000  /* PME# from D2 */
231#define  PCI_PM_CAP_PME_D3      0x4000  /* PME# from D3 (hot) */
232#define  PCI_PM_CAP_PME_D3cold  0x8000  /* PME# from D3 (cold) */
233#define  PCI_PM_CAP_PME_SHIFT   11      /* Start of the PME Mask in PMC */
234#define PCI_PM_CTRL             4       /* PM control and status register */
235#define  PCI_PM_CTRL_STATE_MASK 0x0003  /* Current power state (D0 to D3) */
236#define  PCI_PM_CTRL_NO_SOFT_RESET      0x0008  /* No reset for D3hot->D0 */
237#define  PCI_PM_CTRL_PME_ENABLE 0x0100  /* PME pin enable */
238#define  PCI_PM_CTRL_DATA_SEL_MASK      0x1e00  /* Data select (??) */
239#define  PCI_PM_CTRL_DATA_SCALE_MASK    0x6000  /* Data scale (??) */
240#define  PCI_PM_CTRL_PME_STATUS 0x8000  /* PME pin status */
241#define PCI_PM_PPB_EXTENSIONS   6       /* PPB support extensions (??) */
242#define  PCI_PM_PPB_B2_B3       0x40    /* Stop clock when in D3hot (??) */
243#define  PCI_PM_BPCC_ENABLE     0x80    /* Bus power/clock control enable (??) */
244#define PCI_PM_DATA_REGISTER    7       /* (??) */
245#define PCI_PM_SIZEOF           8
246
247/* AGP registers */
248
249#define PCI_AGP_VERSION         2       /* BCD version number */
250#define PCI_AGP_RFU             3       /* Rest of capability flags */
251#define PCI_AGP_STATUS          4       /* Status register */
252#define  PCI_AGP_STATUS_RQ_MASK 0xff000000      /* Maximum number of requests - 1 */
253#define  PCI_AGP_STATUS_SBA     0x0200  /* Sideband addressing supported */
254#define  PCI_AGP_STATUS_64BIT   0x0020  /* 64-bit addressing supported */
255#define  PCI_AGP_STATUS_FW      0x0010  /* FW transfers supported */
256#define  PCI_AGP_STATUS_RATE4   0x0004  /* 4x transfer rate supported */
257#define  PCI_AGP_STATUS_RATE2   0x0002  /* 2x transfer rate supported */
258#define  PCI_AGP_STATUS_RATE1   0x0001  /* 1x transfer rate supported */
259#define PCI_AGP_COMMAND         8       /* Control register */
260#define  PCI_AGP_COMMAND_RQ_MASK 0xff000000  /* Master: Maximum number of requests */
261#define  PCI_AGP_COMMAND_SBA    0x0200  /* Sideband addressing enabled */
262#define  PCI_AGP_COMMAND_AGP    0x0100  /* Allow processing of AGP transactions */
263#define  PCI_AGP_COMMAND_64BIT  0x0020  /* Allow processing of 64-bit addresses */
264#define  PCI_AGP_COMMAND_FW     0x0010  /* Force FW transfers */
265#define  PCI_AGP_COMMAND_RATE4  0x0004  /* Use 4x rate */
266#define  PCI_AGP_COMMAND_RATE2  0x0002  /* Use 2x rate */
267#define  PCI_AGP_COMMAND_RATE1  0x0001  /* Use 1x rate */
268#define PCI_AGP_SIZEOF          12
269
270/* Vital Product Data */
271
272#define PCI_VPD_ADDR            2       /* Address to access (15 bits!) */
273#define  PCI_VPD_ADDR_MASK      0x7fff  /* Address mask */
274#define  PCI_VPD_ADDR_F         0x8000  /* Write 0, 1 indicates completion */
275#define PCI_VPD_DATA            4       /* 32-bits of data returned here */
276#define PCI_CAP_VPD_SIZEOF      8
277
278/* Slot Identification */
279
280#define PCI_SID_ESR             2       /* Expansion Slot Register */
281#define  PCI_SID_ESR_NSLOTS     0x1f    /* Number of expansion slots available */
282#define  PCI_SID_ESR_FIC        0x20    /* First In Chassis Flag */
283#define PCI_SID_CHASSIS_NR      3       /* Chassis Number */
284
285/* Message Signalled Interrupts registers */
286
287#define PCI_MSI_FLAGS           2       /* Message Control */
288#define  PCI_MSI_FLAGS_ENABLE   0x0001  /* MSI feature enabled */
289#define  PCI_MSI_FLAGS_QMASK    0x000e  /* Maximum queue size available */
290#define  PCI_MSI_FLAGS_QSIZE    0x0070  /* Message queue size configured */
291#define  PCI_MSI_FLAGS_64BIT    0x0080  /* 64-bit addresses allowed */
292#define  PCI_MSI_FLAGS_MASKBIT  0x0100  /* Per-vector masking capable */
293#define PCI_MSI_RFU             3       /* Rest of capability flags */
294#define PCI_MSI_ADDRESS_LO      4       /* Lower 32 bits */
295#define PCI_MSI_ADDRESS_HI      8       /* Upper 32 bits (if PCI_MSI_FLAGS_64BIT set) */
296#define PCI_MSI_DATA_32         8       /* 16 bits of data for 32-bit devices */
297#define PCI_MSI_MASK_32         12      /* Mask bits register for 32-bit devices */
298#define PCI_MSI_PENDING_32      16      /* Pending intrs for 32-bit devices */
299#define PCI_MSI_DATA_64         12      /* 16 bits of data for 64-bit devices */
300#define PCI_MSI_MASK_64         16      /* Mask bits register for 64-bit devices */
301#define PCI_MSI_PENDING_64      20      /* Pending intrs for 64-bit devices */
302
303/* MSI-X registers */
304#define PCI_MSIX_FLAGS          2       /* Message Control */
305#define  PCI_MSIX_FLAGS_QSIZE   0x07FF  /* Table size */
306#define  PCI_MSIX_FLAGS_MASKALL 0x4000  /* Mask all vectors for this function */
307#define  PCI_MSIX_FLAGS_ENABLE  0x8000  /* MSI-X enable */
308#define PCI_MSIX_TABLE          4       /* Table offset */
309#define  PCI_MSIX_TABLE_BIR     0x00000007 /* BAR index */
310#define  PCI_MSIX_TABLE_OFFSET  0xfffffff8 /* Offset into specified BAR */
311#define PCI_MSIX_PBA            8       /* Pending Bit Array offset */
312#define  PCI_MSIX_PBA_BIR       0x00000007 /* BAR index */
313#define  PCI_MSIX_PBA_OFFSET    0xfffffff8 /* Offset into specified BAR */
314#define  PCI_MSIX_FLAGS_BIRMASK (7 << 0)   /* deprecated */
315#define PCI_CAP_MSIX_SIZEOF     12      /* size of MSIX registers */
316
317/* MSI-X entry's format */
318#define PCI_MSIX_ENTRY_SIZE             16
319#define  PCI_MSIX_ENTRY_LOWER_ADDR      0
320#define  PCI_MSIX_ENTRY_UPPER_ADDR      4
321#define  PCI_MSIX_ENTRY_DATA            8
322#define  PCI_MSIX_ENTRY_VECTOR_CTRL     12
323#define   PCI_MSIX_ENTRY_CTRL_MASKBIT   1
324
325/* CompactPCI Hotswap Register */
326
327#define PCI_CHSWP_CSR           2       /* Control and Status Register */
328#define  PCI_CHSWP_DHA          0x01    /* Device Hiding Arm */
329#define  PCI_CHSWP_EIM          0x02    /* ENUM# Signal Mask */
330#define  PCI_CHSWP_PIE          0x04    /* Pending Insert or Extract */
331#define  PCI_CHSWP_LOO          0x08    /* LED On / Off */
332#define  PCI_CHSWP_PI           0x30    /* Programming Interface */
333#define  PCI_CHSWP_EXT          0x40    /* ENUM# status - extraction */
334#define  PCI_CHSWP_INS          0x80    /* ENUM# status - insertion */
335
336/* PCI Advanced Feature registers */
337
338#define PCI_AF_LENGTH           2
339#define PCI_AF_CAP              3
340#define  PCI_AF_CAP_TP          0x01
341#define  PCI_AF_CAP_FLR         0x02
342#define PCI_AF_CTRL             4
343#define  PCI_AF_CTRL_FLR        0x01
344#define PCI_AF_STATUS           5
345#define  PCI_AF_STATUS_TP       0x01
346#define PCI_CAP_AF_SIZEOF       6       /* size of AF registers */
347
348/* PCI-X registers (Type 0 (non-bridge) devices) */
349
350#define PCI_X_CMD               2       /* Modes & Features */
351#define  PCI_X_CMD_DPERR_E      0x0001  /* Data Parity Error Recovery Enable */
352#define  PCI_X_CMD_ERO          0x0002  /* Enable Relaxed Ordering */
353#define  PCI_X_CMD_READ_512     0x0000  /* 512 byte maximum read byte count */
354#define  PCI_X_CMD_READ_1K      0x0004  /* 1Kbyte maximum read byte count */
355#define  PCI_X_CMD_READ_2K      0x0008  /* 2Kbyte maximum read byte count */
356#define  PCI_X_CMD_READ_4K      0x000c  /* 4Kbyte maximum read byte count */
357#define  PCI_X_CMD_MAX_READ     0x000c  /* Max Memory Read Byte Count */
358                             /* Max # of outstanding split transactions */
359#define  PCI_X_CMD_SPLIT_1      0x0000  /* Max 1 */
360#define  PCI_X_CMD_SPLIT_2      0x0010  /* Max 2 */
361#define  PCI_X_CMD_SPLIT_3      0x0020  /* Max 3 */
362#define  PCI_X_CMD_SPLIT_4      0x0030  /* Max 4 */
363#define  PCI_X_CMD_SPLIT_8      0x0040  /* Max 8 */
364#define  PCI_X_CMD_SPLIT_12     0x0050  /* Max 12 */
365#define  PCI_X_CMD_SPLIT_16     0x0060  /* Max 16 */
366#define  PCI_X_CMD_SPLIT_32     0x0070  /* Max 32 */
367#define  PCI_X_CMD_MAX_SPLIT    0x0070  /* Max Outstanding Split Transactions */
368#define  PCI_X_CMD_VERSION(x)   (((x) >> 12) & 3) /* Version */
369#define PCI_X_STATUS            4       /* PCI-X capabilities */
370#define  PCI_X_STATUS_DEVFN     0x000000ff      /* A copy of devfn */
371#define  PCI_X_STATUS_BUS       0x0000ff00      /* A copy of bus nr */
372#define  PCI_X_STATUS_64BIT     0x00010000      /* 64-bit device */
373#define  PCI_X_STATUS_133MHZ    0x00020000      /* 133 MHz capable */
374#define  PCI_X_STATUS_SPL_DISC  0x00040000      /* Split Completion Discarded */
375#define  PCI_X_STATUS_UNX_SPL   0x00080000      /* Unexpected Split Completion */
376#define  PCI_X_STATUS_COMPLEX   0x00100000      /* Device Complexity */
377#define  PCI_X_STATUS_MAX_READ  0x00600000      /* Designed Max Memory Read Count */
378#define  PCI_X_STATUS_MAX_SPLIT 0x03800000      /* Designed Max Outstanding Split Transactions */
379#define  PCI_X_STATUS_MAX_CUM   0x1c000000      /* Designed Max Cumulative Read Size */
380#define  PCI_X_STATUS_SPL_ERR   0x20000000      /* Rcvd Split Completion Error Msg */
381#define  PCI_X_STATUS_266MHZ    0x40000000      /* 266 MHz capable */
382#define  PCI_X_STATUS_533MHZ    0x80000000      /* 533 MHz capable */
383#define PCI_X_ECC_CSR           8       /* ECC control and status */
384#define PCI_CAP_PCIX_SIZEOF_V0  8       /* size of registers for Version 0 */
385#define PCI_CAP_PCIX_SIZEOF_V1  24      /* size for Version 1 */
386#define PCI_CAP_PCIX_SIZEOF_V2  PCI_CAP_PCIX_SIZEOF_V1  /* Same for v2 */
387
388/* PCI-X registers (Type 1 (bridge) devices) */
389
390#define PCI_X_BRIDGE_SSTATUS    2       /* Secondary Status */
391#define  PCI_X_SSTATUS_64BIT    0x0001  /* Secondary AD interface is 64 bits */
392#define  PCI_X_SSTATUS_133MHZ   0x0002  /* 133 MHz capable */
393#define  PCI_X_SSTATUS_FREQ     0x03c0  /* Secondary Bus Mode and Frequency */
394#define  PCI_X_SSTATUS_VERS     0x3000  /* PCI-X Capability Version */
395#define  PCI_X_SSTATUS_V1       0x1000  /* Mode 2, not Mode 1 */
396#define  PCI_X_SSTATUS_V2       0x2000  /* Mode 1 or Modes 1 and 2 */
397#define  PCI_X_SSTATUS_266MHZ   0x4000  /* 266 MHz capable */
398#define  PCI_X_SSTATUS_533MHZ   0x8000  /* 533 MHz capable */
399#define PCI_X_BRIDGE_STATUS     4       /* Bridge Status */
400
401/* PCI Bridge Subsystem ID registers */
402
403#define PCI_SSVID_VENDOR_ID     4       /* PCI-Bridge subsystem vendor id register */
404#define PCI_SSVID_DEVICE_ID     6       /* PCI-Bridge subsystem device id register */
405
406/* PCI Express capability registers */
407
408#define PCI_EXP_FLAGS           2       /* Capabilities register */
409#define PCI_EXP_FLAGS_VERS      0x000f  /* Capability version */
410#define PCI_EXP_FLAGS_TYPE      0x00f0  /* Device/Port type */
411#define  PCI_EXP_TYPE_ENDPOINT  0x0     /* Express Endpoint */
412#define  PCI_EXP_TYPE_LEG_END   0x1     /* Legacy Endpoint */
413#define  PCI_EXP_TYPE_ROOT_PORT 0x4     /* Root Port */
414#define  PCI_EXP_TYPE_UPSTREAM  0x5     /* Upstream Port */
415#define  PCI_EXP_TYPE_DOWNSTREAM 0x6    /* Downstream Port */
416#define  PCI_EXP_TYPE_PCI_BRIDGE 0x7    /* PCI/PCI-X Bridge */
417#define  PCI_EXP_TYPE_PCIE_BRIDGE 0x8   /* PCI/PCI-X to PCIE Bridge */
418#define  PCI_EXP_TYPE_RC_END    0x9     /* Root Complex Integrated Endpoint */
419#define  PCI_EXP_TYPE_RC_EC     0xa     /* Root Complex Event Collector */
420#define PCI_EXP_FLAGS_SLOT      0x0100  /* Slot implemented */
421#define PCI_EXP_FLAGS_IRQ       0x3e00  /* Interrupt message number */
422#define PCI_EXP_DEVCAP          4       /* Device capabilities */
423#define  PCI_EXP_DEVCAP_PAYLOAD 0x07    /* Max_Payload_Size */
424#define  PCI_EXP_DEVCAP_PHANTOM 0x18    /* Phantom functions */
425#define  PCI_EXP_DEVCAP_EXT_TAG 0x20    /* Extended tags */
426#define  PCI_EXP_DEVCAP_L0S     0x1c0   /* L0s Acceptable Latency */
427#define  PCI_EXP_DEVCAP_L1      0xe00   /* L1 Acceptable Latency */
428#define  PCI_EXP_DEVCAP_ATN_BUT 0x1000  /* Attention Button Present */
429#define  PCI_EXP_DEVCAP_ATN_IND 0x2000  /* Attention Indicator Present */
430#define  PCI_EXP_DEVCAP_PWR_IND 0x4000  /* Power Indicator Present */
431#define  PCI_EXP_DEVCAP_RBER    0x8000  /* Role-Based Error Reporting */
432#define  PCI_EXP_DEVCAP_PWR_VAL 0x3fc0000 /* Slot Power Limit Value */
433#define  PCI_EXP_DEVCAP_PWR_SCL 0xc000000 /* Slot Power Limit Scale */
434#define  PCI_EXP_DEVCAP_FLR     0x10000000 /* Function Level Reset */
435#define PCI_EXP_DEVCTL          8       /* Device Control */
436#define  PCI_EXP_DEVCTL_CERE    0x0001  /* Correctable Error Reporting En. */
437#define  PCI_EXP_DEVCTL_NFERE   0x0002  /* Non-Fatal Error Reporting Enable */
438#define  PCI_EXP_DEVCTL_FERE    0x0004  /* Fatal Error Reporting Enable */
439#define  PCI_EXP_DEVCTL_URRE    0x0008  /* Unsupported Request Reporting En. */
440#define  PCI_EXP_DEVCTL_RELAX_EN 0x0010 /* Enable relaxed ordering */
441#define  PCI_EXP_DEVCTL_PAYLOAD 0x00e0  /* Max_Payload_Size */
442#define  PCI_EXP_DEVCTL_EXT_TAG 0x0100  /* Extended Tag Field Enable */
443#define  PCI_EXP_DEVCTL_PHANTOM 0x0200  /* Phantom Functions Enable */
444#define  PCI_EXP_DEVCTL_AUX_PME 0x0400  /* Auxiliary Power PM Enable */
445#define  PCI_EXP_DEVCTL_NOSNOOP_EN 0x0800  /* Enable No Snoop */
446#define  PCI_EXP_DEVCTL_READRQ  0x7000  /* Max_Read_Request_Size */
447#define  PCI_EXP_DEVCTL_BCR_FLR 0x8000  /* Bridge Configuration Retry / FLR */
448#define PCI_EXP_DEVSTA          10      /* Device Status */
449#define  PCI_EXP_DEVSTA_CED     0x01    /* Correctable Error Detected */
450#define  PCI_EXP_DEVSTA_NFED    0x02    /* Non-Fatal Error Detected */
451#define  PCI_EXP_DEVSTA_FED     0x04    /* Fatal Error Detected */
452#define  PCI_EXP_DEVSTA_URD     0x08    /* Unsupported Request Detected */
453#define  PCI_EXP_DEVSTA_AUXPD   0x10    /* AUX Power Detected */
454#define  PCI_EXP_DEVSTA_TRPND   0x20    /* Transactions Pending */
455#define PCI_EXP_LNKCAP          12      /* Link Capabilities */
456#define  PCI_EXP_LNKCAP_SLS     0x0000000f /* Supported Link Speeds */
457#define  PCI_EXP_LNKCAP_SLS_2_5GB 0x1   /* LNKCAP2 SLS Vector bit 0 (2.5GT/s) */
458#define  PCI_EXP_LNKCAP_SLS_5_0GB 0x2   /* LNKCAP2 SLS Vector bit 1 (5.0GT/s) */
459#define  PCI_EXP_LNKCAP_MLW     0x000003f0 /* Maximum Link Width */
460#define  PCI_EXP_LNKCAP_ASPMS   0x00000c00 /* ASPM Support */
461#define  PCI_EXP_LNKCAP_L0SEL   0x00007000 /* L0s Exit Latency */
462#define  PCI_EXP_LNKCAP_L1EL    0x00038000 /* L1 Exit Latency */
463#define  PCI_EXP_LNKCAP_CLKPM   0x00040000 /* Clock Power Management */
464#define  PCI_EXP_LNKCAP_SDERC   0x00080000 /* Surprise Down Error Reporting Capable */
465#define  PCI_EXP_LNKCAP_DLLLARC 0x00100000 /* Data Link Layer Link Active Reporting Capable */
466#define  PCI_EXP_LNKCAP_LBNC    0x00200000 /* Link Bandwidth Notification Capability */
467#define  PCI_EXP_LNKCAP_PN      0xff000000 /* Port Number */
468#define PCI_EXP_LNKCTL          16      /* Link Control */
469#define  PCI_EXP_LNKCTL_ASPMC   0x0003  /* ASPM Control */
470#define  PCI_EXP_LNKCTL_ASPM_L0S  0x01  /* L0s Enable */
471#define  PCI_EXP_LNKCTL_ASPM_L1   0x02  /* L1 Enable */
472#define  PCI_EXP_LNKCTL_RCB     0x0008  /* Read Completion Boundary */
473#define  PCI_EXP_LNKCTL_LD      0x0010  /* Link Disable */
474#define  PCI_EXP_LNKCTL_RL      0x0020  /* Retrain Link */
475#define  PCI_EXP_LNKCTL_CCC     0x0040  /* Common Clock Configuration */
476#define  PCI_EXP_LNKCTL_ES      0x0080  /* Extended Synch */
477#define  PCI_EXP_LNKCTL_CLKREQ_EN 0x100 /* Enable clkreq */
478#define  PCI_EXP_LNKCTL_HAWD    0x0200  /* Hardware Autonomous Width Disable */
479#define  PCI_EXP_LNKCTL_LBMIE   0x0400  /* Link Bandwidth Management Interrupt Enable */
480#define  PCI_EXP_LNKCTL_LABIE   0x0800  /* Lnk Autonomous Bandwidth Interrupt Enable */
481#define PCI_EXP_LNKSTA          18      /* Link Status */
482#define  PCI_EXP_LNKSTA_CLS     0x000f  /* Current Link Speed */
483#define  PCI_EXP_LNKSTA_CLS_2_5GB 0x01  /* Current Link Speed 2.5GT/s */
484#define  PCI_EXP_LNKSTA_CLS_5_0GB 0x02  /* Current Link Speed 5.0GT/s */
485#define  PCI_EXP_LNKSTA_NLW     0x03f0  /* Nogotiated Link Width */
486#define  PCI_EXP_LNKSTA_NLW_SHIFT 4     /* start of NLW mask in link status */
487#define  PCI_EXP_LNKSTA_LT      0x0800  /* Link Training */
488#define  PCI_EXP_LNKSTA_SLC     0x1000  /* Slot Clock Configuration */
489#define  PCI_EXP_LNKSTA_DLLLA   0x2000  /* Data Link Layer Link Active */
490#define  PCI_EXP_LNKSTA_LBMS    0x4000  /* Link Bandwidth Management Status */
491#define  PCI_EXP_LNKSTA_LABS    0x8000  /* Link Autonomous Bandwidth Status */
492#define PCI_CAP_EXP_ENDPOINT_SIZEOF_V1  20      /* v1 endpoints end here */
493#define PCI_EXP_SLTCAP          20      /* Slot Capabilities */
494#define  PCI_EXP_SLTCAP_ABP     0x00000001 /* Attention Button Present */
495#define  PCI_EXP_SLTCAP_PCP     0x00000002 /* Power Controller Present */
496#define  PCI_EXP_SLTCAP_MRLSP   0x00000004 /* MRL Sensor Present */
497#define  PCI_EXP_SLTCAP_AIP     0x00000008 /* Attention Indicator Present */
498#define  PCI_EXP_SLTCAP_PIP     0x00000010 /* Power Indicator Present */
499#define  PCI_EXP_SLTCAP_HPS     0x00000020 /* Hot-Plug Surprise */
500#define  PCI_EXP_SLTCAP_HPC     0x00000040 /* Hot-Plug Capable */
501#define  PCI_EXP_SLTCAP_SPLV    0x00007f80 /* Slot Power Limit Value */
502#define  PCI_EXP_SLTCAP_SPLS    0x00018000 /* Slot Power Limit Scale */
503#define  PCI_EXP_SLTCAP_EIP     0x00020000 /* Electromechanical Interlock Present */
504#define  PCI_EXP_SLTCAP_NCCS    0x00040000 /* No Command Completed Support */
505#define  PCI_EXP_SLTCAP_PSN     0xfff80000 /* Physical Slot Number */
506#define PCI_EXP_SLTCTL          24      /* Slot Control */
507#define  PCI_EXP_SLTCTL_ABPE    0x0001  /* Attention Button Pressed Enable */
508#define  PCI_EXP_SLTCTL_PFDE    0x0002  /* Power Fault Detected Enable */
509#define  PCI_EXP_SLTCTL_MRLSCE  0x0004  /* MRL Sensor Changed Enable */
510#define  PCI_EXP_SLTCTL_PDCE    0x0008  /* Presence Detect Changed Enable */
511#define  PCI_EXP_SLTCTL_CCIE    0x0010  /* Command Completed Interrupt Enable */
512#define  PCI_EXP_SLTCTL_HPIE    0x0020  /* Hot-Plug Interrupt Enable */
513#define  PCI_EXP_SLTCTL_AIC     0x00c0  /* Attention Indicator Control */
514#define  PCI_EXP_SLTCTL_PIC     0x0300  /* Power Indicator Control */
515#define  PCI_EXP_SLTCTL_PCC     0x0400  /* Power Controller Control */
516#define  PCI_EXP_SLTCTL_EIC     0x0800  /* Electromechanical Interlock Control */
517#define  PCI_EXP_SLTCTL_DLLSCE  0x1000  /* Data Link Layer State Changed Enable */
518#define PCI_EXP_SLTSTA          26      /* Slot Status */
519#define  PCI_EXP_SLTSTA_ABP     0x0001  /* Attention Button Pressed */
520#define  PCI_EXP_SLTSTA_PFD     0x0002  /* Power Fault Detected */
521#define  PCI_EXP_SLTSTA_MRLSC   0x0004  /* MRL Sensor Changed */
522#define  PCI_EXP_SLTSTA_PDC     0x0008  /* Presence Detect Changed */
523#define  PCI_EXP_SLTSTA_CC      0x0010  /* Command Completed */
524#define  PCI_EXP_SLTSTA_MRLSS   0x0020  /* MRL Sensor State */
525#define  PCI_EXP_SLTSTA_PDS     0x0040  /* Presence Detect State */
526#define  PCI_EXP_SLTSTA_EIS     0x0080  /* Electromechanical Interlock Status */
527#define  PCI_EXP_SLTSTA_DLLSC   0x0100  /* Data Link Layer State Changed */
528#define PCI_EXP_RTCTL           28      /* Root Control */
529#define  PCI_EXP_RTCTL_SECEE    0x01    /* System Error on Correctable Error */
530#define  PCI_EXP_RTCTL_SENFEE   0x02    /* System Error on Non-Fatal Error */
531#define  PCI_EXP_RTCTL_SEFEE    0x04    /* System Error on Fatal Error */
532#define  PCI_EXP_RTCTL_PMEIE    0x08    /* PME Interrupt Enable */
533#define  PCI_EXP_RTCTL_CRSSVE   0x10    /* CRS Software Visibility Enable */
534#define PCI_EXP_RTCAP           30      /* Root Capabilities */
535#define PCI_EXP_RTSTA           32      /* Root Status */
536#define PCI_EXP_RTSTA_PME       0x10000 /* PME status */
537#define PCI_EXP_RTSTA_PENDING   0x20000 /* PME pending */
538/*
539* Note that the following PCI Express 'Capability Structure' registers
540* were introduced with 'Capability Version' 0x2 (v2).  These registers
541* do not exist on devices with Capability Version 1.  Use pci_pcie_cap2()
542* to use these fields safely.
543*/
544#define PCI_EXP_DEVCAP2         36      /* Device Capabilities 2 */
545#define  PCI_EXP_DEVCAP2_ARI    0x20    /* Alternative Routing-ID */
546#define  PCI_EXP_DEVCAP2_LTR    0x800   /* Latency tolerance reporting */
547#define  PCI_EXP_OBFF_MASK      0xc0000 /* OBFF support mechanism */
548#define  PCI_EXP_OBFF_MSG       0x40000 /* New message signaling */
549#define  PCI_EXP_OBFF_WAKE      0x80000 /* Re-use WAKE# for OBFF */
550#define PCI_EXP_DEVCTL2         40      /* Device Control 2 */
551#define  PCI_EXP_DEVCTL2_ARI    0x20    /* Alternative Routing-ID */
552#define  PCI_EXP_IDO_REQ_EN     0x100   /* ID-based ordering request enable */
553#define  PCI_EXP_IDO_CMP_EN     0x200   /* ID-based ordering completion enable */
554#define  PCI_EXP_LTR_EN         0x400   /* Latency tolerance reporting */
555#define  PCI_EXP_OBFF_MSGA_EN   0x2000  /* OBFF enable with Message type A */
556#define  PCI_EXP_OBFF_MSGB_EN   0x4000  /* OBFF enable with Message type B */
557#define  PCI_EXP_OBFF_WAKE_EN   0x6000  /* OBFF using WAKE# signaling */
558#define PCI_CAP_EXP_ENDPOINT_SIZEOF_V2  44      /* v2 endpoints end here */
559#define PCI_EXP_LNKCAP2         44      /* Link Capability 2 */
560#define  PCI_EXP_LNKCAP2_SLS_2_5GB 0x02 /* Supported Link Speed 2.5GT/s */
561#define  PCI_EXP_LNKCAP2_SLS_5_0GB 0x04 /* Supported Link Speed 5.0GT/s */
562#define  PCI_EXP_LNKCAP2_SLS_8_0GB 0x08 /* Supported Link Speed 8.0GT/s */
563#define  PCI_EXP_LNKCAP2_CROSSLINK 0x100 /* Crosslink supported */
564#define PCI_EXP_LNKCTL2         48      /* Link Control 2 */
565#define PCI_EXP_LNKSTA2         50      /* Link Status 2 */
566#define PCI_EXP_SLTCTL2         56      /* Slot Control 2 */
567
568/* Extended Capabilities (PCI-X 2.0 and Express) */
569#define PCI_EXT_CAP_ID(header)          (header & 0x0000ffff)
570#define PCI_EXT_CAP_VER(header)         ((header >> 16) & 0xf)
571#define PCI_EXT_CAP_NEXT(header)        ((header >> 20) & 0xffc)
572
573#define PCI_EXT_CAP_ID_ERR      0x01    /* Advanced Error Reporting */
574#define PCI_EXT_CAP_ID_VC       0x02    /* Virtual Channel Capability */
575#define PCI_EXT_CAP_ID_DSN      0x03    /* Device Serial Number */
576#define PCI_EXT_CAP_ID_PWR      0x04    /* Power Budgeting */
577#define PCI_EXT_CAP_ID_RCLD     0x05    /* Root Complex Link Declaration */
578#define PCI_EXT_CAP_ID_RCILC    0x06    /* Root Complex Internal Link Control */
579#define PCI_EXT_CAP_ID_RCEC     0x07    /* Root Complex Event Collector */
580#define PCI_EXT_CAP_ID_MFVC     0x08    /* Multi-Function VC Capability */
581#define PCI_EXT_CAP_ID_VC9      0x09    /* same as _VC */
582#define PCI_EXT_CAP_ID_RCRB     0x0A    /* Root Complex RB? */
583#define PCI_EXT_CAP_ID_VNDR     0x0B    /* Vendor Specific */
584#define PCI_EXT_CAP_ID_CAC      0x0C    /* Config Access - obsolete */
585#define PCI_EXT_CAP_ID_ACS      0x0D    /* Access Control Services */
586#define PCI_EXT_CAP_ID_ARI      0x0E    /* Alternate Routing ID */
587#define PCI_EXT_CAP_ID_ATS      0x0F    /* Address Translation Services */
588#define PCI_EXT_CAP_ID_SRIOV    0x10    /* Single Root I/O Virtualization */
589#define PCI_EXT_CAP_ID_MRIOV    0x11    /* Multi Root I/O Virtualization */
590#define PCI_EXT_CAP_ID_MCAST    0x12    /* Multicast */
591#define PCI_EXT_CAP_ID_PRI      0x13    /* Page Request Interface */
592#define PCI_EXT_CAP_ID_AMD_XXX  0x14    /* reserved for AMD */
593#define PCI_EXT_CAP_ID_REBAR    0x15    /* resizable BAR */
594#define PCI_EXT_CAP_ID_DPA      0x16    /* dynamic power alloc */
595#define PCI_EXT_CAP_ID_TPH      0x17    /* TPH request */
596#define PCI_EXT_CAP_ID_LTR      0x18    /* latency tolerance reporting */
597#define PCI_EXT_CAP_ID_SECPCI   0x19    /* Secondary PCIe */
598#define PCI_EXT_CAP_ID_PMUX     0x1A    /* Protocol Multiplexing */
599#define PCI_EXT_CAP_ID_PASID    0x1B    /* Process Address Space ID */
600#define PCI_EXT_CAP_ID_MAX      PCI_EXT_CAP_ID_PASID
601
602#define PCI_EXT_CAP_DSN_SIZEOF  12
603#define PCI_EXT_CAP_MCAST_ENDPOINT_SIZEOF 40
604
605/* Advanced Error Reporting */
606#define PCI_ERR_UNCOR_STATUS    4       /* Uncorrectable Error Status */
607#define  PCI_ERR_UNC_TRAIN      0x00000001      /* Training */
608#define  PCI_ERR_UNC_DLP        0x00000010      /* Data Link Protocol */
609#define  PCI_ERR_UNC_SURPDN     0x00000020      /* Surprise Down */
610#define  PCI_ERR_UNC_POISON_TLP 0x00001000      /* Poisoned TLP */
611#define  PCI_ERR_UNC_FCP        0x00002000      /* Flow Control Protocol */
612#define  PCI_ERR_UNC_COMP_TIME  0x00004000      /* Completion Timeout */
613#define  PCI_ERR_UNC_COMP_ABORT 0x00008000      /* Completer Abort */
614#define  PCI_ERR_UNC_UNX_COMP   0x00010000      /* Unexpected Completion */
615#define  PCI_ERR_UNC_RX_OVER    0x00020000      /* Receiver Overflow */
616#define  PCI_ERR_UNC_MALF_TLP   0x00040000      /* Malformed TLP */
617#define  PCI_ERR_UNC_ECRC       0x00080000      /* ECRC Error Status */
618#define  PCI_ERR_UNC_UNSUP      0x00100000      /* Unsupported Request */
619#define  PCI_ERR_UNC_ACSV       0x00200000      /* ACS Violation */
620#define  PCI_ERR_UNC_INTN       0x00400000      /* internal error */
621#define  PCI_ERR_UNC_MCBTLP     0x00800000      /* MC blocked TLP */
622#define  PCI_ERR_UNC_ATOMEG     0x01000000      /* Atomic egress blocked */
623#define  PCI_ERR_UNC_TLPPRE     0x02000000      /* TLP prefix blocked */
624#define PCI_ERR_UNCOR_MASK      8       /* Uncorrectable Error Mask */
625     /* Same bits as above */
626#define PCI_ERR_UNCOR_SEVER     12      /* Uncorrectable Error Severity */
627     /* Same bits as above */
628#define PCI_ERR_COR_STATUS      16      /* Correctable Error Status */
629#define  PCI_ERR_COR_RCVR       0x00000001      /* Receiver Error Status */
630#define  PCI_ERR_COR_BAD_TLP    0x00000040      /* Bad TLP Status */
631#define  PCI_ERR_COR_BAD_DLLP   0x00000080      /* Bad DLLP Status */
632#define  PCI_ERR_COR_REP_ROLL   0x00000100      /* REPLAY_NUM Rollover */
633#define  PCI_ERR_COR_REP_TIMER  0x00001000      /* Replay Timer Timeout */
634#define  PCI_ERR_COR_ADV_NFAT   0x00002000      /* Advisory Non-Fatal */
635#define  PCI_ERR_COR_INTERNAL   0x00004000      /* Corrected Internal */
636#define  PCI_ERR_COR_LOG_OVER   0x00008000      /* Header Log Overflow */
637#define PCI_ERR_COR_MASK        20      /* Correctable Error Mask */
638     /* Same bits as above */
639#define PCI_ERR_CAP             24      /* Advanced Error Capabilities */
640#define  PCI_ERR_CAP_FEP(x)     ((x) & 31)      /* First Error Pointer */
641#define  PCI_ERR_CAP_ECRC_GENC  0x00000020      /* ECRC Generation Capable */
642#define  PCI_ERR_CAP_ECRC_GENE  0x00000040      /* ECRC Generation Enable */
643#define  PCI_ERR_CAP_ECRC_CHKC  0x00000080      /* ECRC Check Capable */
644#define  PCI_ERR_CAP_ECRC_CHKE  0x00000100      /* ECRC Check Enable */
645#define PCI_ERR_HEADER_LOG      28      /* Header Log Register (16 bytes) */
646#define PCI_ERR_ROOT_COMMAND    44      /* Root Error Command */
647/* Correctable Err Reporting Enable */
648#define PCI_ERR_ROOT_CMD_COR_EN         0x00000001
649/* Non-fatal Err Reporting Enable */
650#define PCI_ERR_ROOT_CMD_NONFATAL_EN    0x00000002
651/* Fatal Err Reporting Enable */
652#define PCI_ERR_ROOT_CMD_FATAL_EN       0x00000004
653#define PCI_ERR_ROOT_STATUS     48
654#define PCI_ERR_ROOT_COR_RCV            0x00000001      /* ERR_COR Received */
655/* Multi ERR_COR Received */
656#define PCI_ERR_ROOT_MULTI_COR_RCV      0x00000002
657/* ERR_FATAL/NONFATAL Recevied */
658#define PCI_ERR_ROOT_UNCOR_RCV          0x00000004
659/* Multi ERR_FATAL/NONFATAL Recevied */
660#define PCI_ERR_ROOT_MULTI_UNCOR_RCV    0x00000008
661#define PCI_ERR_ROOT_FIRST_FATAL        0x00000010      /* First Fatal */
662#define PCI_ERR_ROOT_NONFATAL_RCV       0x00000020      /* Non-Fatal Received */
663#define PCI_ERR_ROOT_FATAL_RCV          0x00000040      /* Fatal Received */
664#define PCI_ERR_ROOT_ERR_SRC    52      /* Error Source Identification */
665
666/* Virtual Channel */
667#define PCI_VC_PORT_REG1        4
668#define  PCI_VC_REG1_EVCC       0x7     /* extended vc count */
669#define PCI_VC_PORT_REG2        8
670#define  PCI_VC_REG2_32_PHASE   0x2
671#define  PCI_VC_REG2_64_PHASE   0x4
672#define  PCI_VC_REG2_128_PHASE  0x8
673#define PCI_VC_PORT_CTRL        12
674#define PCI_VC_PORT_STATUS      14
675#define PCI_VC_RES_CAP          16
676#define PCI_VC_RES_CTRL         20
677#define PCI_VC_RES_STATUS       26
678#define PCI_CAP_VC_BASE_SIZEOF          0x10
679#define PCI_CAP_VC_PER_VC_SIZEOF        0x0C
680
681/* Power Budgeting */
682#define PCI_PWR_DSR             4       /* Data Select Register */
683#define PCI_PWR_DATA            8       /* Data Register */
684#define  PCI_PWR_DATA_BASE(x)   ((x) & 0xff)        /* Base Power */
685#define  PCI_PWR_DATA_SCALE(x)  (((x) >> 8) & 3)    /* Data Scale */
686#define  PCI_PWR_DATA_PM_SUB(x) (((x) >> 10) & 7)   /* PM Sub State */
687#define  PCI_PWR_DATA_PM_STATE(x) (((x) >> 13) & 3) /* PM State */
688#define  PCI_PWR_DATA_TYPE(x)   (((x) >> 15) & 7)   /* Type */
689#define  PCI_PWR_DATA_RAIL(x)   (((x) >> 18) & 7)   /* Power Rail */
690#define PCI_PWR_CAP             12      /* Capability */
691#define  PCI_PWR_CAP_BUDGET(x)  ((x) & 1)       /* Included in system budget */
692#define PCI_EXT_CAP_PWR_SIZEOF  16
693
694/* Vendor-Specific (VSEC, PCI_EXT_CAP_ID_VNDR) */
695#define PCI_VNDR_HEADER         4       /* Vendor-Specific Header */
696#define  PCI_VNDR_HEADER_ID(x)  ((x) & 0xffff)
697#define  PCI_VNDR_HEADER_REV(x) (((x) >> 16) & 0xf)
698#define  PCI_VNDR_HEADER_LEN(x) (((x) >> 20) & 0xfff)
699
700/*
701* Hypertransport sub capability types
702*
703* Unfortunately there are both 3 bit and 5 bit capability types defined
704* in the HT spec, catering for that is a little messy. You probably don't
705* want to use these directly, just use pci_find_ht_capability() and it
706* will do the right thing for you.
707*/
708#define HT_3BIT_CAP_MASK        0xE0
709#define HT_CAPTYPE_SLAVE        0x00    /* Slave/Primary link configuration */
710#define HT_CAPTYPE_HOST         0x20    /* Host/Secondary link configuration */
711
712#define HT_5BIT_CAP_MASK        0xF8
713#define HT_CAPTYPE_IRQ          0x80    /* IRQ Configuration */
714#define HT_CAPTYPE_REMAPPING_40 0xA0    /* 40 bit address remapping */
715#define HT_CAPTYPE_REMAPPING_64 0xA2    /* 64 bit address remapping */
716#define HT_CAPTYPE_UNITID_CLUMP 0x90    /* Unit ID clumping */
717#define HT_CAPTYPE_EXTCONF      0x98    /* Extended Configuration Space Access */
718#define HT_CAPTYPE_MSI_MAPPING  0xA8    /* MSI Mapping Capability */
719#define  HT_MSI_FLAGS           0x02            /* Offset to flags */
720#define  HT_MSI_FLAGS_ENABLE    0x1             /* Mapping enable */
721#define  HT_MSI_FLAGS_FIXED     0x2             /* Fixed mapping only */
722#define  HT_MSI_FIXED_ADDR      0x00000000FEE00000ULL   /* Fixed addr */
723#define  HT_MSI_ADDR_LO         0x04            /* Offset to low addr bits */
724#define  HT_MSI_ADDR_LO_MASK    0xFFF00000      /* Low address bit mask */
725#define  HT_MSI_ADDR_HI         0x08            /* Offset to high addr bits */
726#define HT_CAPTYPE_DIRECT_ROUTE 0xB0    /* Direct routing configuration */
727#define HT_CAPTYPE_VCSET        0xB8    /* Virtual Channel configuration */
728#define HT_CAPTYPE_ERROR_RETRY  0xC0    /* Retry on error configuration */
729#define HT_CAPTYPE_GEN3         0xD0    /* Generation 3 hypertransport configuration */
730#define HT_CAPTYPE_PM           0xE0    /* Hypertransport powermanagement configuration */
731#define HT_CAP_SIZEOF_LONG      28      /* slave & primary */
732#define HT_CAP_SIZEOF_SHORT     24      /* host & secondary */
733
734/* Alternative Routing-ID Interpretation */
735#define PCI_ARI_CAP             0x04    /* ARI Capability Register */
736#define  PCI_ARI_CAP_MFVC       0x0001  /* MFVC Function Groups Capability */
737#define  PCI_ARI_CAP_ACS        0x0002  /* ACS Function Groups Capability */
738#define  PCI_ARI_CAP_NFN(x)     (((x) >> 8) & 0xff) /* Next Function Number */
739#define PCI_ARI_CTRL            0x06    /* ARI Control Register */
740#define  PCI_ARI_CTRL_MFVC      0x0001  /* MFVC Function Groups Enable */
741#define  PCI_ARI_CTRL_ACS       0x0002  /* ACS Function Groups Enable */
742#define  PCI_ARI_CTRL_FG(x)     (((x) >> 4) & 7) /* Function Group */
743#define PCI_EXT_CAP_ARI_SIZEOF  8
744
745/* Address Translation Service */
746#define PCI_ATS_CAP             0x04    /* ATS Capability Register */
747#define  PCI_ATS_CAP_QDEP(x)    ((x) & 0x1f)    /* Invalidate Queue Depth */
748#define  PCI_ATS_MAX_QDEP       32      /* Max Invalidate Queue Depth */
749#define PCI_ATS_CTRL            0x06    /* ATS Control Register */
750#define  PCI_ATS_CTRL_ENABLE    0x8000  /* ATS Enable */
751#define  PCI_ATS_CTRL_STU(x)    ((x) & 0x1f)    /* Smallest Translation Unit */
752#define  PCI_ATS_MIN_STU        12      /* shift of minimum STU block */
753#define PCI_EXT_CAP_ATS_SIZEOF  8
754
755/* Page Request Interface */
756#define PCI_PRI_CTRL            0x04    /* PRI control register */
757#define  PCI_PRI_CTRL_ENABLE    0x01    /* Enable */
758#define  PCI_PRI_CTRL_RESET     0x02    /* Reset */
759#define PCI_PRI_STATUS          0x06    /* PRI status register */
760#define  PCI_PRI_STATUS_RF      0x001   /* Response Failure */
761#define  PCI_PRI_STATUS_UPRGI   0x002   /* Unexpected PRG index */
762#define  PCI_PRI_STATUS_STOPPED 0x100   /* PRI Stopped */
763#define PCI_PRI_MAX_REQ         0x08    /* PRI max reqs supported */
764#define PCI_PRI_ALLOC_REQ       0x0c    /* PRI max reqs allowed */
765#define PCI_EXT_CAP_PRI_SIZEOF  16
766
767/* PASID capability */
768#define PCI_PASID_CAP           0x04    /* PASID feature register */
769#define  PCI_PASID_CAP_EXEC     0x02    /* Exec permissions Supported */
770#define  PCI_PASID_CAP_PRIV     0x04    /* Priviledge Mode Supported */
771#define PCI_PASID_CTRL          0x06    /* PASID control register */
772#define  PCI_PASID_CTRL_ENABLE  0x01    /* Enable bit */
773#define  PCI_PASID_CTRL_EXEC    0x02    /* Exec permissions Enable */
774#define  PCI_PASID_CTRL_PRIV    0x04    /* Priviledge Mode Enable */
775#define PCI_EXT_CAP_PASID_SIZEOF        8
776
777/* Single Root I/O Virtualization */
778#define PCI_SRIOV_CAP           0x04    /* SR-IOV Capabilities */
779#define  PCI_SRIOV_CAP_VFM      0x01    /* VF Migration Capable */
780#define  PCI_SRIOV_CAP_INTR(x)  ((x) >> 21) /* Interrupt Message Number */
781#define PCI_SRIOV_CTRL          0x08    /* SR-IOV Control */
782#define  PCI_SRIOV_CTRL_VFE     0x01    /* VF Enable */
783#define  PCI_SRIOV_CTRL_VFM     0x02    /* VF Migration Enable */
784#define  PCI_SRIOV_CTRL_INTR    0x04    /* VF Migration Interrupt Enable */
785#define  PCI_SRIOV_CTRL_MSE     0x08    /* VF Memory Space Enable */
786#define  PCI_SRIOV_CTRL_ARI     0x10    /* ARI Capable Hierarchy */
787#define PCI_SRIOV_STATUS        0x0a    /* SR-IOV Status */
788#define  PCI_SRIOV_STATUS_VFM   0x01    /* VF Migration Status */
789#define PCI_SRIOV_INITIAL_VF    0x0c    /* Initial VFs */
790#define PCI_SRIOV_TOTAL_VF      0x0e    /* Total VFs */
791#define PCI_SRIOV_NUM_VF        0x10    /* Number of VFs */
792#define PCI_SRIOV_FUNC_LINK     0x12    /* Function Dependency Link */
793#define PCI_SRIOV_VF_OFFSET     0x14    /* First VF Offset */
794#define PCI_SRIOV_VF_STRIDE     0x16    /* Following VF Stride */
795#define PCI_SRIOV_VF_DID        0x1a    /* VF Device ID */
796#define PCI_SRIOV_SUP_PGSIZE    0x1c    /* Supported Page Sizes */
797#define PCI_SRIOV_SYS_PGSIZE    0x20    /* System Page Size */
798#define PCI_SRIOV_BAR           0x24    /* VF BAR0 */
799#define  PCI_SRIOV_NUM_BARS     6       /* Number of VF BARs */
800#define PCI_SRIOV_VFM           0x3c    /* VF Migration State Array Offset*/
801#define  PCI_SRIOV_VFM_BIR(x)   ((x) & 7)       /* State BIR */
802#define  PCI_SRIOV_VFM_OFFSET(x) ((x) & ~7)     /* State Offset */
803#define  PCI_SRIOV_VFM_UA       0x0     /* Inactive.Unavailable */
804#define  PCI_SRIOV_VFM_MI       0x1     /* Dormant.MigrateIn */
805#define  PCI_SRIOV_VFM_MO       0x2     /* Active.MigrateOut */
806#define  PCI_SRIOV_VFM_AV       0x3     /* Active.Available */
807#define PCI_EXT_CAP_SRIOV_SIZEOF 64
808
809#define PCI_LTR_MAX_SNOOP_LAT   0x4
810#define PCI_LTR_MAX_NOSNOOP_LAT 0x6
811#define  PCI_LTR_VALUE_MASK     0x000003ff
812#define  PCI_LTR_SCALE_MASK     0x00001c00
813#define  PCI_LTR_SCALE_SHIFT    10
814#define PCI_EXT_CAP_LTR_SIZEOF  8
815
816/* Access Control Service */
817#define PCI_ACS_CAP             0x04    /* ACS Capability Register */
818#define  PCI_ACS_SV             0x01    /* Source Validation */
819#define  PCI_ACS_TB             0x02    /* Translation Blocking */
820#define  PCI_ACS_RR             0x04    /* P2P Request Redirect */
821#define  PCI_ACS_CR             0x08    /* P2P Completion Redirect */
822#define  PCI_ACS_UF             0x10    /* Upstream Forwarding */
823#define  PCI_ACS_EC             0x20    /* P2P Egress Control */
824#define  PCI_ACS_DT             0x40    /* Direct Translated P2P */
825#define PCI_ACS_EGRESS_BITS     0x05    /* ACS Egress Control Vector Size */
826#define PCI_ACS_CTRL            0x06    /* ACS Control Register */
827#define PCI_ACS_EGRESS_CTL_V    0x08    /* ACS Egress Control Vector */
828
829#define PCI_VSEC_HDR            4       /* extended cap - vendor specific */
830#define  PCI_VSEC_HDR_LEN_SHIFT 20      /* shift for length field */
831
832/* sata capability */
833#define PCI_SATA_REGS           4       /* SATA REGs specifier */
834#define  PCI_SATA_REGS_MASK     0xF     /* location - BAR#/inline */
835#define  PCI_SATA_REGS_INLINE   0xF     /* REGS in config space */
836#define PCI_SATA_SIZEOF_SHORT   8
837#define PCI_SATA_SIZEOF_LONG    16
838
839/* resizable BARs */
840#define PCI_REBAR_CTRL          8       /* control register */
841#define  PCI_REBAR_CTRL_NBAR_MASK       (7 << 5)        /* mask for # bars */
842#define  PCI_REBAR_CTRL_NBAR_SHIFT      5       /* shift for # bars */
843
844/* dynamic power allocation */
845#define PCI_DPA_CAP             4       /* capability register */
846#define  PCI_DPA_CAP_SUBSTATE_MASK      0x1F    /* # substates - 1 */
847#define PCI_DPA_BASE_SIZEOF     16      /* size with 0 substates */
848
849/* TPH Requester */
850#define PCI_TPH_CAP             4       /* capability register */
851#define  PCI_TPH_CAP_LOC_MASK   0x600   /* location mask */
852#define   PCI_TPH_LOC_NONE      0x000   /* no location */
853#define   PCI_TPH_LOC_CAP       0x200   /* in capability */
854#define   PCI_TPH_LOC_MSIX      0x400   /* in MSI-X */
855#define PCI_TPH_CAP_ST_MASK     0x07FF0000      /* st table mask */
856#define PCI_TPH_CAP_ST_SHIFT    16      /* st table shift */
857#define PCI_TPH_BASE_SIZEOF     12      /* size with no st table */
858
859// -------------------------------------------------------------------------------------------------
860
861#define PCI_CLASS_NOT_DEFINED           0x0000
862#define PCI_CLASS_NOT_DEFINED_VGA       0x0001
863
864#define PCI_BASE_CLASS_STORAGE          0x01
865#define PCI_CLASS_STORAGE_SCSI          0x0100
866#define PCI_CLASS_STORAGE_IDE           0x0101
867#define PCI_CLASS_STORAGE_FLOPPY        0x0102
868#define PCI_CLASS_STORAGE_IPI           0x0103
869#define PCI_CLASS_STORAGE_RAID          0x0104
870#define PCI_CLASS_STORAGE_SATA          0x0106
871#define PCI_CLASS_STORAGE_SATA_AHCI     0x010601
872#define PCI_CLASS_STORAGE_SAS           0x0107
873#define PCI_CLASS_STORAGE_OTHER         0x0180
874
875#define PCI_BASE_CLASS_NETWORK          0x02
876#define PCI_CLASS_NETWORK_ETHERNET      0x0200
877#define PCI_CLASS_NETWORK_TOKEN_RING    0x0201
878#define PCI_CLASS_NETWORK_FDDI          0x0202
879#define PCI_CLASS_NETWORK_ATM           0x0203
880#define PCI_CLASS_NETWORK_OTHER         0x0280
881
882#define PCI_BASE_CLASS_DISPLAY          0x03
883#define PCI_CLASS_DISPLAY_VGA           0x0300
884#define PCI_CLASS_DISPLAY_XGA           0x0301
885#define PCI_CLASS_DISPLAY_3D            0x0302
886#define PCI_CLASS_DISPLAY_OTHER         0x0380
887
888#define PCI_BASE_CLASS_MULTIMEDIA       0x04
889#define PCI_CLASS_MULTIMEDIA_VIDEO      0x0400
890#define PCI_CLASS_MULTIMEDIA_AUDIO      0x0401
891#define PCI_CLASS_MULTIMEDIA_PHONE      0x0402
892#define PCI_CLASS_MULTIMEDIA_OTHER      0x0480
893
894#define PCI_BASE_CLASS_MEMORY           0x05
895#define PCI_CLASS_MEMORY_RAM            0x0500
896#define PCI_CLASS_MEMORY_FLASH          0x0501
897#define PCI_CLASS_MEMORY_OTHER          0x0580
898
899#define PCI_BASE_CLASS_BRIDGE           0x06
900#define PCI_CLASS_BRIDGE_HOST           0x0600
901#define PCI_CLASS_BRIDGE_ISA            0x0601
902#define PCI_CLASS_BRIDGE_EISA           0x0602
903#define PCI_CLASS_BRIDGE_MC             0x0603
904#define PCI_CLASS_BRIDGE_PCI            0x0604
905#define PCI_CLASS_BRIDGE_PCMCIA         0x0605
906#define PCI_CLASS_BRIDGE_NUBUS          0x0606
907#define PCI_CLASS_BRIDGE_CARDBUS        0x0607
908#define PCI_CLASS_BRIDGE_RACEWAY        0x0608
909#define PCI_CLASS_BRIDGE_OTHER          0x0680
910
911#define PCI_BASE_CLASS_COMMUNICATION    0x07
912#define PCI_CLASS_COMMUNICATION_SERIAL  0x0700
913#define PCI_CLASS_COMMUNICATION_PARALLEL 0x0701
914#define PCI_CLASS_COMMUNICATION_MULTISERIAL 0x0702
915#define PCI_CLASS_COMMUNICATION_MODEM   0x0703
916#define PCI_CLASS_COMMUNICATION_OTHER   0x0780
917
918#define PCI_BASE_CLASS_SYSTEM           0x08
919#define PCI_CLASS_SYSTEM_PIC            0x0800
920#define PCI_CLASS_SYSTEM_PIC_IOAPIC     0x080010
921#define PCI_CLASS_SYSTEM_PIC_IOXAPIC    0x080020
922#define PCI_CLASS_SYSTEM_DMA            0x0801
923#define PCI_CLASS_SYSTEM_TIMER          0x0802
924#define PCI_CLASS_SYSTEM_RTC            0x0803
925#define PCI_CLASS_SYSTEM_PCI_HOTPLUG    0x0804
926#define PCI_CLASS_SYSTEM_SDHCI          0x0805
927#define PCI_CLASS_SYSTEM_OTHER          0x0880
928
929#define PCI_BASE_CLASS_INPUT            0x09
930#define PCI_CLASS_INPUT_KEYBOARD        0x0900
931#define PCI_CLASS_INPUT_PEN             0x0901
932#define PCI_CLASS_INPUT_MOUSE           0x0902
933#define PCI_CLASS_INPUT_SCANNER         0x0903
934#define PCI_CLASS_INPUT_GAMEPORT        0x0904
935#define PCI_CLASS_INPUT_OTHER           0x0980
936
937#define PCI_BASE_CLASS_DOCKING          0x0a
938#define PCI_CLASS_DOCKING_GENERIC       0x0a00
939#define PCI_CLASS_DOCKING_OTHER         0x0a80
940
941#define PCI_BASE_CLASS_PROCESSOR        0x0b
942#define PCI_CLASS_PROCESSOR_386         0x0b00
943#define PCI_CLASS_PROCESSOR_486         0x0b01
944#define PCI_CLASS_PROCESSOR_PENTIUM     0x0b02
945#define PCI_CLASS_PROCESSOR_ALPHA       0x0b10
946#define PCI_CLASS_PROCESSOR_POWERPC     0x0b20
947#define PCI_CLASS_PROCESSOR_MIPS        0x0b30
948#define PCI_CLASS_PROCESSOR_CO          0x0b40
949
950#define PCI_BASE_CLASS_SERIAL           0x0c
951#define PCI_CLASS_SERIAL_FIREWIRE       0x0c00
952#define PCI_CLASS_SERIAL_FIREWIRE_OHCI  0x0c0010
953#define PCI_CLASS_SERIAL_ACCESS         0x0c01
954#define PCI_CLASS_SERIAL_SSA            0x0c02
955#define PCI_CLASS_SERIAL_USB            0x0c03
956#define PCI_CLASS_SERIAL_USB_UHCI       0x0c0300
957#define PCI_CLASS_SERIAL_USB_OHCI       0x0c0310
958#define PCI_CLASS_SERIAL_USB_EHCI       0x0c0320
959#define PCI_CLASS_SERIAL_USB_XHCI       0x0c0330
960#define PCI_CLASS_SERIAL_FIBER          0x0c04
961#define PCI_CLASS_SERIAL_SMBUS          0x0c05
962
963#define PCI_BASE_CLASS_WIRELESS                 0x0d
964#define PCI_CLASS_WIRELESS_RF_CONTROLLER        0x0d10
965#define PCI_CLASS_WIRELESS_WHCI                 0x0d1010
966
967#define PCI_BASE_CLASS_INTELLIGENT      0x0e
968#define PCI_CLASS_INTELLIGENT_I2O       0x0e00
969
970#define PCI_BASE_CLASS_SATELLITE        0x0f
971#define PCI_CLASS_SATELLITE_TV          0x0f00
972#define PCI_CLASS_SATELLITE_AUDIO       0x0f01
973#define PCI_CLASS_SATELLITE_VOICE       0x0f03
974#define PCI_CLASS_SATELLITE_DATA        0x0f04
975
976#define PCI_BASE_CLASS_CRYPT            0x10
977#define PCI_CLASS_CRYPT_NETWORK         0x1000
978#define PCI_CLASS_CRYPT_ENTERTAINMENT   0x1001
979#define PCI_CLASS_CRYPT_OTHER           0x1080
980
981#define PCI_BASE_CLASS_SIGNAL_PROCESSING 0x11
982#define PCI_CLASS_SP_DPIO               0x1100
983#define PCI_CLASS_SP_OTHER              0x1180
984
985#define PCI_CLASS_OTHERS                0xff
986
987/* Vendors and devices.  Sort key: vendor first, device next. */
988
989#define PCI_VENDOR_ID_TTTECH            0x0357
990#define PCI_DEVICE_ID_TTTECH_MC322      0x000a
991
992#define PCI_VENDOR_ID_DYNALINK          0x0675
993#define PCI_DEVICE_ID_DYNALINK_IS64PH   0x1702
994
995#define PCI_VENDOR_ID_BERKOM                    0x0871
996#define PCI_DEVICE_ID_BERKOM_A1T                0xffa1
997#define PCI_DEVICE_ID_BERKOM_T_CONCEPT          0xffa2
998#define PCI_DEVICE_ID_BERKOM_A4T                0xffa4
999#define PCI_DEVICE_ID_BERKOM_SCITEL_QUADRO      0xffa8
1000
1001#define PCI_VENDOR_ID_COMPAQ            0x0e11
1002#define PCI_DEVICE_ID_COMPAQ_TOKENRING  0x0508
1003#define PCI_DEVICE_ID_COMPAQ_TACHYON    0xa0fc
1004#define PCI_DEVICE_ID_COMPAQ_SMART2P    0xae10
1005#define PCI_DEVICE_ID_COMPAQ_NETEL100   0xae32
1006#define PCI_DEVICE_ID_COMPAQ_NETEL10    0xae34
1007#define PCI_DEVICE_ID_COMPAQ_TRIFLEX_IDE 0xae33
1008#define PCI_DEVICE_ID_COMPAQ_NETFLEX3I  0xae35
1009#define PCI_DEVICE_ID_COMPAQ_NETEL100D  0xae40
1010#define PCI_DEVICE_ID_COMPAQ_NETEL100PI 0xae43
1011#define PCI_DEVICE_ID_COMPAQ_NETEL100I  0xb011
1012#define PCI_DEVICE_ID_COMPAQ_CISS       0xb060
1013#define PCI_DEVICE_ID_COMPAQ_CISSB      0xb178
1014#define PCI_DEVICE_ID_COMPAQ_CISSC      0x46
1015#define PCI_DEVICE_ID_COMPAQ_THUNDER    0xf130
1016#define PCI_DEVICE_ID_COMPAQ_NETFLEX3B  0xf150
1017
1018#define PCI_VENDOR_ID_NCR               0x1000
1019#define PCI_VENDOR_ID_LSI_LOGIC         0x1000
1020#define PCI_DEVICE_ID_NCR_53C810        0x0001
1021#define PCI_DEVICE_ID_NCR_53C820        0x0002
1022#define PCI_DEVICE_ID_NCR_53C825        0x0003
1023#define PCI_DEVICE_ID_NCR_53C815        0x0004
1024#define PCI_DEVICE_ID_LSI_53C810AP      0x0005
1025#define PCI_DEVICE_ID_NCR_53C860        0x0006
1026#define PCI_DEVICE_ID_LSI_53C1510       0x000a
1027#define PCI_DEVICE_ID_NCR_53C896        0x000b
1028#define PCI_DEVICE_ID_NCR_53C895        0x000c
1029#define PCI_DEVICE_ID_NCR_53C885        0x000d
1030#define PCI_DEVICE_ID_NCR_53C875        0x000f
1031#define PCI_DEVICE_ID_NCR_53C1510       0x0010
1032#define PCI_DEVICE_ID_LSI_53C895A       0x0012
1033#define PCI_DEVICE_ID_LSI_53C875A       0x0013
1034#define PCI_DEVICE_ID_LSI_53C1010_33    0x0020
1035#define PCI_DEVICE_ID_LSI_53C1010_66    0x0021
1036#define PCI_DEVICE_ID_LSI_53C1030       0x0030
1037#define PCI_DEVICE_ID_LSI_1030_53C1035  0x0032
1038#define PCI_DEVICE_ID_LSI_53C1035       0x0040
1039#define PCI_DEVICE_ID_NCR_53C875J       0x008f
1040#define PCI_DEVICE_ID_LSI_FC909         0x0621
1041#define PCI_DEVICE_ID_LSI_FC929         0x0622
1042#define PCI_DEVICE_ID_LSI_FC929_LAN     0x0623
1043#define PCI_DEVICE_ID_LSI_FC919         0x0624
1044#define PCI_DEVICE_ID_LSI_FC919_LAN     0x0625
1045#define PCI_DEVICE_ID_LSI_FC929X        0x0626
1046#define PCI_DEVICE_ID_LSI_FC939X        0x0642
1047#define PCI_DEVICE_ID_LSI_FC949X        0x0640
1048#define PCI_DEVICE_ID_LSI_FC949ES       0x0646
1049#define PCI_DEVICE_ID_LSI_FC919X        0x0628
1050#define PCI_DEVICE_ID_NCR_YELLOWFIN     0x0701
1051#define PCI_DEVICE_ID_LSI_61C102        0x0901
1052#define PCI_DEVICE_ID_LSI_63C815        0x1000
1053#define PCI_DEVICE_ID_LSI_SAS1064       0x0050
1054#define PCI_DEVICE_ID_LSI_SAS1064R      0x0411
1055#define PCI_DEVICE_ID_LSI_SAS1066       0x005E
1056#define PCI_DEVICE_ID_LSI_SAS1068       0x0054
1057#define PCI_DEVICE_ID_LSI_SAS1064A      0x005C
1058#define PCI_DEVICE_ID_LSI_SAS1064E      0x0056
1059#define PCI_DEVICE_ID_LSI_SAS1066E      0x005A
1060#define PCI_DEVICE_ID_LSI_SAS1068E      0x0058
1061#define PCI_DEVICE_ID_LSI_SAS1078       0x0060
1062
1063#define PCI_VENDOR_ID_ATI               0x1002
1064/* Mach64 */
1065#define PCI_DEVICE_ID_ATI_68800         0x4158
1066#define PCI_DEVICE_ID_ATI_215CT222      0x4354
1067#define PCI_DEVICE_ID_ATI_210888CX      0x4358
1068#define PCI_DEVICE_ID_ATI_215ET222      0x4554
1069/* Mach64 / Rage */
1070#define PCI_DEVICE_ID_ATI_215GB         0x4742
1071#define PCI_DEVICE_ID_ATI_215GD         0x4744
1072#define PCI_DEVICE_ID_ATI_215GI         0x4749
1073#define PCI_DEVICE_ID_ATI_215GP         0x4750
1074#define PCI_DEVICE_ID_ATI_215GQ         0x4751
1075#define PCI_DEVICE_ID_ATI_215XL         0x4752
1076#define PCI_DEVICE_ID_ATI_215GT         0x4754
1077#define PCI_DEVICE_ID_ATI_215GTB        0x4755
1078#define PCI_DEVICE_ID_ATI_215_IV        0x4756
1079#define PCI_DEVICE_ID_ATI_215_IW        0x4757
1080#define PCI_DEVICE_ID_ATI_215_IZ        0x475A
1081#define PCI_DEVICE_ID_ATI_210888GX      0x4758
1082#define PCI_DEVICE_ID_ATI_215_LB        0x4c42
1083#define PCI_DEVICE_ID_ATI_215_LD        0x4c44
1084#define PCI_DEVICE_ID_ATI_215_LG        0x4c47
1085#define PCI_DEVICE_ID_ATI_215_LI        0x4c49
1086#define PCI_DEVICE_ID_ATI_215_LM        0x4c4D
1087#define PCI_DEVICE_ID_ATI_215_LN        0x4c4E
1088#define PCI_DEVICE_ID_ATI_215_LR        0x4c52
1089#define PCI_DEVICE_ID_ATI_215_LS        0x4c53
1090#define PCI_DEVICE_ID_ATI_264_LT        0x4c54
1091/* Mach64 VT */
1092#define PCI_DEVICE_ID_ATI_264VT         0x5654
1093#define PCI_DEVICE_ID_ATI_264VU         0x5655
1094#define PCI_DEVICE_ID_ATI_264VV         0x5656
1095/* Rage128 GL */
1096#define PCI_DEVICE_ID_ATI_RAGE128_RE    0x5245
1097#define PCI_DEVICE_ID_ATI_RAGE128_RF    0x5246
1098#define PCI_DEVICE_ID_ATI_RAGE128_RG    0x5247
1099/* Rage128 VR */
1100#define PCI_DEVICE_ID_ATI_RAGE128_RK    0x524b
1101#define PCI_DEVICE_ID_ATI_RAGE128_RL    0x524c
1102#define PCI_DEVICE_ID_ATI_RAGE128_SE    0x5345
1103#define PCI_DEVICE_ID_ATI_RAGE128_SF    0x5346
1104#define PCI_DEVICE_ID_ATI_RAGE128_SG    0x5347
1105#define PCI_DEVICE_ID_ATI_RAGE128_SH    0x5348
1106#define PCI_DEVICE_ID_ATI_RAGE128_SK    0x534b
1107#define PCI_DEVICE_ID_ATI_RAGE128_SL    0x534c
1108#define PCI_DEVICE_ID_ATI_RAGE128_SM    0x534d
1109#define PCI_DEVICE_ID_ATI_RAGE128_SN    0x534e
1110/* Rage128 Ultra */
1111#define PCI_DEVICE_ID_ATI_RAGE128_TF    0x5446
1112#define PCI_DEVICE_ID_ATI_RAGE128_TL    0x544c
1113#define PCI_DEVICE_ID_ATI_RAGE128_TR    0x5452
1114#define PCI_DEVICE_ID_ATI_RAGE128_TS    0x5453
1115#define PCI_DEVICE_ID_ATI_RAGE128_TT    0x5454
1116#define PCI_DEVICE_ID_ATI_RAGE128_TU    0x5455
1117/* Rage128 M3 */
1118#define PCI_DEVICE_ID_ATI_RAGE128_LE    0x4c45
1119#define PCI_DEVICE_ID_ATI_RAGE128_LF    0x4c46
1120/* Rage128 M4 */
1121#define PCI_DEVICE_ID_ATI_RAGE128_MF    0x4d46
1122#define PCI_DEVICE_ID_ATI_RAGE128_ML    0x4d4c
1123/* Rage128 Pro GL */
1124#define PCI_DEVICE_ID_ATI_RAGE128_PA    0x5041
1125#define PCI_DEVICE_ID_ATI_RAGE128_PB    0x5042
1126#define PCI_DEVICE_ID_ATI_RAGE128_PC    0x5043
1127#define PCI_DEVICE_ID_ATI_RAGE128_PD    0x5044
1128#define PCI_DEVICE_ID_ATI_RAGE128_PE    0x5045
1129#define PCI_DEVICE_ID_ATI_RAGE128_PF    0x5046
1130/* Rage128 Pro VR */
1131#define PCI_DEVICE_ID_ATI_RAGE128_PG    0x5047
1132#define PCI_DEVICE_ID_ATI_RAGE128_PH    0x5048
1133#define PCI_DEVICE_ID_ATI_RAGE128_PI    0x5049
1134#define PCI_DEVICE_ID_ATI_RAGE128_PJ    0x504A
1135#define PCI_DEVICE_ID_ATI_RAGE128_PK    0x504B
1136#define PCI_DEVICE_ID_ATI_RAGE128_PL    0x504C
1137#define PCI_DEVICE_ID_ATI_RAGE128_PM    0x504D
1138#define PCI_DEVICE_ID_ATI_RAGE128_PN    0x504E
1139#define PCI_DEVICE_ID_ATI_RAGE128_PO    0x504F
1140#define PCI_DEVICE_ID_ATI_RAGE128_PP    0x5050
1141#define PCI_DEVICE_ID_ATI_RAGE128_PQ    0x5051
1142#define PCI_DEVICE_ID_ATI_RAGE128_PR    0x5052
1143#define PCI_DEVICE_ID_ATI_RAGE128_PS    0x5053
1144#define PCI_DEVICE_ID_ATI_RAGE128_PT    0x5054
1145#define PCI_DEVICE_ID_ATI_RAGE128_PU    0x5055
1146#define PCI_DEVICE_ID_ATI_RAGE128_PV    0x5056
1147#define PCI_DEVICE_ID_ATI_RAGE128_PW    0x5057
1148#define PCI_DEVICE_ID_ATI_RAGE128_PX    0x5058
1149/* Rage128 M4 */
1150/* Radeon R100 */
1151#define PCI_DEVICE_ID_ATI_RADEON_QD     0x5144
1152#define PCI_DEVICE_ID_ATI_RADEON_QE     0x5145
1153#define PCI_DEVICE_ID_ATI_RADEON_QF     0x5146
1154#define PCI_DEVICE_ID_ATI_RADEON_QG     0x5147
1155/* Radeon RV100 (VE) */
1156#define PCI_DEVICE_ID_ATI_RADEON_QY     0x5159
1157#define PCI_DEVICE_ID_ATI_RADEON_QZ     0x515a
1158/* Radeon R200 (8500) */
1159#define PCI_DEVICE_ID_ATI_RADEON_QL     0x514c
1160#define PCI_DEVICE_ID_ATI_RADEON_QN     0x514e
1161#define PCI_DEVICE_ID_ATI_RADEON_QO     0x514f
1162#define PCI_DEVICE_ID_ATI_RADEON_Ql     0x516c
1163#define PCI_DEVICE_ID_ATI_RADEON_BB     0x4242
1164/* Radeon R200 (9100) */
1165#define PCI_DEVICE_ID_ATI_RADEON_QM     0x514d
1166/* Radeon RV200 (7500) */
1167#define PCI_DEVICE_ID_ATI_RADEON_QW     0x5157
1168#define PCI_DEVICE_ID_ATI_RADEON_QX     0x5158
1169/* Radeon NV-100 */
1170/* Radeon RV250 (9000) */
1171#define PCI_DEVICE_ID_ATI_RADEON_Id     0x4964
1172#define PCI_DEVICE_ID_ATI_RADEON_Ie     0x4965
1173#define PCI_DEVICE_ID_ATI_RADEON_If     0x4966
1174#define PCI_DEVICE_ID_ATI_RADEON_Ig     0x4967
1175/* Radeon RV280 (9200) */
1176#define PCI_DEVICE_ID_ATI_RADEON_Ya     0x5961
1177#define PCI_DEVICE_ID_ATI_RADEON_Yd     0x5964
1178/* Radeon R300 (9500) */
1179/* Radeon R300 (9700) */
1180#define PCI_DEVICE_ID_ATI_RADEON_ND     0x4e44
1181#define PCI_DEVICE_ID_ATI_RADEON_NE     0x4e45
1182#define PCI_DEVICE_ID_ATI_RADEON_NF     0x4e46
1183#define PCI_DEVICE_ID_ATI_RADEON_NG     0x4e47
1184/* Radeon R350 (9800) */
1185/* Radeon RV350 (9600) */
1186/* Radeon M6 */
1187#define PCI_DEVICE_ID_ATI_RADEON_LY     0x4c59
1188#define PCI_DEVICE_ID_ATI_RADEON_LZ     0x4c5a
1189/* Radeon M7 */
1190#define PCI_DEVICE_ID_ATI_RADEON_LW     0x4c57
1191#define PCI_DEVICE_ID_ATI_RADEON_LX     0x4c58
1192/* Radeon M9 */
1193#define PCI_DEVICE_ID_ATI_RADEON_Ld     0x4c64
1194#define PCI_DEVICE_ID_ATI_RADEON_Le     0x4c65
1195#define PCI_DEVICE_ID_ATI_RADEON_Lf     0x4c66
1196#define PCI_DEVICE_ID_ATI_RADEON_Lg     0x4c67
1197/* Radeon */
1198/* RadeonIGP */
1199#define PCI_DEVICE_ID_ATI_RS100         0xcab0
1200#define PCI_DEVICE_ID_ATI_RS200         0xcab2
1201#define PCI_DEVICE_ID_ATI_RS200_B       0xcbb2
1202#define PCI_DEVICE_ID_ATI_RS250         0xcab3
1203#define PCI_DEVICE_ID_ATI_RS300_100     0x5830
1204#define PCI_DEVICE_ID_ATI_RS300_133     0x5831
1205#define PCI_DEVICE_ID_ATI_RS300_166     0x5832
1206#define PCI_DEVICE_ID_ATI_RS300_200     0x5833
1207#define PCI_DEVICE_ID_ATI_RS350_100     0x7830
1208#define PCI_DEVICE_ID_ATI_RS350_133     0x7831
1209#define PCI_DEVICE_ID_ATI_RS350_166     0x7832
1210#define PCI_DEVICE_ID_ATI_RS350_200     0x7833
1211#define PCI_DEVICE_ID_ATI_RS400_100     0x5a30
1212#define PCI_DEVICE_ID_ATI_RS400_133     0x5a31
1213#define PCI_DEVICE_ID_ATI_RS400_166     0x5a32
1214#define PCI_DEVICE_ID_ATI_RS400_200     0x5a33
1215#define PCI_DEVICE_ID_ATI_RS480         0x5950
1216/* ATI IXP Chipset */
1217#define PCI_DEVICE_ID_ATI_IXP200_IDE    0x4349
1218#define PCI_DEVICE_ID_ATI_IXP200_SMBUS  0x4353
1219#define PCI_DEVICE_ID_ATI_IXP300_SMBUS  0x4363
1220#define PCI_DEVICE_ID_ATI_IXP300_IDE    0x4369
1221#define PCI_DEVICE_ID_ATI_IXP300_SATA   0x436e
1222#define PCI_DEVICE_ID_ATI_IXP400_SMBUS  0x4372
1223#define PCI_DEVICE_ID_ATI_IXP400_IDE    0x4376
1224#define PCI_DEVICE_ID_ATI_IXP400_SATA   0x4379
1225#define PCI_DEVICE_ID_ATI_IXP400_SATA2  0x437a
1226#define PCI_DEVICE_ID_ATI_IXP600_SATA   0x4380
1227#define PCI_DEVICE_ID_ATI_SBX00_SMBUS   0x4385
1228#define PCI_DEVICE_ID_ATI_IXP600_IDE    0x438c
1229#define PCI_DEVICE_ID_ATI_IXP700_SATA   0x4390
1230#define PCI_DEVICE_ID_ATI_IXP700_IDE    0x439c
1231
1232#define PCI_VENDOR_ID_VLSI              0x1004
1233#define PCI_DEVICE_ID_VLSI_82C592       0x0005
1234#define PCI_DEVICE_ID_VLSI_82C593       0x0006
1235#define PCI_DEVICE_ID_VLSI_82C594       0x0007
1236#define PCI_DEVICE_ID_VLSI_82C597       0x0009
1237#define PCI_DEVICE_ID_VLSI_82C541       0x000c
1238#define PCI_DEVICE_ID_VLSI_82C543       0x000d
1239#define PCI_DEVICE_ID_VLSI_82C532       0x0101
1240#define PCI_DEVICE_ID_VLSI_82C534       0x0102
1241#define PCI_DEVICE_ID_VLSI_82C535       0x0104
1242#define PCI_DEVICE_ID_VLSI_82C147       0x0105
1243#define PCI_DEVICE_ID_VLSI_VAS96011     0x0702
1244
1245/* AMD RD890 Chipset */
1246#define PCI_DEVICE_ID_RD890_IOMMU       0x5a23
1247
1248#define PCI_VENDOR_ID_ADL               0x1005
1249#define PCI_DEVICE_ID_ADL_2301          0x2301
1250
1251#define PCI_VENDOR_ID_NS                0x100b
1252#define PCI_DEVICE_ID_NS_87415          0x0002
1253#define PCI_DEVICE_ID_NS_87560_LIO      0x000e
1254#define PCI_DEVICE_ID_NS_87560_USB      0x0012
1255#define PCI_DEVICE_ID_NS_83815          0x0020
1256#define PCI_DEVICE_ID_NS_83820          0x0022
1257#define PCI_DEVICE_ID_NS_CS5535_ISA     0x002b
1258#define PCI_DEVICE_ID_NS_CS5535_IDE     0x002d
1259#define PCI_DEVICE_ID_NS_CS5535_AUDIO   0x002e
1260#define PCI_DEVICE_ID_NS_CS5535_USB     0x002f
1261#define PCI_DEVICE_ID_NS_GX_VIDEO       0x0030
1262#define PCI_DEVICE_ID_NS_SATURN         0x0035
1263#define PCI_DEVICE_ID_NS_SCx200_BRIDGE  0x0500
1264#define PCI_DEVICE_ID_NS_SCx200_SMI     0x0501
1265#define PCI_DEVICE_ID_NS_SCx200_IDE     0x0502
1266#define PCI_DEVICE_ID_NS_SCx200_AUDIO   0x0503
1267#define PCI_DEVICE_ID_NS_SCx200_VIDEO   0x0504
1268#define PCI_DEVICE_ID_NS_SCx200_XBUS    0x0505
1269#define PCI_DEVICE_ID_NS_SC1100_BRIDGE  0x0510
1270#define PCI_DEVICE_ID_NS_SC1100_SMI     0x0511
1271#define PCI_DEVICE_ID_NS_SC1100_XBUS    0x0515
1272#define PCI_DEVICE_ID_NS_87410          0xd001
1273
1274#define PCI_DEVICE_ID_NS_GX_HOST_BRIDGE  0x0028
1275
1276#define PCI_VENDOR_ID_TSENG             0x100c
1277#define PCI_DEVICE_ID_TSENG_W32P_2      0x3202
1278#define PCI_DEVICE_ID_TSENG_W32P_b      0x3205
1279#define PCI_DEVICE_ID_TSENG_W32P_c      0x3206
1280#define PCI_DEVICE_ID_TSENG_W32P_d      0x3207
1281#define PCI_DEVICE_ID_TSENG_ET6000      0x3208
1282
1283#define PCI_VENDOR_ID_WEITEK            0x100e
1284#define PCI_DEVICE_ID_WEITEK_P9000      0x9001
1285#define PCI_DEVICE_ID_WEITEK_P9100      0x9100
1286
1287#define PCI_VENDOR_ID_DEC               0x1011
1288#define PCI_DEVICE_ID_DEC_BRD           0x0001
1289#define PCI_DEVICE_ID_DEC_TULIP         0x0002
1290#define PCI_DEVICE_ID_DEC_TGA           0x0004
1291#define PCI_DEVICE_ID_DEC_TULIP_FAST    0x0009
1292#define PCI_DEVICE_ID_DEC_TGA2          0x000D
1293#define PCI_DEVICE_ID_DEC_FDDI          0x000F
1294#define PCI_DEVICE_ID_DEC_TULIP_PLUS    0x0014
1295#define PCI_DEVICE_ID_DEC_21142         0x0019
1296#define PCI_DEVICE_ID_DEC_21052         0x0021
1297#define PCI_DEVICE_ID_DEC_21150         0x0022
1298#define PCI_DEVICE_ID_DEC_21152         0x0024
1299#define PCI_DEVICE_ID_DEC_21153         0x0025
1300#define PCI_DEVICE_ID_DEC_21154         0x0026
1301#define PCI_DEVICE_ID_DEC_21285         0x1065
1302#define PCI_DEVICE_ID_COMPAQ_42XX       0x0046
1303
1304#define PCI_VENDOR_ID_CIRRUS            0x1013
1305#define PCI_DEVICE_ID_CIRRUS_7548       0x0038
1306#define PCI_DEVICE_ID_CIRRUS_5430       0x00a0
1307#define PCI_DEVICE_ID_CIRRUS_5434_4     0x00a4
1308#define PCI_DEVICE_ID_CIRRUS_5434_8     0x00a8
1309#define PCI_DEVICE_ID_CIRRUS_5436       0x00ac
1310#define PCI_DEVICE_ID_CIRRUS_5446       0x00b8
1311#define PCI_DEVICE_ID_CIRRUS_5480       0x00bc
1312#define PCI_DEVICE_ID_CIRRUS_5462       0x00d0
1313#define PCI_DEVICE_ID_CIRRUS_5464       0x00d4
1314#define PCI_DEVICE_ID_CIRRUS_5465       0x00d6
1315#define PCI_DEVICE_ID_CIRRUS_6729       0x1100
1316#define PCI_DEVICE_ID_CIRRUS_6832       0x1110
1317#define PCI_DEVICE_ID_CIRRUS_7543       0x1202
1318#define PCI_DEVICE_ID_CIRRUS_4610       0x6001
1319#define PCI_DEVICE_ID_CIRRUS_4612       0x6003
1320#define PCI_DEVICE_ID_CIRRUS_4615       0x6004
1321
1322#define PCI_VENDOR_ID_IBM               0x1014
1323#define PCI_DEVICE_ID_IBM_TR            0x0018
1324#define PCI_DEVICE_ID_IBM_TR_WAKE       0x003e
1325#define PCI_DEVICE_ID_IBM_CPC710_PCI64  0x00fc
1326#define PCI_DEVICE_ID_IBM_SNIPE         0x0180
1327#define PCI_DEVICE_ID_IBM_CITRINE               0x028C
1328#define PCI_DEVICE_ID_IBM_GEMSTONE              0xB166
1329#define PCI_DEVICE_ID_IBM_OBSIDIAN              0x02BD
1330#define PCI_DEVICE_ID_IBM_ICOM_DEV_ID_1 0x0031
1331#define PCI_DEVICE_ID_IBM_ICOM_DEV_ID_2 0x0219
1332#define PCI_DEVICE_ID_IBM_ICOM_V2_TWO_PORTS_RVX         0x021A
1333#define PCI_DEVICE_ID_IBM_ICOM_V2_ONE_PORT_RVX_ONE_PORT_MDM     0x0251
1334#define PCI_DEVICE_ID_IBM_ICOM_V2_ONE_PORT_RVX_ONE_PORT_MDM_PCIE 0x0361
1335#define PCI_DEVICE_ID_IBM_ICOM_FOUR_PORT_MODEL  0x252
1336
1337#define PCI_SUBVENDOR_ID_IBM            0x1014
1338#define PCI_SUBDEVICE_ID_IBM_SATURN_SERIAL_ONE_PORT     0x03d4
1339
1340#define PCI_VENDOR_ID_UNISYS            0x1018
1341#define PCI_DEVICE_ID_UNISYS_DMA_DIRECTOR 0x001C
1342
1343#define PCI_VENDOR_ID_COMPEX2           0x101a /* pci.ids says "AT&T GIS (NCR)" */
1344#define PCI_DEVICE_ID_COMPEX2_100VG     0x0005
1345
1346#define PCI_VENDOR_ID_WD                0x101c
1347#define PCI_DEVICE_ID_WD_90C            0xc24a
1348
1349#define PCI_VENDOR_ID_AMI               0x101e
1350#define PCI_DEVICE_ID_AMI_MEGARAID3     0x1960
1351#define PCI_DEVICE_ID_AMI_MEGARAID      0x9010
1352#define PCI_DEVICE_ID_AMI_MEGARAID2     0x9060
1353
1354#define PCI_VENDOR_ID_AMD               0x1022
1355#define PCI_DEVICE_ID_AMD_K8_NB         0x1100
1356#define PCI_DEVICE_ID_AMD_K8_NB_ADDRMAP 0x1101
1357#define PCI_DEVICE_ID_AMD_K8_NB_MEMCTL  0x1102
1358#define PCI_DEVICE_ID_AMD_K8_NB_MISC    0x1103
1359#define PCI_DEVICE_ID_AMD_10H_NB_HT     0x1200
1360#define PCI_DEVICE_ID_AMD_10H_NB_MAP    0x1201
1361#define PCI_DEVICE_ID_AMD_10H_NB_DRAM   0x1202
1362#define PCI_DEVICE_ID_AMD_10H_NB_MISC   0x1203
1363#define PCI_DEVICE_ID_AMD_10H_NB_LINK   0x1204
1364#define PCI_DEVICE_ID_AMD_11H_NB_HT     0x1300
1365#define PCI_DEVICE_ID_AMD_11H_NB_MAP    0x1301
1366#define PCI_DEVICE_ID_AMD_11H_NB_DRAM   0x1302
1367#define PCI_DEVICE_ID_AMD_11H_NB_MISC   0x1303
1368#define PCI_DEVICE_ID_AMD_11H_NB_LINK   0x1304
1369#define PCI_DEVICE_ID_AMD_15H_M10H_F3   0x1403
1370#define PCI_DEVICE_ID_AMD_15H_NB_F0     0x1600
1371#define PCI_DEVICE_ID_AMD_15H_NB_F1     0x1601
1372#define PCI_DEVICE_ID_AMD_15H_NB_F2     0x1602
1373#define PCI_DEVICE_ID_AMD_15H_NB_F3     0x1603
1374#define PCI_DEVICE_ID_AMD_15H_NB_F4     0x1604
1375#define PCI_DEVICE_ID_AMD_15H_NB_F5     0x1605
1376#define PCI_DEVICE_ID_AMD_16H_NB_F3     0x1533
1377#define PCI_DEVICE_ID_AMD_16H_NB_F4     0x1534
1378#define PCI_DEVICE_ID_AMD_CNB17H_F3     0x1703
1379#define PCI_DEVICE_ID_AMD_LANCE         0x2000
1380#define PCI_DEVICE_ID_AMD_LANCE_HOME    0x2001
1381#define PCI_DEVICE_ID_AMD_SCSI          0x2020
1382#define PCI_DEVICE_ID_AMD_SERENADE      0x36c0
1383#define PCI_DEVICE_ID_AMD_FE_GATE_7006  0x7006
1384#define PCI_DEVICE_ID_AMD_FE_GATE_7007  0x7007
1385#define PCI_DEVICE_ID_AMD_FE_GATE_700C  0x700C
1386#define PCI_DEVICE_ID_AMD_FE_GATE_700E  0x700E
1387#define PCI_DEVICE_ID_AMD_COBRA_7401    0x7401
1388#define PCI_DEVICE_ID_AMD_VIPER_7409    0x7409
1389#define PCI_DEVICE_ID_AMD_VIPER_740B    0x740B
1390#define PCI_DEVICE_ID_AMD_VIPER_7410    0x7410
1391#define PCI_DEVICE_ID_AMD_VIPER_7411    0x7411
1392#define PCI_DEVICE_ID_AMD_VIPER_7413    0x7413
1393#define PCI_DEVICE_ID_AMD_VIPER_7440    0x7440
1394#define PCI_DEVICE_ID_AMD_OPUS_7441     0x7441
1395#define PCI_DEVICE_ID_AMD_OPUS_7443     0x7443
1396#define PCI_DEVICE_ID_AMD_VIPER_7443    0x7443
1397#define PCI_DEVICE_ID_AMD_OPUS_7445     0x7445
1398#define PCI_DEVICE_ID_AMD_8111_PCI      0x7460
1399#define PCI_DEVICE_ID_AMD_8111_LPC      0x7468
1400#define PCI_DEVICE_ID_AMD_8111_IDE      0x7469
1401#define PCI_DEVICE_ID_AMD_8111_SMBUS2   0x746a
1402#define PCI_DEVICE_ID_AMD_8111_SMBUS    0x746b
1403#define PCI_DEVICE_ID_AMD_8111_AUDIO    0x746d
1404#define PCI_DEVICE_ID_AMD_8151_0        0x7454
1405#define PCI_DEVICE_ID_AMD_8131_BRIDGE   0x7450
1406#define PCI_DEVICE_ID_AMD_8131_APIC     0x7451
1407#define PCI_DEVICE_ID_AMD_8132_BRIDGE   0x7458
1408#define PCI_DEVICE_ID_AMD_CS5535_IDE    0x208F
1409#define PCI_DEVICE_ID_AMD_CS5536_ISA    0x2090
1410#define PCI_DEVICE_ID_AMD_CS5536_FLASH  0x2091
1411#define PCI_DEVICE_ID_AMD_CS5536_AUDIO  0x2093
1412#define PCI_DEVICE_ID_AMD_CS5536_OHC    0x2094
1413#define PCI_DEVICE_ID_AMD_CS5536_EHC    0x2095
1414#define PCI_DEVICE_ID_AMD_CS5536_UDC    0x2096
1415#define PCI_DEVICE_ID_AMD_CS5536_UOC    0x2097
1416#define PCI_DEVICE_ID_AMD_CS5536_IDE    0x209A
1417#define PCI_DEVICE_ID_AMD_LX_VIDEO  0x2081
1418#define PCI_DEVICE_ID_AMD_LX_AES    0x2082
1419#define PCI_DEVICE_ID_AMD_HUDSON2_SATA_IDE      0x7800
1420#define PCI_DEVICE_ID_AMD_HUDSON2_SMBUS         0x780b
1421#define PCI_DEVICE_ID_AMD_HUDSON2_IDE           0x780c
1422
1423#define PCI_VENDOR_ID_TRIDENT           0x1023
1424#define PCI_DEVICE_ID_TRIDENT_4DWAVE_DX 0x2000
1425#define PCI_DEVICE_ID_TRIDENT_4DWAVE_NX 0x2001
1426#define PCI_DEVICE_ID_TRIDENT_9320      0x9320
1427#define PCI_DEVICE_ID_TRIDENT_9388      0x9388
1428#define PCI_DEVICE_ID_TRIDENT_9397      0x9397
1429#define PCI_DEVICE_ID_TRIDENT_939A      0x939A
1430#define PCI_DEVICE_ID_TRIDENT_9520      0x9520
1431#define PCI_DEVICE_ID_TRIDENT_9525      0x9525
1432#define PCI_DEVICE_ID_TRIDENT_9420      0x9420
1433#define PCI_DEVICE_ID_TRIDENT_9440      0x9440
1434#define PCI_DEVICE_ID_TRIDENT_9660      0x9660
1435#define PCI_DEVICE_ID_TRIDENT_9750      0x9750
1436#define PCI_DEVICE_ID_TRIDENT_9850      0x9850
1437#define PCI_DEVICE_ID_TRIDENT_9880      0x9880
1438#define PCI_DEVICE_ID_TRIDENT_8400      0x8400
1439#define PCI_DEVICE_ID_TRIDENT_8420      0x8420
1440#define PCI_DEVICE_ID_TRIDENT_8500      0x8500
1441
1442#define PCI_VENDOR_ID_AI                0x1025
1443#define PCI_DEVICE_ID_AI_M1435          0x1435
1444
1445#define PCI_VENDOR_ID_DELL              0x1028
1446#define PCI_DEVICE_ID_DELL_RACIII       0x0008
1447#define PCI_DEVICE_ID_DELL_RAC4         0x0012
1448#define PCI_DEVICE_ID_DELL_PERC5        0x0015
1449
1450#define PCI_VENDOR_ID_MATROX            0x102B
1451#define PCI_DEVICE_ID_MATROX_MGA_2      0x0518
1452#define PCI_DEVICE_ID_MATROX_MIL        0x0519
1453#define PCI_DEVICE_ID_MATROX_MYS        0x051A
1454#define PCI_DEVICE_ID_MATROX_MIL_2      0x051b
1455#define PCI_DEVICE_ID_MATROX_MYS_AGP    0x051e
1456#define PCI_DEVICE_ID_MATROX_MIL_2_AGP  0x051f
1457#define PCI_DEVICE_ID_MATROX_MGA_IMP    0x0d10
1458#define PCI_DEVICE_ID_MATROX_G100_MM    0x1000
1459#define PCI_DEVICE_ID_MATROX_G100_AGP   0x1001
1460#define PCI_DEVICE_ID_MATROX_G200_PCI   0x0520
1461#define PCI_DEVICE_ID_MATROX_G200_AGP   0x0521
1462#define PCI_DEVICE_ID_MATROX_G400       0x0525
1463#define PCI_DEVICE_ID_MATROX_G200EV_PCI 0x0530
1464#define PCI_DEVICE_ID_MATROX_G550       0x2527
1465#define PCI_DEVICE_ID_MATROX_VIA        0x4536
1466
1467#define PCI_VENDOR_ID_MOBILITY_ELECTRONICS      0x14f2
1468
1469#define PCI_VENDOR_ID_CT                0x102c
1470#define PCI_DEVICE_ID_CT_69000          0x00c0
1471#define PCI_DEVICE_ID_CT_65545          0x00d8
1472#define PCI_DEVICE_ID_CT_65548          0x00dc
1473#define PCI_DEVICE_ID_CT_65550          0x00e0
1474#define PCI_DEVICE_ID_CT_65554          0x00e4
1475#define PCI_DEVICE_ID_CT_65555          0x00e5
1476
1477#define PCI_VENDOR_ID_MIRO              0x1031
1478#define PCI_DEVICE_ID_MIRO_36050        0x5601
1479#define PCI_DEVICE_ID_MIRO_DC10PLUS     0x7efe
1480#define PCI_DEVICE_ID_MIRO_DC30PLUS     0xd801
1481
1482#define PCI_VENDOR_ID_NEC               0x1033
1483#define PCI_DEVICE_ID_NEC_CBUS_1        0x0001 /* PCI-Cbus Bridge */
1484#define PCI_DEVICE_ID_NEC_LOCAL         0x0002 /* Local Bridge */
1485#define PCI_DEVICE_ID_NEC_ATM           0x0003 /* ATM LAN Controller */
1486#define PCI_DEVICE_ID_NEC_R4000         0x0004 /* R4000 Bridge */
1487#define PCI_DEVICE_ID_NEC_486           0x0005 /* 486 Like Peripheral Bus Bridge */
1488#define PCI_DEVICE_ID_NEC_ACCEL_1       0x0006 /* Graphic Accelerator */
1489#define PCI_DEVICE_ID_NEC_UXBUS         0x0007 /* UX-Bus Bridge */
1490#define PCI_DEVICE_ID_NEC_ACCEL_2       0x0008 /* Graphic Accelerator */
1491#define PCI_DEVICE_ID_NEC_GRAPH         0x0009 /* PCI-CoreGraph Bridge */
1492#define PCI_DEVICE_ID_NEC_VL            0x0016 /* PCI-VL Bridge */
1493#define PCI_DEVICE_ID_NEC_STARALPHA2    0x002c /* STAR ALPHA2 */
1494#define PCI_DEVICE_ID_NEC_CBUS_2        0x002d /* PCI-Cbus Bridge */
1495#define PCI_DEVICE_ID_NEC_USB           0x0035 /* PCI-USB Host */
1496#define PCI_DEVICE_ID_NEC_CBUS_3        0x003b
1497#define PCI_DEVICE_ID_NEC_NAPCCARD      0x003e
1498#define PCI_DEVICE_ID_NEC_PCX2          0x0046 /* PowerVR */
1499#define PCI_DEVICE_ID_NEC_VRC5476       0x009b
1500#define PCI_DEVICE_ID_NEC_VRC4173       0x00a5
1501#define PCI_DEVICE_ID_NEC_VRC5477_AC97  0x00a6
1502#define PCI_DEVICE_ID_NEC_PC9821CS01    0x800c /* PC-9821-CS01 */
1503#define PCI_DEVICE_ID_NEC_PC9821NRB06   0x800d /* PC-9821NR-B06 */
1504
1505#define PCI_VENDOR_ID_FD                0x1036
1506#define PCI_DEVICE_ID_FD_36C70          0x0000
1507
1508#define PCI_VENDOR_ID_SI                0x1039
1509#define PCI_DEVICE_ID_SI_5591_AGP       0x0001
1510#define PCI_DEVICE_ID_SI_6202           0x0002
1511#define PCI_DEVICE_ID_SI_503            0x0008
1512#define PCI_DEVICE_ID_SI_ACPI           0x0009
1513#define PCI_DEVICE_ID_SI_SMBUS          0x0016
1514#define PCI_DEVICE_ID_SI_LPC            0x0018
1515#define PCI_DEVICE_ID_SI_5597_VGA       0x0200
1516#define PCI_DEVICE_ID_SI_6205           0x0205
1517#define PCI_DEVICE_ID_SI_501            0x0406
1518#define PCI_DEVICE_ID_SI_496            0x0496
1519#define PCI_DEVICE_ID_SI_300            0x0300
1520#define PCI_DEVICE_ID_SI_315H           0x0310
1521#define PCI_DEVICE_ID_SI_315            0x0315
1522#define PCI_DEVICE_ID_SI_315PRO         0x0325
1523#define PCI_DEVICE_ID_SI_530            0x0530
1524#define PCI_DEVICE_ID_SI_540            0x0540
1525#define PCI_DEVICE_ID_SI_550            0x0550
1526#define PCI_DEVICE_ID_SI_540_VGA        0x5300
1527#define PCI_DEVICE_ID_SI_550_VGA        0x5315
1528#define PCI_DEVICE_ID_SI_620            0x0620
1529#define PCI_DEVICE_ID_SI_630            0x0630
1530#define PCI_DEVICE_ID_SI_633            0x0633
1531#define PCI_DEVICE_ID_SI_635            0x0635
1532#define PCI_DEVICE_ID_SI_640            0x0640
1533#define PCI_DEVICE_ID_SI_645            0x0645
1534#define PCI_DEVICE_ID_SI_646            0x0646
1535#define PCI_DEVICE_ID_SI_648            0x0648
1536#define PCI_DEVICE_ID_SI_650            0x0650
1537#define PCI_DEVICE_ID_SI_651            0x0651
1538#define PCI_DEVICE_ID_SI_655            0x0655
1539#define PCI_DEVICE_ID_SI_661            0x0661
1540#define PCI_DEVICE_ID_SI_730            0x0730
1541#define PCI_DEVICE_ID_SI_733            0x0733
1542#define PCI_DEVICE_ID_SI_630_VGA        0x6300
1543#define PCI_DEVICE_ID_SI_735            0x0735
1544#define PCI_DEVICE_ID_SI_740            0x0740
1545#define PCI_DEVICE_ID_SI_741            0x0741
1546#define PCI_DEVICE_ID_SI_745            0x0745
1547#define PCI_DEVICE_ID_SI_746            0x0746
1548#define PCI_DEVICE_ID_SI_755            0x0755
1549#define PCI_DEVICE_ID_SI_760            0x0760
1550#define PCI_DEVICE_ID_SI_900            0x0900
1551#define PCI_DEVICE_ID_SI_961            0x0961
1552#define PCI_DEVICE_ID_SI_962            0x0962
1553#define PCI_DEVICE_ID_SI_963            0x0963
1554#define PCI_DEVICE_ID_SI_965            0x0965
1555#define PCI_DEVICE_ID_SI_966            0x0966
1556#define PCI_DEVICE_ID_SI_968            0x0968
1557#define PCI_DEVICE_ID_SI_1180           0x1180
1558#define PCI_DEVICE_ID_SI_5511           0x5511
1559#define PCI_DEVICE_ID_SI_5513           0x5513
1560#define PCI_DEVICE_ID_SI_5517           0x5517
1561#define PCI_DEVICE_ID_SI_5518           0x5518
1562#define PCI_DEVICE_ID_SI_5571           0x5571
1563#define PCI_DEVICE_ID_SI_5581           0x5581
1564#define PCI_DEVICE_ID_SI_5582           0x5582
1565#define PCI_DEVICE_ID_SI_5591           0x5591
1566#define PCI_DEVICE_ID_SI_5596           0x5596
1567#define PCI_DEVICE_ID_SI_5597           0x5597
1568#define PCI_DEVICE_ID_SI_5598           0x5598
1569#define PCI_DEVICE_ID_SI_5600           0x5600
1570#define PCI_DEVICE_ID_SI_7012           0x7012
1571#define PCI_DEVICE_ID_SI_7013           0x7013
1572#define PCI_DEVICE_ID_SI_7016           0x7016
1573#define PCI_DEVICE_ID_SI_7018           0x7018
1574
1575#define PCI_VENDOR_ID_HP                0x103c
1576#define PCI_DEVICE_ID_HP_VISUALIZE_EG   0x1005
1577#define PCI_DEVICE_ID_HP_VISUALIZE_FX6  0x1006
1578#define PCI_DEVICE_ID_HP_VISUALIZE_FX4  0x1008
1579#define PCI_DEVICE_ID_HP_VISUALIZE_FX2  0x100a
1580#define PCI_DEVICE_ID_HP_TACHYON        0x1028
1581#define PCI_DEVICE_ID_HP_TACHLITE       0x1029
1582#define PCI_DEVICE_ID_HP_J2585A         0x1030
1583#define PCI_DEVICE_ID_HP_J2585B         0x1031
1584#define PCI_DEVICE_ID_HP_J2973A         0x1040
1585#define PCI_DEVICE_ID_HP_J2970A         0x1042
1586#define PCI_DEVICE_ID_HP_DIVA           0x1048
1587#define PCI_DEVICE_ID_HP_DIVA_TOSCA1    0x1049
1588#define PCI_DEVICE_ID_HP_DIVA_TOSCA2    0x104A
1589#define PCI_DEVICE_ID_HP_DIVA_MAESTRO   0x104B
1590#define PCI_DEVICE_ID_HP_REO_IOC        0x10f1
1591#define PCI_DEVICE_ID_HP_VISUALIZE_FXE  0x108b
1592#define PCI_DEVICE_ID_HP_DIVA_HALFDOME  0x1223
1593#define PCI_DEVICE_ID_HP_DIVA_KEYSTONE  0x1226
1594#define PCI_DEVICE_ID_HP_DIVA_POWERBAR  0x1227
1595#define PCI_DEVICE_ID_HP_ZX1_IOC        0x122a
1596#define PCI_DEVICE_ID_HP_PCIX_LBA       0x122e
1597#define PCI_DEVICE_ID_HP_SX1000_IOC     0x127c
1598#define PCI_DEVICE_ID_HP_DIVA_EVEREST   0x1282
1599#define PCI_DEVICE_ID_HP_DIVA_AUX       0x1290
1600#define PCI_DEVICE_ID_HP_DIVA_RMP3      0x1301
1601#define PCI_DEVICE_ID_HP_DIVA_HURRICANE 0x132a
1602#define PCI_DEVICE_ID_HP_CISSA          0x3220
1603#define PCI_DEVICE_ID_HP_CISSC          0x3230
1604#define PCI_DEVICE_ID_HP_CISSD          0x3238
1605#define PCI_DEVICE_ID_HP_CISSE          0x323a
1606#define PCI_DEVICE_ID_HP_CISSF          0x323b
1607#define PCI_DEVICE_ID_HP_CISSH          0x323c
1608#define PCI_DEVICE_ID_HP_ZX2_IOC        0x4031
1609
1610#define PCI_VENDOR_ID_PCTECH            0x1042
1611#define PCI_DEVICE_ID_PCTECH_RZ1000     0x1000
1612#define PCI_DEVICE_ID_PCTECH_RZ1001     0x1001
1613#define PCI_DEVICE_ID_PCTECH_SAMURAI_IDE 0x3020
1614
1615#define PCI_VENDOR_ID_ASUSTEK           0x1043
1616#define PCI_DEVICE_ID_ASUSTEK_0675      0x0675
1617
1618#define PCI_VENDOR_ID_DPT               0x1044
1619#define PCI_DEVICE_ID_DPT               0xa400
1620
1621#define PCI_VENDOR_ID_OPTI              0x1045
1622#define PCI_DEVICE_ID_OPTI_82C558       0xc558
1623#define PCI_DEVICE_ID_OPTI_82C621       0xc621
1624#define PCI_DEVICE_ID_OPTI_82C700       0xc700
1625#define PCI_DEVICE_ID_OPTI_82C825       0xd568
1626
1627#define PCI_VENDOR_ID_ELSA              0x1048
1628#define PCI_DEVICE_ID_ELSA_MICROLINK    0x1000
1629#define PCI_DEVICE_ID_ELSA_QS3000       0x3000
1630
1631#define PCI_VENDOR_ID_STMICRO           0x104A
1632#define PCI_DEVICE_ID_STMICRO_USB_HOST  0xCC00
1633#define PCI_DEVICE_ID_STMICRO_USB_OHCI  0xCC01
1634#define PCI_DEVICE_ID_STMICRO_USB_OTG   0xCC02
1635#define PCI_DEVICE_ID_STMICRO_UART_HWFC 0xCC03
1636#define PCI_DEVICE_ID_STMICRO_UART_NO_HWFC      0xCC04
1637#define PCI_DEVICE_ID_STMICRO_SOC_DMA   0xCC05
1638#define PCI_DEVICE_ID_STMICRO_SATA      0xCC06
1639#define PCI_DEVICE_ID_STMICRO_I2C       0xCC07
1640#define PCI_DEVICE_ID_STMICRO_SPI_HS    0xCC08
1641#define PCI_DEVICE_ID_STMICRO_MAC       0xCC09
1642#define PCI_DEVICE_ID_STMICRO_SDIO_EMMC 0xCC0A
1643#define PCI_DEVICE_ID_STMICRO_SDIO      0xCC0B
1644#define PCI_DEVICE_ID_STMICRO_GPIO      0xCC0C
1645#define PCI_DEVICE_ID_STMICRO_VIP       0xCC0D
1646#define PCI_DEVICE_ID_STMICRO_AUDIO_ROUTER_DMA  0xCC0E
1647#define PCI_DEVICE_ID_STMICRO_AUDIO_ROUTER_SRCS 0xCC0F
1648#define PCI_DEVICE_ID_STMICRO_AUDIO_ROUTER_MSPS 0xCC10
1649#define PCI_DEVICE_ID_STMICRO_CAN       0xCC11
1650#define PCI_DEVICE_ID_STMICRO_MLB       0xCC12
1651#define PCI_DEVICE_ID_STMICRO_DBP       0xCC13
1652#define PCI_DEVICE_ID_STMICRO_SATA_PHY  0xCC14
1653#define PCI_DEVICE_ID_STMICRO_ESRAM     0xCC15
1654#define PCI_DEVICE_ID_STMICRO_VIC       0xCC16
1655
1656#define PCI_VENDOR_ID_BUSLOGIC                0x104B
1657#define PCI_DEVICE_ID_BUSLOGIC_MULTIMASTER_NC 0x0140
1658#define PCI_DEVICE_ID_BUSLOGIC_MULTIMASTER    0x1040
1659#define PCI_DEVICE_ID_BUSLOGIC_FLASHPOINT     0x8130
1660
1661#define PCI_VENDOR_ID_TI                0x104c
1662#define PCI_DEVICE_ID_TI_TVP4020        0x3d07
1663#define PCI_DEVICE_ID_TI_4450           0x8011
1664#define PCI_DEVICE_ID_TI_XX21_XX11      0x8031
1665#define PCI_DEVICE_ID_TI_XX21_XX11_FM   0x8033
1666#define PCI_DEVICE_ID_TI_XX21_XX11_SD   0x8034
1667#define PCI_DEVICE_ID_TI_X515           0x8036
1668#define PCI_DEVICE_ID_TI_XX12           0x8039
1669#define PCI_DEVICE_ID_TI_XX12_FM        0x803b
1670#define PCI_DEVICE_ID_TI_XIO2000A       0x8231
1671#define PCI_DEVICE_ID_TI_1130           0xac12
1672#define PCI_DEVICE_ID_TI_1031           0xac13
1673#define PCI_DEVICE_ID_TI_1131           0xac15
1674#define PCI_DEVICE_ID_TI_1250           0xac16
1675#define PCI_DEVICE_ID_TI_1220           0xac17
1676#define PCI_DEVICE_ID_TI_1221           0xac19
1677#define PCI_DEVICE_ID_TI_1210           0xac1a
1678#define PCI_DEVICE_ID_TI_1450           0xac1b
1679#define PCI_DEVICE_ID_TI_1225           0xac1c
1680#define PCI_DEVICE_ID_TI_1251A          0xac1d
1681#define PCI_DEVICE_ID_TI_1211           0xac1e
1682#define PCI_DEVICE_ID_TI_1251B          0xac1f
1683#define PCI_DEVICE_ID_TI_4410           0xac41
1684#define PCI_DEVICE_ID_TI_4451           0xac42
1685#define PCI_DEVICE_ID_TI_4510           0xac44
1686#define PCI_DEVICE_ID_TI_4520           0xac46
1687#define PCI_DEVICE_ID_TI_7510           0xac47
1688#define PCI_DEVICE_ID_TI_7610           0xac48
1689#define PCI_DEVICE_ID_TI_7410           0xac49
1690#define PCI_DEVICE_ID_TI_1410           0xac50
1691#define PCI_DEVICE_ID_TI_1420           0xac51
1692#define PCI_DEVICE_ID_TI_1451A          0xac52
1693#define PCI_DEVICE_ID_TI_1620           0xac54
1694#define PCI_DEVICE_ID_TI_1520           0xac55
1695#define PCI_DEVICE_ID_TI_1510           0xac56
1696#define PCI_DEVICE_ID_TI_X620           0xac8d
1697#define PCI_DEVICE_ID_TI_X420           0xac8e
1698#define PCI_DEVICE_ID_TI_XX20_FM        0xac8f
1699
1700#define PCI_VENDOR_ID_SONY              0x104d
1701
1702/* Winbond have two vendor IDs! See 0x10ad as well */
1703#define PCI_VENDOR_ID_WINBOND2          0x1050
1704#define PCI_DEVICE_ID_WINBOND2_89C940F  0x5a5a
1705#define PCI_DEVICE_ID_WINBOND2_6692     0x6692
1706
1707#define PCI_VENDOR_ID_ANIGMA            0x1051
1708#define PCI_DEVICE_ID_ANIGMA_MC145575   0x0100
1709
1710#define PCI_VENDOR_ID_EFAR              0x1055
1711#define PCI_DEVICE_ID_EFAR_SLC90E66_1   0x9130
1712#define PCI_DEVICE_ID_EFAR_SLC90E66_3   0x9463
1713
1714#define PCI_VENDOR_ID_MOTOROLA          0x1057
1715#define PCI_DEVICE_ID_MOTOROLA_MPC105   0x0001
1716#define PCI_DEVICE_ID_MOTOROLA_MPC106   0x0002
1717#define PCI_DEVICE_ID_MOTOROLA_MPC107   0x0004
1718#define PCI_DEVICE_ID_MOTOROLA_RAVEN    0x4801
1719#define PCI_DEVICE_ID_MOTOROLA_FALCON   0x4802
1720#define PCI_DEVICE_ID_MOTOROLA_HAWK     0x4803
1721#define PCI_DEVICE_ID_MOTOROLA_HARRIER  0x480b
1722#define PCI_DEVICE_ID_MOTOROLA_MPC5200  0x5803
1723#define PCI_DEVICE_ID_MOTOROLA_MPC5200B 0x5809
1724
1725#define PCI_VENDOR_ID_PROMISE           0x105a
1726#define PCI_DEVICE_ID_PROMISE_20265     0x0d30
1727#define PCI_DEVICE_ID_PROMISE_20267     0x4d30
1728#define PCI_DEVICE_ID_PROMISE_20246     0x4d33
1729#define PCI_DEVICE_ID_PROMISE_20262     0x4d38
1730#define PCI_DEVICE_ID_PROMISE_20263     0x0D38
1731#define PCI_DEVICE_ID_PROMISE_20268     0x4d68
1732#define PCI_DEVICE_ID_PROMISE_20269     0x4d69
1733#define PCI_DEVICE_ID_PROMISE_20270     0x6268
1734#define PCI_DEVICE_ID_PROMISE_20271     0x6269
1735#define PCI_DEVICE_ID_PROMISE_20275     0x1275
1736#define PCI_DEVICE_ID_PROMISE_20276     0x5275
1737#define PCI_DEVICE_ID_PROMISE_20277     0x7275
1738
1739#define PCI_VENDOR_ID_FOXCONN           0x105b
1740
1741#define PCI_VENDOR_ID_UMC               0x1060
1742#define PCI_DEVICE_ID_UMC_UM8673F       0x0101
1743#define PCI_DEVICE_ID_UMC_UM8886BF      0x673a
1744#define PCI_DEVICE_ID_UMC_UM8886A       0x886a
1745
1746#define PCI_VENDOR_ID_PICOPOWER         0x1066
1747#define PCI_DEVICE_ID_PICOPOWER_PT86C523        0x0002
1748#define PCI_DEVICE_ID_PICOPOWER_PT86C523BBP     0x8002
1749
1750#define PCI_VENDOR_ID_MYLEX             0x1069
1751#define PCI_DEVICE_ID_MYLEX_DAC960_P    0x0001
1752#define PCI_DEVICE_ID_MYLEX_DAC960_PD   0x0002
1753#define PCI_DEVICE_ID_MYLEX_DAC960_PG   0x0010
1754#define PCI_DEVICE_ID_MYLEX_DAC960_LA   0x0020
1755#define PCI_DEVICE_ID_MYLEX_DAC960_LP   0x0050
1756#define PCI_DEVICE_ID_MYLEX_DAC960_BA   0xBA56
1757#define PCI_DEVICE_ID_MYLEX_DAC960_GEM  0xB166
1758
1759#define PCI_VENDOR_ID_APPLE             0x106b
1760#define PCI_DEVICE_ID_APPLE_BANDIT      0x0001
1761#define PCI_DEVICE_ID_APPLE_HYDRA       0x000e
1762#define PCI_DEVICE_ID_APPLE_UNI_N_FW    0x0018
1763#define PCI_DEVICE_ID_APPLE_UNI_N_AGP   0x0020
1764#define PCI_DEVICE_ID_APPLE_UNI_N_GMAC  0x0021
1765#define PCI_DEVICE_ID_APPLE_UNI_N_GMACP 0x0024
1766#define PCI_DEVICE_ID_APPLE_UNI_N_AGP_P 0x0027
1767#define PCI_DEVICE_ID_APPLE_UNI_N_AGP15 0x002d
1768#define PCI_DEVICE_ID_APPLE_UNI_N_PCI15 0x002e
1769#define PCI_DEVICE_ID_APPLE_UNI_N_GMAC2 0x0032
1770#define PCI_DEVICE_ID_APPLE_UNI_N_ATA   0x0033
1771#define PCI_DEVICE_ID_APPLE_UNI_N_AGP2  0x0034
1772#define PCI_DEVICE_ID_APPLE_IPID_ATA100 0x003b
1773#define PCI_DEVICE_ID_APPLE_K2_ATA100   0x0043
1774#define PCI_DEVICE_ID_APPLE_U3_AGP      0x004b
1775#define PCI_DEVICE_ID_APPLE_K2_GMAC     0x004c
1776#define PCI_DEVICE_ID_APPLE_SH_ATA      0x0050
1777#define PCI_DEVICE_ID_APPLE_SH_SUNGEM   0x0051
1778#define PCI_DEVICE_ID_APPLE_U3L_AGP     0x0058
1779#define PCI_DEVICE_ID_APPLE_U3H_AGP     0x0059
1780#define PCI_DEVICE_ID_APPLE_U4_PCIE     0x005b
1781#define PCI_DEVICE_ID_APPLE_IPID2_AGP   0x0066
1782#define PCI_DEVICE_ID_APPLE_IPID2_ATA   0x0069
1783#define PCI_DEVICE_ID_APPLE_IPID2_FW    0x006a
1784#define PCI_DEVICE_ID_APPLE_IPID2_GMAC  0x006b
1785#define PCI_DEVICE_ID_APPLE_TIGON3      0x1645
1786
1787#define PCI_VENDOR_ID_YAMAHA            0x1073
1788#define PCI_DEVICE_ID_YAMAHA_724        0x0004
1789#define PCI_DEVICE_ID_YAMAHA_724F       0x000d
1790#define PCI_DEVICE_ID_YAMAHA_740        0x000a
1791#define PCI_DEVICE_ID_YAMAHA_740C       0x000c
1792#define PCI_DEVICE_ID_YAMAHA_744        0x0010
1793#define PCI_DEVICE_ID_YAMAHA_754        0x0012
1794
1795#define PCI_VENDOR_ID_QLOGIC            0x1077
1796#define PCI_DEVICE_ID_QLOGIC_ISP10160   0x1016
1797#define PCI_DEVICE_ID_QLOGIC_ISP1020    0x1020
1798#define PCI_DEVICE_ID_QLOGIC_ISP1080    0x1080
1799#define PCI_DEVICE_ID_QLOGIC_ISP12160   0x1216
1800#define PCI_DEVICE_ID_QLOGIC_ISP1240    0x1240
1801#define PCI_DEVICE_ID_QLOGIC_ISP1280    0x1280
1802#define PCI_DEVICE_ID_QLOGIC_ISP2100    0x2100
1803#define PCI_DEVICE_ID_QLOGIC_ISP2200    0x2200
1804#define PCI_DEVICE_ID_QLOGIC_ISP2300    0x2300
1805#define PCI_DEVICE_ID_QLOGIC_ISP2312    0x2312
1806#define PCI_DEVICE_ID_QLOGIC_ISP2322    0x2322
1807#define PCI_DEVICE_ID_QLOGIC_ISP6312    0x6312
1808#define PCI_DEVICE_ID_QLOGIC_ISP6322    0x6322
1809#define PCI_DEVICE_ID_QLOGIC_ISP2422    0x2422
1810#define PCI_DEVICE_ID_QLOGIC_ISP2432    0x2432
1811#define PCI_DEVICE_ID_QLOGIC_ISP2512    0x2512
1812#define PCI_DEVICE_ID_QLOGIC_ISP2522    0x2522
1813#define PCI_DEVICE_ID_QLOGIC_ISP5422    0x5422
1814#define PCI_DEVICE_ID_QLOGIC_ISP5432    0x5432
1815
1816#define PCI_VENDOR_ID_CYRIX             0x1078
1817#define PCI_DEVICE_ID_CYRIX_5510        0x0000
1818#define PCI_DEVICE_ID_CYRIX_PCI_MASTER  0x0001
1819#define PCI_DEVICE_ID_CYRIX_5520        0x0002
1820#define PCI_DEVICE_ID_CYRIX_5530_LEGACY 0x0100
1821#define PCI_DEVICE_ID_CYRIX_5530_IDE    0x0102
1822#define PCI_DEVICE_ID_CYRIX_5530_AUDIO  0x0103
1823#define PCI_DEVICE_ID_CYRIX_5530_VIDEO  0x0104
1824
1825#define PCI_VENDOR_ID_CONTAQ            0x1080
1826#define PCI_DEVICE_ID_CONTAQ_82C693     0xc693
1827
1828#define PCI_VENDOR_ID_OLICOM            0x108d
1829#define PCI_DEVICE_ID_OLICOM_OC2325     0x0012
1830#define PCI_DEVICE_ID_OLICOM_OC2183     0x0013
1831#define PCI_DEVICE_ID_OLICOM_OC2326     0x0014
1832
1833#define PCI_VENDOR_ID_SUN               0x108e
1834#define PCI_DEVICE_ID_SUN_EBUS          0x1000
1835#define PCI_DEVICE_ID_SUN_HAPPYMEAL     0x1001
1836#define PCI_DEVICE_ID_SUN_RIO_EBUS      0x1100
1837#define PCI_DEVICE_ID_SUN_RIO_GEM       0x1101
1838#define PCI_DEVICE_ID_SUN_RIO_1394      0x1102
1839#define PCI_DEVICE_ID_SUN_RIO_USB       0x1103
1840#define PCI_DEVICE_ID_SUN_GEM           0x2bad
1841#define PCI_DEVICE_ID_SUN_SIMBA         0x5000
1842#define PCI_DEVICE_ID_SUN_PBM           0x8000
1843#define PCI_DEVICE_ID_SUN_SCHIZO        0x8001
1844#define PCI_DEVICE_ID_SUN_SABRE         0xa000
1845#define PCI_DEVICE_ID_SUN_HUMMINGBIRD   0xa001
1846#define PCI_DEVICE_ID_SUN_TOMATILLO     0xa801
1847#define PCI_DEVICE_ID_SUN_CASSINI       0xabba
1848
1849#define PCI_VENDOR_ID_NI                0x1093
1850#define PCI_DEVICE_ID_NI_PCI2322        0xd130
1851#define PCI_DEVICE_ID_NI_PCI2324        0xd140
1852#define PCI_DEVICE_ID_NI_PCI2328        0xd150
1853#define PCI_DEVICE_ID_NI_PXI8422_2322   0xd190
1854#define PCI_DEVICE_ID_NI_PXI8422_2324   0xd1a0
1855#define PCI_DEVICE_ID_NI_PXI8420_2322   0xd1d0
1856#define PCI_DEVICE_ID_NI_PXI8420_2324   0xd1e0
1857#define PCI_DEVICE_ID_NI_PXI8420_2328   0xd1f0
1858#define PCI_DEVICE_ID_NI_PXI8420_23216  0xd1f1
1859#define PCI_DEVICE_ID_NI_PCI2322I       0xd250
1860#define PCI_DEVICE_ID_NI_PCI2324I       0xd270
1861#define PCI_DEVICE_ID_NI_PCI23216       0xd2b0
1862#define PCI_DEVICE_ID_NI_PXI8430_2322   0x7080
1863#define PCI_DEVICE_ID_NI_PCI8430_2322   0x70db
1864#define PCI_DEVICE_ID_NI_PXI8430_2324   0x70dd
1865#define PCI_DEVICE_ID_NI_PCI8430_2324   0x70df
1866#define PCI_DEVICE_ID_NI_PXI8430_2328   0x70e2
1867#define PCI_DEVICE_ID_NI_PCI8430_2328   0x70e4
1868#define PCI_DEVICE_ID_NI_PXI8430_23216  0x70e6
1869#define PCI_DEVICE_ID_NI_PCI8430_23216  0x70e7
1870#define PCI_DEVICE_ID_NI_PXI8432_2322   0x70e8
1871#define PCI_DEVICE_ID_NI_PCI8432_2322   0x70ea
1872#define PCI_DEVICE_ID_NI_PXI8432_2324   0x70ec
1873#define PCI_DEVICE_ID_NI_PCI8432_2324   0x70ee
1874
1875#define PCI_VENDOR_ID_CMD               0x1095
1876#define PCI_DEVICE_ID_CMD_643           0x0643
1877#define PCI_DEVICE_ID_CMD_646           0x0646
1878#define PCI_DEVICE_ID_CMD_648           0x0648
1879#define PCI_DEVICE_ID_CMD_649           0x0649
1880
1881#define PCI_DEVICE_ID_SII_680           0x0680
1882#define PCI_DEVICE_ID_SII_3112          0x3112
1883#define PCI_DEVICE_ID_SII_1210SA        0x0240
1884
1885#define PCI_VENDOR_ID_BROOKTREE         0x109e
1886#define PCI_DEVICE_ID_BROOKTREE_878     0x0878
1887#define PCI_DEVICE_ID_BROOKTREE_879     0x0879
1888
1889#define PCI_VENDOR_ID_SGI               0x10a9
1890#define PCI_DEVICE_ID_SGI_IOC3          0x0003
1891#define PCI_DEVICE_ID_SGI_LITHIUM       0x1002
1892#define PCI_DEVICE_ID_SGI_IOC4          0x100a
1893
1894#define PCI_VENDOR_ID_WINBOND           0x10ad
1895#define PCI_DEVICE_ID_WINBOND_82C105    0x0105
1896#define PCI_DEVICE_ID_WINBOND_83C553    0x0565
1897
1898#define PCI_VENDOR_ID_PLX               0x10b5
1899#define PCI_DEVICE_ID_PLX_R685          0x1030
1900#define PCI_DEVICE_ID_PLX_ROMULUS       0x106a
1901#define PCI_DEVICE_ID_PLX_SPCOM800      0x1076
1902#define PCI_DEVICE_ID_PLX_1077          0x1077
1903#define PCI_DEVICE_ID_PLX_SPCOM200      0x1103
1904#define PCI_DEVICE_ID_PLX_DJINN_ITOO    0x1151
1905#define PCI_DEVICE_ID_PLX_R753          0x1152
1906#define PCI_DEVICE_ID_PLX_OLITEC        0x1187
1907#define PCI_DEVICE_ID_PLX_PCI200SYN     0x3196
1908#define PCI_DEVICE_ID_PLX_9030          0x9030
1909#define PCI_DEVICE_ID_PLX_9050          0x9050
1910#define PCI_DEVICE_ID_PLX_9056          0x9056
1911#define PCI_DEVICE_ID_PLX_9080          0x9080
1912#define PCI_DEVICE_ID_PLX_GTEK_SERIAL2  0xa001
1913
1914#define PCI_VENDOR_ID_MADGE             0x10b6
1915#define PCI_DEVICE_ID_MADGE_MK2         0x0002
1916
1917#define PCI_VENDOR_ID_3COM              0x10b7
1918#define PCI_DEVICE_ID_3COM_3C985        0x0001
1919#define PCI_DEVICE_ID_3COM_3C940        0x1700
1920#define PCI_DEVICE_ID_3COM_3C339        0x3390
1921#define PCI_DEVICE_ID_3COM_3C359        0x3590
1922#define PCI_DEVICE_ID_3COM_3C940B       0x80eb
1923#define PCI_DEVICE_ID_3COM_3CR990       0x9900
1924#define PCI_DEVICE_ID_3COM_3CR990_TX_95 0x9902
1925#define PCI_DEVICE_ID_3COM_3CR990_TX_97 0x9903
1926#define PCI_DEVICE_ID_3COM_3CR990B      0x9904
1927#define PCI_DEVICE_ID_3COM_3CR990_FX    0x9905
1928#define PCI_DEVICE_ID_3COM_3CR990SVR95  0x9908
1929#define PCI_DEVICE_ID_3COM_3CR990SVR97  0x9909
1930#define PCI_DEVICE_ID_3COM_3CR990SVR    0x990a
1931
1932#define PCI_VENDOR_ID_AL                0x10b9
1933#define PCI_DEVICE_ID_AL_M1533          0x1533
1934#define PCI_DEVICE_ID_AL_M1535          0x1535
1935#define PCI_DEVICE_ID_AL_M1541          0x1541
1936#define PCI_DEVICE_ID_AL_M1563          0x1563
1937#define PCI_DEVICE_ID_AL_M1621          0x1621
1938#define PCI_DEVICE_ID_AL_M1631          0x1631
1939#define PCI_DEVICE_ID_AL_M1632          0x1632
1940#define PCI_DEVICE_ID_AL_M1641          0x1641
1941#define PCI_DEVICE_ID_AL_M1644          0x1644
1942#define PCI_DEVICE_ID_AL_M1647          0x1647
1943#define PCI_DEVICE_ID_AL_M1651          0x1651
1944#define PCI_DEVICE_ID_AL_M1671          0x1671
1945#define PCI_DEVICE_ID_AL_M1681          0x1681
1946#define PCI_DEVICE_ID_AL_M1683          0x1683
1947#define PCI_DEVICE_ID_AL_M1689          0x1689
1948#define PCI_DEVICE_ID_AL_M5219          0x5219
1949#define PCI_DEVICE_ID_AL_M5228          0x5228
1950#define PCI_DEVICE_ID_AL_M5229          0x5229
1951#define PCI_DEVICE_ID_AL_M5451          0x5451
1952#define PCI_DEVICE_ID_AL_M7101          0x7101
1953
1954#define PCI_VENDOR_ID_NEOMAGIC          0x10c8
1955#define PCI_DEVICE_ID_NEOMAGIC_NM256AV_AUDIO 0x8005
1956#define PCI_DEVICE_ID_NEOMAGIC_NM256ZX_AUDIO 0x8006
1957#define PCI_DEVICE_ID_NEOMAGIC_NM256XL_PLUS_AUDIO 0x8016
1958
1959#define PCI_VENDOR_ID_TCONRAD           0x10da
1960#define PCI_DEVICE_ID_TCONRAD_TOKENRING 0x0508
1961
1962#define PCI_VENDOR_ID_NVIDIA                    0x10de
1963#define PCI_DEVICE_ID_NVIDIA_TNT                0x0020
1964#define PCI_DEVICE_ID_NVIDIA_TNT2               0x0028
1965#define PCI_DEVICE_ID_NVIDIA_UTNT2              0x0029
1966#define PCI_DEVICE_ID_NVIDIA_TNT_UNKNOWN        0x002a
1967#define PCI_DEVICE_ID_NVIDIA_VTNT2              0x002C
1968#define PCI_DEVICE_ID_NVIDIA_UVTNT2             0x002D
1969#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP04_SMBUS 0x0034
1970#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP04_IDE   0x0035
1971#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP04_SATA  0x0036
1972#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP04_SATA2 0x003e
1973#define PCI_DEVICE_ID_NVIDIA_GEFORCE_6800_ULTRA 0x0040
1974#define PCI_DEVICE_ID_NVIDIA_GEFORCE_6800       0x0041
1975#define PCI_DEVICE_ID_NVIDIA_GEFORCE_6800_LE    0x0042
1976#define PCI_DEVICE_ID_NVIDIA_GEFORCE_6800_GT    0x0045
1977#define PCI_DEVICE_ID_NVIDIA_QUADRO_FX_4000     0x004E
1978#define PCI_DEVICE_ID_NVIDIA_NFORCE4_SMBUS      0x0052
1979#define PCI_DEVICE_ID_NVIDIA_NFORCE_CK804_IDE   0x0053
1980#define PCI_DEVICE_ID_NVIDIA_NFORCE_CK804_SATA  0x0054
1981#define PCI_DEVICE_ID_NVIDIA_NFORCE_CK804_SATA2 0x0055
1982#define PCI_DEVICE_ID_NVIDIA_CK804_AUDIO        0x0059
1983#define PCI_DEVICE_ID_NVIDIA_CK804_PCIE         0x005d
1984#define PCI_DEVICE_ID_NVIDIA_NFORCE2_SMBUS      0x0064
1985#define PCI_DEVICE_ID_NVIDIA_NFORCE2_IDE        0x0065
1986#define PCI_DEVICE_ID_NVIDIA_MCP2_MODEM         0x0069
1987#define PCI_DEVICE_ID_NVIDIA_MCP2_AUDIO         0x006a
1988#define PCI_DEVICE_ID_NVIDIA_NFORCE2S_SMBUS     0x0084
1989#define PCI_DEVICE_ID_NVIDIA_NFORCE2S_IDE       0x0085
1990#define PCI_DEVICE_ID_NVIDIA_MCP2S_MODEM        0x0089
1991#define PCI_DEVICE_ID_NVIDIA_CK8_AUDIO          0x008a
1992#define PCI_DEVICE_ID_NVIDIA_NFORCE2S_SATA      0x008e
1993#define PCI_DEVICE_ID_NVIDIA_GEFORCE_7800_GT   0x0090
1994#define PCI_DEVICE_ID_NVIDIA_GEFORCE_7800_GTX   0x0091
1995#define PCI_DEVICE_ID_NVIDIA_GEFORCE_GO_7800   0x0098
1996#define PCI_DEVICE_ID_NVIDIA_GEFORCE_GO_7800_GTX 0x0099
1997#define PCI_DEVICE_ID_NVIDIA_ITNT2              0x00A0
1998#define PCI_DEVICE_ID_GEFORCE_6800A             0x00c1
1999#define PCI_DEVICE_ID_GEFORCE_6800A_LE          0x00c2
2000#define PCI_DEVICE_ID_GEFORCE_GO_6800           0x00c8
2001#define PCI_DEVICE_ID_GEFORCE_GO_6800_ULTRA     0x00c9
2002#define PCI_DEVICE_ID_QUADRO_FX_GO1400          0x00cc
2003#define PCI_DEVICE_ID_QUADRO_FX_1400            0x00ce
2004#define PCI_DEVICE_ID_NVIDIA_NFORCE3            0x00d1
2005#define PCI_DEVICE_ID_NVIDIA_NFORCE3_SMBUS      0x00d4
2006#define PCI_DEVICE_ID_NVIDIA_NFORCE3_IDE        0x00d5
2007#define PCI_DEVICE_ID_NVIDIA_MCP3_MODEM         0x00d9
2008#define PCI_DEVICE_ID_NVIDIA_MCP3_AUDIO         0x00da
2009#define PCI_DEVICE_ID_NVIDIA_NFORCE3S           0x00e1
2010#define PCI_DEVICE_ID_NVIDIA_NFORCE3S_SATA      0x00e3
2011#define PCI_DEVICE_ID_NVIDIA_NFORCE3S_SMBUS     0x00e4
2012#define PCI_DEVICE_ID_NVIDIA_NFORCE3S_IDE       0x00e5
2013#define PCI_DEVICE_ID_NVIDIA_CK8S_AUDIO         0x00ea
2014#define PCI_DEVICE_ID_NVIDIA_NFORCE3S_SATA2     0x00ee
2015#define PCIE_DEVICE_ID_NVIDIA_GEFORCE_6800_ALT1 0x00f0
2016#define PCIE_DEVICE_ID_NVIDIA_GEFORCE_6600_ALT1 0x00f1
2017#define PCIE_DEVICE_ID_NVIDIA_GEFORCE_6600_ALT2 0x00f2
2018#define PCIE_DEVICE_ID_NVIDIA_GEFORCE_6200_ALT1 0x00f3
2019#define PCIE_DEVICE_ID_NVIDIA_GEFORCE_6800_GT   0x00f9
2020#define PCIE_DEVICE_ID_NVIDIA_QUADRO_NVS280     0x00fd
2021#define PCI_DEVICE_ID_NVIDIA_GEFORCE_SDR        0x0100
2022#define PCI_DEVICE_ID_NVIDIA_GEFORCE_DDR        0x0101
2023#define PCI_DEVICE_ID_NVIDIA_QUADRO             0x0103
2024#define PCI_DEVICE_ID_NVIDIA_GEFORCE2_MX        0x0110
2025#define PCI_DEVICE_ID_NVIDIA_GEFORCE2_MX2       0x0111
2026#define PCI_DEVICE_ID_NVIDIA_GEFORCE2_GO        0x0112
2027#define PCI_DEVICE_ID_NVIDIA_QUADRO2_MXR        0x0113
2028#define PCI_DEVICE_ID_NVIDIA_GEFORCE_6600_GT    0x0140
2029#define PCI_DEVICE_ID_NVIDIA_GEFORCE_6600       0x0141
2030#define PCI_DEVICE_ID_NVIDIA_GEFORCE_6610_XL    0x0145
2031#define PCI_DEVICE_ID_NVIDIA_QUADRO_FX_540      0x014E
2032#define PCI_DEVICE_ID_NVIDIA_GEFORCE_6200       0x014F
2033#define PCI_DEVICE_ID_NVIDIA_GEFORCE2_GTS       0x0150
2034#define PCI_DEVICE_ID_NVIDIA_GEFORCE2_GTS2      0x0151
2035#define PCI_DEVICE_ID_NVIDIA_GEFORCE2_ULTRA     0x0152
2036#define PCI_DEVICE_ID_NVIDIA_QUADRO2_PRO        0x0153
2037#define PCI_DEVICE_ID_NVIDIA_GEFORCE_6200_TURBOCACHE 0x0161
2038#define PCI_DEVICE_ID_NVIDIA_GEFORCE_GO_6200    0x0164
2039#define PCI_DEVICE_ID_NVIDIA_GEFORCE_GO_6250    0x0166
2040#define PCI_DEVICE_ID_NVIDIA_GEFORCE_GO_6200_1  0x0167
2041#define PCI_DEVICE_ID_NVIDIA_GEFORCE_GO_6250_1  0x0168
2042#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_MX_460    0x0170
2043#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_MX_440    0x0171
2044#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_MX_420    0x0172
2045#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_MX_440_SE 0x0173
2046#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_440_GO    0x0174
2047#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_420_GO    0x0175
2048#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_420_GO_M32 0x0176
2049#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_460_GO    0x0177
2050#define PCI_DEVICE_ID_NVIDIA_QUADRO4_500XGL     0x0178
2051#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_440_GO_M64 0x0179
2052#define PCI_DEVICE_ID_NVIDIA_QUADRO4_200        0x017A
2053#define PCI_DEVICE_ID_NVIDIA_QUADRO4_550XGL     0x017B
2054#define PCI_DEVICE_ID_NVIDIA_QUADRO4_500_GOGL   0x017C
2055#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_410_GO_M16 0x017D
2056#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_MX_440_8X 0x0181
2057#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_MX_440SE_8X 0x0182
2058#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_MX_420_8X 0x0183
2059#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_MX_4000   0x0185
2060#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_448_GO    0x0186
2061#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_488_GO    0x0187
2062#define PCI_DEVICE_ID_NVIDIA_QUADRO4_580_XGL    0x0188
2063#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_MX_MAC    0x0189
2064#define PCI_DEVICE_ID_NVIDIA_QUADRO4_280_NVS    0x018A
2065#define PCI_DEVICE_ID_NVIDIA_QUADRO4_380_XGL    0x018B
2066#define PCI_DEVICE_ID_NVIDIA_IGEFORCE2          0x01a0
2067#define PCI_DEVICE_ID_NVIDIA_NFORCE             0x01a4
2068#define PCI_DEVICE_ID_NVIDIA_MCP1_AUDIO         0x01b1
2069#define PCI_DEVICE_ID_NVIDIA_NFORCE_SMBUS       0x01b4
2070#define PCI_DEVICE_ID_NVIDIA_NFORCE_IDE         0x01bc
2071#define PCI_DEVICE_ID_NVIDIA_MCP1_MODEM         0x01c1
2072#define PCI_DEVICE_ID_NVIDIA_NFORCE2            0x01e0
2073#define PCI_DEVICE_ID_NVIDIA_GEFORCE3           0x0200
2074#define PCI_DEVICE_ID_NVIDIA_GEFORCE3_1         0x0201
2075#define PCI_DEVICE_ID_NVIDIA_GEFORCE3_2         0x0202
2076#define PCI_DEVICE_ID_NVIDIA_QUADRO_DDC         0x0203
2077#define PCI_DEVICE_ID_NVIDIA_GEFORCE_6800B      0x0211
2078#define PCI_DEVICE_ID_NVIDIA_GEFORCE_6800B_LE   0x0212
2079#define PCI_DEVICE_ID_NVIDIA_GEFORCE_6800B_GT   0x0215
2080#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_TI_4600   0x0250
2081#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_TI_4400   0x0251
2082#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_TI_4200   0x0253
2083#define PCI_DEVICE_ID_NVIDIA_QUADRO4_900XGL     0x0258
2084#define PCI_DEVICE_ID_NVIDIA_QUADRO4_750XGL     0x0259
2085#define PCI_DEVICE_ID_NVIDIA_QUADRO4_700XGL     0x025B
2086#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP51_SMBUS 0x0264
2087#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP51_IDE   0x0265
2088#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP51_SATA  0x0266
2089#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP51_SATA2 0x0267
2090#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP55_SMBUS 0x0368
2091#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP55_IDE   0x036E
2092#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP55_SATA  0x037E
2093#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP55_SATA2 0x037F
2094#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_TI_4800   0x0280
2095#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_TI_4800_8X    0x0281
2096#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_TI_4800SE     0x0282
2097#define PCI_DEVICE_ID_NVIDIA_GEFORCE4_4200_GO       0x0286
2098#define PCI_DEVICE_ID_NVIDIA_QUADRO4_980_XGL        0x0288
2099#define PCI_DEVICE_ID_NVIDIA_QUADRO4_780_XGL        0x0289
2100#define PCI_DEVICE_ID_NVIDIA_QUADRO4_700_GOGL       0x028C
2101#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_5800_ULTRA  0x0301
2102#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_5800        0x0302
2103#define PCI_DEVICE_ID_NVIDIA_QUADRO_FX_2000         0x0308
2104#define PCI_DEVICE_ID_NVIDIA_QUADRO_FX_1000         0x0309
2105#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_5600_ULTRA  0x0311
2106#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_5600        0x0312
2107#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_5600SE      0x0314
2108#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_GO5600      0x031A
2109#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_GO5650      0x031B
2110#define PCI_DEVICE_ID_NVIDIA_QUADRO_FX_GO700        0x031C
2111#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_5200        0x0320
2112#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_5200_ULTRA  0x0321
2113#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_5200_1      0x0322
2114#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_5200SE      0x0323
2115#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_GO5200      0x0324
2116#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_GO5250      0x0325
2117#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_5500        0x0326
2118#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_5100        0x0327
2119#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_GO5250_32   0x0328
2120#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_GO_5200     0x0329
2121#define PCI_DEVICE_ID_NVIDIA_QUADRO_NVS_280_PCI     0x032A
2122#define PCI_DEVICE_ID_NVIDIA_QUADRO_FX_500          0x032B
2123#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_GO5300      0x032C
2124#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_GO5100      0x032D
2125#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_5900_ULTRA  0x0330
2126#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_5900        0x0331
2127#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_5900XT      0x0332
2128#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_5950_ULTRA  0x0333
2129#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_5900ZT      0x0334
2130#define PCI_DEVICE_ID_NVIDIA_QUADRO_FX_3000         0x0338
2131#define PCI_DEVICE_ID_NVIDIA_QUADRO_FX_700          0x033F
2132#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_5700_ULTRA  0x0341
2133#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_5700        0x0342
2134#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_5700LE      0x0343
2135#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_5700VE      0x0344
2136#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_GO5700_1    0x0347
2137#define PCI_DEVICE_ID_NVIDIA_GEFORCE_FX_GO5700_2    0x0348
2138#define PCI_DEVICE_ID_NVIDIA_QUADRO_FX_GO1000       0x034C
2139#define PCI_DEVICE_ID_NVIDIA_QUADRO_FX_1100         0x034E
2140#define PCI_DEVICE_ID_NVIDIA_MCP55_BRIDGE_V0        0x0360
2141#define PCI_DEVICE_ID_NVIDIA_MCP55_BRIDGE_V4        0x0364
2142#define PCI_DEVICE_ID_NVIDIA_NVENET_15              0x0373
2143#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP61_SATA      0x03E7
2144#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP61_SMBUS     0x03EB
2145#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP61_IDE       0x03EC
2146#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP61_SATA2     0x03F6
2147#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP61_SATA3     0x03F7
2148#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP65_SMBUS     0x0446
2149#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP65_IDE       0x0448
2150#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP67_SMBUS     0x0542
2151#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP67_IDE       0x0560
2152#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP73_IDE       0x056C
2153#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP78S_SMBUS    0x0752
2154#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP77_IDE       0x0759
2155#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP73_SMBUS     0x07D8
2156#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP79_SMBUS     0x0AA2
2157#define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP89_SATA      0x0D85
2158
2159#define PCI_VENDOR_ID_IMS               0x10e0
2160#define PCI_DEVICE_ID_IMS_TT128         0x9128
2161#define PCI_DEVICE_ID_IMS_TT3D          0x9135
2162
2163#define PCI_VENDOR_ID_INTERG            0x10ea
2164#define PCI_DEVICE_ID_INTERG_1682       0x1682
2165#define PCI_DEVICE_ID_INTERG_2000       0x2000
2166#define PCI_DEVICE_ID_INTERG_2010       0x2010
2167#define PCI_DEVICE_ID_INTERG_5000       0x5000
2168#define PCI_DEVICE_ID_INTERG_5050       0x5050
2169
2170#define PCI_VENDOR_ID_REALTEK           0x10ec
2171#define PCI_DEVICE_ID_REALTEK_8139      0x8139
2172
2173#define PCI_VENDOR_ID_XILINX            0x10ee
2174#define PCI_DEVICE_ID_RME_DIGI96        0x3fc0
2175#define PCI_DEVICE_ID_RME_DIGI96_8      0x3fc1
2176#define PCI_DEVICE_ID_RME_DIGI96_8_PRO  0x3fc2
2177#define PCI_DEVICE_ID_RME_DIGI96_8_PAD_OR_PST 0x3fc3
2178#define PCI_DEVICE_ID_XILINX_HAMMERFALL_DSP 0x3fc5
2179#define PCI_DEVICE_ID_XILINX_HAMMERFALL_DSP_MADI 0x3fc6
2180
2181#define PCI_VENDOR_ID_INIT              0x1101
2182
2183#define PCI_VENDOR_ID_CREATIVE          0x1102 /* duplicate: ECTIVA */
2184#define PCI_DEVICE_ID_CREATIVE_EMU10K1  0x0002
2185#define PCI_DEVICE_ID_CREATIVE_20K1     0x0005
2186#define PCI_DEVICE_ID_CREATIVE_20K2     0x000b
2187#define PCI_SUBDEVICE_ID_CREATIVE_SB0760        0x0024
2188#define PCI_SUBDEVICE_ID_CREATIVE_SB08801       0x0041
2189#define PCI_SUBDEVICE_ID_CREATIVE_SB08802       0x0042
2190#define PCI_SUBDEVICE_ID_CREATIVE_SB08803       0x0043
2191#define PCI_SUBDEVICE_ID_CREATIVE_SB1270        0x0062
2192#define PCI_SUBDEVICE_ID_CREATIVE_HENDRIX       0x6000
2193
2194#define PCI_VENDOR_ID_ECTIVA            0x1102 /* duplicate: CREATIVE */
2195#define PCI_DEVICE_ID_ECTIVA_EV1938     0x8938
2196
2197#define PCI_VENDOR_ID_TTI               0x1103
2198#define PCI_DEVICE_ID_TTI_HPT343        0x0003
2199#define PCI_DEVICE_ID_TTI_HPT366        0x0004
2200#define PCI_DEVICE_ID_TTI_HPT372        0x0005
2201#define PCI_DEVICE_ID_TTI_HPT302        0x0006
2202#define PCI_DEVICE_ID_TTI_HPT371        0x0007
2203#define PCI_DEVICE_ID_TTI_HPT374        0x0008
2204#define PCI_DEVICE_ID_TTI_HPT372N       0x0009  /* apparently a 372N variant? */
2205
2206#define PCI_VENDOR_ID_VIA               0x1106
2207#define PCI_DEVICE_ID_VIA_8763_0        0x0198
2208#define PCI_DEVICE_ID_VIA_8380_0        0x0204
2209#define PCI_DEVICE_ID_VIA_3238_0        0x0238
2210#define PCI_DEVICE_ID_VIA_PT880         0x0258
2211#define PCI_DEVICE_ID_VIA_PT880ULTRA    0x0308
2212#define PCI_DEVICE_ID_VIA_PX8X0_0       0x0259
2213#define PCI_DEVICE_ID_VIA_3269_0        0x0269
2214#define PCI_DEVICE_ID_VIA_K8T800PRO_0   0x0282
2215#define PCI_DEVICE_ID_VIA_3296_0        0x0296
2216#define PCI_DEVICE_ID_VIA_8363_0        0x0305
2217#define PCI_DEVICE_ID_VIA_P4M800CE      0x0314
2218#define PCI_DEVICE_ID_VIA_P4M890        0x0327
2219#define PCI_DEVICE_ID_VIA_VT3324        0x0324
2220#define PCI_DEVICE_ID_VIA_VT3336        0x0336
2221#define PCI_DEVICE_ID_VIA_VT3351        0x0351
2222#define PCI_DEVICE_ID_VIA_VT3364        0x0364
2223#define PCI_DEVICE_ID_VIA_8371_0        0x0391
2224#define PCI_DEVICE_ID_VIA_6415          0x0415
2225#define PCI_DEVICE_ID_VIA_8501_0        0x0501
2226#define PCI_DEVICE_ID_VIA_82C561        0x0561
2227#define PCI_DEVICE_ID_VIA_82C586_1      0x0571
2228#define PCI_DEVICE_ID_VIA_82C576        0x0576
2229#define PCI_DEVICE_ID_VIA_82C586_0      0x0586
2230#define PCI_DEVICE_ID_VIA_82C596        0x0596
2231#define PCI_DEVICE_ID_VIA_82C597_0      0x0597
2232#define PCI_DEVICE_ID_VIA_82C598_0      0x0598
2233#define PCI_DEVICE_ID_VIA_8601_0        0x0601
2234#define PCI_DEVICE_ID_VIA_8605_0        0x0605
2235#define PCI_DEVICE_ID_VIA_82C686        0x0686
2236#define PCI_DEVICE_ID_VIA_82C691_0      0x0691
2237#define PCI_DEVICE_ID_VIA_82C576_1      0x1571
2238#define PCI_DEVICE_ID_VIA_82C586_2      0x3038
2239#define PCI_DEVICE_ID_VIA_82C586_3      0x3040
2240#define PCI_DEVICE_ID_VIA_82C596_3      0x3050
2241#define PCI_DEVICE_ID_VIA_82C596B_3     0x3051
2242#define PCI_DEVICE_ID_VIA_82C686_4      0x3057
2243#define PCI_DEVICE_ID_VIA_82C686_5      0x3058
2244#define PCI_DEVICE_ID_VIA_8233_5        0x3059
2245#define PCI_DEVICE_ID_VIA_8233_0        0x3074
2246#define PCI_DEVICE_ID_VIA_8633_0        0x3091
2247#define PCI_DEVICE_ID_VIA_8367_0        0x3099
2248#define PCI_DEVICE_ID_VIA_8653_0        0x3101
2249#define PCI_DEVICE_ID_VIA_8622          0x3102
2250#define PCI_DEVICE_ID_VIA_8235_USB_2    0x3104
2251#define PCI_DEVICE_ID_VIA_8233C_0       0x3109
2252#define PCI_DEVICE_ID_VIA_8361          0x3112
2253#define PCI_DEVICE_ID_VIA_XM266         0x3116
2254#define PCI_DEVICE_ID_VIA_612X          0x3119
2255#define PCI_DEVICE_ID_VIA_862X_0        0x3123
2256#define PCI_DEVICE_ID_VIA_8753_0        0x3128
2257#define PCI_DEVICE_ID_VIA_8233A         0x3147
2258#define PCI_DEVICE_ID_VIA_8703_51_0     0x3148
2259#define PCI_DEVICE_ID_VIA_8237_SATA     0x3149
2260#define PCI_DEVICE_ID_VIA_XN266         0x3156
2261#define PCI_DEVICE_ID_VIA_6410          0x3164
2262#define PCI_DEVICE_ID_VIA_8754C_0       0x3168
2263#define PCI_DEVICE_ID_VIA_8235          0x3177
2264#define PCI_DEVICE_ID_VIA_8385_0        0x3188
2265#define PCI_DEVICE_ID_VIA_8377_0        0x3189
2266#define PCI_DEVICE_ID_VIA_8378_0        0x3205
2267#define PCI_DEVICE_ID_VIA_8783_0        0x3208
2268#define PCI_DEVICE_ID_VIA_8237          0x3227
2269#define PCI_DEVICE_ID_VIA_8251          0x3287
2270#define PCI_DEVICE_ID_VIA_8261          0x3402
2271#define PCI_DEVICE_ID_VIA_8237A         0x3337
2272#define PCI_DEVICE_ID_VIA_8237S         0x3372
2273#define PCI_DEVICE_ID_VIA_SATA_EIDE     0x5324
2274#define PCI_DEVICE_ID_VIA_8231          0x8231
2275#define PCI_DEVICE_ID_VIA_8231_4        0x8235
2276#define PCI_DEVICE_ID_VIA_8365_1        0x8305
2277#define PCI_DEVICE_ID_VIA_CX700         0x8324
2278#define PCI_DEVICE_ID_VIA_CX700_IDE     0x0581
2279#define PCI_DEVICE_ID_VIA_VX800         0x8353
2280#define PCI_DEVICE_ID_VIA_VX855         0x8409
2281#define PCI_DEVICE_ID_VIA_VX900         0x8410
2282#define PCI_DEVICE_ID_VIA_8371_1        0x8391
2283#define PCI_DEVICE_ID_VIA_82C598_1      0x8598
2284#define PCI_DEVICE_ID_VIA_838X_1        0xB188
2285#define PCI_DEVICE_ID_VIA_83_87XX_1     0xB198
2286#define PCI_DEVICE_ID_VIA_VX855_IDE     0xC409
2287#define PCI_DEVICE_ID_VIA_ANON          0xFFFF
2288
2289#define PCI_VENDOR_ID_SIEMENS           0x110A
2290#define PCI_DEVICE_ID_SIEMENS_DSCC4     0x2102
2291
2292#define PCI_VENDOR_ID_VORTEX            0x1119
2293#define PCI_DEVICE_ID_VORTEX_GDT60x0    0x0000
2294#define PCI_DEVICE_ID_VORTEX_GDT6000B   0x0001
2295#define PCI_DEVICE_ID_VORTEX_GDT6x10    0x0002
2296#define PCI_DEVICE_ID_VORTEX_GDT6x20    0x0003
2297#define PCI_DEVICE_ID_VORTEX_GDT6530    0x0004
2298#define PCI_DEVICE_ID_VORTEX_GDT6550    0x0005
2299#define PCI_DEVICE_ID_VORTEX_GDT6x17    0x0006
2300#define PCI_DEVICE_ID_VORTEX_GDT6x27    0x0007
2301#define PCI_DEVICE_ID_VORTEX_GDT6537    0x0008
2302#define PCI_DEVICE_ID_VORTEX_GDT6557    0x0009
2303#define PCI_DEVICE_ID_VORTEX_GDT6x15    0x000a
2304#define PCI_DEVICE_ID_VORTEX_GDT6x25    0x000b
2305#define PCI_DEVICE_ID_VORTEX_GDT6535    0x000c
2306#define PCI_DEVICE_ID_VORTEX_GDT6555    0x000d
2307#define PCI_DEVICE_ID_VORTEX_GDT6x17RP  0x0100
2308#define PCI_DEVICE_ID_VORTEX_GDT6x27RP  0x0101
2309#define PCI_DEVICE_ID_VORTEX_GDT6537RP  0x0102
2310#define PCI_DEVICE_ID_VORTEX_GDT6557RP  0x0103
2311#define PCI_DEVICE_ID_VORTEX_GDT6x11RP  0x0104
2312#define PCI_DEVICE_ID_VORTEX_GDT6x21RP  0x0105
2313
2314#define PCI_VENDOR_ID_EF                0x111a
2315#define PCI_DEVICE_ID_EF_ATM_FPGA       0x0000
2316#define PCI_DEVICE_ID_EF_ATM_ASIC       0x0002
2317#define PCI_DEVICE_ID_EF_ATM_LANAI2     0x0003
2318#define PCI_DEVICE_ID_EF_ATM_LANAIHB    0x0005
2319
2320#define PCI_VENDOR_ID_IDT               0x111d
2321#define PCI_DEVICE_ID_IDT_IDT77201      0x0001
2322
2323#define PCI_VENDOR_ID_FORE              0x1127
2324#define PCI_DEVICE_ID_FORE_PCA200E      0x0300
2325
2326#define PCI_VENDOR_ID_PHILIPS           0x1131
2327#define PCI_DEVICE_ID_PHILIPS_SAA7146   0x7146
2328#define PCI_DEVICE_ID_PHILIPS_SAA9730   0x9730
2329
2330#define PCI_VENDOR_ID_EICON             0x1133
2331#define PCI_DEVICE_ID_EICON_DIVA20      0xe002
2332#define PCI_DEVICE_ID_EICON_DIVA20_U    0xe004
2333#define PCI_DEVICE_ID_EICON_DIVA201     0xe005
2334#define PCI_DEVICE_ID_EICON_DIVA202     0xe00b
2335#define PCI_DEVICE_ID_EICON_MAESTRA     0xe010
2336#define PCI_DEVICE_ID_EICON_MAESTRAQ    0xe012
2337#define PCI_DEVICE_ID_EICON_MAESTRAQ_U  0xe013
2338#define PCI_DEVICE_ID_EICON_MAESTRAP    0xe014
2339
2340#define PCI_VENDOR_ID_CISCO             0x1137
2341
2342#define PCI_VENDOR_ID_ZIATECH           0x1138
2343#define PCI_DEVICE_ID_ZIATECH_5550_HC   0x5550
2344
2345#define PCI_VENDOR_ID_SYSKONNECT        0x1148
2346#define PCI_DEVICE_ID_SYSKONNECT_TR     0x4200
2347#define PCI_DEVICE_ID_SYSKONNECT_GE     0x4300
2348#define PCI_DEVICE_ID_SYSKONNECT_YU     0x4320
2349#define PCI_DEVICE_ID_SYSKONNECT_9DXX   0x4400
2350#define PCI_DEVICE_ID_SYSKONNECT_9MXX   0x4500
2351
2352#define PCI_VENDOR_ID_DIGI              0x114f
2353#define PCI_DEVICE_ID_DIGI_DF_M_IOM2_E  0x0070
2354#define PCI_DEVICE_ID_DIGI_DF_M_E       0x0071
2355#define PCI_DEVICE_ID_DIGI_DF_M_IOM2_A  0x0072
2356#define PCI_DEVICE_ID_DIGI_DF_M_A       0x0073
2357#define PCI_DEVICE_ID_DIGI_NEO_8        0x00B1
2358#define PCI_DEVICE_ID_NEO_2DB9          0x00C8
2359#define PCI_DEVICE_ID_NEO_2DB9PRI       0x00C9
2360#define PCI_DEVICE_ID_NEO_2RJ45         0x00CA
2361#define PCI_DEVICE_ID_NEO_2RJ45PRI      0x00CB
2362#define PCIE_DEVICE_ID_NEO_4_IBM        0x00F4
2363
2364#define PCI_VENDOR_ID_XIRCOM            0x115d
2365#define PCI_DEVICE_ID_XIRCOM_RBM56G     0x0101
2366#define PCI_DEVICE_ID_XIRCOM_X3201_MDM  0x0103
2367
2368#define PCI_VENDOR_ID_SERVERWORKS         0x1166
2369#define PCI_DEVICE_ID_SERVERWORKS_HE      0x0008
2370#define PCI_DEVICE_ID_SERVERWORKS_LE      0x0009
2371#define PCI_DEVICE_ID_SERVERWORKS_GCNB_LE 0x0017
2372#define PCI_DEVICE_ID_SERVERWORKS_HT1000_PXB    0x0036
2373#define PCI_DEVICE_ID_SERVERWORKS_EPB     0x0103
2374#define PCI_DEVICE_ID_SERVERWORKS_HT2000_PCIE   0x0132
2375#define PCI_DEVICE_ID_SERVERWORKS_OSB4    0x0200
2376#define PCI_DEVICE_ID_SERVERWORKS_CSB5    0x0201
2377#define PCI_DEVICE_ID_SERVERWORKS_CSB6    0x0203
2378#define PCI_DEVICE_ID_SERVERWORKS_HT1000SB 0x0205
2379#define PCI_DEVICE_ID_SERVERWORKS_OSB4IDE 0x0211
2380#define PCI_DEVICE_ID_SERVERWORKS_CSB5IDE 0x0212
2381#define PCI_DEVICE_ID_SERVERWORKS_CSB6IDE 0x0213
2382#define PCI_DEVICE_ID_SERVERWORKS_HT1000IDE 0x0214
2383#define PCI_DEVICE_ID_SERVERWORKS_CSB6IDE2 0x0217
2384#define PCI_DEVICE_ID_SERVERWORKS_CSB6LPC 0x0227
2385#define PCI_DEVICE_ID_SERVERWORKS_HT1100LD 0x0408
2386
2387#define PCI_VENDOR_ID_SBE               0x1176
2388#define PCI_DEVICE_ID_SBE_WANXL100      0x0301
2389#define PCI_DEVICE_ID_SBE_WANXL200      0x0302
2390#define PCI_DEVICE_ID_SBE_WANXL400      0x0104
2391#define PCI_SUBDEVICE_ID_SBE_T3E3       0x0009
2392#define PCI_SUBDEVICE_ID_SBE_2T3E3_P0   0x0901
2393#define PCI_SUBDEVICE_ID_SBE_2T3E3_P1   0x0902
2394
2395#define PCI_VENDOR_ID_TOSHIBA           0x1179
2396#define PCI_DEVICE_ID_TOSHIBA_PICCOLO_1 0x0101
2397#define PCI_DEVICE_ID_TOSHIBA_PICCOLO_2 0x0102
2398#define PCI_DEVICE_ID_TOSHIBA_PICCOLO_3 0x0103
2399#define PCI_DEVICE_ID_TOSHIBA_PICCOLO_5 0x0105
2400#define PCI_DEVICE_ID_TOSHIBA_TOPIC95   0x060a
2401#define PCI_DEVICE_ID_TOSHIBA_TOPIC97   0x060f
2402#define PCI_DEVICE_ID_TOSHIBA_TOPIC100  0x0617
2403
2404#define PCI_VENDOR_ID_TOSHIBA_2         0x102f
2405#define PCI_DEVICE_ID_TOSHIBA_TC35815CF 0x0030
2406#define PCI_DEVICE_ID_TOSHIBA_TC35815_NWU       0x0031
2407#define PCI_DEVICE_ID_TOSHIBA_TC35815_TX4939    0x0032
2408#define PCI_DEVICE_ID_TOSHIBA_TC86C001_IDE      0x0105
2409#define PCI_DEVICE_ID_TOSHIBA_TC86C001_MISC     0x0108
2410#define PCI_DEVICE_ID_TOSHIBA_SPIDER_NET 0x01b3
2411
2412#define PCI_VENDOR_ID_ATTO              0x117c
2413
2414#define PCI_VENDOR_ID_RICOH             0x1180
2415#define PCI_DEVICE_ID_RICOH_RL5C465     0x0465
2416#define PCI_DEVICE_ID_RICOH_RL5C466     0x0466
2417#define PCI_DEVICE_ID_RICOH_RL5C475     0x0475
2418#define PCI_DEVICE_ID_RICOH_RL5C476     0x0476
2419#define PCI_DEVICE_ID_RICOH_RL5C478     0x0478
2420#define PCI_DEVICE_ID_RICOH_R5C822      0x0822
2421#define PCI_DEVICE_ID_RICOH_R5CE822     0xe822
2422#define PCI_DEVICE_ID_RICOH_R5CE823     0xe823
2423#define PCI_DEVICE_ID_RICOH_R5C832      0x0832
2424#define PCI_DEVICE_ID_RICOH_R5C843      0x0843
2425
2426#define PCI_VENDOR_ID_DLINK             0x1186
2427#define PCI_DEVICE_ID_DLINK_DGE510T     0x4c00
2428
2429#define PCI_VENDOR_ID_ARTOP             0x1191
2430#define PCI_DEVICE_ID_ARTOP_ATP850UF    0x0005
2431#define PCI_DEVICE_ID_ARTOP_ATP860      0x0006
2432#define PCI_DEVICE_ID_ARTOP_ATP860R     0x0007
2433#define PCI_DEVICE_ID_ARTOP_ATP865      0x0008
2434#define PCI_DEVICE_ID_ARTOP_ATP865R     0x0009
2435#define PCI_DEVICE_ID_ARTOP_ATP867A     0x000A
2436#define PCI_DEVICE_ID_ARTOP_ATP867B     0x000B
2437#define PCI_DEVICE_ID_ARTOP_AEC7610     0x8002
2438#define PCI_DEVICE_ID_ARTOP_AEC7612UW   0x8010
2439#define PCI_DEVICE_ID_ARTOP_AEC7612U    0x8020
2440#define PCI_DEVICE_ID_ARTOP_AEC7612S    0x8030
2441#define PCI_DEVICE_ID_ARTOP_AEC7612D    0x8040
2442#define PCI_DEVICE_ID_ARTOP_AEC7612SUW  0x8050
2443#define PCI_DEVICE_ID_ARTOP_8060        0x8060
2444
2445#define PCI_VENDOR_ID_ZEITNET           0x1193
2446#define PCI_DEVICE_ID_ZEITNET_1221      0x0001
2447#define PCI_DEVICE_ID_ZEITNET_1225      0x0002
2448
2449#define PCI_VENDOR_ID_FUJITSU_ME        0x119e
2450#define PCI_DEVICE_ID_FUJITSU_FS155     0x0001
2451#define PCI_DEVICE_ID_FUJITSU_FS50      0x0003
2452
2453#define PCI_SUBVENDOR_ID_KEYSPAN        0x11a9
2454#define PCI_SUBDEVICE_ID_KEYSPAN_SX2    0x5334
2455
2456#define PCI_VENDOR_ID_MARVELL           0x11ab
2457#define PCI_VENDOR_ID_MARVELL_EXT       0x1b4b
2458#define PCI_DEVICE_ID_MARVELL_GT64111   0x4146
2459#define PCI_DEVICE_ID_MARVELL_GT64260   0x6430
2460#define PCI_DEVICE_ID_MARVELL_MV64360   0x6460
2461#define PCI_DEVICE_ID_MARVELL_MV64460   0x6480
2462#define PCI_DEVICE_ID_MARVELL_88ALP01_NAND      0x4100
2463#define PCI_DEVICE_ID_MARVELL_88ALP01_SD        0x4101
2464#define PCI_DEVICE_ID_MARVELL_88ALP01_CCIC      0x4102
2465
2466#define PCI_VENDOR_ID_V3                0x11b0
2467#define PCI_DEVICE_ID_V3_V960           0x0001
2468#define PCI_DEVICE_ID_V3_V351           0x0002
2469
2470#define PCI_VENDOR_ID_ATT               0x11c1
2471#define PCI_DEVICE_ID_ATT_VENUS_MODEM   0x480
2472
2473#define PCI_VENDOR_ID_SPECIALIX         0x11cb
2474#define PCI_DEVICE_ID_SPECIALIX_IO8     0x2000
2475#define PCI_DEVICE_ID_SPECIALIX_RIO     0x8000
2476#define PCI_SUBDEVICE_ID_SPECIALIX_SPEED4 0xa004
2477
2478#define PCI_VENDOR_ID_ANALOG_DEVICES    0x11d4
2479#define PCI_DEVICE_ID_AD1889JS          0x1889
2480
2481#define PCI_DEVICE_ID_SEGA_BBA          0x1234
2482
2483#define PCI_VENDOR_ID_ZORAN             0x11de
2484#define PCI_DEVICE_ID_ZORAN_36057       0x6057
2485#define PCI_DEVICE_ID_ZORAN_36120       0x6120
2486
2487#define PCI_VENDOR_ID_COMPEX            0x11f6
2488#define PCI_DEVICE_ID_COMPEX_ENET100VG4 0x0112
2489
2490#define PCI_VENDOR_ID_PMC_Sierra        0x11f8
2491
2492#define PCI_VENDOR_ID_RP                0x11fe
2493#define PCI_DEVICE_ID_RP32INTF          0x0001
2494#define PCI_DEVICE_ID_RP8INTF           0x0002
2495#define PCI_DEVICE_ID_RP16INTF          0x0003
2496#define PCI_DEVICE_ID_RP4QUAD           0x0004
2497#define PCI_DEVICE_ID_RP8OCTA           0x0005
2498#define PCI_DEVICE_ID_RP8J              0x0006
2499#define PCI_DEVICE_ID_RP4J              0x0007
2500#define PCI_DEVICE_ID_RP8SNI            0x0008
2501#define PCI_DEVICE_ID_RP16SNI           0x0009
2502#define PCI_DEVICE_ID_RPP4              0x000A
2503#define PCI_DEVICE_ID_RPP8              0x000B
2504#define PCI_DEVICE_ID_RP4M              0x000D
2505#define PCI_DEVICE_ID_RP2_232           0x000E
2506#define PCI_DEVICE_ID_RP2_422           0x000F
2507#define PCI_DEVICE_ID_URP32INTF         0x0801
2508#define PCI_DEVICE_ID_URP8INTF          0x0802
2509#define PCI_DEVICE_ID_URP16INTF         0x0803
2510#define PCI_DEVICE_ID_URP8OCTA          0x0805
2511#define PCI_DEVICE_ID_UPCI_RM3_8PORT    0x080C
2512#define PCI_DEVICE_ID_UPCI_RM3_4PORT    0x080D
2513#define PCI_DEVICE_ID_CRP16INTF         0x0903
2514
2515#define PCI_VENDOR_ID_CYCLADES          0x120e
2516#define PCI_DEVICE_ID_CYCLOM_Y_Lo       0x0100
2517#define PCI_DEVICE_ID_CYCLOM_Y_Hi       0x0101
2518#define PCI_DEVICE_ID_CYCLOM_4Y_Lo      0x0102
2519#define PCI_DEVICE_ID_CYCLOM_4Y_Hi      0x0103
2520#define PCI_DEVICE_ID_CYCLOM_8Y_Lo      0x0104
2521#define PCI_DEVICE_ID_CYCLOM_8Y_Hi      0x0105
2522#define PCI_DEVICE_ID_CYCLOM_Z_Lo       0x0200
2523#define PCI_DEVICE_ID_CYCLOM_Z_Hi       0x0201
2524#define PCI_DEVICE_ID_PC300_RX_2        0x0300
2525#define PCI_DEVICE_ID_PC300_RX_1        0x0301
2526#define PCI_DEVICE_ID_PC300_TE_2        0x0310
2527#define PCI_DEVICE_ID_PC300_TE_1        0x0311
2528#define PCI_DEVICE_ID_PC300_TE_M_2      0x0320
2529#define PCI_DEVICE_ID_PC300_TE_M_1      0x0321
2530
2531#define PCI_VENDOR_ID_ESSENTIAL         0x120f
2532#define PCI_DEVICE_ID_ESSENTIAL_ROADRUNNER      0x0001
2533
2534#define PCI_VENDOR_ID_O2                0x1217
2535#define PCI_DEVICE_ID_O2_6729           0x6729
2536#define PCI_DEVICE_ID_O2_6730           0x673a
2537#define PCI_DEVICE_ID_O2_6832           0x6832
2538#define PCI_DEVICE_ID_O2_6836           0x6836
2539#define PCI_DEVICE_ID_O2_6812           0x6872
2540#define PCI_DEVICE_ID_O2_6933           0x6933
2541#define PCI_DEVICE_ID_O2_8120           0x8120
2542#define PCI_DEVICE_ID_O2_8220           0x8220
2543#define PCI_DEVICE_ID_O2_8221           0x8221
2544#define PCI_DEVICE_ID_O2_8320           0x8320
2545#define PCI_DEVICE_ID_O2_8321           0x8321
2546
2547#define PCI_VENDOR_ID_3DFX              0x121a
2548#define PCI_DEVICE_ID_3DFX_VOODOO       0x0001
2549#define PCI_DEVICE_ID_3DFX_VOODOO2      0x0002
2550#define PCI_DEVICE_ID_3DFX_BANSHEE      0x0003
2551#define PCI_DEVICE_ID_3DFX_VOODOO3      0x0005
2552#define PCI_DEVICE_ID_3DFX_VOODOO5      0x0009
2553
2554#define PCI_VENDOR_ID_AVM               0x1244
2555#define PCI_DEVICE_ID_AVM_B1            0x0700
2556#define PCI_DEVICE_ID_AVM_C4            0x0800
2557#define PCI_DEVICE_ID_AVM_A1            0x0a00
2558#define PCI_DEVICE_ID_AVM_A1_V2         0x0e00
2559#define PCI_DEVICE_ID_AVM_C2            0x1100
2560#define PCI_DEVICE_ID_AVM_T1            0x1200
2561
2562#define PCI_VENDOR_ID_STALLION          0x124d
2563
2564/* Allied Telesyn */
2565#define PCI_VENDOR_ID_AT                0x1259
2566#define PCI_SUBDEVICE_ID_AT_2700FX      0x2701
2567#define PCI_SUBDEVICE_ID_AT_2701FX      0x2703
2568
2569#define PCI_VENDOR_ID_ESS               0x125d
2570#define PCI_DEVICE_ID_ESS_ESS1968       0x1968
2571#define PCI_DEVICE_ID_ESS_ESS1978       0x1978
2572#define PCI_DEVICE_ID_ESS_ALLEGRO_1     0x1988
2573#define PCI_DEVICE_ID_ESS_ALLEGRO       0x1989
2574#define PCI_DEVICE_ID_ESS_CANYON3D_2LE  0x1990
2575#define PCI_DEVICE_ID_ESS_CANYON3D_2    0x1992
2576#define PCI_DEVICE_ID_ESS_MAESTRO3      0x1998
2577#define PCI_DEVICE_ID_ESS_MAESTRO3_1    0x1999
2578#define PCI_DEVICE_ID_ESS_MAESTRO3_HW   0x199a
2579#define PCI_DEVICE_ID_ESS_MAESTRO3_2    0x199b
2580
2581#define PCI_VENDOR_ID_SATSAGEM          0x1267
2582#define PCI_DEVICE_ID_SATSAGEM_NICCY    0x1016
2583
2584#define PCI_VENDOR_ID_ENSONIQ           0x1274
2585#define PCI_DEVICE_ID_ENSONIQ_CT5880    0x5880
2586#define PCI_DEVICE_ID_ENSONIQ_ES1370    0x5000
2587#define PCI_DEVICE_ID_ENSONIQ_ES1371    0x1371
2588
2589#define PCI_VENDOR_ID_TRANSMETA         0x1279
2590#define PCI_DEVICE_ID_EFFICEON          0x0060
2591
2592#define PCI_VENDOR_ID_ROCKWELL          0x127A
2593
2594#define PCI_VENDOR_ID_ITE               0x1283
2595#define PCI_DEVICE_ID_ITE_8172          0x8172
2596#define PCI_DEVICE_ID_ITE_8211          0x8211
2597#define PCI_DEVICE_ID_ITE_8212          0x8212
2598#define PCI_DEVICE_ID_ITE_8213          0x8213
2599#define PCI_DEVICE_ID_ITE_8152          0x8152
2600#define PCI_DEVICE_ID_ITE_8872          0x8872
2601#define PCI_DEVICE_ID_ITE_IT8330G_0     0xe886
2602
2603/* formerly Platform Tech */
2604#define PCI_DEVICE_ID_ESS_ESS0100       0x0100
2605
2606#define PCI_VENDOR_ID_ALTEON            0x12ae
2607
2608#define PCI_SUBVENDOR_ID_CONNECT_TECH                   0x12c4
2609#define PCI_SUBDEVICE_ID_CONNECT_TECH_BH8_232           0x0001
2610#define PCI_SUBDEVICE_ID_CONNECT_TECH_BH4_232           0x0002
2611#define PCI_SUBDEVICE_ID_CONNECT_TECH_BH2_232           0x0003
2612#define PCI_SUBDEVICE_ID_CONNECT_TECH_BH8_485           0x0004
2613#define PCI_SUBDEVICE_ID_CONNECT_TECH_BH8_485_4_4       0x0005
2614#define PCI_SUBDEVICE_ID_CONNECT_TECH_BH4_485           0x0006
2615#define PCI_SUBDEVICE_ID_CONNECT_TECH_BH4_485_2_2       0x0007
2616#define PCI_SUBDEVICE_ID_CONNECT_TECH_BH2_485           0x0008
2617#define PCI_SUBDEVICE_ID_CONNECT_TECH_BH8_485_2_6       0x0009
2618#define PCI_SUBDEVICE_ID_CONNECT_TECH_BH081101V1        0x000A
2619#define PCI_SUBDEVICE_ID_CONNECT_TECH_BH041101V1        0x000B
2620#define PCI_SUBDEVICE_ID_CONNECT_TECH_BH2_20MHZ         0x000C
2621#define PCI_SUBDEVICE_ID_CONNECT_TECH_BH2_PTM           0x000D
2622#define PCI_SUBDEVICE_ID_CONNECT_TECH_NT960PCI          0x0100
2623#define PCI_SUBDEVICE_ID_CONNECT_TECH_TITAN_2           0x0201
2624#define PCI_SUBDEVICE_ID_CONNECT_TECH_TITAN_4           0x0202
2625#define PCI_SUBDEVICE_ID_CONNECT_TECH_PCI_UART_2_232    0x0300
2626#define PCI_SUBDEVICE_ID_CONNECT_TECH_PCI_UART_4_232    0x0301
2627#define PCI_SUBDEVICE_ID_CONNECT_TECH_PCI_UART_8_232    0x0302
2628#define PCI_SUBDEVICE_ID_CONNECT_TECH_PCI_UART_1_1      0x0310
2629#define PCI_SUBDEVICE_ID_CONNECT_TECH_PCI_UART_2_2      0x0311
2630#define PCI_SUBDEVICE_ID_CONNECT_TECH_PCI_UART_4_4      0x0312
2631#define PCI_SUBDEVICE_ID_CONNECT_TECH_PCI_UART_2        0x0320
2632#define PCI_SUBDEVICE_ID_CONNECT_TECH_PCI_UART_4        0x0321
2633#define PCI_SUBDEVICE_ID_CONNECT_TECH_PCI_UART_8        0x0322
2634#define PCI_SUBDEVICE_ID_CONNECT_TECH_PCI_UART_2_485    0x0330
2635#define PCI_SUBDEVICE_ID_CONNECT_TECH_PCI_UART_4_485    0x0331
2636#define PCI_SUBDEVICE_ID_CONNECT_TECH_PCI_UART_8_485    0x0332
2637
2638#define PCI_VENDOR_ID_NVIDIA_SGS        0x12d2
2639#define PCI_DEVICE_ID_NVIDIA_SGS_RIVA128 0x0018
2640
2641#define PCI_SUBVENDOR_ID_CHASE_PCIFAST          0x12E0
2642#define PCI_SUBDEVICE_ID_CHASE_PCIFAST4         0x0031
2643#define PCI_SUBDEVICE_ID_CHASE_PCIFAST8         0x0021
2644#define PCI_SUBDEVICE_ID_CHASE_PCIFAST16        0x0011
2645#define PCI_SUBDEVICE_ID_CHASE_PCIFAST16FMC     0x0041
2646#define PCI_SUBVENDOR_ID_CHASE_PCIRAS           0x124D
2647#define PCI_SUBDEVICE_ID_CHASE_PCIRAS4          0xF001
2648#define PCI_SUBDEVICE_ID_CHASE_PCIRAS8          0xF010
2649
2650#define PCI_VENDOR_ID_AUREAL            0x12eb
2651#define PCI_DEVICE_ID_AUREAL_VORTEX_1   0x0001
2652#define PCI_DEVICE_ID_AUREAL_VORTEX_2   0x0002
2653#define PCI_DEVICE_ID_AUREAL_ADVANTAGE  0x0003
2654
2655#define PCI_VENDOR_ID_ELECTRONICDESIGNGMBH 0x12f8
2656#define PCI_DEVICE_ID_LML_33R10         0x8a02
2657
2658#define PCI_VENDOR_ID_ESDGMBH           0x12fe
2659#define PCI_DEVICE_ID_ESDGMBH_CPCIASIO4 0x0111
2660
2661#define PCI_VENDOR_ID_CB                0x1307  /* Measurement Computing */
2662
2663#define PCI_VENDOR_ID_SIIG              0x131f
2664#define PCI_SUBVENDOR_ID_SIIG           0x131f
2665#define PCI_DEVICE_ID_SIIG_1S_10x_550   0x1000
2666#define PCI_DEVICE_ID_SIIG_1S_10x_650   0x1001
2667#define PCI_DEVICE_ID_SIIG_1S_10x_850   0x1002
2668#define PCI_DEVICE_ID_SIIG_1S1P_10x_550 0x1010
2669#define PCI_DEVICE_ID_SIIG_1S1P_10x_650 0x1011
2670#define PCI_DEVICE_ID_SIIG_1S1P_10x_850 0x1012
2671#define PCI_DEVICE_ID_SIIG_1P_10x       0x1020
2672#define PCI_DEVICE_ID_SIIG_2P_10x       0x1021
2673#define PCI_DEVICE_ID_SIIG_2S_10x_550   0x1030
2674#define PCI_DEVICE_ID_SIIG_2S_10x_650   0x1031
2675#define PCI_DEVICE_ID_SIIG_2S_10x_850   0x1032
2676#define PCI_DEVICE_ID_SIIG_2S1P_10x_550 0x1034
2677#define PCI_DEVICE_ID_SIIG_2S1P_10x_650 0x1035
2678#define PCI_DEVICE_ID_SIIG_2S1P_10x_850 0x1036
2679#define PCI_DEVICE_ID_SIIG_4S_10x_550   0x1050
2680#define PCI_DEVICE_ID_SIIG_4S_10x_650   0x1051
2681#define PCI_DEVICE_ID_SIIG_4S_10x_850   0x1052
2682#define PCI_DEVICE_ID_SIIG_1S_20x_550   0x2000
2683#define PCI_DEVICE_ID_SIIG_1S_20x_650   0x2001
2684#define PCI_DEVICE_ID_SIIG_1S_20x_850   0x2002
2685#define PCI_DEVICE_ID_SIIG_1P_20x       0x2020
2686#define PCI_DEVICE_ID_SIIG_2P_20x       0x2021
2687#define PCI_DEVICE_ID_SIIG_2S_20x_550   0x2030
2688#define PCI_DEVICE_ID_SIIG_2S_20x_650   0x2031
2689#define PCI_DEVICE_ID_SIIG_2S_20x_850   0x2032
2690#define PCI_DEVICE_ID_SIIG_2P1S_20x_550 0x2040
2691#define PCI_DEVICE_ID_SIIG_2P1S_20x_650 0x2041
2692#define PCI_DEVICE_ID_SIIG_2P1S_20x_850 0x2042
2693#define PCI_DEVICE_ID_SIIG_1S1P_20x_550 0x2010
2694#define PCI_DEVICE_ID_SIIG_1S1P_20x_650 0x2011
2695#define PCI_DEVICE_ID_SIIG_1S1P_20x_850 0x2012
2696#define PCI_DEVICE_ID_SIIG_4S_20x_550   0x2050
2697#define PCI_DEVICE_ID_SIIG_4S_20x_650   0x2051
2698#define PCI_DEVICE_ID_SIIG_4S_20x_850   0x2052
2699#define PCI_DEVICE_ID_SIIG_2S1P_20x_550 0x2060
2700#define PCI_DEVICE_ID_SIIG_2S1P_20x_650 0x2061
2701#define PCI_DEVICE_ID_SIIG_2S1P_20x_850 0x2062
2702#define PCI_DEVICE_ID_SIIG_8S_20x_550   0x2080
2703#define PCI_DEVICE_ID_SIIG_8S_20x_650   0x2081
2704#define PCI_DEVICE_ID_SIIG_8S_20x_850   0x2082
2705#define PCI_SUBDEVICE_ID_SIIG_QUARTET_SERIAL    0x2050
2706
2707#define PCI_VENDOR_ID_RADISYS           0x1331
2708
2709#define PCI_VENDOR_ID_MICRO_MEMORY              0x1332
2710#define PCI_DEVICE_ID_MICRO_MEMORY_5415CN       0x5415
2711#define PCI_DEVICE_ID_MICRO_MEMORY_5425CN       0x5425
2712#define PCI_DEVICE_ID_MICRO_MEMORY_6155         0x6155
2713
2714#define PCI_VENDOR_ID_DOMEX             0x134a
2715#define PCI_DEVICE_ID_DOMEX_DMX3191D    0x0001
2716
2717#define PCI_VENDOR_ID_INTASHIELD        0x135a
2718#define PCI_DEVICE_ID_INTASHIELD_IS200  0x0d80
2719#define PCI_DEVICE_ID_INTASHIELD_IS400  0x0dc0
2720
2721#define PCI_VENDOR_ID_QUATECH           0x135C
2722#define PCI_DEVICE_ID_QUATECH_QSC100    0x0010
2723#define PCI_DEVICE_ID_QUATECH_DSC100    0x0020
2724#define PCI_DEVICE_ID_QUATECH_DSC200    0x0030
2725#define PCI_DEVICE_ID_QUATECH_QSC200    0x0040
2726#define PCI_DEVICE_ID_QUATECH_ESC100D   0x0050
2727#define PCI_DEVICE_ID_QUATECH_ESC100M   0x0060
2728#define PCI_DEVICE_ID_QUATECH_QSCP100   0x0120
2729#define PCI_DEVICE_ID_QUATECH_DSCP100   0x0130
2730#define PCI_DEVICE_ID_QUATECH_QSCP200   0x0140
2731#define PCI_DEVICE_ID_QUATECH_DSCP200   0x0150
2732#define PCI_DEVICE_ID_QUATECH_QSCLP100  0x0170
2733#define PCI_DEVICE_ID_QUATECH_DSCLP100  0x0180
2734#define PCI_DEVICE_ID_QUATECH_DSC100E   0x0181
2735#define PCI_DEVICE_ID_QUATECH_SSCLP100  0x0190
2736#define PCI_DEVICE_ID_QUATECH_QSCLP200  0x01A0
2737#define PCI_DEVICE_ID_QUATECH_DSCLP200  0x01B0
2738#define PCI_DEVICE_ID_QUATECH_DSC200E   0x01B1
2739#define PCI_DEVICE_ID_QUATECH_SSCLP200  0x01C0
2740#define PCI_DEVICE_ID_QUATECH_ESCLP100  0x01E0
2741#define PCI_DEVICE_ID_QUATECH_SPPXP_100 0x0278
2742
2743#define PCI_VENDOR_ID_SEALEVEL          0x135e
2744#define PCI_DEVICE_ID_SEALEVEL_U530     0x7101
2745#define PCI_DEVICE_ID_SEALEVEL_UCOMM2   0x7201
2746#define PCI_DEVICE_ID_SEALEVEL_UCOMM422 0x7402
2747#define PCI_DEVICE_ID_SEALEVEL_UCOMM232 0x7202
2748#define PCI_DEVICE_ID_SEALEVEL_COMM4    0x7401
2749#define PCI_DEVICE_ID_SEALEVEL_COMM8    0x7801
2750#define PCI_DEVICE_ID_SEALEVEL_7803     0x7803
2751#define PCI_DEVICE_ID_SEALEVEL_UCOMM8   0x7804
2752
2753#define PCI_VENDOR_ID_HYPERCOPE         0x1365
2754#define PCI_DEVICE_ID_HYPERCOPE_PLX     0x9050
2755#define PCI_SUBDEVICE_ID_HYPERCOPE_OLD_ERGO     0x0104
2756#define PCI_SUBDEVICE_ID_HYPERCOPE_ERGO         0x0106
2757#define PCI_SUBDEVICE_ID_HYPERCOPE_METRO        0x0107
2758#define PCI_SUBDEVICE_ID_HYPERCOPE_CHAMP2       0x0108
2759
2760#define PCI_VENDOR_ID_DIGIGRAM          0x1369
2761#define PCI_SUBDEVICE_ID_DIGIGRAM_LX6464ES_SERIAL_SUBSYSTEM     0xc001
2762#define PCI_SUBDEVICE_ID_DIGIGRAM_LX6464ES_CAE_SERIAL_SUBSYSTEM 0xc002
2763
2764#define PCI_VENDOR_ID_KAWASAKI          0x136b
2765#define PCI_DEVICE_ID_MCHIP_KL5A72002   0xff01
2766
2767#define PCI_VENDOR_ID_CNET              0x1371
2768#define PCI_DEVICE_ID_CNET_GIGACARD     0x434e
2769
2770#define PCI_VENDOR_ID_LMC               0x1376
2771#define PCI_DEVICE_ID_LMC_HSSI          0x0003
2772#define PCI_DEVICE_ID_LMC_DS3           0x0004
2773#define PCI_DEVICE_ID_LMC_SSI           0x0005
2774#define PCI_DEVICE_ID_LMC_T1            0x0006
2775
2776#define PCI_VENDOR_ID_NETGEAR           0x1385
2777#define PCI_DEVICE_ID_NETGEAR_GA620     0x620a
2778
2779#define PCI_VENDOR_ID_APPLICOM          0x1389
2780#define PCI_DEVICE_ID_APPLICOM_PCIGENERIC 0x0001
2781#define PCI_DEVICE_ID_APPLICOM_PCI2000IBS_CAN 0x0002
2782#define PCI_DEVICE_ID_APPLICOM_PCI2000PFB 0x0003
2783
2784#define PCI_VENDOR_ID_MOXA              0x1393
2785#define PCI_DEVICE_ID_MOXA_RC7000       0x0001
2786#define PCI_DEVICE_ID_MOXA_CP102        0x1020
2787#define PCI_DEVICE_ID_MOXA_CP102UL      0x1021
2788#define PCI_DEVICE_ID_MOXA_CP102U       0x1022
2789#define PCI_DEVICE_ID_MOXA_C104         0x1040
2790#define PCI_DEVICE_ID_MOXA_CP104U       0x1041
2791#define PCI_DEVICE_ID_MOXA_CP104JU      0x1042
2792#define PCI_DEVICE_ID_MOXA_CP104EL      0x1043
2793#define PCI_DEVICE_ID_MOXA_CT114        0x1140
2794#define PCI_DEVICE_ID_MOXA_CP114        0x1141
2795#define PCI_DEVICE_ID_MOXA_CP118U       0x1180
2796#define PCI_DEVICE_ID_MOXA_CP118EL      0x1181
2797#define PCI_DEVICE_ID_MOXA_CP132        0x1320
2798#define PCI_DEVICE_ID_MOXA_CP132U       0x1321
2799#define PCI_DEVICE_ID_MOXA_CP134U       0x1340
2800#define PCI_DEVICE_ID_MOXA_C168         0x1680
2801#define PCI_DEVICE_ID_MOXA_CP168U       0x1681
2802#define PCI_DEVICE_ID_MOXA_CP168EL      0x1682
2803#define PCI_DEVICE_ID_MOXA_CP204J       0x2040
2804#define PCI_DEVICE_ID_MOXA_C218         0x2180
2805#define PCI_DEVICE_ID_MOXA_C320         0x3200
2806
2807#define PCI_VENDOR_ID_CCD               0x1397
2808#define PCI_DEVICE_ID_CCD_HFC4S         0x08B4
2809#define PCI_SUBDEVICE_ID_CCD_PMX2S      0x1234
2810#define PCI_DEVICE_ID_CCD_HFC8S         0x16B8
2811#define PCI_DEVICE_ID_CCD_2BD0          0x2bd0
2812#define PCI_DEVICE_ID_CCD_HFCE1         0x30B1
2813#define PCI_SUBDEVICE_ID_CCD_SPD4S      0x3136
2814#define PCI_SUBDEVICE_ID_CCD_SPDE1      0x3137
2815#define PCI_DEVICE_ID_CCD_B000          0xb000
2816#define PCI_DEVICE_ID_CCD_B006          0xb006
2817#define PCI_DEVICE_ID_CCD_B007          0xb007
2818#define PCI_DEVICE_ID_CCD_B008          0xb008
2819#define PCI_DEVICE_ID_CCD_B009          0xb009
2820#define PCI_DEVICE_ID_CCD_B00A          0xb00a
2821#define PCI_DEVICE_ID_CCD_B00B          0xb00b
2822#define PCI_DEVICE_ID_CCD_B00C          0xb00c
2823#define PCI_DEVICE_ID_CCD_B100          0xb100
2824#define PCI_SUBDEVICE_ID_CCD_IOB4ST     0xB520
2825#define PCI_SUBDEVICE_ID_CCD_IOB8STR    0xB521
2826#define PCI_SUBDEVICE_ID_CCD_IOB8ST     0xB522
2827#define PCI_SUBDEVICE_ID_CCD_IOB1E1     0xB523
2828#define PCI_SUBDEVICE_ID_CCD_SWYX4S     0xB540
2829#define PCI_SUBDEVICE_ID_CCD_JH4S20     0xB550
2830#define PCI_SUBDEVICE_ID_CCD_IOB8ST_1   0xB552
2831#define PCI_SUBDEVICE_ID_CCD_JHSE1      0xB553
2832#define PCI_SUBDEVICE_ID_CCD_JH8S       0xB55B
2833#define PCI_SUBDEVICE_ID_CCD_BN4S       0xB560
2834#define PCI_SUBDEVICE_ID_CCD_BN8S       0xB562
2835#define PCI_SUBDEVICE_ID_CCD_BNE1       0xB563
2836#define PCI_SUBDEVICE_ID_CCD_BNE1D      0xB564
2837#define PCI_SUBDEVICE_ID_CCD_BNE1DP     0xB565
2838#define PCI_SUBDEVICE_ID_CCD_BN2S       0xB566
2839#define PCI_SUBDEVICE_ID_CCD_BN1SM      0xB567
2840#define PCI_SUBDEVICE_ID_CCD_BN4SM      0xB568
2841#define PCI_SUBDEVICE_ID_CCD_BN2SM      0xB569
2842#define PCI_SUBDEVICE_ID_CCD_BNE1M      0xB56A
2843#define PCI_SUBDEVICE_ID_CCD_BN8SP      0xB56B
2844#define PCI_SUBDEVICE_ID_CCD_HFC4S      0xB620
2845#define PCI_SUBDEVICE_ID_CCD_HFC8S      0xB622
2846#define PCI_DEVICE_ID_CCD_B700          0xb700
2847#define PCI_DEVICE_ID_CCD_B701          0xb701
2848#define PCI_SUBDEVICE_ID_CCD_HFCE1      0xC523
2849#define PCI_SUBDEVICE_ID_CCD_OV2S       0xE884
2850#define PCI_SUBDEVICE_ID_CCD_OV4S       0xE888
2851#define PCI_SUBDEVICE_ID_CCD_OV8S       0xE998
2852
2853#define PCI_VENDOR_ID_EXAR              0x13a8
2854#define PCI_DEVICE_ID_EXAR_XR17C152     0x0152
2855#define PCI_DEVICE_ID_EXAR_XR17C154     0x0154
2856#define PCI_DEVICE_ID_EXAR_XR17C158     0x0158
2857#define PCI_DEVICE_ID_EXAR_XR17V352     0x0352
2858#define PCI_DEVICE_ID_EXAR_XR17V354     0x0354
2859#define PCI_DEVICE_ID_EXAR_XR17V358     0x0358
2860
2861#define PCI_VENDOR_ID_MICROGATE         0x13c0
2862#define PCI_DEVICE_ID_MICROGATE_USC     0x0010
2863#define PCI_DEVICE_ID_MICROGATE_SCA     0x0030
2864
2865#define PCI_VENDOR_ID_3WARE             0x13C1
2866#define PCI_DEVICE_ID_3WARE_1000        0x1000
2867#define PCI_DEVICE_ID_3WARE_7000        0x1001
2868#define PCI_DEVICE_ID_3WARE_9000        0x1002
2869
2870#define PCI_VENDOR_ID_IOMEGA            0x13ca
2871#define PCI_DEVICE_ID_IOMEGA_BUZ        0x4231
2872
2873#define PCI_VENDOR_ID_ABOCOM            0x13D1
2874#define PCI_DEVICE_ID_ABOCOM_2BD1       0x2BD1
2875
2876#define PCI_VENDOR_ID_SUNDANCE          0x13f0
2877
2878#define PCI_VENDOR_ID_CMEDIA            0x13f6
2879#define PCI_DEVICE_ID_CMEDIA_CM8338A    0x0100
2880#define PCI_DEVICE_ID_CMEDIA_CM8338B    0x0101
2881#define PCI_DEVICE_ID_CMEDIA_CM8738     0x0111
2882#define PCI_DEVICE_ID_CMEDIA_CM8738B    0x0112
2883
2884#define PCI_VENDOR_ID_ADVANTECH         0x13fe
2885
2886#define PCI_VENDOR_ID_MEILHAUS          0x1402
2887
2888#define PCI_VENDOR_ID_LAVA              0x1407
2889#define PCI_DEVICE_ID_LAVA_DSERIAL      0x0100 /* 2x 16550 */
2890#define PCI_DEVICE_ID_LAVA_QUATRO_A     0x0101 /* 2x 16550, half of 4 port */
2891#define PCI_DEVICE_ID_LAVA_QUATRO_B     0x0102 /* 2x 16550, half of 4 port */
2892#define PCI_DEVICE_ID_LAVA_QUATTRO_A    0x0120 /* 2x 16550A, half of 4 port */
2893#define PCI_DEVICE_ID_LAVA_QUATTRO_B    0x0121 /* 2x 16550A, half of 4 port */
2894#define PCI_DEVICE_ID_LAVA_OCTO_A       0x0180 /* 4x 16550A, half of 8 port */
2895#define PCI_DEVICE_ID_LAVA_OCTO_B       0x0181 /* 4x 16550A, half of 8 port */
2896#define PCI_DEVICE_ID_LAVA_PORT_PLUS    0x0200 /* 2x 16650 */
2897#define PCI_DEVICE_ID_LAVA_QUAD_A       0x0201 /* 2x 16650, half of 4 port */
2898#define PCI_DEVICE_ID_LAVA_QUAD_B       0x0202 /* 2x 16650, half of 4 port */
2899#define PCI_DEVICE_ID_LAVA_SSERIAL      0x0500 /* 1x 16550 */
2900#define PCI_DEVICE_ID_LAVA_PORT_650     0x0600 /* 1x 16650 */
2901#define PCI_DEVICE_ID_LAVA_PARALLEL     0x8000
2902#define PCI_DEVICE_ID_LAVA_DUAL_PAR_A   0x8002 /* The Lava Dual Parallel is */
2903#define PCI_DEVICE_ID_LAVA_DUAL_PAR_B   0x8003 /* two PCI devices on a card */
2904#define PCI_DEVICE_ID_LAVA_BOCA_IOPPAR  0x8800
2905
2906#define PCI_VENDOR_ID_TIMEDIA           0x1409
2907#define PCI_DEVICE_ID_TIMEDIA_1889      0x7168
2908
2909#define PCI_VENDOR_ID_ICE               0x1412
2910#define PCI_DEVICE_ID_ICE_1712          0x1712
2911#define PCI_DEVICE_ID_VT1724            0x1724
2912
2913#define PCI_VENDOR_ID_OXSEMI            0x1415
2914#define PCI_DEVICE_ID_OXSEMI_12PCI840   0x8403
2915#define PCI_DEVICE_ID_OXSEMI_PCIe840            0xC000
2916#define PCI_DEVICE_ID_OXSEMI_PCIe840_G          0xC004
2917#define PCI_DEVICE_ID_OXSEMI_PCIe952_0          0xC100
2918#define PCI_DEVICE_ID_OXSEMI_PCIe952_0_G        0xC104
2919#define PCI_DEVICE_ID_OXSEMI_PCIe952_1          0xC110
2920#define PCI_DEVICE_ID_OXSEMI_PCIe952_1_G        0xC114
2921#define PCI_DEVICE_ID_OXSEMI_PCIe952_1_U        0xC118
2922#define PCI_DEVICE_ID_OXSEMI_PCIe952_1_GU       0xC11C
2923#define PCI_DEVICE_ID_OXSEMI_16PCI954   0x9501
2924#define PCI_DEVICE_ID_OXSEMI_C950       0x950B
2925#define PCI_DEVICE_ID_OXSEMI_16PCI95N   0x9511
2926#define PCI_DEVICE_ID_OXSEMI_16PCI954PP 0x9513
2927#define PCI_DEVICE_ID_OXSEMI_16PCI952   0x9521
2928#define PCI_DEVICE_ID_OXSEMI_16PCI952PP 0x9523
2929#define PCI_SUBDEVICE_ID_OXSEMI_C950    0x0001
2930
2931#define PCI_VENDOR_ID_CHELSIO           0x1425
2932
2933#define PCI_VENDOR_ID_ADLINK            0x144a
2934
2935#define PCI_VENDOR_ID_SAMSUNG           0x144d
2936
2937#define PCI_VENDOR_ID_GIGABYTE          0x1458
2938
2939#define PCI_VENDOR_ID_AMBIT             0x1468
2940
2941#define PCI_VENDOR_ID_MYRICOM           0x14c1
2942
2943#define PCI_VENDOR_ID_TITAN             0x14D2
2944#define PCI_DEVICE_ID_TITAN_010L        0x8001
2945#define PCI_DEVICE_ID_TITAN_100L        0x8010
2946#define PCI_DEVICE_ID_TITAN_110L        0x8011
2947#define PCI_DEVICE_ID_TITAN_200L        0x8020
2948#define PCI_DEVICE_ID_TITAN_210L        0x8021
2949#define PCI_DEVICE_ID_TITAN_400L        0x8040
2950#define PCI_DEVICE_ID_TITAN_800L        0x8080
2951#define PCI_DEVICE_ID_TITAN_100         0xA001
2952#define PCI_DEVICE_ID_TITAN_200         0xA005
2953#define PCI_DEVICE_ID_TITAN_400         0xA003
2954#define PCI_DEVICE_ID_TITAN_800B        0xA004
2955
2956#define PCI_VENDOR_ID_PANACOM           0x14d4
2957#define PCI_DEVICE_ID_PANACOM_QUADMODEM 0x0400
2958#define PCI_DEVICE_ID_PANACOM_DUALMODEM 0x0402
2959
2960#define PCI_VENDOR_ID_SIPACKETS         0x14d9
2961#define PCI_DEVICE_ID_SP1011            0x0010
2962
2963#define PCI_VENDOR_ID_AFAVLAB           0x14db
2964#define PCI_DEVICE_ID_AFAVLAB_P028      0x2180
2965#define PCI_DEVICE_ID_AFAVLAB_P030      0x2182
2966#define PCI_SUBDEVICE_ID_AFAVLAB_P061           0x2150
2967
2968#define PCI_VENDOR_ID_AMPLICON          0x14dc
2969
2970#define PCI_VENDOR_ID_BCM_GVC          0x14a4
2971#define PCI_VENDOR_ID_BROADCOM          0x14e4
2972#define PCI_DEVICE_ID_TIGON3_5752       0x1600
2973#define PCI_DEVICE_ID_TIGON3_5752M      0x1601
2974#define PCI_DEVICE_ID_NX2_5709          0x1639
2975#define PCI_DEVICE_ID_NX2_5709S         0x163a
2976#define PCI_DEVICE_ID_TIGON3_5700       0x1644
2977#define PCI_DEVICE_ID_TIGON3_5701       0x1645
2978#define PCI_DEVICE_ID_TIGON3_5702       0x1646
2979#define PCI_DEVICE_ID_TIGON3_5703       0x1647
2980#define PCI_DEVICE_ID_TIGON3_5704       0x1648
2981#define PCI_DEVICE_ID_TIGON3_5704S_2    0x1649
2982#define PCI_DEVICE_ID_NX2_5706          0x164a
2983#define PCI_DEVICE_ID_NX2_5708          0x164c
2984#define PCI_DEVICE_ID_TIGON3_5702FE     0x164d
2985#define PCI_DEVICE_ID_NX2_57710         0x164e
2986#define PCI_DEVICE_ID_NX2_57711         0x164f
2987#define PCI_DEVICE_ID_NX2_57711E        0x1650
2988#define PCI_DEVICE_ID_TIGON3_5705       0x1653
2989#define PCI_DEVICE_ID_TIGON3_5705_2     0x1654
2990#define PCI_DEVICE_ID_TIGON3_5719       0x1657
2991#define PCI_DEVICE_ID_TIGON3_5721       0x1659
2992#define PCI_DEVICE_ID_TIGON3_5722       0x165a
2993#define PCI_DEVICE_ID_TIGON3_5723       0x165b
2994#define PCI_DEVICE_ID_TIGON3_5705M      0x165d
2995#define PCI_DEVICE_ID_TIGON3_5705M_2    0x165e
2996#define PCI_DEVICE_ID_NX2_57712         0x1662
2997#define PCI_DEVICE_ID_NX2_57712E        0x1663
2998#define PCI_DEVICE_ID_NX2_57712_MF      0x1663
2999#define PCI_DEVICE_ID_TIGON3_5714       0x1668
3000#define PCI_DEVICE_ID_TIGON3_5714S      0x1669
3001#define PCI_DEVICE_ID_TIGON3_5780       0x166a
3002#define PCI_DEVICE_ID_TIGON3_5780S      0x166b
3003#define PCI_DEVICE_ID_TIGON3_5705F      0x166e
3004#define PCI_DEVICE_ID_NX2_57712_VF      0x166f
3005#define PCI_DEVICE_ID_TIGON3_5754M      0x1672
3006#define PCI_DEVICE_ID_TIGON3_5755M      0x1673
3007#define PCI_DEVICE_ID_TIGON3_5756       0x1674
3008#define PCI_DEVICE_ID_TIGON3_5750       0x1676
3009#define PCI_DEVICE_ID_TIGON3_5751       0x1677
3010#define PCI_DEVICE_ID_TIGON3_5715       0x1678
3011#define PCI_DEVICE_ID_TIGON3_5715S      0x1679
3012#define PCI_DEVICE_ID_TIGON3_5754       0x167a
3013#define PCI_DEVICE_ID_TIGON3_5755       0x167b
3014#define PCI_DEVICE_ID_TIGON3_5751M      0x167d
3015#define PCI_DEVICE_ID_TIGON3_5751F      0x167e
3016#define PCI_DEVICE_ID_TIGON3_5787F      0x167f
3017#define PCI_DEVICE_ID_TIGON3_5761E      0x1680
3018#define PCI_DEVICE_ID_TIGON3_5761       0x1681
3019#define PCI_DEVICE_ID_TIGON3_5764       0x1684
3020#define PCI_DEVICE_ID_NX2_57800         0x168a
3021#define PCI_DEVICE_ID_NX2_57840         0x168d
3022#define PCI_DEVICE_ID_NX2_57810         0x168e
3023#define PCI_DEVICE_ID_TIGON3_5787M      0x1693
3024#define PCI_DEVICE_ID_TIGON3_5782       0x1696
3025#define PCI_DEVICE_ID_TIGON3_5784       0x1698
3026#define PCI_DEVICE_ID_TIGON3_5786       0x169a
3027#define PCI_DEVICE_ID_TIGON3_5787       0x169b
3028#define PCI_DEVICE_ID_TIGON3_5788       0x169c
3029#define PCI_DEVICE_ID_TIGON3_5789       0x169d
3030#define PCI_DEVICE_ID_NX2_57840_4_10    0x16a1
3031#define PCI_DEVICE_ID_NX2_57840_2_20    0x16a2
3032#define PCI_DEVICE_ID_NX2_57840_MF      0x16a4
3033#define PCI_DEVICE_ID_NX2_57800_MF      0x16a5
3034#define PCI_DEVICE_ID_TIGON3_5702X      0x16a6
3035#define PCI_DEVICE_ID_TIGON3_5703X      0x16a7
3036#define PCI_DEVICE_ID_TIGON3_5704S      0x16a8
3037#define PCI_DEVICE_ID_NX2_57800_VF      0x16a9
3038#define PCI_DEVICE_ID_NX2_5706S         0x16aa
3039#define PCI_DEVICE_ID_NX2_5708S         0x16ac
3040#define PCI_DEVICE_ID_NX2_57840_VF      0x16ad
3041#define PCI_DEVICE_ID_NX2_57810_MF      0x16ae
3042#define PCI_DEVICE_ID_NX2_57810_VF      0x16af
3043#define PCI_DEVICE_ID_TIGON3_5702A3     0x16c6
3044#define PCI_DEVICE_ID_TIGON3_5703A3     0x16c7
3045#define PCI_DEVICE_ID_TIGON3_5781       0x16dd
3046#define PCI_DEVICE_ID_TIGON3_5753       0x16f7
3047#define PCI_DEVICE_ID_TIGON3_5753M      0x16fd
3048#define PCI_DEVICE_ID_TIGON3_5753F      0x16fe
3049#define PCI_DEVICE_ID_TIGON3_5901       0x170d
3050#define PCI_DEVICE_ID_BCM4401B1         0x170c
3051#define PCI_DEVICE_ID_TIGON3_5901_2     0x170e
3052#define PCI_DEVICE_ID_TIGON3_5906       0x1712
3053#define PCI_DEVICE_ID_TIGON3_5906M      0x1713
3054#define PCI_DEVICE_ID_BCM4401           0x4401
3055#define PCI_DEVICE_ID_BCM4401B0         0x4402
3056
3057#define PCI_VENDOR_ID_TOPIC             0x151f
3058#define PCI_DEVICE_ID_TOPIC_TP560       0x0000
3059
3060#define PCI_VENDOR_ID_MAINPINE          0x1522
3061#define PCI_DEVICE_ID_MAINPINE_PBRIDGE  0x0100
3062#define PCI_VENDOR_ID_ENE               0x1524
3063#define PCI_DEVICE_ID_ENE_CB710_FLASH   0x0510
3064#define PCI_DEVICE_ID_ENE_CB712_SD      0x0550
3065#define PCI_DEVICE_ID_ENE_CB712_SD_2    0x0551
3066#define PCI_DEVICE_ID_ENE_CB714_SD      0x0750
3067#define PCI_DEVICE_ID_ENE_CB714_SD_2    0x0751
3068#define PCI_DEVICE_ID_ENE_1211          0x1211
3069#define PCI_DEVICE_ID_ENE_1225          0x1225
3070#define PCI_DEVICE_ID_ENE_1410          0x1410
3071#define PCI_DEVICE_ID_ENE_710           0x1411
3072#define PCI_DEVICE_ID_ENE_712           0x1412
3073#define PCI_DEVICE_ID_ENE_1420          0x1420
3074#define PCI_DEVICE_ID_ENE_720           0x1421
3075#define PCI_DEVICE_ID_ENE_722           0x1422
3076
3077#define PCI_SUBVENDOR_ID_PERLE          0x155f
3078#define PCI_SUBDEVICE_ID_PCI_RAS4       0xf001
3079#define PCI_SUBDEVICE_ID_PCI_RAS8       0xf010
3080
3081#define PCI_VENDOR_ID_SYBA              0x1592
3082#define PCI_DEVICE_ID_SYBA_2P_EPP       0x0782
3083#define PCI_DEVICE_ID_SYBA_1P_ECP       0x0783
3084
3085#define PCI_VENDOR_ID_MORETON           0x15aa
3086#define PCI_DEVICE_ID_RASTEL_2PORT      0x2000
3087
3088#define PCI_VENDOR_ID_ZOLTRIX           0x15b0
3089#define PCI_DEVICE_ID_ZOLTRIX_2BD0      0x2bd0
3090
3091#define PCI_VENDOR_ID_MELLANOX          0x15b3
3092#define PCI_DEVICE_ID_MELLANOX_TAVOR    0x5a44
3093#define PCI_DEVICE_ID_MELLANOX_TAVOR_BRIDGE     0x5a46
3094#define PCI_DEVICE_ID_MELLANOX_ARBEL_COMPAT 0x6278
3095#define PCI_DEVICE_ID_MELLANOX_ARBEL    0x6282
3096#define PCI_DEVICE_ID_MELLANOX_SINAI_OLD 0x5e8c
3097#define PCI_DEVICE_ID_MELLANOX_SINAI    0x6274
3098
3099#define PCI_VENDOR_ID_DFI               0x15bd
3100
3101#define PCI_VENDOR_ID_QUICKNET          0x15e2
3102#define PCI_DEVICE_ID_QUICKNET_XJ       0x0500
3103
3104/*
3105* ADDI-DATA GmbH communication cards <info@addi-data.com>
3106*/
3107#define PCI_VENDOR_ID_ADDIDATA_OLD             0x10E8
3108#define PCI_VENDOR_ID_ADDIDATA                 0x15B8
3109#define PCI_DEVICE_ID_ADDIDATA_APCI7500        0x7000
3110#define PCI_DEVICE_ID_ADDIDATA_APCI7420        0x7001
3111#define PCI_DEVICE_ID_ADDIDATA_APCI7300        0x7002
3112#define PCI_DEVICE_ID_ADDIDATA_APCI7800        0x818E
3113#define PCI_DEVICE_ID_ADDIDATA_APCI7500_2      0x7009
3114#define PCI_DEVICE_ID_ADDIDATA_APCI7420_2      0x700A
3115#define PCI_DEVICE_ID_ADDIDATA_APCI7300_2      0x700B
3116#define PCI_DEVICE_ID_ADDIDATA_APCI7500_3      0x700C
3117#define PCI_DEVICE_ID_ADDIDATA_APCI7420_3      0x700D
3118#define PCI_DEVICE_ID_ADDIDATA_APCI7300_3      0x700E
3119#define PCI_DEVICE_ID_ADDIDATA_APCI7800_3      0x700F
3120#define PCI_DEVICE_ID_ADDIDATA_APCIe7300       0x7010
3121#define PCI_DEVICE_ID_ADDIDATA_APCIe7420       0x7011
3122#define PCI_DEVICE_ID_ADDIDATA_APCIe7500       0x7012
3123#define PCI_DEVICE_ID_ADDIDATA_APCIe7800       0x7013
3124
3125#define PCI_VENDOR_ID_PDC               0x15e9
3126
3127#define PCI_VENDOR_ID_FARSITE           0x1619
3128#define PCI_DEVICE_ID_FARSITE_T2P       0x0400
3129#define PCI_DEVICE_ID_FARSITE_T4P       0x0440
3130#define PCI_DEVICE_ID_FARSITE_T1U       0x0610
3131#define PCI_DEVICE_ID_FARSITE_T2U       0x0620
3132#define PCI_DEVICE_ID_FARSITE_T4U       0x0640
3133#define PCI_DEVICE_ID_FARSITE_TE1       0x1610
3134#define PCI_DEVICE_ID_FARSITE_TE1C      0x1612
3135
3136#define PCI_VENDOR_ID_ARIMA             0x161f
3137
3138#define PCI_VENDOR_ID_BROCADE           0x1657
3139#define PCI_DEVICE_ID_BROCADE_CT        0x0014
3140#define PCI_DEVICE_ID_BROCADE_FC_8G1P   0x0017
3141#define PCI_DEVICE_ID_BROCADE_CT_FC     0x0021
3142
3143#define PCI_VENDOR_ID_SIBYTE            0x166d
3144#define PCI_DEVICE_ID_BCM1250_PCI       0x0001
3145#define PCI_DEVICE_ID_BCM1250_HT        0x0002
3146
3147#define PCI_VENDOR_ID_ATHEROS           0x168c
3148
3149#define PCI_VENDOR_ID_NETCELL           0x169c
3150#define PCI_DEVICE_ID_REVOLUTION        0x0044
3151
3152#define PCI_VENDOR_ID_CENATEK           0x16CA
3153#define PCI_DEVICE_ID_CENATEK_IDE       0x0001
3154
3155#define PCI_VENDOR_ID_VITESSE           0x1725
3156#define PCI_DEVICE_ID_VITESSE_VSC7174   0x7174
3157
3158#define PCI_VENDOR_ID_LINKSYS           0x1737
3159#define PCI_DEVICE_ID_LINKSYS_EG1064    0x1064
3160
3161#define PCI_VENDOR_ID_ALTIMA            0x173b
3162#define PCI_DEVICE_ID_ALTIMA_AC1000     0x03e8
3163#define PCI_DEVICE_ID_ALTIMA_AC1001     0x03e9
3164#define PCI_DEVICE_ID_ALTIMA_AC9100     0x03ea
3165#define PCI_DEVICE_ID_ALTIMA_AC1003     0x03eb
3166
3167#define PCI_VENDOR_ID_BELKIN            0x1799
3168#define PCI_DEVICE_ID_BELKIN_F5D7010V7  0x701f
3169
3170#define PCI_VENDOR_ID_RDC               0x17f3
3171#define PCI_DEVICE_ID_RDC_R6020         0x6020
3172#define PCI_DEVICE_ID_RDC_R6030         0x6030
3173#define PCI_DEVICE_ID_RDC_R6040         0x6040
3174#define PCI_DEVICE_ID_RDC_R6060         0x6060
3175#define PCI_DEVICE_ID_RDC_R6061         0x6061
3176#define PCI_DEVICE_ID_RDC_D1010         0x1010
3177
3178#define PCI_VENDOR_ID_LENOVO            0x17aa
3179
3180#define PCI_VENDOR_ID_ARECA             0x17d3
3181#define PCI_DEVICE_ID_ARECA_1110        0x1110
3182#define PCI_DEVICE_ID_ARECA_1120        0x1120
3183#define PCI_DEVICE_ID_ARECA_1130        0x1130
3184#define PCI_DEVICE_ID_ARECA_1160        0x1160
3185#define PCI_DEVICE_ID_ARECA_1170        0x1170
3186#define PCI_DEVICE_ID_ARECA_1200        0x1200
3187#define PCI_DEVICE_ID_ARECA_1201        0x1201
3188#define PCI_DEVICE_ID_ARECA_1202        0x1202
3189#define PCI_DEVICE_ID_ARECA_1210        0x1210
3190#define PCI_DEVICE_ID_ARECA_1220        0x1220
3191#define PCI_DEVICE_ID_ARECA_1230        0x1230
3192#define PCI_DEVICE_ID_ARECA_1260        0x1260
3193#define PCI_DEVICE_ID_ARECA_1270        0x1270
3194#define PCI_DEVICE_ID_ARECA_1280        0x1280
3195#define PCI_DEVICE_ID_ARECA_1380        0x1380
3196#define PCI_DEVICE_ID_ARECA_1381        0x1381
3197#define PCI_DEVICE_ID_ARECA_1680        0x1680
3198#define PCI_DEVICE_ID_ARECA_1681        0x1681
3199
3200#define PCI_VENDOR_ID_S2IO              0x17d5
3201#define PCI_DEVICE_ID_S2IO_WIN          0x5731
3202#define PCI_DEVICE_ID_S2IO_UNI          0x5831
3203#define PCI_DEVICE_ID_HERC_WIN          0x5732
3204#define PCI_DEVICE_ID_HERC_UNI          0x5832
3205
3206#define PCI_VENDOR_ID_SITECOM           0x182d
3207#define PCI_DEVICE_ID_SITECOM_DC105V2   0x3069
3208
3209#define PCI_VENDOR_ID_TOPSPIN           0x1867
3210
3211#define PCI_VENDOR_ID_COMMTECH          0x18f7
3212
3213#define PCI_VENDOR_ID_SILAN             0x1904
3214
3215#define PCI_VENDOR_ID_RENESAS           0x1912
3216#define PCI_DEVICE_ID_RENESAS_SH7781    0x0001
3217#define PCI_DEVICE_ID_RENESAS_SH7780    0x0002
3218#define PCI_DEVICE_ID_RENESAS_SH7763    0x0004
3219#define PCI_DEVICE_ID_RENESAS_SH7785    0x0007
3220#define PCI_DEVICE_ID_RENESAS_SH7786    0x0010
3221
3222#define PCI_VENDOR_ID_SOLARFLARE        0x1924
3223#define PCI_DEVICE_ID_SOLARFLARE_SFC4000A_0     0x0703
3224#define PCI_DEVICE_ID_SOLARFLARE_SFC4000A_1     0x6703
3225#define PCI_DEVICE_ID_SOLARFLARE_SFC4000B       0x0710
3226
3227#define PCI_VENDOR_ID_TDI               0x192E
3228#define PCI_DEVICE_ID_TDI_EHCI          0x0101
3229
3230#define PCI_VENDOR_ID_FREESCALE         0x1957
3231#define PCI_DEVICE_ID_MPC8308           0xc006
3232#define PCI_DEVICE_ID_MPC8315E          0x00b4
3233#define PCI_DEVICE_ID_MPC8315           0x00b5
3234#define PCI_DEVICE_ID_MPC8314E          0x00b6
3235#define PCI_DEVICE_ID_MPC8314           0x00b7
3236#define PCI_DEVICE_ID_MPC8378E          0x00c4
3237#define PCI_DEVICE_ID_MPC8378           0x00c5
3238#define PCI_DEVICE_ID_MPC8377E          0x00c6
3239#define PCI_DEVICE_ID_MPC8377           0x00c7
3240#define PCI_DEVICE_ID_MPC8548E          0x0012
3241#define PCI_DEVICE_ID_MPC8548           0x0013
3242#define PCI_DEVICE_ID_MPC8543E          0x0014
3243#define PCI_DEVICE_ID_MPC8543           0x0015
3244#define PCI_DEVICE_ID_MPC8547E          0x0018
3245#define PCI_DEVICE_ID_MPC8545E          0x0019
3246#define PCI_DEVICE_ID_MPC8545           0x001a
3247#define PCI_DEVICE_ID_MPC8569E          0x0061
3248#define PCI_DEVICE_ID_MPC8569           0x0060
3249#define PCI_DEVICE_ID_MPC8568E          0x0020
3250#define PCI_DEVICE_ID_MPC8568           0x0021
3251#define PCI_DEVICE_ID_MPC8567E          0x0022
3252#define PCI_DEVICE_ID_MPC8567           0x0023
3253#define PCI_DEVICE_ID_MPC8533E          0x0030
3254#define PCI_DEVICE_ID_MPC8533           0x0031
3255#define PCI_DEVICE_ID_MPC8544E          0x0032
3256#define PCI_DEVICE_ID_MPC8544           0x0033
3257#define PCI_DEVICE_ID_MPC8572E          0x0040
3258#define PCI_DEVICE_ID_MPC8572           0x0041
3259#define PCI_DEVICE_ID_MPC8536E          0x0050
3260#define PCI_DEVICE_ID_MPC8536           0x0051
3261#define PCI_DEVICE_ID_P2020E            0x0070
3262#define PCI_DEVICE_ID_P2020             0x0071
3263#define PCI_DEVICE_ID_P2010E            0x0078
3264#define PCI_DEVICE_ID_P2010             0x0079
3265#define PCI_DEVICE_ID_P1020E            0x0100
3266#define PCI_DEVICE_ID_P1020             0x0101
3267#define PCI_DEVICE_ID_P1021E            0x0102
3268#define PCI_DEVICE_ID_P1021             0x0103
3269#define PCI_DEVICE_ID_P1011E            0x0108
3270#define PCI_DEVICE_ID_P1011             0x0109
3271#define PCI_DEVICE_ID_P1022E            0x0110
3272#define PCI_DEVICE_ID_P1022             0x0111
3273#define PCI_DEVICE_ID_P1013E            0x0118
3274#define PCI_DEVICE_ID_P1013             0x0119
3275#define PCI_DEVICE_ID_P4080E            0x0400
3276#define PCI_DEVICE_ID_P4080             0x0401
3277#define PCI_DEVICE_ID_P4040E            0x0408
3278#define PCI_DEVICE_ID_P4040             0x0409
3279#define PCI_DEVICE_ID_P2040E            0x0410
3280#define PCI_DEVICE_ID_P2040             0x0411
3281#define PCI_DEVICE_ID_P3041E            0x041E
3282#define PCI_DEVICE_ID_P3041             0x041F
3283#define PCI_DEVICE_ID_P5020E            0x0420
3284#define PCI_DEVICE_ID_P5020             0x0421
3285#define PCI_DEVICE_ID_P5010E            0x0428
3286#define PCI_DEVICE_ID_P5010             0x0429
3287#define PCI_DEVICE_ID_MPC8641           0x7010
3288#define PCI_DEVICE_ID_MPC8641D          0x7011
3289#define PCI_DEVICE_ID_MPC8610           0x7018
3290
3291#define PCI_VENDOR_ID_PASEMI            0x1959
3292
3293#define PCI_VENDOR_ID_ATTANSIC          0x1969
3294#define PCI_DEVICE_ID_ATTANSIC_L1       0x1048
3295#define PCI_DEVICE_ID_ATTANSIC_L2       0x2048
3296
3297#define PCI_VENDOR_ID_JMICRON           0x197B
3298#define PCI_DEVICE_ID_JMICRON_JMB360    0x2360
3299#define PCI_DEVICE_ID_JMICRON_JMB361    0x2361
3300#define PCI_DEVICE_ID_JMICRON_JMB362    0x2362
3301#define PCI_DEVICE_ID_JMICRON_JMB363    0x2363
3302#define PCI_DEVICE_ID_JMICRON_JMB364    0x2364
3303#define PCI_DEVICE_ID_JMICRON_JMB365    0x2365
3304#define PCI_DEVICE_ID_JMICRON_JMB366    0x2366
3305#define PCI_DEVICE_ID_JMICRON_JMB368    0x2368
3306#define PCI_DEVICE_ID_JMICRON_JMB369    0x2369
3307#define PCI_DEVICE_ID_JMICRON_JMB38X_SD 0x2381
3308#define PCI_DEVICE_ID_JMICRON_JMB38X_MMC 0x2382
3309#define PCI_DEVICE_ID_JMICRON_JMB38X_MS 0x2383
3310#define PCI_DEVICE_ID_JMICRON_JMB385_MS 0x2388
3311#define PCI_DEVICE_ID_JMICRON_JMB388_SD 0x2391
3312#define PCI_DEVICE_ID_JMICRON_JMB388_ESD 0x2392
3313#define PCI_DEVICE_ID_JMICRON_JMB390_MS 0x2393
3314
3315#define PCI_VENDOR_ID_KORENIX           0x1982
3316#define PCI_DEVICE_ID_KORENIX_JETCARDF0 0x1600
3317#define PCI_DEVICE_ID_KORENIX_JETCARDF1 0x16ff
3318#define PCI_DEVICE_ID_KORENIX_JETCARDF2 0x1700
3319#define PCI_DEVICE_ID_KORENIX_JETCARDF3 0x17ff
3320
3321#define PCI_VENDOR_ID_QMI               0x1a32
3322
3323#define PCI_VENDOR_ID_AZWAVE            0x1a3b
3324
3325#define PCI_VENDOR_ID_ASMEDIA           0x1b21
3326
3327#define PCI_VENDOR_ID_CIRCUITCO         0x1cc8
3328#define PCI_SUBSYSTEM_ID_CIRCUITCO_MINNOWBOARD  0x0001
3329
3330#define PCI_VENDOR_ID_TEKRAM            0x1de1
3331#define PCI_DEVICE_ID_TEKRAM_DC290      0xdc29
3332
3333#define PCI_VENDOR_ID_TEHUTI            0x1fc9
3334#define PCI_DEVICE_ID_TEHUTI_3009       0x3009
3335#define PCI_DEVICE_ID_TEHUTI_3010       0x3010
3336#define PCI_DEVICE_ID_TEHUTI_3014       0x3014
3337
3338#define PCI_VENDOR_ID_HINT             0x3388
3339#define PCI_DEVICE_ID_HINT_VXPROII_IDE 0x8013
3340
3341#define PCI_VENDOR_ID_3DLABS            0x3d3d
3342#define PCI_DEVICE_ID_3DLABS_PERMEDIA2  0x0007
3343#define PCI_DEVICE_ID_3DLABS_PERMEDIA2V 0x0009
3344
3345#define PCI_VENDOR_ID_NETXEN            0x4040
3346#define PCI_DEVICE_ID_NX2031_10GXSR     0x0001
3347#define PCI_DEVICE_ID_NX2031_10GCX4     0x0002
3348#define PCI_DEVICE_ID_NX2031_4GCU       0x0003
3349#define PCI_DEVICE_ID_NX2031_IMEZ       0x0004
3350#define PCI_DEVICE_ID_NX2031_HMEZ       0x0005
3351#define PCI_DEVICE_ID_NX2031_XG_MGMT    0x0024
3352#define PCI_DEVICE_ID_NX2031_XG_MGMT2   0x0025
3353#define PCI_DEVICE_ID_NX3031            0x0100
3354
3355#define PCI_VENDOR_ID_AKS               0x416c
3356#define PCI_DEVICE_ID_AKS_ALADDINCARD   0x0100
3357
3358#define PCI_VENDOR_ID_ACCESSIO          0x494f
3359#define PCI_DEVICE_ID_ACCESSIO_WDG_CSM  0x22c0
3360
3361#define PCI_VENDOR_ID_S3                0x5333
3362#define PCI_DEVICE_ID_S3_TRIO           0x8811
3363#define PCI_DEVICE_ID_S3_868            0x8880
3364#define PCI_DEVICE_ID_S3_968            0x88f0
3365#define PCI_DEVICE_ID_S3_SAVAGE4        0x8a25
3366#define PCI_DEVICE_ID_S3_PROSAVAGE8     0x8d04
3367#define PCI_DEVICE_ID_S3_SONICVIBES     0xca00
3368
3369#define PCI_VENDOR_ID_DUNORD            0x5544
3370#define PCI_DEVICE_ID_DUNORD_I3000      0x0001
3371
3372#define PCI_VENDOR_ID_DCI               0x6666
3373#define PCI_DEVICE_ID_DCI_PCCOM4        0x0001
3374#define PCI_DEVICE_ID_DCI_PCCOM8        0x0002
3375#define PCI_DEVICE_ID_DCI_PCCOM2        0x0004
3376
3377#define PCI_VENDOR_ID_INTEL             0x8086
3378#define PCI_DEVICE_ID_INTEL_EESSC       0x0008
3379#define PCI_DEVICE_ID_INTEL_PXHD_0      0x0320
3380#define PCI_DEVICE_ID_INTEL_PXHD_1      0x0321
3381#define PCI_DEVICE_ID_INTEL_PXH_0       0x0329
3382#define PCI_DEVICE_ID_INTEL_PXH_1       0x032A
3383#define PCI_DEVICE_ID_INTEL_PXHV        0x032C
3384#define PCI_DEVICE_ID_INTEL_80332_0     0x0330
3385#define PCI_DEVICE_ID_INTEL_80332_1     0x0332
3386#define PCI_DEVICE_ID_INTEL_80333_0     0x0370
3387#define PCI_DEVICE_ID_INTEL_80333_1     0x0372
3388#define PCI_DEVICE_ID_INTEL_82375       0x0482
3389#define PCI_DEVICE_ID_INTEL_82424       0x0483
3390#define PCI_DEVICE_ID_INTEL_82378       0x0484
3391#define PCI_DEVICE_ID_INTEL_MRST_SD0    0x0807
3392#define PCI_DEVICE_ID_INTEL_MRST_SD1    0x0808
3393#define PCI_DEVICE_ID_INTEL_MFD_SD      0x0820
3394#define PCI_DEVICE_ID_INTEL_MFD_SDIO1   0x0821
3395#define PCI_DEVICE_ID_INTEL_MFD_SDIO2   0x0822
3396#define PCI_DEVICE_ID_INTEL_MFD_EMMC0   0x0823
3397#define PCI_DEVICE_ID_INTEL_MFD_EMMC1   0x0824
3398#define PCI_DEVICE_ID_INTEL_MRST_SD2    0x084F
3399#define PCI_DEVICE_ID_INTEL_I960        0x0960
3400#define PCI_DEVICE_ID_INTEL_I960RM      0x0962
3401#define PCI_DEVICE_ID_INTEL_CENTERTON_ILB       0x0c60
3402#define PCI_DEVICE_ID_INTEL_8257X_SOL   0x1062
3403#define PCI_DEVICE_ID_INTEL_82573E_SOL  0x1085
3404#define PCI_DEVICE_ID_INTEL_82573L_SOL  0x108F
3405#define PCI_DEVICE_ID_INTEL_82815_MC    0x1130
3406#define PCI_DEVICE_ID_INTEL_82815_CGC   0x1132
3407#define PCI_DEVICE_ID_INTEL_82092AA_0   0x1221
3408#define PCI_DEVICE_ID_INTEL_7505_0      0x2550
3409#define PCI_DEVICE_ID_INTEL_7205_0      0x255d
3410#define PCI_DEVICE_ID_INTEL_82437       0x122d
3411#define PCI_DEVICE_ID_INTEL_82371FB_0   0x122e
3412#define PCI_DEVICE_ID_INTEL_82371FB_1   0x1230
3413#define PCI_DEVICE_ID_INTEL_82371MX     0x1234
3414#define PCI_DEVICE_ID_INTEL_82441       0x1237
3415#define PCI_DEVICE_ID_INTEL_82380FB     0x124b
3416#define PCI_DEVICE_ID_INTEL_82439       0x1250
3417#define PCI_DEVICE_ID_INTEL_80960_RP    0x1960
3418#define PCI_DEVICE_ID_INTEL_82840_HB    0x1a21
3419#define PCI_DEVICE_ID_INTEL_82845_HB    0x1a30
3420#define PCI_DEVICE_ID_INTEL_IOAT        0x1a38
3421#define PCI_DEVICE_ID_INTEL_COUGARPOINT_LPC_MIN 0x1c41
3422#define PCI_DEVICE_ID_INTEL_COUGARPOINT_LPC_MAX 0x1c5f
3423#define PCI_DEVICE_ID_INTEL_PATSBURG_LPC_0      0x1d40
3424#define PCI_DEVICE_ID_INTEL_PATSBURG_LPC_1      0x1d41
3425#define PCI_DEVICE_ID_INTEL_PANTHERPOINT_XHCI   0x1e31
3426#define PCI_DEVICE_ID_INTEL_PANTHERPOINT_LPC_MIN        0x1e40
3427#define PCI_DEVICE_ID_INTEL_PANTHERPOINT_LPC_MAX        0x1e5f
3428#define PCI_DEVICE_ID_INTEL_DH89XXCC_LPC_MIN    0x2310
3429#define PCI_DEVICE_ID_INTEL_DH89XXCC_LPC_MAX    0x231f
3430#define PCI_DEVICE_ID_INTEL_82801AA_0   0x2410
3431#define PCI_DEVICE_ID_INTEL_82801AA_1   0x2411
3432#define PCI_DEVICE_ID_INTEL_82801AA_3   0x2413
3433#define PCI_DEVICE_ID_INTEL_82801AA_5   0x2415
3434#define PCI_DEVICE_ID_INTEL_82801AA_6   0x2416
3435#define PCI_DEVICE_ID_INTEL_82801AA_8   0x2418
3436#define PCI_DEVICE_ID_INTEL_82801AB_0   0x2420
3437#define PCI_DEVICE_ID_INTEL_82801AB_1   0x2421
3438#define PCI_DEVICE_ID_INTEL_82801AB_3   0x2423
3439#define PCI_DEVICE_ID_INTEL_82801AB_5   0x2425
3440#define PCI_DEVICE_ID_INTEL_82801AB_6   0x2426
3441#define PCI_DEVICE_ID_INTEL_82801AB_8   0x2428
3442#define PCI_DEVICE_ID_INTEL_82801BA_0   0x2440
3443#define PCI_DEVICE_ID_INTEL_82801BA_2   0x2443
3444#define PCI_DEVICE_ID_INTEL_82801BA_4   0x2445
3445#define PCI_DEVICE_ID_INTEL_82801BA_6   0x2448
3446#define PCI_DEVICE_ID_INTEL_82801BA_8   0x244a
3447#define PCI_DEVICE_ID_INTEL_82801BA_9   0x244b
3448#define PCI_DEVICE_ID_INTEL_82801BA_10  0x244c
3449#define PCI_DEVICE_ID_INTEL_82801BA_11  0x244e
3450#define PCI_DEVICE_ID_INTEL_82801E_0    0x2450
3451#define PCI_DEVICE_ID_INTEL_82801E_11   0x245b
3452#define PCI_DEVICE_ID_INTEL_82801CA_0   0x2480
3453#define PCI_DEVICE_ID_INTEL_82801CA_3   0x2483
3454#define PCI_DEVICE_ID_INTEL_82801CA_5   0x2485
3455#define PCI_DEVICE_ID_INTEL_82801CA_6   0x2486
3456#define PCI_DEVICE_ID_INTEL_82801CA_10  0x248a
3457#define PCI_DEVICE_ID_INTEL_82801CA_11  0x248b
3458#define PCI_DEVICE_ID_INTEL_82801CA_12  0x248c
3459#define PCI_DEVICE_ID_INTEL_82801DB_0   0x24c0
3460#define PCI_DEVICE_ID_INTEL_82801DB_1   0x24c1
3461#define PCI_DEVICE_ID_INTEL_82801DB_2   0x24c2
3462#define PCI_DEVICE_ID_INTEL_82801DB_3   0x24c3
3463#define PCI_DEVICE_ID_INTEL_82801DB_5   0x24c5
3464#define PCI_DEVICE_ID_INTEL_82801DB_6   0x24c6
3465#define PCI_DEVICE_ID_INTEL_82801DB_9   0x24c9
3466#define PCI_DEVICE_ID_INTEL_82801DB_10  0x24ca
3467#define PCI_DEVICE_ID_INTEL_82801DB_11  0x24cb
3468#define PCI_DEVICE_ID_INTEL_82801DB_12  0x24cc
3469#define PCI_DEVICE_ID_INTEL_82801EB_0   0x24d0
3470#define PCI_DEVICE_ID_INTEL_82801EB_1   0x24d1
3471#define PCI_DEVICE_ID_INTEL_82801EB_3   0x24d3
3472#define PCI_DEVICE_ID_INTEL_82801EB_5   0x24d5
3473#define PCI_DEVICE_ID_INTEL_82801EB_6   0x24d6
3474#define PCI_DEVICE_ID_INTEL_82801EB_11  0x24db
3475#define PCI_DEVICE_ID_INTEL_82801EB_12  0x24dc
3476#define PCI_DEVICE_ID_INTEL_82801EB_13  0x24dd
3477#define PCI_DEVICE_ID_INTEL_ESB_1       0x25a1
3478#define PCI_DEVICE_ID_INTEL_ESB_2       0x25a2
3479#define PCI_DEVICE_ID_INTEL_ESB_4       0x25a4
3480#define PCI_DEVICE_ID_INTEL_ESB_5       0x25a6
3481#define PCI_DEVICE_ID_INTEL_ESB_9       0x25ab
3482#define PCI_DEVICE_ID_INTEL_ESB_10      0x25ac
3483#define PCI_DEVICE_ID_INTEL_82820_HB    0x2500
3484#define PCI_DEVICE_ID_INTEL_82820_UP_HB 0x2501
3485#define PCI_DEVICE_ID_INTEL_82850_HB    0x2530
3486#define PCI_DEVICE_ID_INTEL_82860_HB    0x2531
3487#define PCI_DEVICE_ID_INTEL_E7501_MCH   0x254c
3488#define PCI_DEVICE_ID_INTEL_82845G_HB   0x2560
3489#define PCI_DEVICE_ID_INTEL_82845G_IG   0x2562
3490#define PCI_DEVICE_ID_INTEL_82865_HB    0x2570
3491#define PCI_DEVICE_ID_INTEL_82865_IG    0x2572
3492#define PCI_DEVICE_ID_INTEL_82875_HB    0x2578
3493#define PCI_DEVICE_ID_INTEL_82915G_HB   0x2580
3494#define PCI_DEVICE_ID_INTEL_82915G_IG   0x2582
3495#define PCI_DEVICE_ID_INTEL_82915GM_HB  0x2590
3496#define PCI_DEVICE_ID_INTEL_82915GM_IG  0x2592
3497#define PCI_DEVICE_ID_INTEL_5000_ERR    0x25F0
3498#define PCI_DEVICE_ID_INTEL_5000_FBD0   0x25F5
3499#define PCI_DEVICE_ID_INTEL_5000_FBD1   0x25F6
3500#define PCI_DEVICE_ID_INTEL_82945G_HB   0x2770
3501#define PCI_DEVICE_ID_INTEL_82945G_IG   0x2772
3502#define PCI_DEVICE_ID_INTEL_3000_HB     0x2778
3503#define PCI_DEVICE_ID_INTEL_82945GM_HB  0x27A0
3504#define PCI_DEVICE_ID_INTEL_82945GM_IG  0x27A2
3505#define PCI_DEVICE_ID_INTEL_ICH6_0      0x2640
3506#define PCI_DEVICE_ID_INTEL_ICH6_1      0x2641
3507#define PCI_DEVICE_ID_INTEL_ICH6_2      0x2642
3508#define PCI_DEVICE_ID_INTEL_ICH6_16     0x266a
3509#define PCI_DEVICE_ID_INTEL_ICH6_17     0x266d
3510#define PCI_DEVICE_ID_INTEL_ICH6_18     0x266e
3511#define PCI_DEVICE_ID_INTEL_ICH6_19     0x266f
3512#define PCI_DEVICE_ID_INTEL_ESB2_0      0x2670
3513#define PCI_DEVICE_ID_INTEL_ESB2_14     0x2698
3514#define PCI_DEVICE_ID_INTEL_ESB2_17     0x269b
3515#define PCI_DEVICE_ID_INTEL_ESB2_18     0x269e
3516#define PCI_DEVICE_ID_INTEL_ICH7_0      0x27b8
3517#define PCI_DEVICE_ID_INTEL_ICH7_1      0x27b9
3518#define PCI_DEVICE_ID_INTEL_ICH7_30     0x27b0
3519#define PCI_DEVICE_ID_INTEL_TGP_LPC     0x27bc
3520#define PCI_DEVICE_ID_INTEL_ICH7_31     0x27bd
3521#define PCI_DEVICE_ID_INTEL_ICH7_17     0x27da
3522#define PCI_DEVICE_ID_INTEL_ICH7_19     0x27dd
3523#define PCI_DEVICE_ID_INTEL_ICH7_20     0x27de
3524#define PCI_DEVICE_ID_INTEL_ICH7_21     0x27df
3525#define PCI_DEVICE_ID_INTEL_ICH8_0      0x2810
3526#define PCI_DEVICE_ID_INTEL_ICH8_1      0x2811
3527#define PCI_DEVICE_ID_INTEL_ICH8_2      0x2812
3528#define PCI_DEVICE_ID_INTEL_ICH8_3      0x2814
3529#define PCI_DEVICE_ID_INTEL_ICH8_4      0x2815
3530#define PCI_DEVICE_ID_INTEL_ICH8_5      0x283e
3531#define PCI_DEVICE_ID_INTEL_ICH8_6      0x2850
3532#define PCI_DEVICE_ID_INTEL_ICH9_0      0x2910
3533#define PCI_DEVICE_ID_INTEL_ICH9_1      0x2917
3534#define PCI_DEVICE_ID_INTEL_ICH9_2      0x2912
3535#define PCI_DEVICE_ID_INTEL_ICH9_3      0x2913
3536#define PCI_DEVICE_ID_INTEL_ICH9_4      0x2914
3537#define PCI_DEVICE_ID_INTEL_ICH9_5      0x2919
3538#define PCI_DEVICE_ID_INTEL_ICH9_6      0x2930
3539#define PCI_DEVICE_ID_INTEL_ICH9_7      0x2916
3540#define PCI_DEVICE_ID_INTEL_ICH9_8      0x2918
3541#define PCI_DEVICE_ID_INTEL_I7_MCR      0x2c18
3542#define PCI_DEVICE_ID_INTEL_I7_MC_TAD   0x2c19
3543#define PCI_DEVICE_ID_INTEL_I7_MC_RAS   0x2c1a
3544#define PCI_DEVICE_ID_INTEL_I7_MC_TEST  0x2c1c
3545#define PCI_DEVICE_ID_INTEL_I7_MC_CH0_CTRL  0x2c20
3546#define PCI_DEVICE_ID_INTEL_I7_MC_CH0_ADDR  0x2c21
3547#define PCI_DEVICE_ID_INTEL_I7_MC_CH0_RANK  0x2c22
3548#define PCI_DEVICE_ID_INTEL_I7_MC_CH0_TC    0x2c23
3549#define PCI_DEVICE_ID_INTEL_I7_MC_CH1_CTRL  0x2c28
3550#define PCI_DEVICE_ID_INTEL_I7_MC_CH1_ADDR  0x2c29
3551#define PCI_DEVICE_ID_INTEL_I7_MC_CH1_RANK  0x2c2a
3552#define PCI_DEVICE_ID_INTEL_I7_MC_CH1_TC    0x2c2b
3553#define PCI_DEVICE_ID_INTEL_I7_MC_CH2_CTRL  0x2c30
3554#define PCI_DEVICE_ID_INTEL_I7_MC_CH2_ADDR  0x2c31
3555#define PCI_DEVICE_ID_INTEL_I7_MC_CH2_RANK  0x2c32
3556#define PCI_DEVICE_ID_INTEL_I7_MC_CH2_TC    0x2c33
3557#define PCI_DEVICE_ID_INTEL_I7_NONCORE  0x2c41
3558#define PCI_DEVICE_ID_INTEL_I7_NONCORE_ALT 0x2c40
3559#define PCI_DEVICE_ID_INTEL_LYNNFIELD_NONCORE     0x2c50
3560#define PCI_DEVICE_ID_INTEL_LYNNFIELD_NONCORE_ALT 0x2c51
3561#define PCI_DEVICE_ID_INTEL_LYNNFIELD_NONCORE_REV2 0x2c70
3562#define PCI_DEVICE_ID_INTEL_LYNNFIELD_SAD         0x2c81
3563#define PCI_DEVICE_ID_INTEL_LYNNFIELD_QPI_LINK0   0x2c90
3564#define PCI_DEVICE_ID_INTEL_LYNNFIELD_QPI_PHY0    0x2c91
3565#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MCR         0x2c98
3566#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_TAD      0x2c99
3567#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_TEST     0x2c9C
3568#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH0_CTRL 0x2ca0
3569#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH0_ADDR 0x2ca1
3570#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH0_RANK 0x2ca2
3571#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH0_TC   0x2ca3
3572#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH1_CTRL 0x2ca8
3573#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH1_ADDR 0x2ca9
3574#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH1_RANK 0x2caa
3575#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH1_TC   0x2cab
3576#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MCR_REV2          0x2d98
3577#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_TAD_REV2       0x2d99
3578#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_RAS_REV2       0x2d9a
3579#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_TEST_REV2      0x2d9c
3580#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH0_CTRL_REV2  0x2da0
3581#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH0_ADDR_REV2  0x2da1
3582#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH0_RANK_REV2  0x2da2
3583#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH0_TC_REV2    0x2da3
3584#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH1_CTRL_REV2  0x2da8
3585#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH1_ADDR_REV2  0x2da9
3586#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH1_RANK_REV2  0x2daa
3587#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH1_TC_REV2    0x2dab
3588#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH2_CTRL_REV2  0x2db0
3589#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH2_ADDR_REV2  0x2db1
3590#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH2_RANK_REV2  0x2db2
3591#define PCI_DEVICE_ID_INTEL_LYNNFIELD_MC_CH2_TC_REV2    0x2db3
3592#define PCI_DEVICE_ID_INTEL_82855PM_HB  0x3340
3593#define PCI_DEVICE_ID_INTEL_IOAT_TBG4   0x3429
3594#define PCI_DEVICE_ID_INTEL_IOAT_TBG5   0x342a
3595#define PCI_DEVICE_ID_INTEL_IOAT_TBG6   0x342b
3596#define PCI_DEVICE_ID_INTEL_IOAT_TBG7   0x342c
3597#define PCI_DEVICE_ID_INTEL_X58_HUB_MGMT 0x342e
3598#define PCI_DEVICE_ID_INTEL_IOAT_TBG0   0x3430
3599#define PCI_DEVICE_ID_INTEL_IOAT_TBG1   0x3431
3600#define PCI_DEVICE_ID_INTEL_IOAT_TBG2   0x3432
3601#define PCI_DEVICE_ID_INTEL_IOAT_TBG3   0x3433
3602#define PCI_DEVICE_ID_INTEL_82830_HB    0x3575
3603#define PCI_DEVICE_ID_INTEL_82830_CGC   0x3577
3604#define PCI_DEVICE_ID_INTEL_82854_HB    0x358c
3605#define PCI_DEVICE_ID_INTEL_82854_IG    0x358e
3606#define PCI_DEVICE_ID_INTEL_82855GM_HB  0x3580
3607#define PCI_DEVICE_ID_INTEL_82855GM_IG  0x3582
3608#define PCI_DEVICE_ID_INTEL_E7520_MCH   0x3590
3609#define PCI_DEVICE_ID_INTEL_E7320_MCH   0x3592
3610#define PCI_DEVICE_ID_INTEL_MCH_PA      0x3595
3611#define PCI_DEVICE_ID_INTEL_MCH_PA1     0x3596
3612#define PCI_DEVICE_ID_INTEL_MCH_PB      0x3597
3613#define PCI_DEVICE_ID_INTEL_MCH_PB1     0x3598
3614#define PCI_DEVICE_ID_INTEL_MCH_PC      0x3599
3615#define PCI_DEVICE_ID_INTEL_MCH_PC1     0x359a
3616#define PCI_DEVICE_ID_INTEL_E7525_MCH   0x359e
3617#define PCI_DEVICE_ID_INTEL_I7300_MCH_ERR 0x360c
3618#define PCI_DEVICE_ID_INTEL_I7300_MCH_FB0 0x360f
3619#define PCI_DEVICE_ID_INTEL_I7300_MCH_FB1 0x3610
3620#define PCI_DEVICE_ID_INTEL_IOAT_CNB    0x360b
3621#define PCI_DEVICE_ID_INTEL_FBD_CNB     0x360c
3622#define PCI_DEVICE_ID_INTEL_IOAT_JSF0   0x3710
3623#define PCI_DEVICE_ID_INTEL_IOAT_JSF1   0x3711
3624#define PCI_DEVICE_ID_INTEL_IOAT_JSF2   0x3712
3625#define PCI_DEVICE_ID_INTEL_IOAT_JSF3   0x3713
3626#define PCI_DEVICE_ID_INTEL_IOAT_JSF4   0x3714
3627#define PCI_DEVICE_ID_INTEL_IOAT_JSF5   0x3715
3628#define PCI_DEVICE_ID_INTEL_IOAT_JSF6   0x3716
3629#define PCI_DEVICE_ID_INTEL_IOAT_JSF7   0x3717
3630#define PCI_DEVICE_ID_INTEL_IOAT_JSF8   0x3718
3631#define PCI_DEVICE_ID_INTEL_IOAT_JSF9   0x3719
3632#define PCI_DEVICE_ID_INTEL_ICH10_0     0x3a14
3633#define PCI_DEVICE_ID_INTEL_ICH10_1     0x3a16
3634#define PCI_DEVICE_ID_INTEL_ICH10_2     0x3a18
3635#define PCI_DEVICE_ID_INTEL_ICH10_3     0x3a1a
3636#define PCI_DEVICE_ID_INTEL_ICH10_4     0x3a30
3637#define PCI_DEVICE_ID_INTEL_ICH10_5     0x3a60
3638#define PCI_DEVICE_ID_INTEL_5_3400_SERIES_LPC_MIN       0x3b00
3639#define PCI_DEVICE_ID_INTEL_5_3400_SERIES_LPC_MAX       0x3b1f
3640#define PCI_DEVICE_ID_INTEL_IOAT_SNB0   0x3c20
3641#define PCI_DEVICE_ID_INTEL_IOAT_SNB1   0x3c21
3642#define PCI_DEVICE_ID_INTEL_IOAT_SNB2   0x3c22
3643#define PCI_DEVICE_ID_INTEL_IOAT_SNB3   0x3c23
3644#define PCI_DEVICE_ID_INTEL_IOAT_SNB4   0x3c24
3645#define PCI_DEVICE_ID_INTEL_IOAT_SNB5   0x3c25
3646#define PCI_DEVICE_ID_INTEL_IOAT_SNB6   0x3c26
3647#define PCI_DEVICE_ID_INTEL_IOAT_SNB7   0x3c27
3648#define PCI_DEVICE_ID_INTEL_IOAT_SNB8   0x3c2e
3649#define PCI_DEVICE_ID_INTEL_IOAT_SNB9   0x3c2f
3650#define PCI_DEVICE_ID_INTEL_UNC_HA      0x3c46
3651#define PCI_DEVICE_ID_INTEL_UNC_IMC0    0x3cb0
3652#define PCI_DEVICE_ID_INTEL_UNC_IMC1    0x3cb1
3653#define PCI_DEVICE_ID_INTEL_UNC_IMC2    0x3cb4
3654#define PCI_DEVICE_ID_INTEL_UNC_IMC3    0x3cb5
3655#define PCI_DEVICE_ID_INTEL_UNC_QPI0    0x3c41
3656#define PCI_DEVICE_ID_INTEL_UNC_QPI1    0x3c42
3657#define PCI_DEVICE_ID_INTEL_UNC_R2PCIE  0x3c43
3658#define PCI_DEVICE_ID_INTEL_UNC_R3QPI0  0x3c44
3659#define PCI_DEVICE_ID_INTEL_UNC_R3QPI1  0x3c45
3660#define PCI_DEVICE_ID_INTEL_JAKETOWN_UBOX       0x3ce0
3661#define PCI_DEVICE_ID_INTEL_IOAT_SNB    0x402f
3662#define PCI_DEVICE_ID_INTEL_5100_16     0x65f0
3663#define PCI_DEVICE_ID_INTEL_5100_19     0x65f3
3664#define PCI_DEVICE_ID_INTEL_5100_21     0x65f5
3665#define PCI_DEVICE_ID_INTEL_5100_22     0x65f6
3666#define PCI_DEVICE_ID_INTEL_5400_ERR    0x4030
3667#define PCI_DEVICE_ID_INTEL_5400_FBD0   0x4035
3668#define PCI_DEVICE_ID_INTEL_5400_FBD1   0x4036
3669#define PCI_DEVICE_ID_INTEL_IOAT_SCNB   0x65ff
3670#define PCI_DEVICE_ID_INTEL_EP80579_0   0x5031
3671#define PCI_DEVICE_ID_INTEL_EP80579_1   0x5032
3672#define PCI_DEVICE_ID_INTEL_82371SB_0   0x7000
3673#define PCI_DEVICE_ID_INTEL_82371SB_1   0x7010
3674#define PCI_DEVICE_ID_INTEL_82371SB_2   0x7020
3675#define PCI_DEVICE_ID_INTEL_82437VX     0x7030
3676#define PCI_DEVICE_ID_INTEL_82439TX     0x7100
3677#define PCI_DEVICE_ID_INTEL_82371AB_0   0x7110
3678#define PCI_DEVICE_ID_INTEL_82371AB     0x7111
3679#define PCI_DEVICE_ID_INTEL_82371AB_2   0x7112
3680#define PCI_DEVICE_ID_INTEL_82371AB_3   0x7113
3681#define PCI_DEVICE_ID_INTEL_82810_MC1   0x7120
3682#define PCI_DEVICE_ID_INTEL_82810_IG1   0x7121
3683#define PCI_DEVICE_ID_INTEL_82810_MC3   0x7122
3684#define PCI_DEVICE_ID_INTEL_82810_IG3   0x7123
3685#define PCI_DEVICE_ID_INTEL_82810E_MC   0x7124
3686#define PCI_DEVICE_ID_INTEL_82810E_IG   0x7125
3687#define PCI_DEVICE_ID_INTEL_82443LX_0   0x7180
3688#define PCI_DEVICE_ID_INTEL_82443LX_1   0x7181
3689#define PCI_DEVICE_ID_INTEL_82443BX_0   0x7190
3690#define PCI_DEVICE_ID_INTEL_82443BX_1   0x7191
3691#define PCI_DEVICE_ID_INTEL_82443BX_2   0x7192
3692#define PCI_DEVICE_ID_INTEL_440MX       0x7195
3693#define PCI_DEVICE_ID_INTEL_440MX_6     0x7196
3694#define PCI_DEVICE_ID_INTEL_82443MX_0   0x7198
3695#define PCI_DEVICE_ID_INTEL_82443MX_1   0x7199
3696#define PCI_DEVICE_ID_INTEL_82443MX_3   0x719b
3697#define PCI_DEVICE_ID_INTEL_82443GX_0   0x71a0
3698#define PCI_DEVICE_ID_INTEL_82443GX_2   0x71a2
3699#define PCI_DEVICE_ID_INTEL_82372FB_1   0x7601
3700#define PCI_DEVICE_ID_INTEL_SCH_LPC     0x8119
3701#define PCI_DEVICE_ID_INTEL_SCH_IDE     0x811a
3702#define PCI_DEVICE_ID_INTEL_ITC_LPC     0x8186
3703#define PCI_DEVICE_ID_INTEL_82454GX     0x84c4
3704#define PCI_DEVICE_ID_INTEL_82450GX     0x84c5
3705#define PCI_DEVICE_ID_INTEL_82451NX     0x84ca
3706#define PCI_DEVICE_ID_INTEL_82454NX     0x84cb
3707#define PCI_DEVICE_ID_INTEL_84460GX     0x84ea
3708#define PCI_DEVICE_ID_INTEL_IXP4XX      0x8500
3709#define PCI_DEVICE_ID_INTEL_IXP2800     0x9004
3710#define PCI_DEVICE_ID_INTEL_S21152BB    0xb152
3711
3712#define PCI_VENDOR_ID_SCALEMP           0x8686
3713#define PCI_DEVICE_ID_SCALEMP_VSMP_CTL  0x1010
3714
3715#define PCI_VENDOR_ID_COMPUTONE         0x8e0e
3716#define PCI_DEVICE_ID_COMPUTONE_IP2EX   0x0291
3717#define PCI_DEVICE_ID_COMPUTONE_PG      0x0302
3718#define PCI_SUBVENDOR_ID_COMPUTONE      0x8e0e
3719#define PCI_SUBDEVICE_ID_COMPUTONE_PG4  0x0001
3720#define PCI_SUBDEVICE_ID_COMPUTONE_PG8  0x0002
3721#define PCI_SUBDEVICE_ID_COMPUTONE_PG6  0x0003
3722
3723#define PCI_VENDOR_ID_KTI               0x8e2e
3724
3725#define PCI_VENDOR_ID_ADAPTEC           0x9004
3726#define PCI_DEVICE_ID_ADAPTEC_7810      0x1078
3727#define PCI_DEVICE_ID_ADAPTEC_7821      0x2178
3728#define PCI_DEVICE_ID_ADAPTEC_38602     0x3860
3729#define PCI_DEVICE_ID_ADAPTEC_7850      0x5078
3730#define PCI_DEVICE_ID_ADAPTEC_7855      0x5578
3731#define PCI_DEVICE_ID_ADAPTEC_3860      0x6038
3732#define PCI_DEVICE_ID_ADAPTEC_1480A     0x6075
3733#define PCI_DEVICE_ID_ADAPTEC_7860      0x6078
3734#define PCI_DEVICE_ID_ADAPTEC_7861      0x6178
3735#define PCI_DEVICE_ID_ADAPTEC_7870      0x7078
3736#define PCI_DEVICE_ID_ADAPTEC_7871      0x7178
3737#define PCI_DEVICE_ID_ADAPTEC_7872      0x7278
3738#define PCI_DEVICE_ID_ADAPTEC_7873      0x7378
3739#define PCI_DEVICE_ID_ADAPTEC_7874      0x7478
3740#define PCI_DEVICE_ID_ADAPTEC_7895      0x7895
3741#define PCI_DEVICE_ID_ADAPTEC_7880      0x8078
3742#define PCI_DEVICE_ID_ADAPTEC_7881      0x8178
3743#define PCI_DEVICE_ID_ADAPTEC_7882      0x8278
3744#define PCI_DEVICE_ID_ADAPTEC_7883      0x8378
3745#define PCI_DEVICE_ID_ADAPTEC_7884      0x8478
3746#define PCI_DEVICE_ID_ADAPTEC_7885      0x8578
3747#define PCI_DEVICE_ID_ADAPTEC_7886      0x8678
3748#define PCI_DEVICE_ID_ADAPTEC_7887      0x8778
3749#define PCI_DEVICE_ID_ADAPTEC_7888      0x8878
3750
3751#define PCI_VENDOR_ID_ADAPTEC2          0x9005
3752#define PCI_DEVICE_ID_ADAPTEC2_2940U2   0x0010
3753#define PCI_DEVICE_ID_ADAPTEC2_2930U2   0x0011
3754#define PCI_DEVICE_ID_ADAPTEC2_7890B    0x0013
3755#define PCI_DEVICE_ID_ADAPTEC2_7890     0x001f
3756#define PCI_DEVICE_ID_ADAPTEC2_3940U2   0x0050
3757#define PCI_DEVICE_ID_ADAPTEC2_3950U2D  0x0051
3758#define PCI_DEVICE_ID_ADAPTEC2_7896     0x005f
3759#define PCI_DEVICE_ID_ADAPTEC2_7892A    0x0080
3760#define PCI_DEVICE_ID_ADAPTEC2_7892B    0x0081
3761#define PCI_DEVICE_ID_ADAPTEC2_7892D    0x0083
3762#define PCI_DEVICE_ID_ADAPTEC2_7892P    0x008f
3763#define PCI_DEVICE_ID_ADAPTEC2_7899A    0x00c0
3764#define PCI_DEVICE_ID_ADAPTEC2_7899B    0x00c1
3765#define PCI_DEVICE_ID_ADAPTEC2_7899D    0x00c3
3766#define PCI_DEVICE_ID_ADAPTEC2_7899P    0x00cf
3767#define PCI_DEVICE_ID_ADAPTEC2_OBSIDIAN   0x0500
3768#define PCI_DEVICE_ID_ADAPTEC2_SCAMP    0x0503
3769
3770#define PCI_VENDOR_ID_HOLTEK            0x9412
3771#define PCI_DEVICE_ID_HOLTEK_6565       0x6565
3772
3773#define PCI_VENDOR_ID_NETMOS            0x9710
3774#define PCI_DEVICE_ID_NETMOS_9705       0x9705
3775#define PCI_DEVICE_ID_NETMOS_9715       0x9715
3776#define PCI_DEVICE_ID_NETMOS_9735       0x9735
3777#define PCI_DEVICE_ID_NETMOS_9745       0x9745
3778#define PCI_DEVICE_ID_NETMOS_9755       0x9755
3779#define PCI_DEVICE_ID_NETMOS_9805       0x9805
3780#define PCI_DEVICE_ID_NETMOS_9815       0x9815
3781#define PCI_DEVICE_ID_NETMOS_9835       0x9835
3782#define PCI_DEVICE_ID_NETMOS_9845       0x9845
3783#define PCI_DEVICE_ID_NETMOS_9855       0x9855
3784#define PCI_DEVICE_ID_NETMOS_9865       0x9865
3785#define PCI_DEVICE_ID_NETMOS_9900       0x9900
3786#define PCI_DEVICE_ID_NETMOS_9901       0x9901
3787#define PCI_DEVICE_ID_NETMOS_9904       0x9904
3788#define PCI_DEVICE_ID_NETMOS_9912       0x9912
3789#define PCI_DEVICE_ID_NETMOS_9922       0x9922
3790
3791#define PCI_VENDOR_ID_3COM_2            0xa727
3792
3793#define PCI_VENDOR_ID_DIGIUM            0xd161
3794#define PCI_DEVICE_ID_DIGIUM_HFC4S      0xb410
3795
3796#define PCI_SUBVENDOR_ID_EXSYS          0xd84d
3797#define PCI_SUBDEVICE_ID_EXSYS_4014     0x4014
3798#define PCI_SUBDEVICE_ID_EXSYS_4055     0x4055
3799
3800#define PCI_VENDOR_ID_TIGERJET          0xe159
3801#define PCI_DEVICE_ID_TIGERJET_300      0x0001
3802#define PCI_DEVICE_ID_TIGERJET_100      0x0002
3803
3804#define PCI_VENDOR_ID_XILINX_RME        0xea60
3805#define PCI_DEVICE_ID_RME_DIGI32        0x9896
3806#define PCI_DEVICE_ID_RME_DIGI32_PRO    0x9897
3807#define PCI_DEVICE_ID_RME_DIGI32_8      0x9898
3808
3809#define PCI_VENDOR_ID_XEN               0x5853
3810#define PCI_DEVICE_ID_XEN_PLATFORM      0x0001
3811
3812#define PCI_VENDOR_ID_OCZ               0x1b85
3813
3814//--------------------------------------------------------------------------------------------------
3815
3816#define PCI_VENDOR_ID_VMWARE            0x15ad
3817#define PCI_DEVICE_ID_VMWARE_PCI_BRIDGE 0x0790
3818#define PCI_DEVICE_ID_VMWARE_PCI_EXPRES 0x07a0
3819#define PCI_DEVICE_ID_VMWARE_PCI_TO_USB 0x0770
3820#define PCI_DEVICE_ID_VMWARE_USB_TO_PLL 0x0778
3821#define PCI_DEVICE_ID_VMWARE_VHDA_AUDIO   0x1977
3822#define PCI_DEVICE_ID_VMWARE_VHDA_CODEC   0x1975
3823#define PCI_DEVICE_ID_VMWARE_VMCI_BUS   0x0740
3824#define PCI_DEVICE_ID_VMWARE_VMEMCTRL   0x0801
3825#define PCI_DEVICE_ID_VMWARE_VMXNET     0x0720
3826#define PCI_DEVICE_ID_VMWARE_VMXNET3    0x07b0
3827#define PCI_DEVICE_ID_VMWARE_VSVGA      0x0710
3828#define PCI_DEVICE_ID_VMWARE_VSVGA2     0x0405
3829
3830#define PCI_VENDOR_ID_INVALID   0xffff
3831
3832char* libpci_vendorID_str(int vid);
3833char* libpci_deviceID_str(int vid, int did);
3834