11da177e4SLinus Torvalds /* 21da177e4SLinus Torvalds * Device tables which are exported to userspace via 31da177e4SLinus Torvalds * scripts/table2alias.c. You must keep that file in sync with this 41da177e4SLinus Torvalds * header. 51da177e4SLinus Torvalds */ 61da177e4SLinus Torvalds 71da177e4SLinus Torvalds #ifndef LINUX_MOD_DEVICETABLE_H 81da177e4SLinus Torvalds #define LINUX_MOD_DEVICETABLE_H 91da177e4SLinus Torvalds 101da177e4SLinus Torvalds #ifdef __KERNEL__ 111da177e4SLinus Torvalds #include <linux/types.h> 121da177e4SLinus Torvalds typedef unsigned long kernel_ulong_t; 131da177e4SLinus Torvalds #endif 141da177e4SLinus Torvalds 151da177e4SLinus Torvalds #define PCI_ANY_ID (~0) 161da177e4SLinus Torvalds 171da177e4SLinus Torvalds struct pci_device_id { 181da177e4SLinus Torvalds __u32 vendor, device; /* Vendor and device ID or PCI_ANY_ID*/ 191da177e4SLinus Torvalds __u32 subvendor, subdevice; /* Subsystem ID's or PCI_ANY_ID */ 201da177e4SLinus Torvalds __u32 class, class_mask; /* (class,subclass,prog-if) triplet */ 211da177e4SLinus Torvalds kernel_ulong_t driver_data; /* Data private to the driver */ 221da177e4SLinus Torvalds }; 231da177e4SLinus Torvalds 241da177e4SLinus Torvalds 251da177e4SLinus Torvalds #define IEEE1394_MATCH_VENDOR_ID 0x0001 261da177e4SLinus Torvalds #define IEEE1394_MATCH_MODEL_ID 0x0002 271da177e4SLinus Torvalds #define IEEE1394_MATCH_SPECIFIER_ID 0x0004 281da177e4SLinus Torvalds #define IEEE1394_MATCH_VERSION 0x0008 291da177e4SLinus Torvalds 301da177e4SLinus Torvalds struct ieee1394_device_id { 311da177e4SLinus Torvalds __u32 match_flags; 321da177e4SLinus Torvalds __u32 vendor_id; 331da177e4SLinus Torvalds __u32 model_id; 341da177e4SLinus Torvalds __u32 specifier_id; 351da177e4SLinus Torvalds __u32 version; 361da177e4SLinus Torvalds kernel_ulong_t driver_data; 371da177e4SLinus Torvalds }; 381da177e4SLinus Torvalds 391da177e4SLinus Torvalds 401da177e4SLinus Torvalds /* 411da177e4SLinus Torvalds * Device table entry for "new style" table-driven USB drivers. 421da177e4SLinus Torvalds * User mode code can read these tables to choose which modules to load. 431da177e4SLinus Torvalds * Declare the table as a MODULE_DEVICE_TABLE. 441da177e4SLinus Torvalds * 451da177e4SLinus Torvalds * A probe() parameter will point to a matching entry from this table. 461da177e4SLinus Torvalds * Use the driver_info field for each match to hold information tied 471da177e4SLinus Torvalds * to that match: device quirks, etc. 481da177e4SLinus Torvalds * 491da177e4SLinus Torvalds * Terminate the driver's table with an all-zeroes entry. 501da177e4SLinus Torvalds * Use the flag values to control which fields are compared. 511da177e4SLinus Torvalds */ 521da177e4SLinus Torvalds 531da177e4SLinus Torvalds /** 541da177e4SLinus Torvalds * struct usb_device_id - identifies USB devices for probing and hotplugging 551da177e4SLinus Torvalds * @match_flags: Bit mask controlling of the other fields are used to match 561da177e4SLinus Torvalds * against new devices. Any field except for driver_info may be used, 571da177e4SLinus Torvalds * although some only make sense in conjunction with other fields. 581da177e4SLinus Torvalds * This is usually set by a USB_DEVICE_*() macro, which sets all 591da177e4SLinus Torvalds * other fields in this structure except for driver_info. 601da177e4SLinus Torvalds * @idVendor: USB vendor ID for a device; numbers are assigned 611da177e4SLinus Torvalds * by the USB forum to its members. 621da177e4SLinus Torvalds * @idProduct: Vendor-assigned product ID. 631da177e4SLinus Torvalds * @bcdDevice_lo: Low end of range of vendor-assigned product version numbers. 641da177e4SLinus Torvalds * This is also used to identify individual product versions, for 651da177e4SLinus Torvalds * a range consisting of a single device. 661da177e4SLinus Torvalds * @bcdDevice_hi: High end of version number range. The range of product 671da177e4SLinus Torvalds * versions is inclusive. 681da177e4SLinus Torvalds * @bDeviceClass: Class of device; numbers are assigned 691da177e4SLinus Torvalds * by the USB forum. Products may choose to implement classes, 701da177e4SLinus Torvalds * or be vendor-specific. Device classes specify behavior of all 711da177e4SLinus Torvalds * the interfaces on a devices. 721da177e4SLinus Torvalds * @bDeviceSubClass: Subclass of device; associated with bDeviceClass. 731da177e4SLinus Torvalds * @bDeviceProtocol: Protocol of device; associated with bDeviceClass. 741da177e4SLinus Torvalds * @bInterfaceClass: Class of interface; numbers are assigned 751da177e4SLinus Torvalds * by the USB forum. Products may choose to implement classes, 761da177e4SLinus Torvalds * or be vendor-specific. Interface classes specify behavior only 771da177e4SLinus Torvalds * of a given interface; other interfaces may support other classes. 781da177e4SLinus Torvalds * @bInterfaceSubClass: Subclass of interface; associated with bInterfaceClass. 791da177e4SLinus Torvalds * @bInterfaceProtocol: Protocol of interface; associated with bInterfaceClass. 801da177e4SLinus Torvalds * @driver_info: Holds information used by the driver. Usually it holds 811da177e4SLinus Torvalds * a pointer to a descriptor understood by the driver, or perhaps 821da177e4SLinus Torvalds * device flags. 831da177e4SLinus Torvalds * 841da177e4SLinus Torvalds * In most cases, drivers will create a table of device IDs by using 851da177e4SLinus Torvalds * USB_DEVICE(), or similar macros designed for that purpose. 861da177e4SLinus Torvalds * They will then export it to userspace using MODULE_DEVICE_TABLE(), 871da177e4SLinus Torvalds * and provide it to the USB core through their usb_driver structure. 881da177e4SLinus Torvalds * 891da177e4SLinus Torvalds * See the usb_match_id() function for information about how matches are 901da177e4SLinus Torvalds * performed. Briefly, you will normally use one of several macros to help 911da177e4SLinus Torvalds * construct these entries. Each entry you provide will either identify 921da177e4SLinus Torvalds * one or more specific products, or will identify a class of products 931da177e4SLinus Torvalds * which have agreed to behave the same. You should put the more specific 941da177e4SLinus Torvalds * matches towards the beginning of your table, so that driver_info can 951da177e4SLinus Torvalds * record quirks of specific products. 961da177e4SLinus Torvalds */ 971da177e4SLinus Torvalds struct usb_device_id { 981da177e4SLinus Torvalds /* which fields to match against? */ 991da177e4SLinus Torvalds __u16 match_flags; 1001da177e4SLinus Torvalds 1011da177e4SLinus Torvalds /* Used for product specific matches; range is inclusive */ 1021da177e4SLinus Torvalds __u16 idVendor; 1031da177e4SLinus Torvalds __u16 idProduct; 1041da177e4SLinus Torvalds __u16 bcdDevice_lo; 1051da177e4SLinus Torvalds __u16 bcdDevice_hi; 1061da177e4SLinus Torvalds 1071da177e4SLinus Torvalds /* Used for device class matches */ 1081da177e4SLinus Torvalds __u8 bDeviceClass; 1091da177e4SLinus Torvalds __u8 bDeviceSubClass; 1101da177e4SLinus Torvalds __u8 bDeviceProtocol; 1111da177e4SLinus Torvalds 1121da177e4SLinus Torvalds /* Used for interface class matches */ 1131da177e4SLinus Torvalds __u8 bInterfaceClass; 1141da177e4SLinus Torvalds __u8 bInterfaceSubClass; 1151da177e4SLinus Torvalds __u8 bInterfaceProtocol; 1161da177e4SLinus Torvalds 1171da177e4SLinus Torvalds /* not matched against */ 1181da177e4SLinus Torvalds kernel_ulong_t driver_info; 1191da177e4SLinus Torvalds }; 1201da177e4SLinus Torvalds 1211da177e4SLinus Torvalds /* Some useful macros to use to create struct usb_device_id */ 1221da177e4SLinus Torvalds #define USB_DEVICE_ID_MATCH_VENDOR 0x0001 1231da177e4SLinus Torvalds #define USB_DEVICE_ID_MATCH_PRODUCT 0x0002 1241da177e4SLinus Torvalds #define USB_DEVICE_ID_MATCH_DEV_LO 0x0004 1251da177e4SLinus Torvalds #define USB_DEVICE_ID_MATCH_DEV_HI 0x0008 1261da177e4SLinus Torvalds #define USB_DEVICE_ID_MATCH_DEV_CLASS 0x0010 1271da177e4SLinus Torvalds #define USB_DEVICE_ID_MATCH_DEV_SUBCLASS 0x0020 1281da177e4SLinus Torvalds #define USB_DEVICE_ID_MATCH_DEV_PROTOCOL 0x0040 1291da177e4SLinus Torvalds #define USB_DEVICE_ID_MATCH_INT_CLASS 0x0080 1301da177e4SLinus Torvalds #define USB_DEVICE_ID_MATCH_INT_SUBCLASS 0x0100 1311da177e4SLinus Torvalds #define USB_DEVICE_ID_MATCH_INT_PROTOCOL 0x0200 1321da177e4SLinus Torvalds 1331da177e4SLinus Torvalds /* s390 CCW devices */ 1341da177e4SLinus Torvalds struct ccw_device_id { 1351da177e4SLinus Torvalds __u16 match_flags; /* which fields to match against */ 1361da177e4SLinus Torvalds 1371da177e4SLinus Torvalds __u16 cu_type; /* control unit type */ 1381da177e4SLinus Torvalds __u16 dev_type; /* device type */ 1391da177e4SLinus Torvalds __u8 cu_model; /* control unit model */ 1401da177e4SLinus Torvalds __u8 dev_model; /* device model */ 1411da177e4SLinus Torvalds 1421da177e4SLinus Torvalds kernel_ulong_t driver_info; 1431da177e4SLinus Torvalds }; 1441da177e4SLinus Torvalds 1451da177e4SLinus Torvalds #define CCW_DEVICE_ID_MATCH_CU_TYPE 0x01 1461da177e4SLinus Torvalds #define CCW_DEVICE_ID_MATCH_CU_MODEL 0x02 1471da177e4SLinus Torvalds #define CCW_DEVICE_ID_MATCH_DEVICE_TYPE 0x04 1481da177e4SLinus Torvalds #define CCW_DEVICE_ID_MATCH_DEVICE_MODEL 0x08 1491da177e4SLinus Torvalds 1501da177e4SLinus Torvalds 1511da177e4SLinus Torvalds #define PNP_ID_LEN 8 1521da177e4SLinus Torvalds #define PNP_MAX_DEVICES 8 1531da177e4SLinus Torvalds 1541da177e4SLinus Torvalds struct pnp_device_id { 1551da177e4SLinus Torvalds __u8 id[PNP_ID_LEN]; 1561da177e4SLinus Torvalds kernel_ulong_t driver_data; 1571da177e4SLinus Torvalds }; 1581da177e4SLinus Torvalds 1591da177e4SLinus Torvalds struct pnp_card_device_id { 1601da177e4SLinus Torvalds __u8 id[PNP_ID_LEN]; 1611da177e4SLinus Torvalds kernel_ulong_t driver_data; 1621da177e4SLinus Torvalds struct { 1631da177e4SLinus Torvalds __u8 id[PNP_ID_LEN]; 1641da177e4SLinus Torvalds } devs[PNP_MAX_DEVICES]; 1651da177e4SLinus Torvalds }; 1661da177e4SLinus Torvalds 1671da177e4SLinus Torvalds 1681da177e4SLinus Torvalds #define SERIO_ANY 0xff 1691da177e4SLinus Torvalds 1701da177e4SLinus Torvalds struct serio_device_id { 1711da177e4SLinus Torvalds __u8 type; 1721da177e4SLinus Torvalds __u8 extra; 1731da177e4SLinus Torvalds __u8 id; 1741da177e4SLinus Torvalds __u8 proto; 1751da177e4SLinus Torvalds }; 1761da177e4SLinus Torvalds 1771da177e4SLinus Torvalds 1781ad275e3SDominik Brodowski /* PCMCIA */ 1791ad275e3SDominik Brodowski 1801ad275e3SDominik Brodowski struct pcmcia_device_id { 1811ad275e3SDominik Brodowski __u16 match_flags; 1821ad275e3SDominik Brodowski 1831ad275e3SDominik Brodowski __u16 manf_id; 1841ad275e3SDominik Brodowski __u16 card_id; 1851ad275e3SDominik Brodowski 1861ad275e3SDominik Brodowski __u8 func_id; 1871ad275e3SDominik Brodowski 1881ad275e3SDominik Brodowski /* for real multi-function devices */ 1891ad275e3SDominik Brodowski __u8 function; 1901ad275e3SDominik Brodowski 1911ad275e3SDominik Brodowski /* for pseude multi-function devices */ 1921ad275e3SDominik Brodowski __u8 device_no; 1931ad275e3SDominik Brodowski 1941ad275e3SDominik Brodowski const char * prod_id[4]; 1951ad275e3SDominik Brodowski __u32 prod_id_hash[4]; 1961ad275e3SDominik Brodowski 1971ad275e3SDominik Brodowski /* not matched against */ 1981ad275e3SDominik Brodowski kernel_ulong_t driver_info; 199ea7b3882SDominik Brodowski char * cisfile; 2001ad275e3SDominik Brodowski }; 2011ad275e3SDominik Brodowski 2021ad275e3SDominik Brodowski #define PCMCIA_DEV_ID_MATCH_MANF_ID 0x0001 2031ad275e3SDominik Brodowski #define PCMCIA_DEV_ID_MATCH_CARD_ID 0x0002 2041ad275e3SDominik Brodowski #define PCMCIA_DEV_ID_MATCH_FUNC_ID 0x0004 2051ad275e3SDominik Brodowski #define PCMCIA_DEV_ID_MATCH_FUNCTION 0x0008 2061ad275e3SDominik Brodowski #define PCMCIA_DEV_ID_MATCH_PROD_ID1 0x0010 2071ad275e3SDominik Brodowski #define PCMCIA_DEV_ID_MATCH_PROD_ID2 0x0020 2081ad275e3SDominik Brodowski #define PCMCIA_DEV_ID_MATCH_PROD_ID3 0x0040 2091ad275e3SDominik Brodowski #define PCMCIA_DEV_ID_MATCH_PROD_ID4 0x0080 2101ad275e3SDominik Brodowski #define PCMCIA_DEV_ID_MATCH_DEVICE_NO 0x0100 211ea7b3882SDominik Brodowski #define PCMCIA_DEV_ID_MATCH_FAKE_CIS 0x0200 212*f602ff7eSDominik Brodowski #define PCMCIA_DEV_ID_MATCH_ANONYMOUS 0x0400 2131ad275e3SDominik Brodowski 2141da177e4SLinus Torvalds #endif /* LINUX_MOD_DEVICETABLE_H */ 215