blob: 6aa7ff2c1cf74b953dc5669e08500b43ccb9e115 [file] [log] [blame]
Greg Kroah-Hartman1f923072013-08-05 19:27:19 +08001/*
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>
Greg Kroah-Hartman1f923072013-08-05 19:27:19 +080018#include <linux/tty.h>
19#include <linux/module.h>
20#include <linux/usb.h>
21#include <linux/usb/serial.h>
22
Johan Hovoldb9f04032014-08-18 18:14:52 +020023#define DEVICE_N(vendor, IDS, nport) \
Greg Kroah-Hartman1f923072013-08-05 19:27:19 +080024static 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, \
Yann Droneaud68c91d32013-08-18 21:29:00 +020031 .name = #vendor, \
Greg Kroah-Hartman1f923072013-08-05 19:27:19 +080032 }, \
33 .id_table = vendor##_id_table, \
Johan Hovoldb9f04032014-08-18 18:14:52 +020034 .num_ports = nport, \
Greg Kroah-Hartman1f923072013-08-05 19:27:19 +080035};
36
Johan Hovoldb9f04032014-08-18 18:14:52 +020037#define DEVICE(vendor, IDS) DEVICE_N(vendor, IDS, 1)
Greg Kroah-Hartman1f923072013-08-05 19:27:19 +080038
Johan Hovoldcff9c232014-08-18 18:23:19 +020039/* Medtronic CareLink USB driver */
40#define CARELINK_IDS() \
41 { USB_DEVICE(0x0a21, 0x8001) } /* MMT-7305WW */
42DEVICE(carelink, CARELINK_IDS);
Greg Kroah-Hartman1f923072013-08-05 19:27:19 +080043
44/* ZIO Motherboard USB driver */
45#define ZIO_IDS() \
46 { USB_DEVICE(0x1CBE, 0x0103) }
47DEVICE(zio, ZIO_IDS);
48
49/* Funsoft Serial USB driver */
50#define FUNSOFT_IDS() \
51 { USB_DEVICE(0x1404, 0xcddc) }
52DEVICE(funsoft, FUNSOFT_IDS);
53
54/* Infineon Flashloader driver */
55#define FLASHLOADER_IDS() \
Jonas Jonssona0e80fbd2015-11-22 11:47:18 +010056 { USB_DEVICE_INTERFACE_CLASS(0x058b, 0x0041, USB_CLASS_CDC_DATA) }, \
Daniele Palmasf190fd92016-09-02 10:37:56 +020057 { USB_DEVICE(0x8087, 0x0716) }, \
58 { USB_DEVICE(0x8087, 0x0801) }
Greg Kroah-Hartman1f923072013-08-05 19:27:19 +080059DEVICE(flashloader, FLASHLOADER_IDS);
60
Anton Staaf679315e2014-11-03 08:43:20 -080061/* Google Serial USB SubClass */
62#define GOOGLE_IDS() \
63 { USB_VENDOR_AND_INTERFACE_INFO(0x18d1, \
64 USB_CLASS_VENDOR_SPEC, \
65 0x50, \
66 0x01) }
67DEVICE(google, GOOGLE_IDS);
68
Greg Kroah-Hartman1f923072013-08-05 19:27:19 +080069/* ViVOpay USB Serial Driver */
70#define VIVOPAY_IDS() \
71 { USB_DEVICE(0x1d5f, 0x1004) } /* ViVOpay 8800 */
72DEVICE(vivopay, VIVOPAY_IDS);
73
74/* Motorola USB Phone driver */
75#define MOTO_IDS() \
76 { USB_DEVICE(0x05c6, 0x3197) }, /* unknown Motorola phone */ \
Roman Mindalev8b648f12014-09-27 10:08:35 +040077 { USB_DEVICE(0x0c44, 0x0022) }, /* unknown Motorola phone */ \
Greg Kroah-Hartman1f923072013-08-05 19:27:19 +080078 { USB_DEVICE(0x22b8, 0x2a64) }, /* Motorola KRZR K1m */ \
79 { USB_DEVICE(0x22b8, 0x2c84) }, /* Motorola VE240 phone */ \
80 { USB_DEVICE(0x22b8, 0x2c64) } /* Motorola V950 phone */
81DEVICE(moto_modem, MOTO_IDS);
82
Johan Hovold800de0f2018-01-18 14:46:41 +110083/* Motorola Tetra driver */
84#define MOTOROLA_TETRA_IDS() \
85 { USB_DEVICE(0x0cad, 0x9011) } /* Motorola Solutions TETRA PEI */
86DEVICE(motorola_tetra, MOTOROLA_TETRA_IDS);
87
Johan Hovoldc5cd24d2014-08-18 18:14:53 +020088/* Novatel Wireless GPS driver */
89#define NOVATEL_IDS() \
90 { USB_DEVICE(0x09d7, 0x0100) } /* NovAtel FlexPack GPS */
91DEVICE_N(novatel_gps, NOVATEL_IDS, 3);
92
Greg Kroah-Hartman1f923072013-08-05 19:27:19 +080093/* HP4x (48/49) Generic Serial driver */
94#define HP4X_IDS() \
95 { USB_DEVICE(0x03f0, 0x0121) }
96DEVICE(hp4x, HP4X_IDS);
97
98/* Suunto ANT+ USB Driver */
99#define SUUNTO_IDS() \
Kristóf Ralovich2240c362014-01-24 12:18:35 +0100100 { USB_DEVICE(0x0fcf, 0x1008) }, \
101 { USB_DEVICE(0x0fcf, 0x1009) } /* Dynastream ANT USB-m Stick */
Greg Kroah-Hartman1f923072013-08-05 19:27:19 +0800102DEVICE(suunto, SUUNTO_IDS);
103
104/* Siemens USB/MPI adapter */
105#define SIEMENS_IDS() \
106 { USB_DEVICE(0x908, 0x0004) }
107DEVICE(siemens_mpi, SIEMENS_IDS);
108
109/* All of the above structures mushed into two lists */
110static struct usb_serial_driver * const serial_drivers[] = {
Johan Hovoldcff9c232014-08-18 18:23:19 +0200111 &carelink_device,
Greg Kroah-Hartman1f923072013-08-05 19:27:19 +0800112 &zio_device,
113 &funsoft_device,
114 &flashloader_device,
Anton Staaf679315e2014-11-03 08:43:20 -0800115 &google_device,
Greg Kroah-Hartman1f923072013-08-05 19:27:19 +0800116 &vivopay_device,
117 &moto_modem_device,
Johan Hovold800de0f2018-01-18 14:46:41 +1100118 &motorola_tetra_device,
Johan Hovoldc5cd24d2014-08-18 18:14:53 +0200119 &novatel_gps_device,
Greg Kroah-Hartman1f923072013-08-05 19:27:19 +0800120 &hp4x_device,
121 &suunto_device,
122 &siemens_mpi_device,
123 NULL
124};
125
126static const struct usb_device_id id_table[] = {
Johan Hovoldcff9c232014-08-18 18:23:19 +0200127 CARELINK_IDS(),
Greg Kroah-Hartman1f923072013-08-05 19:27:19 +0800128 ZIO_IDS(),
129 FUNSOFT_IDS(),
130 FLASHLOADER_IDS(),
Anton Staaf679315e2014-11-03 08:43:20 -0800131 GOOGLE_IDS(),
Greg Kroah-Hartman1f923072013-08-05 19:27:19 +0800132 VIVOPAY_IDS(),
133 MOTO_IDS(),
Johan Hovold800de0f2018-01-18 14:46:41 +1100134 MOTOROLA_TETRA_IDS(),
Johan Hovoldc5cd24d2014-08-18 18:14:53 +0200135 NOVATEL_IDS(),
Greg Kroah-Hartman1f923072013-08-05 19:27:19 +0800136 HP4X_IDS(),
137 SUUNTO_IDS(),
138 SIEMENS_IDS(),
139 { },
140};
141MODULE_DEVICE_TABLE(usb, id_table);
142
143module_usb_serial_driver(serial_drivers, id_table);
144MODULE_LICENSE("GPL");