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