inet: frag: enforce memory limits earlier
[linux/fpc-iii.git] / drivers / usb / serial / usb-serial-simple.c
blob2674da40d9cd78d31c702a2b9b597639b02982a8
1 /*
2 * USB Serial "Simple" driver
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
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.
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>
23 #define DEVICE_N(vendor, IDS, nport) \
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 = nport, \
37 #define DEVICE(vendor, IDS) DEVICE_N(vendor, IDS, 1)
39 /* Medtronic CareLink USB driver */
40 #define CARELINK_IDS() \
41 { USB_DEVICE(0x0a21, 0x8001) } /* MMT-7305WW */
42 DEVICE(carelink, CARELINK_IDS);
44 /* ZIO Motherboard USB driver */
45 #define ZIO_IDS() \
46 { USB_DEVICE(0x1CBE, 0x0103) }
47 DEVICE(zio, ZIO_IDS);
49 /* Funsoft Serial USB driver */
50 #define FUNSOFT_IDS() \
51 { USB_DEVICE(0x1404, 0xcddc) }
52 DEVICE(funsoft, FUNSOFT_IDS);
54 /* Infineon Flashloader driver */
55 #define FLASHLOADER_IDS() \
56 { USB_DEVICE_INTERFACE_CLASS(0x058b, 0x0041, USB_CLASS_CDC_DATA) }, \
57 { USB_DEVICE(0x8087, 0x0716) }, \
58 { USB_DEVICE(0x8087, 0x0801) }
59 DEVICE(flashloader, FLASHLOADER_IDS);
61 /* Google Serial USB SubClass */
62 #define GOOGLE_IDS() \
63 { USB_VENDOR_AND_INTERFACE_INFO(0x18d1, \
64 USB_CLASS_VENDOR_SPEC, \
65 0x50, \
66 0x01) }
67 DEVICE(google, GOOGLE_IDS);
69 /* Libtransistor USB console */
70 #define LIBTRANSISTOR_IDS() \
71 { USB_DEVICE(0x1209, 0x8b00) }
72 DEVICE(libtransistor, LIBTRANSISTOR_IDS);
74 /* ViVOpay USB Serial Driver */
75 #define VIVOPAY_IDS() \
76 { USB_DEVICE(0x1d5f, 0x1004) } /* ViVOpay 8800 */
77 DEVICE(vivopay, VIVOPAY_IDS);
79 /* Motorola USB Phone driver */
80 #define MOTO_IDS() \
81 { USB_DEVICE(0x05c6, 0x3197) }, /* unknown Motorola phone */ \
82 { USB_DEVICE(0x0c44, 0x0022) }, /* unknown Motorola phone */ \
83 { USB_DEVICE(0x22b8, 0x2a64) }, /* Motorola KRZR K1m */ \
84 { USB_DEVICE(0x22b8, 0x2c84) }, /* Motorola VE240 phone */ \
85 { USB_DEVICE(0x22b8, 0x2c64) } /* Motorola V950 phone */
86 DEVICE(moto_modem, MOTO_IDS);
88 /* Motorola Tetra driver */
89 #define MOTOROLA_TETRA_IDS() \
90 { USB_DEVICE(0x0cad, 0x9011) } /* Motorola Solutions TETRA PEI */
91 DEVICE(motorola_tetra, MOTOROLA_TETRA_IDS);
93 /* Novatel Wireless GPS driver */
94 #define NOVATEL_IDS() \
95 { USB_DEVICE(0x09d7, 0x0100) } /* NovAtel FlexPack GPS */
96 DEVICE_N(novatel_gps, NOVATEL_IDS, 3);
98 /* HP4x (48/49) Generic Serial driver */
99 #define HP4X_IDS() \
100 { USB_DEVICE(0x03f0, 0x0121) }
101 DEVICE(hp4x, HP4X_IDS);
103 /* Suunto ANT+ USB Driver */
104 #define SUUNTO_IDS() \
105 { USB_DEVICE(0x0fcf, 0x1008) }, \
106 { USB_DEVICE(0x0fcf, 0x1009) } /* Dynastream ANT USB-m Stick */
107 DEVICE(suunto, SUUNTO_IDS);
109 /* Siemens USB/MPI adapter */
110 #define SIEMENS_IDS() \
111 { USB_DEVICE(0x908, 0x0004) }
112 DEVICE(siemens_mpi, SIEMENS_IDS);
114 /* All of the above structures mushed into two lists */
115 static struct usb_serial_driver * const serial_drivers[] = {
116 &carelink_device,
117 &zio_device,
118 &funsoft_device,
119 &flashloader_device,
120 &google_device,
121 &libtransistor_device,
122 &vivopay_device,
123 &moto_modem_device,
124 &motorola_tetra_device,
125 &novatel_gps_device,
126 &hp4x_device,
127 &suunto_device,
128 &siemens_mpi_device,
129 NULL
132 static const struct usb_device_id id_table[] = {
133 CARELINK_IDS(),
134 ZIO_IDS(),
135 FUNSOFT_IDS(),
136 FLASHLOADER_IDS(),
137 GOOGLE_IDS(),
138 LIBTRANSISTOR_IDS(),
139 VIVOPAY_IDS(),
140 MOTO_IDS(),
141 MOTOROLA_TETRA_IDS(),
142 NOVATEL_IDS(),
143 HP4X_IDS(),
144 SUUNTO_IDS(),
145 SIEMENS_IDS(),
146 { },
148 MODULE_DEVICE_TABLE(usb, id_table);
150 module_usb_serial_driver(serial_drivers, id_table);
151 MODULE_LICENSE("GPL");