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_N(vendor, IDS, nport)				\
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 =		nport,				\
35};
36
37#define DEVICE(vendor, IDS)	DEVICE_N(vendor, IDS, 1)
38
39/* Medtronic CareLink USB driver */
40#define CARELINK_IDS()			\
41	{ USB_DEVICE(0x0a21, 0x8001) }	/* MMT-7305WW */
42DEVICE(carelink, CARELINK_IDS);
43
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()		\
56	{ USB_DEVICE_INTERFACE_CLASS(0x058b, 0x0041, USB_CLASS_CDC_DATA) }, \
57	{ USB_DEVICE(0x8087, 0x0716) }
58DEVICE(flashloader, FLASHLOADER_IDS);
59
60/* Google Serial USB SubClass */
61#define GOOGLE_IDS()						\
62	{ USB_VENDOR_AND_INTERFACE_INFO(0x18d1,			\
63					USB_CLASS_VENDOR_SPEC,	\
64					0x50,			\
65					0x01) }
66DEVICE(google, GOOGLE_IDS);
67
68/* ViVOpay USB Serial Driver */
69#define VIVOPAY_IDS()			\
70	{ USB_DEVICE(0x1d5f, 0x1004) }	/* ViVOpay 8800 */
71DEVICE(vivopay, VIVOPAY_IDS);
72
73/* Motorola USB Phone driver */
74#define MOTO_IDS()			\
75	{ USB_DEVICE(0x05c6, 0x3197) },	/* unknown Motorola phone */	\
76	{ USB_DEVICE(0x0c44, 0x0022) },	/* unknown Motorola phone */	\
77	{ USB_DEVICE(0x22b8, 0x2a64) },	/* Motorola KRZR K1m */		\
78	{ USB_DEVICE(0x22b8, 0x2c84) },	/* Motorola VE240 phone */	\
79	{ USB_DEVICE(0x22b8, 0x2c64) }	/* Motorola V950 phone */
80DEVICE(moto_modem, MOTO_IDS);
81
82/* Novatel Wireless GPS driver */
83#define NOVATEL_IDS()			\
84	{ USB_DEVICE(0x09d7, 0x0100) }	/* NovAtel FlexPack GPS */
85DEVICE_N(novatel_gps, NOVATEL_IDS, 3);
86
87/* HP4x (48/49) Generic Serial driver */
88#define HP4X_IDS()			\
89	{ USB_DEVICE(0x03f0, 0x0121) }
90DEVICE(hp4x, HP4X_IDS);
91
92/* Suunto ANT+ USB Driver */
93#define SUUNTO_IDS()			\
94	{ USB_DEVICE(0x0fcf, 0x1008) },	\
95	{ USB_DEVICE(0x0fcf, 0x1009) } /* Dynastream ANT USB-m Stick */
96DEVICE(suunto, SUUNTO_IDS);
97
98/* Siemens USB/MPI adapter */
99#define SIEMENS_IDS()			\
100	{ USB_DEVICE(0x908, 0x0004) }
101DEVICE(siemens_mpi, SIEMENS_IDS);
102
103/* All of the above structures mushed into two lists */
104static struct usb_serial_driver * const serial_drivers[] = {
105	&carelink_device,
106	&zio_device,
107	&funsoft_device,
108	&flashloader_device,
109	&google_device,
110	&vivopay_device,
111	&moto_modem_device,
112	&novatel_gps_device,
113	&hp4x_device,
114	&suunto_device,
115	&siemens_mpi_device,
116	NULL
117};
118
119static const struct usb_device_id id_table[] = {
120	CARELINK_IDS(),
121	ZIO_IDS(),
122	FUNSOFT_IDS(),
123	FLASHLOADER_IDS(),
124	GOOGLE_IDS(),
125	VIVOPAY_IDS(),
126	MOTO_IDS(),
127	NOVATEL_IDS(),
128	HP4X_IDS(),
129	SUUNTO_IDS(),
130	SIEMENS_IDS(),
131	{ },
132};
133MODULE_DEVICE_TABLE(usb, id_table);
134
135module_usb_serial_driver(serial_drivers, id_table);
136MODULE_LICENSE("GPL");
137