1 // SPDX-License-Identifier: GPL-2.0
3 * USB Serial "Simple" driver
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
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>
20 #define DEVICE_N(vendor, IDS, nport) \
21 static const struct usb_device_id vendor##_id_table[] = { \
25 static struct usb_serial_driver vendor##_device = { \
29 .id_table = vendor##_id_table, \
33 #define DEVICE(vendor, IDS) DEVICE_N(vendor, IDS, 1)
35 /* Medtronic CareLink USB driver */
36 #define CARELINK_IDS() \
37 { USB_DEVICE(0x0a21, 0x8001) } /* MMT-7305WW */
38 DEVICE(carelink
, CARELINK_IDS
);
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
);
47 /* Funsoft Serial USB driver */
48 #define FUNSOFT_IDS() \
49 { USB_DEVICE(0x1404, 0xcddc) }
50 DEVICE(funsoft
, FUNSOFT_IDS
);
52 /* Google Serial USB SubClass */
53 #define GOOGLE_IDS() \
54 { USB_VENDOR_AND_INTERFACE_INFO(0x18d1, \
55 USB_CLASS_VENDOR_SPEC, \
58 DEVICE(google
, GOOGLE_IDS
);
60 /* HP4x (48/49) Generic Serial driver */
62 { USB_DEVICE(0x03f0, 0x0121) }
63 DEVICE(hp4x
, HP4X_IDS
);
65 /* KAUFMANN RKS+CAN VCP */
66 #define KAUFMANN_IDS() \
67 { USB_DEVICE(0x16d0, 0x0870) }
68 DEVICE(kaufmann
, KAUFMANN_IDS
);
70 /* Libtransistor USB console */
71 #define LIBTRANSISTOR_IDS() \
72 { USB_DEVICE(0x1209, 0x8b00) }
73 DEVICE(libtransistor
, LIBTRANSISTOR_IDS
);
75 /* Motorola USB Phone driver */
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
);
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
);
93 /* Nokia mobile phone driver */
95 { USB_DEVICE(0x0421, 0x069a) } /* Nokia 130 (RM-1035) */
96 DEVICE(nokia
, NOKIA_IDS
);
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);
103 /* Siemens USB/MPI adapter */
104 #define SIEMENS_IDS() \
105 { USB_DEVICE(0x908, 0x0004) }
106 DEVICE(siemens_mpi
, SIEMENS_IDS
);
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
);
114 /* ViVOpay USB Serial Driver */
115 #define VIVOPAY_IDS() \
116 { USB_DEVICE(0x1d5f, 0x1004) } /* ViVOpay 8800 */
117 DEVICE(vivopay
, VIVOPAY_IDS
);
119 /* ZIO Motherboard USB driver */
121 { USB_DEVICE(0x1CBE, 0x0103) }
122 DEVICE(zio
, ZIO_IDS
);
124 /* All of the above structures mushed into two lists */
125 static struct usb_serial_driver
* const serial_drivers
[] = {
132 &libtransistor_device
,
134 &motorola_tetra_device
,
144 static const struct usb_device_id id_table
[] = {
153 MOTOROLA_TETRA_IDS(),
162 MODULE_DEVICE_TABLE(usb
, id_table
);
164 module_usb_serial_driver(serial_drivers
, id_table
);
165 MODULE_DESCRIPTION("USB Serial 'Simple' driver");
166 MODULE_LICENSE("GPL v2");