Linux Audio

Check our new training course

Loading...
v6.13.7
  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		.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 */
 38DEVICE(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) }
 45DEVICE(flashloader, FLASHLOADER_IDS);
 46
 47/* Funsoft Serial USB driver */
 48#define FUNSOFT_IDS()			\
 49	{ USB_DEVICE(0x1404, 0xcddc) }
 50DEVICE(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) }
 58DEVICE(google, GOOGLE_IDS);
 59
 60/* HP4x (48/49) Generic Serial driver */
 61#define HP4X_IDS()			\
 62	{ USB_DEVICE(0x03f0, 0x0121) }
 63DEVICE(hp4x, HP4X_IDS);
 64
 65/* KAUFMANN RKS+CAN VCP */
 66#define KAUFMANN_IDS()			\
 67	{ USB_DEVICE(0x16d0, 0x0870) }
 68DEVICE(kaufmann, KAUFMANN_IDS);
 69
 70/* Libtransistor USB console */
 71#define LIBTRANSISTOR_IDS()			\
 72	{ USB_DEVICE(0x1209, 0x8b00) }
 73DEVICE(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 */
 82DEVICE(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 */
 91DEVICE(motorola_tetra, MOTOROLA_TETRA_IDS);
 92
 93/* Nokia mobile phone driver */
 94#define NOKIA_IDS()			\
 95	{ USB_DEVICE(0x0421, 0x069a) }	/* Nokia 130 (RM-1035) */
 96DEVICE(nokia, NOKIA_IDS);
 97
 98/* Novatel Wireless GPS driver */
 99#define NOVATEL_IDS()			\
100	{ USB_DEVICE(0x09d7, 0x0100) }	/* NovAtel FlexPack GPS */
101DEVICE_N(novatel_gps, NOVATEL_IDS, 3);
102
103/* Siemens USB/MPI adapter */
104#define SIEMENS_IDS()			\
105	{ USB_DEVICE(0x908, 0x0004) }
106DEVICE(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 */
112DEVICE(suunto, SUUNTO_IDS);
113
114/* ViVOpay USB Serial Driver */
115#define VIVOPAY_IDS()			\
116	{ USB_DEVICE(0x1d5f, 0x1004) }	/* ViVOpay 8800 */
117DEVICE(vivopay, VIVOPAY_IDS);
118
119/* ZIO Motherboard USB driver */
120#define ZIO_IDS()			\
121	{ USB_DEVICE(0x1CBE, 0x0103) }
122DEVICE(zio, ZIO_IDS);
123
124/* All of the above structures mushed into two lists */
125static 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
144static 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};
162MODULE_DEVICE_TABLE(usb, id_table);
163
164module_usb_serial_driver(serial_drivers, id_table);
165MODULE_DESCRIPTION("USB Serial 'Simple' driver");
166MODULE_LICENSE("GPL v2");
v5.4
  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/* ZIO Motherboard USB driver */
 42#define ZIO_IDS()			\
 43	{ USB_DEVICE(0x1CBE, 0x0103) }
 44DEVICE(zio, ZIO_IDS);
 45
 46/* Funsoft Serial USB driver */
 47#define FUNSOFT_IDS()			\
 48	{ USB_DEVICE(0x1404, 0xcddc) }
 49DEVICE(funsoft, FUNSOFT_IDS);
 50
 51/* Infineon Flashloader driver */
 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) }
 56DEVICE(flashloader, FLASHLOADER_IDS);
 57
 
 
 
 
 
 58/* Google Serial USB SubClass */
 59#define GOOGLE_IDS()						\
 60	{ USB_VENDOR_AND_INTERFACE_INFO(0x18d1,			\
 61					USB_CLASS_VENDOR_SPEC,	\
 62					0x50,			\
 63					0x01) }
 64DEVICE(google, GOOGLE_IDS);
 65
 
 
 
 
 
 
 
 
 
 
 66/* Libtransistor USB console */
 67#define LIBTRANSISTOR_IDS()			\
 68	{ USB_DEVICE(0x1209, 0x8b00) }
 69DEVICE(libtransistor, LIBTRANSISTOR_IDS);
 70
 71/* ViVOpay USB Serial Driver */
 72#define VIVOPAY_IDS()			\
 73	{ USB_DEVICE(0x1d5f, 0x1004) }	/* ViVOpay 8800 */
 74DEVICE(vivopay, VIVOPAY_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, 0x9016) }	/* TPG2200 */
 90DEVICE(motorola_tetra, MOTOROLA_TETRA_IDS);
 91
 
 
 
 
 
 92/* Novatel Wireless GPS driver */
 93#define NOVATEL_IDS()			\
 94	{ USB_DEVICE(0x09d7, 0x0100) }	/* NovAtel FlexPack GPS */
 95DEVICE_N(novatel_gps, NOVATEL_IDS, 3);
 96
 97/* HP4x (48/49) Generic Serial driver */
 98#define HP4X_IDS()			\
 99	{ USB_DEVICE(0x03f0, 0x0121) }
100DEVICE(hp4x, HP4X_IDS);
101
102/* Suunto ANT+ USB Driver */
103#define SUUNTO_IDS()			\
104	{ USB_DEVICE(0x0fcf, 0x1008) },	\
105	{ USB_DEVICE(0x0fcf, 0x1009) } /* Dynastream ANT USB-m Stick */
106DEVICE(suunto, SUUNTO_IDS);
107
108/* Siemens USB/MPI adapter */
109#define SIEMENS_IDS()			\
110	{ USB_DEVICE(0x908, 0x0004) }
111DEVICE(siemens_mpi, SIEMENS_IDS);
 
 
 
 
 
112
113/* All of the above structures mushed into two lists */
114static struct usb_serial_driver * const serial_drivers[] = {
115	&carelink_device,
116	&zio_device,
117	&funsoft_device,
118	&flashloader_device,
119	&google_device,
 
 
120	&libtransistor_device,
121	&vivopay_device,
122	&moto_modem_device,
123	&motorola_tetra_device,
 
124	&novatel_gps_device,
125	&hp4x_device,
126	&suunto_device,
127	&siemens_mpi_device,
 
128	NULL
129};
130
131static const struct usb_device_id id_table[] = {
132	CARELINK_IDS(),
133	ZIO_IDS(),
134	FUNSOFT_IDS(),
135	FLASHLOADER_IDS(),
136	GOOGLE_IDS(),
 
 
137	LIBTRANSISTOR_IDS(),
138	VIVOPAY_IDS(),
139	MOTO_IDS(),
140	MOTOROLA_TETRA_IDS(),
 
141	NOVATEL_IDS(),
142	HP4X_IDS(),
143	SUUNTO_IDS(),
144	SIEMENS_IDS(),
 
145	{ },
146};
147MODULE_DEVICE_TABLE(usb, id_table);
148
149module_usb_serial_driver(serial_drivers, id_table);
 
150MODULE_LICENSE("GPL v2");