pci_id_driver_map.h revision 9f464c52
1#ifndef _PCI_ID_DRIVER_MAP_H_
2#define _PCI_ID_DRIVER_MAP_H_
3
4#include <stddef.h>
5
6#ifndef ARRAY_SIZE
7#define ARRAY_SIZE(a) (sizeof(a) / sizeof((a)[0]))
8#endif
9
10#ifndef __IS_LOADER
11#  error "Only include from loader.c"
12#endif
13
14static const int i915_chip_ids[] = {
15#define CHIPSET(chip, desc, name) chip,
16#include "pci_ids/i915_pci_ids.h"
17#undef CHIPSET
18};
19
20static const int i965_chip_ids[] = {
21#define CHIPSET(chip, family, name) chip,
22#include "pci_ids/i965_pci_ids.h"
23#undef CHIPSET
24};
25
26static const int iris_chip_ids[] = {
27#define CHIPSET(chip, family, name) chip,
28#define IRIS 1
29#include "pci_ids/i965_pci_ids.h"
30#undef IRIS
31#undef CHIPSET
32};
33
34static const int r100_chip_ids[] = {
35#define CHIPSET(chip, name, family) chip,
36#include "pci_ids/radeon_pci_ids.h"
37#undef CHIPSET
38};
39
40static const int r200_chip_ids[] = {
41#define CHIPSET(chip, name, family) chip,
42#include "pci_ids/r200_pci_ids.h"
43#undef CHIPSET
44};
45
46static const int r300_chip_ids[] = {
47#define CHIPSET(chip, name, family) chip,
48#include "pci_ids/r300_pci_ids.h"
49#undef CHIPSET
50};
51
52static const int r600_chip_ids[] = {
53#define CHIPSET(chip, name, family) chip,
54#include "pci_ids/r600_pci_ids.h"
55#undef CHIPSET
56};
57
58static const int radeonsi_chip_ids[] = {
59#define CHIPSET(chip, family) chip,
60#include "pci_ids/radeonsi_pci_ids.h"
61#undef CHIPSET
62};
63
64static const int virtio_gpu_chip_ids[] = {
65#define CHIPSET(chip, name, family) chip,
66#include "pci_ids/virtio_gpu_pci_ids.h"
67#undef CHIPSET
68};
69
70static const int vmwgfx_chip_ids[] = {
71#define CHIPSET(chip, name, family) chip,
72#include "pci_ids/vmwgfx_pci_ids.h"
73#undef CHIPSET
74};
75
76int is_nouveau_vieux(int fd);
77
78static const struct {
79   int vendor_id;
80   const char *driver;
81   const int *chip_ids;
82   int num_chips_ids;
83   int (*predicate)(int fd);
84} driver_map[] = {
85   { 0x8086, "i915", i915_chip_ids, ARRAY_SIZE(i915_chip_ids) },
86   { 0x8086, "i965", i965_chip_ids, ARRAY_SIZE(i965_chip_ids) },
87   { 0x8086, "iris", iris_chip_ids, ARRAY_SIZE(iris_chip_ids) },
88   { 0x1002, "radeon", r100_chip_ids, ARRAY_SIZE(r100_chip_ids) },
89   { 0x1002, "r200", r200_chip_ids, ARRAY_SIZE(r200_chip_ids) },
90   { 0x1002, "r300", r300_chip_ids, ARRAY_SIZE(r300_chip_ids) },
91   { 0x1002, "r600", r600_chip_ids, ARRAY_SIZE(r600_chip_ids) },
92   { 0x1002, "radeonsi", radeonsi_chip_ids, ARRAY_SIZE(radeonsi_chip_ids) },
93   { 0x10de, "nouveau_vieux", NULL, -1, is_nouveau_vieux },
94   { 0x10de, "nouveau", NULL, -1, },
95   { 0x1af4, "virtio_gpu", virtio_gpu_chip_ids, ARRAY_SIZE(virtio_gpu_chip_ids) },
96   { 0x15ad, "vmwgfx", vmwgfx_chip_ids, ARRAY_SIZE(vmwgfx_chip_ids) },
97   { 0x0000, NULL, NULL, 0 },
98};
99
100#endif /* _PCI_ID_DRIVER_MAP_H_ */
101