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