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)					\
24 static const struct usb_device_id vendor##_id_table[] = {	\
25 	IDS(),							\
26 	{ },							\
27 };								\
28 static 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) }
41 DEVICE(zio, ZIO_IDS);
42 
43 /* Funsoft Serial USB driver */
44 #define FUNSOFT_IDS()			\
45 	{ USB_DEVICE(0x1404, 0xcddc) }
46 DEVICE(funsoft, FUNSOFT_IDS);
47 
48 /* Infineon Flashloader driver */
49 #define FLASHLOADER_IDS()		\
50 	{ USB_DEVICE(0x8087, 0x0716) }
51 DEVICE(flashloader, FLASHLOADER_IDS);
52 
53 /* ViVOpay USB Serial Driver */
54 #define VIVOPAY_IDS()			\
55 	{ USB_DEVICE(0x1d5f, 0x1004) }	/* ViVOpay 8800 */
56 DEVICE(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 */
65 DEVICE(moto_modem, MOTO_IDS);
66 
67 /* HP4x (48/49) Generic Serial driver */
68 #define HP4X_IDS()			\
69 	{ USB_DEVICE(0x03f0, 0x0121) }
70 DEVICE(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 */
76 DEVICE(suunto, SUUNTO_IDS);
77 
78 /* Siemens USB/MPI adapter */
79 #define SIEMENS_IDS()			\
80 	{ USB_DEVICE(0x908, 0x0004) }
81 DEVICE(siemens_mpi, SIEMENS_IDS);
82 
83 /* All of the above structures mushed into two lists */
84 static 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 
96 static 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 };
107 MODULE_DEVICE_TABLE(usb, id_table);
108 
109 module_usb_serial_driver(serial_drivers, id_table);
110 MODULE_LICENSE("GPL");
111