loader: include limits.h for PATH_MAX
[mesa.git] / src / loader / pci_id_driver_map.h
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
14 static 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
20 static const int i965_chip_ids[] = {
21 #define CHIPSET(chip, family, name) chip,
22 #define IRIS 0 /* all i965 devices */
23 #include "pci_ids/i965_pci_ids.h"
24 #undef IRIS
25 #undef CHIPSET
26 };
27
28 static const int iris_chip_ids_1[] = {
29 #define CHIPSET(chip, family, name) chip,
30 #define IRIS 1 /* iris devices to try before i965 */
31 #include "pci_ids/i965_pci_ids.h"
32 #undef IRIS
33 #undef CHIPSET
34 };
35
36 static const int iris_chip_ids_2[] = {
37 #define CHIPSET(chip, family, name) chip,
38 #define IRIS 2 /* iris devices to try after i965 */
39 #include "pci_ids/i965_pci_ids.h"
40 #undef IRIS
41 #undef CHIPSET
42 };
43
44 static const int r100_chip_ids[] = {
45 #define CHIPSET(chip, name, family) chip,
46 #include "pci_ids/radeon_pci_ids.h"
47 #undef CHIPSET
48 };
49
50 static const int r200_chip_ids[] = {
51 #define CHIPSET(chip, name, family) chip,
52 #include "pci_ids/r200_pci_ids.h"
53 #undef CHIPSET
54 };
55
56 static const int r300_chip_ids[] = {
57 #define CHIPSET(chip, name, family) chip,
58 #include "pci_ids/r300_pci_ids.h"
59 #undef CHIPSET
60 };
61
62 static const int r600_chip_ids[] = {
63 #define CHIPSET(chip, name, family) chip,
64 #include "pci_ids/r600_pci_ids.h"
65 #undef CHIPSET
66 };
67
68 static const int radeonsi_chip_ids[] = {
69 #define CHIPSET(chip, family) chip,
70 #include "pci_ids/radeonsi_pci_ids.h"
71 #undef CHIPSET
72 };
73
74 static const int virtio_gpu_chip_ids[] = {
75 #define CHIPSET(chip, name, family) chip,
76 #include "pci_ids/virtio_gpu_pci_ids.h"
77 #undef CHIPSET
78 };
79
80 static const int vmwgfx_chip_ids[] = {
81 #define CHIPSET(chip, name, family) chip,
82 #include "pci_ids/vmwgfx_pci_ids.h"
83 #undef CHIPSET
84 };
85
86 int is_nouveau_vieux(int fd);
87
88 static const struct {
89 int vendor_id;
90 const char *driver;
91 const int *chip_ids;
92 int num_chips_ids;
93 int (*predicate)(int fd);
94 } driver_map[] = {
95 { 0x8086, "i915", i915_chip_ids, ARRAY_SIZE(i915_chip_ids) },
96 { 0x8086, "iris", iris_chip_ids_1, ARRAY_SIZE(iris_chip_ids_1) },
97 { 0x8086, "i965", i965_chip_ids, ARRAY_SIZE(i965_chip_ids) },
98 { 0x8086, "iris", iris_chip_ids_2, ARRAY_SIZE(iris_chip_ids_2) },
99 { 0x1002, "radeon", r100_chip_ids, ARRAY_SIZE(r100_chip_ids) },
100 { 0x1002, "r200", r200_chip_ids, ARRAY_SIZE(r200_chip_ids) },
101 { 0x1002, "r300", r300_chip_ids, ARRAY_SIZE(r300_chip_ids) },
102 { 0x1002, "r600", r600_chip_ids, ARRAY_SIZE(r600_chip_ids) },
103 { 0x1002, "radeonsi", radeonsi_chip_ids, ARRAY_SIZE(radeonsi_chip_ids) },
104 { 0x10de, "nouveau_vieux", NULL, -1, is_nouveau_vieux },
105 { 0x10de, "nouveau", NULL, -1, },
106 { 0x1af4, "virtio_gpu", virtio_gpu_chip_ids, ARRAY_SIZE(virtio_gpu_chip_ids) },
107 { 0x15ad, "vmwgfx", vmwgfx_chip_ids, ARRAY_SIZE(vmwgfx_chip_ids) },
108 { 0x0000, NULL, NULL, 0 },
109 };
110
111 #endif /* _PCI_ID_DRIVER_MAP_H_ */