11da177e4SLinus Torvalds /* 21da177e4SLinus Torvalds * Device tables which are exported to userspace via 3fb120da6SStephen Rothwell * scripts/mod/file2alias.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; 369e2d3cd3SAl Viro kernel_ulong_t driver_data 379e2d3cd3SAl Viro __attribute__((aligned(sizeof(kernel_ulong_t)))); 381da177e4SLinus Torvalds }; 391da177e4SLinus Torvalds 401da177e4SLinus Torvalds 411da177e4SLinus Torvalds /* 421da177e4SLinus Torvalds * Device table entry for "new style" table-driven USB drivers. 431da177e4SLinus Torvalds * User mode code can read these tables to choose which modules to load. 441da177e4SLinus Torvalds * Declare the table as a MODULE_DEVICE_TABLE. 451da177e4SLinus Torvalds * 461da177e4SLinus Torvalds * A probe() parameter will point to a matching entry from this table. 471da177e4SLinus Torvalds * Use the driver_info field for each match to hold information tied 481da177e4SLinus Torvalds * to that match: device quirks, etc. 491da177e4SLinus Torvalds * 501da177e4SLinus Torvalds * Terminate the driver's table with an all-zeroes entry. 511da177e4SLinus Torvalds * Use the flag values to control which fields are compared. 521da177e4SLinus Torvalds */ 531da177e4SLinus Torvalds 541da177e4SLinus Torvalds /** 551da177e4SLinus Torvalds * struct usb_device_id - identifies USB devices for probing and hotplugging 561da177e4SLinus Torvalds * @match_flags: Bit mask controlling of the other fields are used to match 571da177e4SLinus Torvalds * against new devices. Any field except for driver_info may be used, 581da177e4SLinus Torvalds * although some only make sense in conjunction with other fields. 591da177e4SLinus Torvalds * This is usually set by a USB_DEVICE_*() macro, which sets all 601da177e4SLinus Torvalds * other fields in this structure except for driver_info. 611da177e4SLinus Torvalds * @idVendor: USB vendor ID for a device; numbers are assigned 621da177e4SLinus Torvalds * by the USB forum to its members. 631da177e4SLinus Torvalds * @idProduct: Vendor-assigned product ID. 641da177e4SLinus Torvalds * @bcdDevice_lo: Low end of range of vendor-assigned product version numbers. 651da177e4SLinus Torvalds * This is also used to identify individual product versions, for 661da177e4SLinus Torvalds * a range consisting of a single device. 671da177e4SLinus Torvalds * @bcdDevice_hi: High end of version number range. The range of product 681da177e4SLinus Torvalds * versions is inclusive. 691da177e4SLinus Torvalds * @bDeviceClass: Class of device; numbers are assigned 701da177e4SLinus Torvalds * by the USB forum. Products may choose to implement classes, 711da177e4SLinus Torvalds * or be vendor-specific. Device classes specify behavior of all 721da177e4SLinus Torvalds * the interfaces on a devices. 731da177e4SLinus Torvalds * @bDeviceSubClass: Subclass of device; associated with bDeviceClass. 741da177e4SLinus Torvalds * @bDeviceProtocol: Protocol of device; associated with bDeviceClass. 751da177e4SLinus Torvalds * @bInterfaceClass: Class of interface; numbers are assigned 761da177e4SLinus Torvalds * by the USB forum. Products may choose to implement classes, 771da177e4SLinus Torvalds * or be vendor-specific. Interface classes specify behavior only 781da177e4SLinus Torvalds * of a given interface; other interfaces may support other classes. 791da177e4SLinus Torvalds * @bInterfaceSubClass: Subclass of interface; associated with bInterfaceClass. 801da177e4SLinus Torvalds * @bInterfaceProtocol: Protocol of interface; associated with bInterfaceClass. 811da177e4SLinus Torvalds * @driver_info: Holds information used by the driver. Usually it holds 821da177e4SLinus Torvalds * a pointer to a descriptor understood by the driver, or perhaps 831da177e4SLinus Torvalds * device flags. 841da177e4SLinus Torvalds * 851da177e4SLinus Torvalds * In most cases, drivers will create a table of device IDs by using 861da177e4SLinus Torvalds * USB_DEVICE(), or similar macros designed for that purpose. 871da177e4SLinus Torvalds * They will then export it to userspace using MODULE_DEVICE_TABLE(), 881da177e4SLinus Torvalds * and provide it to the USB core through their usb_driver structure. 891da177e4SLinus Torvalds * 901da177e4SLinus Torvalds * See the usb_match_id() function for information about how matches are 911da177e4SLinus Torvalds * performed. Briefly, you will normally use one of several macros to help 921da177e4SLinus Torvalds * construct these entries. Each entry you provide will either identify 931da177e4SLinus Torvalds * one or more specific products, or will identify a class of products 941da177e4SLinus Torvalds * which have agreed to behave the same. You should put the more specific 951da177e4SLinus Torvalds * matches towards the beginning of your table, so that driver_info can 961da177e4SLinus Torvalds * record quirks of specific products. 971da177e4SLinus Torvalds */ 981da177e4SLinus Torvalds struct usb_device_id { 991da177e4SLinus Torvalds /* which fields to match against? */ 1001da177e4SLinus Torvalds __u16 match_flags; 1011da177e4SLinus Torvalds 1021da177e4SLinus Torvalds /* Used for product specific matches; range is inclusive */ 1031da177e4SLinus Torvalds __u16 idVendor; 1041da177e4SLinus Torvalds __u16 idProduct; 1051da177e4SLinus Torvalds __u16 bcdDevice_lo; 1061da177e4SLinus Torvalds __u16 bcdDevice_hi; 1071da177e4SLinus Torvalds 1081da177e4SLinus Torvalds /* Used for device class matches */ 1091da177e4SLinus Torvalds __u8 bDeviceClass; 1101da177e4SLinus Torvalds __u8 bDeviceSubClass; 1111da177e4SLinus Torvalds __u8 bDeviceProtocol; 1121da177e4SLinus Torvalds 1131da177e4SLinus Torvalds /* Used for interface class matches */ 1141da177e4SLinus Torvalds __u8 bInterfaceClass; 1151da177e4SLinus Torvalds __u8 bInterfaceSubClass; 1161da177e4SLinus Torvalds __u8 bInterfaceProtocol; 1171da177e4SLinus Torvalds 1181da177e4SLinus Torvalds /* not matched against */ 1191da177e4SLinus Torvalds kernel_ulong_t driver_info; 1201da177e4SLinus Torvalds }; 1211da177e4SLinus Torvalds 1221da177e4SLinus Torvalds /* Some useful macros to use to create struct usb_device_id */ 1231da177e4SLinus Torvalds #define USB_DEVICE_ID_MATCH_VENDOR 0x0001 1241da177e4SLinus Torvalds #define USB_DEVICE_ID_MATCH_PRODUCT 0x0002 1251da177e4SLinus Torvalds #define USB_DEVICE_ID_MATCH_DEV_LO 0x0004 1261da177e4SLinus Torvalds #define USB_DEVICE_ID_MATCH_DEV_HI 0x0008 1271da177e4SLinus Torvalds #define USB_DEVICE_ID_MATCH_DEV_CLASS 0x0010 1281da177e4SLinus Torvalds #define USB_DEVICE_ID_MATCH_DEV_SUBCLASS 0x0020 1291da177e4SLinus Torvalds #define USB_DEVICE_ID_MATCH_DEV_PROTOCOL 0x0040 1301da177e4SLinus Torvalds #define USB_DEVICE_ID_MATCH_INT_CLASS 0x0080 1311da177e4SLinus Torvalds #define USB_DEVICE_ID_MATCH_INT_SUBCLASS 0x0100 1321da177e4SLinus Torvalds #define USB_DEVICE_ID_MATCH_INT_PROTOCOL 0x0200 1331da177e4SLinus Torvalds 1341da177e4SLinus Torvalds /* s390 CCW devices */ 1351da177e4SLinus Torvalds struct ccw_device_id { 1361da177e4SLinus Torvalds __u16 match_flags; /* which fields to match against */ 1371da177e4SLinus Torvalds 1381da177e4SLinus Torvalds __u16 cu_type; /* control unit type */ 1391da177e4SLinus Torvalds __u16 dev_type; /* device type */ 1401da177e4SLinus Torvalds __u8 cu_model; /* control unit model */ 1411da177e4SLinus Torvalds __u8 dev_model; /* device model */ 1421da177e4SLinus Torvalds 1431da177e4SLinus Torvalds kernel_ulong_t driver_info; 1441da177e4SLinus Torvalds }; 1451da177e4SLinus Torvalds 1461da177e4SLinus Torvalds #define CCW_DEVICE_ID_MATCH_CU_TYPE 0x01 1471da177e4SLinus Torvalds #define CCW_DEVICE_ID_MATCH_CU_MODEL 0x02 1481da177e4SLinus Torvalds #define CCW_DEVICE_ID_MATCH_DEVICE_TYPE 0x04 1491da177e4SLinus Torvalds #define CCW_DEVICE_ID_MATCH_DEVICE_MODEL 0x08 1501da177e4SLinus Torvalds 1511da177e4SLinus Torvalds 1521da177e4SLinus Torvalds #define PNP_ID_LEN 8 1531da177e4SLinus Torvalds #define PNP_MAX_DEVICES 8 1541da177e4SLinus Torvalds 1551da177e4SLinus Torvalds struct pnp_device_id { 1561da177e4SLinus Torvalds __u8 id[PNP_ID_LEN]; 1571da177e4SLinus Torvalds kernel_ulong_t driver_data; 1581da177e4SLinus Torvalds }; 1591da177e4SLinus Torvalds 1601da177e4SLinus Torvalds struct pnp_card_device_id { 1611da177e4SLinus Torvalds __u8 id[PNP_ID_LEN]; 1621da177e4SLinus Torvalds kernel_ulong_t driver_data; 1631da177e4SLinus Torvalds struct { 1641da177e4SLinus Torvalds __u8 id[PNP_ID_LEN]; 1651da177e4SLinus Torvalds } devs[PNP_MAX_DEVICES]; 1661da177e4SLinus Torvalds }; 1671da177e4SLinus Torvalds 1681da177e4SLinus Torvalds 1691da177e4SLinus Torvalds #define SERIO_ANY 0xff 1701da177e4SLinus Torvalds 1711da177e4SLinus Torvalds struct serio_device_id { 1721da177e4SLinus Torvalds __u8 type; 1731da177e4SLinus Torvalds __u8 extra; 1741da177e4SLinus Torvalds __u8 id; 1751da177e4SLinus Torvalds __u8 proto; 1761da177e4SLinus Torvalds }; 1771da177e4SLinus Torvalds 1785e655772SJeff Mahoney /* 1795e655772SJeff Mahoney * Struct used for matching a device 1805e655772SJeff Mahoney */ 1815e655772SJeff Mahoney struct of_device_id 1825e655772SJeff Mahoney { 1835e655772SJeff Mahoney char name[32]; 1845e655772SJeff Mahoney char type[32]; 1855e655772SJeff Mahoney char compatible[128]; 186*fd2e54b3SDiego Calleja #ifdef __KERNEL__ 1875e655772SJeff Mahoney void *data; 1889e2d3cd3SAl Viro #else 1899e2d3cd3SAl Viro kernel_ulong_t data; 1909e2d3cd3SAl Viro #endif 1915e655772SJeff Mahoney }; 1925e655772SJeff Mahoney 193fb120da6SStephen Rothwell /* VIO */ 194fb120da6SStephen Rothwell struct vio_device_id { 195fb120da6SStephen Rothwell char type[32]; 196fb120da6SStephen Rothwell char compat[32]; 197fb120da6SStephen Rothwell }; 1981da177e4SLinus Torvalds 1991ad275e3SDominik Brodowski /* PCMCIA */ 2001ad275e3SDominik Brodowski 2011ad275e3SDominik Brodowski struct pcmcia_device_id { 2021ad275e3SDominik Brodowski __u16 match_flags; 2031ad275e3SDominik Brodowski 2041ad275e3SDominik Brodowski __u16 manf_id; 2051ad275e3SDominik Brodowski __u16 card_id; 2061ad275e3SDominik Brodowski 2071ad275e3SDominik Brodowski __u8 func_id; 2081ad275e3SDominik Brodowski 2091ad275e3SDominik Brodowski /* for real multi-function devices */ 2101ad275e3SDominik Brodowski __u8 function; 2111ad275e3SDominik Brodowski 2124fb7edceSKars de Jong /* for pseudo multi-function devices */ 2131ad275e3SDominik Brodowski __u8 device_no; 2141ad275e3SDominik Brodowski 2154fb7edceSKars de Jong __u32 prod_id_hash[4] 2164fb7edceSKars de Jong __attribute__((aligned(sizeof(__u32)))); 2171ad275e3SDominik Brodowski 218aecab27aSDominik Brodowski /* not matched against in kernelspace*/ 219aecab27aSDominik Brodowski #ifdef __KERNEL__ 220aecab27aSDominik Brodowski const char * prod_id[4]; 221aecab27aSDominik Brodowski #else 2229e2d3cd3SAl Viro kernel_ulong_t prod_id[4] 2239e2d3cd3SAl Viro __attribute__((aligned(sizeof(kernel_ulong_t)))); 224aecab27aSDominik Brodowski #endif 225aecab27aSDominik Brodowski 2261ad275e3SDominik Brodowski /* not matched against */ 2271ad275e3SDominik Brodowski kernel_ulong_t driver_info; 228aecab27aSDominik Brodowski #ifdef __KERNEL__ 229ea7b3882SDominik Brodowski char * cisfile; 230aecab27aSDominik Brodowski #else 231aecab27aSDominik Brodowski kernel_ulong_t cisfile; 232aecab27aSDominik Brodowski #endif 2331ad275e3SDominik Brodowski }; 2341ad275e3SDominik Brodowski 2351ad275e3SDominik Brodowski #define PCMCIA_DEV_ID_MATCH_MANF_ID 0x0001 2361ad275e3SDominik Brodowski #define PCMCIA_DEV_ID_MATCH_CARD_ID 0x0002 2371ad275e3SDominik Brodowski #define PCMCIA_DEV_ID_MATCH_FUNC_ID 0x0004 2381ad275e3SDominik Brodowski #define PCMCIA_DEV_ID_MATCH_FUNCTION 0x0008 2391ad275e3SDominik Brodowski #define PCMCIA_DEV_ID_MATCH_PROD_ID1 0x0010 2401ad275e3SDominik Brodowski #define PCMCIA_DEV_ID_MATCH_PROD_ID2 0x0020 2411ad275e3SDominik Brodowski #define PCMCIA_DEV_ID_MATCH_PROD_ID3 0x0040 2421ad275e3SDominik Brodowski #define PCMCIA_DEV_ID_MATCH_PROD_ID4 0x0080 2431ad275e3SDominik Brodowski #define PCMCIA_DEV_ID_MATCH_DEVICE_NO 0x0100 244ea7b3882SDominik Brodowski #define PCMCIA_DEV_ID_MATCH_FAKE_CIS 0x0200 245f602ff7eSDominik Brodowski #define PCMCIA_DEV_ID_MATCH_ANONYMOUS 0x0400 2461ad275e3SDominik Brodowski 2471da177e4SLinus Torvalds #endif /* LINUX_MOD_DEVICETABLE_H */ 248