1
2
3
4
5
6
7#ifndef LINUX_MOD_DEVICETABLE_H
8#define LINUX_MOD_DEVICETABLE_H
9
10#ifdef __KERNEL__
11#include <linux/types.h>
12#include <linux/uuid.h>
13typedef unsigned long kernel_ulong_t;
14#endif
15
16#define PCI_ANY_ID (~0)
17
18struct pci_device_id {
19 __u32 vendor, device;
20 __u32 subvendor, subdevice;
21 __u32 class, class_mask;
22 kernel_ulong_t driver_data;
23};
24
25
26#define IEEE1394_MATCH_VENDOR_ID 0x0001
27#define IEEE1394_MATCH_MODEL_ID 0x0002
28#define IEEE1394_MATCH_SPECIFIER_ID 0x0004
29#define IEEE1394_MATCH_VERSION 0x0008
30
31struct ieee1394_device_id {
32 __u32 match_flags;
33 __u32 vendor_id;
34 __u32 model_id;
35 __u32 specifier_id;
36 __u32 version;
37 kernel_ulong_t driver_data;
38};
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101struct usb_device_id {
102
103 __u16 match_flags;
104
105
106 __u16 idVendor;
107 __u16 idProduct;
108 __u16 bcdDevice_lo;
109 __u16 bcdDevice_hi;
110
111
112 __u8 bDeviceClass;
113 __u8 bDeviceSubClass;
114 __u8 bDeviceProtocol;
115
116
117 __u8 bInterfaceClass;
118 __u8 bInterfaceSubClass;
119 __u8 bInterfaceProtocol;
120
121
122 __u8 bInterfaceNumber;
123
124
125 kernel_ulong_t driver_info
126 __attribute__((aligned(sizeof(kernel_ulong_t))));
127};
128
129
130#define USB_DEVICE_ID_MATCH_VENDOR 0x0001
131#define USB_DEVICE_ID_MATCH_PRODUCT 0x0002
132#define USB_DEVICE_ID_MATCH_DEV_LO 0x0004
133#define USB_DEVICE_ID_MATCH_DEV_HI 0x0008
134#define USB_DEVICE_ID_MATCH_DEV_CLASS 0x0010
135#define USB_DEVICE_ID_MATCH_DEV_SUBCLASS 0x0020
136#define USB_DEVICE_ID_MATCH_DEV_PROTOCOL 0x0040
137#define USB_DEVICE_ID_MATCH_INT_CLASS 0x0080
138#define USB_DEVICE_ID_MATCH_INT_SUBCLASS 0x0100
139#define USB_DEVICE_ID_MATCH_INT_PROTOCOL 0x0200
140#define USB_DEVICE_ID_MATCH_INT_NUMBER 0x0400
141
142#define HID_ANY_ID (~0)
143#define HID_BUS_ANY 0xffff
144#define HID_GROUP_ANY 0x0000
145
146struct hid_device_id {
147 __u16 bus;
148 __u16 group;
149 __u32 vendor;
150 __u32 product;
151 kernel_ulong_t driver_data;
152};
153
154
155struct ccw_device_id {
156 __u16 match_flags;
157
158 __u16 cu_type;
159 __u16 dev_type;
160 __u8 cu_model;
161 __u8 dev_model;
162
163 kernel_ulong_t driver_info;
164};
165
166#define CCW_DEVICE_ID_MATCH_CU_TYPE 0x01
167#define CCW_DEVICE_ID_MATCH_CU_MODEL 0x02
168#define CCW_DEVICE_ID_MATCH_DEVICE_TYPE 0x04
169#define CCW_DEVICE_ID_MATCH_DEVICE_MODEL 0x08
170
171
172struct ap_device_id {
173 __u16 match_flags;
174 __u8 dev_type;
175 kernel_ulong_t driver_info;
176};
177
178#define AP_DEVICE_ID_MATCH_CARD_TYPE 0x01
179#define AP_DEVICE_ID_MATCH_QUEUE_TYPE 0x02
180
181
182struct css_device_id {
183 __u8 match_flags;
184 __u8 type;
185 kernel_ulong_t driver_data;
186};
187
188#define ACPI_ID_LEN 9
189
190struct acpi_device_id {
191 __u8 id[ACPI_ID_LEN];
192 kernel_ulong_t driver_data;
193};
194
195#define PNP_ID_LEN 8
196#define PNP_MAX_DEVICES 8
197
198struct pnp_device_id {
199 __u8 id[PNP_ID_LEN];
200 kernel_ulong_t driver_data;
201};
202
203struct pnp_card_device_id {
204 __u8 id[PNP_ID_LEN];
205 kernel_ulong_t driver_data;
206 struct {
207 __u8 id[PNP_ID_LEN];
208 } devs[PNP_MAX_DEVICES];
209};
210
211
212#define SERIO_ANY 0xff
213
214struct serio_device_id {
215 __u8 type;
216 __u8 extra;
217 __u8 id;
218 __u8 proto;
219};
220
221struct hda_device_id {
222 __u32 vendor_id;
223 __u32 rev_id;
224 __u8 api_version;
225 const char *name;
226 unsigned long driver_data;
227};
228
229
230
231
232struct of_device_id
233{
234 char name[32];
235 char type[32];
236 char compatible[128];
237 const void *data;
238};
239
240
241struct vio_device_id {
242 char type[32];
243 char compat[32];
244};
245
246
247
248struct pcmcia_device_id {
249 __u16 match_flags;
250
251 __u16 manf_id;
252 __u16 card_id;
253
254 __u8 func_id;
255
256
257 __u8 function;
258
259
260 __u8 device_no;
261
262 __u32 prod_id_hash[4];
263
264
265 const char * prod_id[4];
266
267
268 kernel_ulong_t driver_info;
269 char * cisfile;
270};
271
272#define PCMCIA_DEV_ID_MATCH_MANF_ID 0x0001
273#define PCMCIA_DEV_ID_MATCH_CARD_ID 0x0002
274#define PCMCIA_DEV_ID_MATCH_FUNC_ID 0x0004
275#define PCMCIA_DEV_ID_MATCH_FUNCTION 0x0008
276#define PCMCIA_DEV_ID_MATCH_PROD_ID1 0x0010
277#define PCMCIA_DEV_ID_MATCH_PROD_ID2 0x0020
278#define PCMCIA_DEV_ID_MATCH_PROD_ID3 0x0040
279#define PCMCIA_DEV_ID_MATCH_PROD_ID4 0x0080
280#define PCMCIA_DEV_ID_MATCH_DEVICE_NO 0x0100
281#define PCMCIA_DEV_ID_MATCH_FAKE_CIS 0x0200
282#define PCMCIA_DEV_ID_MATCH_ANONYMOUS 0x0400
283
284
285#define INPUT_DEVICE_ID_EV_MAX 0x1f
286#define INPUT_DEVICE_ID_KEY_MIN_INTERESTING 0x71
287#define INPUT_DEVICE_ID_KEY_MAX 0x2ff
288#define INPUT_DEVICE_ID_REL_MAX 0x0f
289#define INPUT_DEVICE_ID_ABS_MAX 0x3f
290#define INPUT_DEVICE_ID_MSC_MAX 0x07
291#define INPUT_DEVICE_ID_LED_MAX 0x0f
292#define INPUT_DEVICE_ID_SND_MAX 0x07
293#define INPUT_DEVICE_ID_FF_MAX 0x7f
294#define INPUT_DEVICE_ID_SW_MAX 0x0f
295
296#define INPUT_DEVICE_ID_MATCH_BUS 1
297#define INPUT_DEVICE_ID_MATCH_VENDOR 2
298#define INPUT_DEVICE_ID_MATCH_PRODUCT 4
299#define INPUT_DEVICE_ID_MATCH_VERSION 8
300
301#define INPUT_DEVICE_ID_MATCH_EVBIT 0x0010
302#define INPUT_DEVICE_ID_MATCH_KEYBIT 0x0020
303#define INPUT_DEVICE_ID_MATCH_RELBIT 0x0040
304#define INPUT_DEVICE_ID_MATCH_ABSBIT 0x0080
305#define INPUT_DEVICE_ID_MATCH_MSCIT 0x0100
306#define INPUT_DEVICE_ID_MATCH_LEDBIT 0x0200
307#define INPUT_DEVICE_ID_MATCH_SNDBIT 0x0400
308#define INPUT_DEVICE_ID_MATCH_FFBIT 0x0800
309#define INPUT_DEVICE_ID_MATCH_SWBIT 0x1000
310
311struct input_device_id {
312
313 kernel_ulong_t flags;
314
315 __u16 bustype;
316 __u16 vendor;
317 __u16 product;
318 __u16 version;
319
320 kernel_ulong_t evbit[INPUT_DEVICE_ID_EV_MAX / BITS_PER_LONG + 1];
321 kernel_ulong_t keybit[INPUT_DEVICE_ID_KEY_MAX / BITS_PER_LONG + 1];
322 kernel_ulong_t relbit[INPUT_DEVICE_ID_REL_MAX / BITS_PER_LONG + 1];
323 kernel_ulong_t absbit[INPUT_DEVICE_ID_ABS_MAX / BITS_PER_LONG + 1];
324 kernel_ulong_t mscbit[INPUT_DEVICE_ID_MSC_MAX / BITS_PER_LONG + 1];
325 kernel_ulong_t ledbit[INPUT_DEVICE_ID_LED_MAX / BITS_PER_LONG + 1];
326 kernel_ulong_t sndbit[INPUT_DEVICE_ID_SND_MAX / BITS_PER_LONG + 1];
327 kernel_ulong_t ffbit[INPUT_DEVICE_ID_FF_MAX / BITS_PER_LONG + 1];
328 kernel_ulong_t swbit[INPUT_DEVICE_ID_SW_MAX / BITS_PER_LONG + 1];
329
330 kernel_ulong_t driver_info;
331};
332
333
334
335#define EISA_SIG_LEN 8
336
337
338struct eisa_device_id {
339 char sig[EISA_SIG_LEN];
340 kernel_ulong_t driver_data;
341};
342
343#define EISA_DEVICE_MODALIAS_FMT "eisa:s%s"
344
345struct parisc_device_id {
346 __u8 hw_type;
347 __u8 hversion_rev;
348 __u16 hversion;
349 __u32 sversion;
350};
351
352#define PA_HWTYPE_ANY_ID 0xff
353#define PA_HVERSION_REV_ANY_ID 0xff
354#define PA_HVERSION_ANY_ID 0xffff
355#define PA_SVERSION_ANY_ID 0xffffffff
356
357
358
359#define SDIO_ANY_ID (~0)
360
361struct sdio_device_id {
362 __u8 class;
363 __u16 vendor;
364 __u16 device;
365 kernel_ulong_t driver_data;
366};
367
368
369struct ssb_device_id {
370 __u16 vendor;
371 __u16 coreid;
372 __u8 revision;
373};
374#define SSB_DEVICE(_vendor, _coreid, _revision) \
375 { .vendor = _vendor, .coreid = _coreid, .revision = _revision, }
376#define SSB_DEVTABLE_END \
377 { 0, },
378
379#define SSB_ANY_VENDOR 0xFFFF
380#define SSB_ANY_ID 0xFFFF
381#define SSB_ANY_REV 0xFF
382
383
384struct bcma_device_id {
385 __u16 manuf;
386 __u16 id;
387 __u8 rev;
388 __u8 class;
389};
390#define BCMA_CORE(_manuf, _id, _rev, _class) \
391 { .manuf = _manuf, .id = _id, .rev = _rev, .class = _class, }
392#define BCMA_CORETABLE_END \
393 { 0, },
394
395#define BCMA_ANY_MANUF 0xFFFF
396#define BCMA_ANY_ID 0xFFFF
397#define BCMA_ANY_REV 0xFF
398#define BCMA_ANY_CLASS 0xFF
399
400struct virtio_device_id {
401 __u32 device;
402 __u32 vendor;
403};
404#define VIRTIO_DEV_ANY_ID 0xffffffff
405
406
407
408
409struct hv_vmbus_device_id {
410 uuid_le guid;
411 kernel_ulong_t driver_data;
412};
413
414
415
416#define RPMSG_NAME_SIZE 32
417#define RPMSG_DEVICE_MODALIAS_FMT "rpmsg:%s"
418
419struct rpmsg_device_id {
420 char name[RPMSG_NAME_SIZE];
421};
422
423
424
425#define I2C_NAME_SIZE 20
426#define I2C_MODULE_PREFIX "i2c:"
427
428struct i2c_device_id {
429 char name[I2C_NAME_SIZE];
430 kernel_ulong_t driver_data;
431};
432
433
434
435#define SPI_NAME_SIZE 32
436#define SPI_MODULE_PREFIX "spi:"
437
438struct spi_device_id {
439 char name[SPI_NAME_SIZE];
440 kernel_ulong_t driver_data;
441};
442
443
444enum dmi_field {
445 DMI_NONE,
446 DMI_BIOS_VENDOR,
447 DMI_BIOS_VERSION,
448 DMI_BIOS_DATE,
449 DMI_SYS_VENDOR,
450 DMI_PRODUCT_NAME,
451 DMI_PRODUCT_VERSION,
452 DMI_PRODUCT_SERIAL,
453 DMI_PRODUCT_UUID,
454 DMI_BOARD_VENDOR,
455 DMI_BOARD_NAME,
456 DMI_BOARD_VERSION,
457 DMI_BOARD_SERIAL,
458 DMI_BOARD_ASSET_TAG,
459 DMI_CHASSIS_VENDOR,
460 DMI_CHASSIS_TYPE,
461 DMI_CHASSIS_VERSION,
462 DMI_CHASSIS_SERIAL,
463 DMI_CHASSIS_ASSET_TAG,
464 DMI_STRING_MAX,
465};
466
467struct dmi_strmatch {
468 unsigned char slot:7;
469 unsigned char exact_match:1;
470 char substr[79];
471};
472
473struct dmi_system_id {
474 int (*callback)(const struct dmi_system_id *);
475 const char *ident;
476 struct dmi_strmatch matches[4];
477 void *driver_data;
478};
479
480
481
482
483
484
485#define dmi_device_id dmi_system_id
486
487#define DMI_MATCH(a, b) { .slot = a, .substr = b }
488#define DMI_EXACT_MATCH(a, b) { .slot = a, .substr = b, .exact_match = 1 }
489
490#define PLATFORM_NAME_SIZE 20
491#define PLATFORM_MODULE_PREFIX "platform:"
492
493struct platform_device_id {
494 char name[PLATFORM_NAME_SIZE];
495 kernel_ulong_t driver_data;
496};
497
498#define MDIO_MODULE_PREFIX "mdio:"
499
500#define MDIO_ID_FMT "%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d%d"
501#define MDIO_ID_ARGS(_id) \
502 (_id)>>31, ((_id)>>30) & 1, ((_id)>>29) & 1, ((_id)>>28) & 1, \
503 ((_id)>>27) & 1, ((_id)>>26) & 1, ((_id)>>25) & 1, ((_id)>>24) & 1, \
504 ((_id)>>23) & 1, ((_id)>>22) & 1, ((_id)>>21) & 1, ((_id)>>20) & 1, \
505 ((_id)>>19) & 1, ((_id)>>18) & 1, ((_id)>>17) & 1, ((_id)>>16) & 1, \
506 ((_id)>>15) & 1, ((_id)>>14) & 1, ((_id)>>13) & 1, ((_id)>>12) & 1, \
507 ((_id)>>11) & 1, ((_id)>>10) & 1, ((_id)>>9) & 1, ((_id)>>8) & 1, \
508 ((_id)>>7) & 1, ((_id)>>6) & 1, ((_id)>>5) & 1, ((_id)>>4) & 1, \
509 ((_id)>>3) & 1, ((_id)>>2) & 1, ((_id)>>1) & 1, (_id) & 1
510
511
512
513
514
515
516
517
518
519struct mdio_device_id {
520 __u32 phy_id;
521 __u32 phy_id_mask;
522};
523
524struct zorro_device_id {
525 __u32 id;
526 kernel_ulong_t driver_data;
527};
528
529#define ZORRO_WILDCARD (0xffffffff)
530
531#define ZORRO_DEVICE_MODALIAS_FMT "zorro:i%08X"
532
533#define ISAPNP_ANY_ID 0xffff
534struct isapnp_device_id {
535 unsigned short card_vendor, card_device;
536 unsigned short vendor, function;
537 kernel_ulong_t driver_data;
538};
539
540
541
542
543
544
545
546
547
548struct amba_id {
549 unsigned int id;
550 unsigned int mask;
551 void *data;
552};
553
554
555
556
557
558
559
560
561
562
563#define x86cpu_device_id x86_cpu_id
564struct x86_cpu_id {
565 __u16 vendor;
566 __u16 family;
567 __u16 model;
568 __u16 feature;
569 kernel_ulong_t driver_data;
570};
571
572#define X86_FEATURE_MATCH(x) \
573 { X86_VENDOR_ANY, X86_FAMILY_ANY, X86_MODEL_ANY, x }
574
575#define X86_VENDOR_ANY 0xffff
576#define X86_FAMILY_ANY 0
577#define X86_MODEL_ANY 0
578#define X86_FEATURE_ANY 0
579
580#define IPACK_ANY_FORMAT 0xff
581#define IPACK_ANY_ID (~0)
582struct ipack_device_id {
583 __u8 format;
584 __u32 vendor;
585 __u32 device;
586};
587
588#define MEI_CL_MODULE_PREFIX "mei:"
589#define MEI_CL_NAME_SIZE 32
590#define MEI_CL_VERSION_ANY 0xff
591
592
593
594
595
596
597
598
599
600
601struct mei_cl_device_id {
602 char name[MEI_CL_NAME_SIZE];
603 uuid_le uuid;
604 __u8 version;
605 kernel_ulong_t driver_info;
606};
607
608struct ulpi_device_id {
609 __u16 vendor;
610 __u16 product;
611 kernel_ulong_t driver_data;
612};
613
614#endif
615