1 // SPDX-License-Identifier: GPL-2.0
2 /*
3  * USB Serial "Simple" driver
4  *
5  * Copyright (C) 2001-2006,2008,2013 Greg Kroah-Hartman <greg@kroah.com>
6  * Copyright (C) 2005 Arthur Huillet (ahuillet@users.sf.net)
7  * Copyright (C) 2005 Thomas Hergenhahn <thomas.hergenhahn@suse.de>
8  * Copyright (C) 2009 Outpost Embedded, LLC
9  * Copyright (C) 2010 Zilogic Systems <code@zilogic.com>
10  * Copyright (C) 2013 Wei Shuai <cpuwolf@gmail.com>
11  * Copyright (C) 2013 Linux Foundation
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 		.name =		#vendor,			\
28 	},							\
29 	.id_table =		vendor##_id_table,		\
30 	.num_ports =		nport,				\
31 };
32 
33 #define DEVICE(vendor, IDS)	DEVICE_N(vendor, IDS, 1)
34 
35 /* Medtronic CareLink USB driver */
36 #define CARELINK_IDS()			\
37 	{ USB_DEVICE(0x0a21, 0x8001) }	/* MMT-7305WW */
38 DEVICE(carelink, CARELINK_IDS);
39 
40 /* Infineon Flashloader driver */
41 #define FLASHLOADER_IDS()		\
42 	{ USB_DEVICE_INTERFACE_CLASS(0x058b, 0x0041, USB_CLASS_CDC_DATA) }, \
43 	{ USB_DEVICE(0x8087, 0x0716) }, \
44 	{ USB_DEVICE(0x8087, 0x0801) }
45 DEVICE(flashloader, FLASHLOADER_IDS);
46 
47 /* Funsoft Serial USB driver */
48 #define FUNSOFT_IDS()			\
49 	{ USB_DEVICE(0x1404, 0xcddc) }
50 DEVICE(funsoft, FUNSOFT_IDS);
51 
52 /* Google Serial USB SubClass */
53 #define GOOGLE_IDS()						\
54 	{ USB_VENDOR_AND_INTERFACE_INFO(0x18d1,			\
55 					USB_CLASS_VENDOR_SPEC,	\
56 					0x50,			\
57 					0x01) }
58 DEVICE(google, GOOGLE_IDS);
59 
60 /* HP4x (48/49) Generic Serial driver */
61 #define HP4X_IDS()			\
62 	{ USB_DEVICE(0x03f0, 0x0121) }
63 DEVICE(hp4x, HP4X_IDS);
64 
65 /* KAUFMANN RKS+CAN VCP */
66 #define KAUFMANN_IDS()			\
67 	{ USB_DEVICE(0x16d0, 0x0870) }
68 DEVICE(kaufmann, KAUFMANN_IDS);
69 
70 /* Libtransistor USB console */
71 #define LIBTRANSISTOR_IDS()			\
72 	{ USB_DEVICE(0x1209, 0x8b00) }
73 DEVICE(libtransistor, LIBTRANSISTOR_IDS);
74 
75 /* Motorola USB Phone driver */
76 #define MOTO_IDS()			\
77 	{ USB_DEVICE(0x05c6, 0x3197) },	/* unknown Motorola phone */	\
78 	{ USB_DEVICE(0x0c44, 0x0022) },	/* unknown Motorola phone */	\
79 	{ USB_DEVICE(0x22b8, 0x2a64) },	/* Motorola KRZR K1m */		\
80 	{ USB_DEVICE(0x22b8, 0x2c84) },	/* Motorola VE240 phone */	\
81 	{ USB_DEVICE(0x22b8, 0x2c64) }	/* Motorola V950 phone */
82 DEVICE(moto_modem, MOTO_IDS);
83 
84 /* Motorola Tetra driver */
85 #define MOTOROLA_TETRA_IDS()			\
86 	{ USB_DEVICE(0x0cad, 0x9011) },	/* Motorola Solutions TETRA PEI */ \
87 	{ USB_DEVICE(0x0cad, 0x9012) },	/* MTP6550 */ \
88 	{ USB_DEVICE(0x0cad, 0x9013) },	/* MTP3xxx */ \
89 	{ USB_DEVICE(0x0cad, 0x9015) },	/* MTP85xx */ \
90 	{ USB_DEVICE(0x0cad, 0x9016) }	/* TPG2200 */
91 DEVICE(motorola_tetra, MOTOROLA_TETRA_IDS);
92 
93 /* Nokia mobile phone driver */
94 #define NOKIA_IDS()			\
95 	{ USB_DEVICE(0x0421, 0x069a) }	/* Nokia 130 (RM-1035) */
96 DEVICE(nokia, NOKIA_IDS);
97 
98 /* Novatel Wireless GPS driver */
99 #define NOVATEL_IDS()			\
100 	{ USB_DEVICE(0x09d7, 0x0100) }	/* NovAtel FlexPack GPS */
101 DEVICE_N(novatel_gps, NOVATEL_IDS, 3);
102 
103 /* Siemens USB/MPI adapter */
104 #define SIEMENS_IDS()			\
105 	{ USB_DEVICE(0x908, 0x0004) }
106 DEVICE(siemens_mpi, SIEMENS_IDS);
107 
108 /* Suunto ANT+ USB Driver */
109 #define SUUNTO_IDS()			\
110 	{ USB_DEVICE(0x0fcf, 0x1008) },	\
111 	{ USB_DEVICE(0x0fcf, 0x1009) } /* Dynastream ANT USB-m Stick */
112 DEVICE(suunto, SUUNTO_IDS);
113 
114 /* ViVOpay USB Serial Driver */
115 #define VIVOPAY_IDS()			\
116 	{ USB_DEVICE(0x1d5f, 0x1004) }	/* ViVOpay 8800 */
117 DEVICE(vivopay, VIVOPAY_IDS);
118 
119 /* ZIO Motherboard USB driver */
120 #define ZIO_IDS()			\
121 	{ USB_DEVICE(0x1CBE, 0x0103) }
122 DEVICE(zio, ZIO_IDS);
123 
124 /* All of the above structures mushed into two lists */
125 static struct usb_serial_driver * const serial_drivers[] = {
126 	&carelink_device,
127 	&flashloader_device,
128 	&funsoft_device,
129 	&google_device,
130 	&hp4x_device,
131 	&kaufmann_device,
132 	&libtransistor_device,
133 	&moto_modem_device,
134 	&motorola_tetra_device,
135 	&nokia_device,
136 	&novatel_gps_device,
137 	&siemens_mpi_device,
138 	&suunto_device,
139 	&vivopay_device,
140 	&zio_device,
141 	NULL
142 };
143 
144 static const struct usb_device_id id_table[] = {
145 	CARELINK_IDS(),
146 	FLASHLOADER_IDS(),
147 	FUNSOFT_IDS(),
148 	GOOGLE_IDS(),
149 	HP4X_IDS(),
150 	KAUFMANN_IDS(),
151 	LIBTRANSISTOR_IDS(),
152 	MOTO_IDS(),
153 	MOTOROLA_TETRA_IDS(),
154 	NOKIA_IDS(),
155 	NOVATEL_IDS(),
156 	SIEMENS_IDS(),
157 	SUUNTO_IDS(),
158 	VIVOPAY_IDS(),
159 	ZIO_IDS(),
160 	{ },
161 };
162 MODULE_DEVICE_TABLE(usb, id_table);
163 
164 module_usb_serial_driver(serial_drivers, id_table);
165 MODULE_DESCRIPTION("USB Serial 'Simple' driver");
166 MODULE_LICENSE("GPL v2");
167