1
2
3
4
5
6
7
8
9
10
11
12
13
14 #include <linux/kernel.h>
15 #include <linux/tty.h>
16 #include <linux/module.h>
17 #include <linux/usb.h>
18 #include <linux/usb/serial.h>
19
20 #define DEVICE_N(vendor, IDS, nport) \
21 static const struct usb_device_id vendor##_id_table[] = { \
22 IDS(), \
23 { }, \
24 }; \
25 static struct usb_serial_driver vendor##_device = { \
26 .driver = { \
27 .owner = THIS_MODULE, \
28 .name = #vendor, \
29 }, \
30 .id_table = vendor##_id_table, \
31 .num_ports = nport, \
32 };
33
34 #define DEVICE(vendor, IDS) DEVICE_N(vendor, IDS, 1)
35
36
37 #define CARELINK_IDS() \
38 { USB_DEVICE(0x0a21, 0x8001) }
39 DEVICE(carelink, CARELINK_IDS);
40
41
42 #define ZIO_IDS() \
43 { USB_DEVICE(0x1CBE, 0x0103) }
44 DEVICE(zio, ZIO_IDS);
45
46
47 #define FUNSOFT_IDS() \
48 { USB_DEVICE(0x1404, 0xcddc) }
49 DEVICE(funsoft, FUNSOFT_IDS);
50
51
52 #define FLASHLOADER_IDS() \
53 { USB_DEVICE_INTERFACE_CLASS(0x058b, 0x0041, USB_CLASS_CDC_DATA) }, \
54 { USB_DEVICE(0x8087, 0x0716) }, \
55 { USB_DEVICE(0x8087, 0x0801) }
56 DEVICE(flashloader, FLASHLOADER_IDS);
57
58
59 #define GOOGLE_IDS() \
60 { USB_VENDOR_AND_INTERFACE_INFO(0x18d1, \
61 USB_CLASS_VENDOR_SPEC, \
62 0x50, \
63 0x01) }
64 DEVICE(google, GOOGLE_IDS);
65
66
67 #define LIBTRANSISTOR_IDS() \
68 { USB_DEVICE(0x1209, 0x8b00) }
69 DEVICE(libtransistor, LIBTRANSISTOR_IDS);
70
71
72 #define VIVOPAY_IDS() \
73 { USB_DEVICE(0x1d5f, 0x1004) }
74 DEVICE(vivopay, VIVOPAY_IDS);
75
76
77 #define MOTO_IDS() \
78 { USB_DEVICE(0x05c6, 0x3197) }, \
79 { USB_DEVICE(0x0c44, 0x0022) }, \
80 { USB_DEVICE(0x22b8, 0x2a64) }, \
81 { USB_DEVICE(0x22b8, 0x2c84) }, \
82 { USB_DEVICE(0x22b8, 0x2c64) }
83 DEVICE(moto_modem, MOTO_IDS);
84
85
86 #define MOTOROLA_TETRA_IDS() \
87 { USB_DEVICE(0x0cad, 0x9011) }, \
88 { USB_DEVICE(0x0cad, 0x9012) }, \
89 { USB_DEVICE(0x0cad, 0x9013) }, \
90 { USB_DEVICE(0x0cad, 0x9015) }, \
91 { USB_DEVICE(0x0cad, 0x9016) }
92 DEVICE(motorola_tetra, MOTOROLA_TETRA_IDS);
93
94
95 #define NOVATEL_IDS() \
96 { USB_DEVICE(0x09d7, 0x0100) }
97 DEVICE_N(novatel_gps, NOVATEL_IDS, 3);
98
99
100 #define HP4X_IDS() \
101 { USB_DEVICE(0x03f0, 0x0121) }
102 DEVICE(hp4x, HP4X_IDS);
103
104
105 #define SUUNTO_IDS() \
106 { USB_DEVICE(0x0fcf, 0x1008) }, \
107 { USB_DEVICE(0x0fcf, 0x1009) }
108 DEVICE(suunto, SUUNTO_IDS);
109
110
111 #define SIEMENS_IDS() \
112 { USB_DEVICE(0x908, 0x0004) }
113 DEVICE(siemens_mpi, SIEMENS_IDS);
114
115
116 static struct usb_serial_driver * const serial_drivers[] = {
117 &carelink_device,
118 &zio_device,
119 &funsoft_device,
120 &flashloader_device,
121 &google_device,
122 &libtransistor_device,
123 &vivopay_device,
124 &moto_modem_device,
125 &motorola_tetra_device,
126 &novatel_gps_device,
127 &hp4x_device,
128 &suunto_device,
129 &siemens_mpi_device,
130 NULL
131 };
132
133 static const struct usb_device_id id_table[] = {
134 CARELINK_IDS(),
135 ZIO_IDS(),
136 FUNSOFT_IDS(),
137 FLASHLOADER_IDS(),
138 GOOGLE_IDS(),
139 LIBTRANSISTOR_IDS(),
140 VIVOPAY_IDS(),
141 MOTO_IDS(),
142 MOTOROLA_TETRA_IDS(),
143 NOVATEL_IDS(),
144 HP4X_IDS(),
145 SUUNTO_IDS(),
146 SIEMENS_IDS(),
147 { },
148 };
149 MODULE_DEVICE_TABLE(usb, id_table);
150
151 module_usb_serial_driver(serial_drivers, id_table);
152 MODULE_LICENSE("GPL v2");