15fd54aceSGreg Kroah-Hartman // SPDX-License-Identifier: GPL-2.0
21f923071SGreg Kroah-Hartman /*
31f923071SGreg Kroah-Hartman  * USB Serial "Simple" driver
41f923071SGreg Kroah-Hartman  *
51f923071SGreg Kroah-Hartman  * Copyright (C) 2001-2006,2008,2013 Greg Kroah-Hartman <greg@kroah.com>
61f923071SGreg Kroah-Hartman  * Copyright (C) 2005 Arthur Huillet (ahuillet@users.sf.net)
71f923071SGreg Kroah-Hartman  * Copyright (C) 2005 Thomas Hergenhahn <thomas.hergenhahn@suse.de>
81f923071SGreg Kroah-Hartman  * Copyright (C) 2009 Outpost Embedded, LLC
91f923071SGreg Kroah-Hartman  * Copyright (C) 2010 Zilogic Systems <code@zilogic.com>
101f923071SGreg Kroah-Hartman  * Copyright (C) 2013 Wei Shuai <cpuwolf@gmail.com>
111f923071SGreg Kroah-Hartman  * Copyright (C) 2013 Linux Foundation
121f923071SGreg Kroah-Hartman  *
131f923071SGreg Kroah-Hartman  *	This program is free software; you can redistribute it and/or
141f923071SGreg Kroah-Hartman  *	modify it under the terms of the GNU General Public License version
151f923071SGreg Kroah-Hartman  *	2 as published by the Free Software Foundation.
161f923071SGreg Kroah-Hartman  */
171f923071SGreg Kroah-Hartman 
181f923071SGreg Kroah-Hartman #include <linux/kernel.h>
191f923071SGreg Kroah-Hartman #include <linux/tty.h>
201f923071SGreg Kroah-Hartman #include <linux/module.h>
211f923071SGreg Kroah-Hartman #include <linux/usb.h>
221f923071SGreg Kroah-Hartman #include <linux/usb/serial.h>
231f923071SGreg Kroah-Hartman 
24b9f04038SJohan Hovold #define DEVICE_N(vendor, IDS, nport)				\
251f923071SGreg Kroah-Hartman static const struct usb_device_id vendor##_id_table[] = {	\
261f923071SGreg Kroah-Hartman 	IDS(),							\
271f923071SGreg Kroah-Hartman 	{ },							\
281f923071SGreg Kroah-Hartman };								\
291f923071SGreg Kroah-Hartman static struct usb_serial_driver vendor##_device = {		\
301f923071SGreg Kroah-Hartman 	.driver = {						\
311f923071SGreg Kroah-Hartman 		.owner =	THIS_MODULE,			\
3268c91d37SYann Droneaud 		.name =		#vendor,			\
331f923071SGreg Kroah-Hartman 	},							\
341f923071SGreg Kroah-Hartman 	.id_table =		vendor##_id_table,		\
35b9f04038SJohan Hovold 	.num_ports =		nport,				\
361f923071SGreg Kroah-Hartman };
371f923071SGreg Kroah-Hartman 
38b9f04038SJohan Hovold #define DEVICE(vendor, IDS)	DEVICE_N(vendor, IDS, 1)
391f923071SGreg Kroah-Hartman 
40cff9c233SJohan Hovold /* Medtronic CareLink USB driver */
41cff9c233SJohan Hovold #define CARELINK_IDS()			\
42cff9c233SJohan Hovold 	{ USB_DEVICE(0x0a21, 0x8001) }	/* MMT-7305WW */
43cff9c233SJohan Hovold DEVICE(carelink, CARELINK_IDS);
441f923071SGreg Kroah-Hartman 
451f923071SGreg Kroah-Hartman /* ZIO Motherboard USB driver */
461f923071SGreg Kroah-Hartman #define ZIO_IDS()			\
471f923071SGreg Kroah-Hartman 	{ USB_DEVICE(0x1CBE, 0x0103) }
481f923071SGreg Kroah-Hartman DEVICE(zio, ZIO_IDS);
491f923071SGreg Kroah-Hartman 
501f923071SGreg Kroah-Hartman /* Funsoft Serial USB driver */
511f923071SGreg Kroah-Hartman #define FUNSOFT_IDS()			\
521f923071SGreg Kroah-Hartman 	{ USB_DEVICE(0x1404, 0xcddc) }
531f923071SGreg Kroah-Hartman DEVICE(funsoft, FUNSOFT_IDS);
541f923071SGreg Kroah-Hartman 
551f923071SGreg Kroah-Hartman /* Infineon Flashloader driver */
561f923071SGreg Kroah-Hartman #define FLASHLOADER_IDS()		\
57a0e80fbdSJonas Jonsson 	{ USB_DEVICE_INTERFACE_CLASS(0x058b, 0x0041, USB_CLASS_CDC_DATA) }, \
58f190fd92SDaniele Palmas 	{ USB_DEVICE(0x8087, 0x0716) }, \
59f190fd92SDaniele Palmas 	{ USB_DEVICE(0x8087, 0x0801) }
601f923071SGreg Kroah-Hartman DEVICE(flashloader, FLASHLOADER_IDS);
611f923071SGreg Kroah-Hartman 
62679315e5SAnton Staaf /* Google Serial USB SubClass */
63679315e5SAnton Staaf #define GOOGLE_IDS()						\
64679315e5SAnton Staaf 	{ USB_VENDOR_AND_INTERFACE_INFO(0x18d1,			\
65679315e5SAnton Staaf 					USB_CLASS_VENDOR_SPEC,	\
66679315e5SAnton Staaf 					0x50,			\
67679315e5SAnton Staaf 					0x01) }
68679315e5SAnton Staaf DEVICE(google, GOOGLE_IDS);
69679315e5SAnton Staaf 
701f923071SGreg Kroah-Hartman /* ViVOpay USB Serial Driver */
711f923071SGreg Kroah-Hartman #define VIVOPAY_IDS()			\
721f923071SGreg Kroah-Hartman 	{ USB_DEVICE(0x1d5f, 0x1004) }	/* ViVOpay 8800 */
731f923071SGreg Kroah-Hartman DEVICE(vivopay, VIVOPAY_IDS);
741f923071SGreg Kroah-Hartman 
751f923071SGreg Kroah-Hartman /* Motorola USB Phone driver */
761f923071SGreg Kroah-Hartman #define MOTO_IDS()			\
771f923071SGreg Kroah-Hartman 	{ USB_DEVICE(0x05c6, 0x3197) },	/* unknown Motorola phone */	\
788b648f13SRoman Mindalev 	{ USB_DEVICE(0x0c44, 0x0022) },	/* unknown Motorola phone */	\
791f923071SGreg Kroah-Hartman 	{ USB_DEVICE(0x22b8, 0x2a64) },	/* Motorola KRZR K1m */		\
801f923071SGreg Kroah-Hartman 	{ USB_DEVICE(0x22b8, 0x2c84) },	/* Motorola VE240 phone */	\
811f923071SGreg Kroah-Hartman 	{ USB_DEVICE(0x22b8, 0x2c64) }	/* Motorola V950 phone */
821f923071SGreg Kroah-Hartman DEVICE(moto_modem, MOTO_IDS);
831f923071SGreg Kroah-Hartman 
84c5cd24d7SJohan Hovold /* Novatel Wireless GPS driver */
85c5cd24d7SJohan Hovold #define NOVATEL_IDS()			\
86c5cd24d7SJohan Hovold 	{ USB_DEVICE(0x09d7, 0x0100) }	/* NovAtel FlexPack GPS */
87c5cd24d7SJohan Hovold DEVICE_N(novatel_gps, NOVATEL_IDS, 3);
88c5cd24d7SJohan Hovold 
891f923071SGreg Kroah-Hartman /* HP4x (48/49) Generic Serial driver */
901f923071SGreg Kroah-Hartman #define HP4X_IDS()			\
911f923071SGreg Kroah-Hartman 	{ USB_DEVICE(0x03f0, 0x0121) }
921f923071SGreg Kroah-Hartman DEVICE(hp4x, HP4X_IDS);
931f923071SGreg Kroah-Hartman 
941f923071SGreg Kroah-Hartman /* Suunto ANT+ USB Driver */
951f923071SGreg Kroah-Hartman #define SUUNTO_IDS()			\
962240c365SKristóf Ralovich 	{ USB_DEVICE(0x0fcf, 0x1008) },	\
972240c365SKristóf Ralovich 	{ USB_DEVICE(0x0fcf, 0x1009) } /* Dynastream ANT USB-m Stick */
981f923071SGreg Kroah-Hartman DEVICE(suunto, SUUNTO_IDS);
991f923071SGreg Kroah-Hartman 
1001f923071SGreg Kroah-Hartman /* Siemens USB/MPI adapter */
1011f923071SGreg Kroah-Hartman #define SIEMENS_IDS()			\
1021f923071SGreg Kroah-Hartman 	{ USB_DEVICE(0x908, 0x0004) }
1031f923071SGreg Kroah-Hartman DEVICE(siemens_mpi, SIEMENS_IDS);
1041f923071SGreg Kroah-Hartman 
1051f923071SGreg Kroah-Hartman /* All of the above structures mushed into two lists */
1061f923071SGreg Kroah-Hartman static struct usb_serial_driver * const serial_drivers[] = {
107cff9c233SJohan Hovold 	&carelink_device,
1081f923071SGreg Kroah-Hartman 	&zio_device,
1091f923071SGreg Kroah-Hartman 	&funsoft_device,
1101f923071SGreg Kroah-Hartman 	&flashloader_device,
111679315e5SAnton Staaf 	&google_device,
1121f923071SGreg Kroah-Hartman 	&vivopay_device,
1131f923071SGreg Kroah-Hartman 	&moto_modem_device,
114c5cd24d7SJohan Hovold 	&novatel_gps_device,
1151f923071SGreg Kroah-Hartman 	&hp4x_device,
1161f923071SGreg Kroah-Hartman 	&suunto_device,
1171f923071SGreg Kroah-Hartman 	&siemens_mpi_device,
1181f923071SGreg Kroah-Hartman 	NULL
1191f923071SGreg Kroah-Hartman };
1201f923071SGreg Kroah-Hartman 
1211f923071SGreg Kroah-Hartman static const struct usb_device_id id_table[] = {
122cff9c233SJohan Hovold 	CARELINK_IDS(),
1231f923071SGreg Kroah-Hartman 	ZIO_IDS(),
1241f923071SGreg Kroah-Hartman 	FUNSOFT_IDS(),
1251f923071SGreg Kroah-Hartman 	FLASHLOADER_IDS(),
126679315e5SAnton Staaf 	GOOGLE_IDS(),
1271f923071SGreg Kroah-Hartman 	VIVOPAY_IDS(),
1281f923071SGreg Kroah-Hartman 	MOTO_IDS(),
129c5cd24d7SJohan Hovold 	NOVATEL_IDS(),
1301f923071SGreg Kroah-Hartman 	HP4X_IDS(),
1311f923071SGreg Kroah-Hartman 	SUUNTO_IDS(),
1321f923071SGreg Kroah-Hartman 	SIEMENS_IDS(),
1331f923071SGreg Kroah-Hartman 	{ },
1341f923071SGreg Kroah-Hartman };
1351f923071SGreg Kroah-Hartman MODULE_DEVICE_TABLE(usb, id_table);
1361f923071SGreg Kroah-Hartman 
1371f923071SGreg Kroah-Hartman module_usb_serial_driver(serial_drivers, id_table);
1381f923071SGreg Kroah-Hartman MODULE_LICENSE("GPL");
139