1 // SPDX-License-Identifier: GPL-2.0+
3 Keyspan USB to Serial Converter driver
5 (C) Copyright (C) 2000-2001 Hugh Blemings <hugh@blemings.org>
6 (C) Copyright (C) 2002 Greg Kroah-Hartman <greg@kroah.com>
8 See http://blemings.org/hugh/keyspan.html for more information.
10 Code in this driver inspired by and in a number of places taken
11 from Brian Warner's original Keyspan-PDA driver.
13 This driver has been put together with the support of Innosys, Inc.
14 and Keyspan, Inc the manufacturers of the Keyspan USB-serial products.
17 Thanks to Paulus for miscellaneous tidy ups, some largish chunks
18 of much nicer and/or completely new code and (perhaps most uniquely)
19 having the patience to sit down and explain why and where he'd changed
22 Tip 'o the hat to IBM (and previously Linuxcare :) for supporting
23 staff in their work on open source projects.
27 #include <linux/kernel.h>
28 #include <linux/jiffies.h>
29 #include <linux/errno.h>
30 #include <linux/slab.h>
31 #include <linux/tty.h>
32 #include <linux/tty_driver.h>
33 #include <linux/tty_flip.h>
34 #include <linux/module.h>
35 #include <linux/spinlock.h>
36 #include <linux/uaccess.h>
37 #include <linux/usb.h>
38 #include <linux/usb/serial.h>
39 #include <linux/usb/ezusb.h>
41 #define DRIVER_AUTHOR "Hugh Blemings <hugh@misc.nu"
42 #define DRIVER_DESC "Keyspan USB to Serial Converter Driver"
44 static void keyspan_send_setup(struct usb_serial_port *port, int reset_port);
46 static int keyspan_usa19_calc_baud(struct usb_serial_port *port,
47 u32 baud_rate, u32 baudclk,
48 u8 *rate_hi, u8 *rate_low,
49 u8 *prescaler, int portnum);
50 static int keyspan_usa19w_calc_baud(struct usb_serial_port *port,
51 u32 baud_rate, u32 baudclk,
52 u8 *rate_hi, u8 *rate_low,
53 u8 *prescaler, int portnum);
54 static int keyspan_usa28_calc_baud(struct usb_serial_port *port,
55 u32 baud_rate, u32 baudclk,
56 u8 *rate_hi, u8 *rate_low,
57 u8 *prescaler, int portnum);
58 static int keyspan_usa19hs_calc_baud(struct usb_serial_port *port,
59 u32 baud_rate, u32 baudclk,
60 u8 *rate_hi, u8 *rate_low,
61 u8 *prescaler, int portnum);
63 static int keyspan_usa28_send_setup(struct usb_serial *serial,
64 struct usb_serial_port *port,
66 static int keyspan_usa26_send_setup(struct usb_serial *serial,
67 struct usb_serial_port *port,
69 static int keyspan_usa49_send_setup(struct usb_serial *serial,
70 struct usb_serial_port *port,
72 static int keyspan_usa90_send_setup(struct usb_serial *serial,
73 struct usb_serial_port *port,
75 static int keyspan_usa67_send_setup(struct usb_serial *serial,
76 struct usb_serial_port *port,
79 /* Values used for baud rate calculation - device specific */
80 #define KEYSPAN_INVALID_BAUD_RATE (-1)
81 #define KEYSPAN_BAUD_RATE_OK (0)
82 #define KEYSPAN_USA18X_BAUDCLK (12000000L) /* a guess */
83 #define KEYSPAN_USA19_BAUDCLK (12000000L)
84 #define KEYSPAN_USA19W_BAUDCLK (24000000L)
85 #define KEYSPAN_USA19HS_BAUDCLK (14769231L)
86 #define KEYSPAN_USA28_BAUDCLK (1843200L)
87 #define KEYSPAN_USA28X_BAUDCLK (12000000L)
88 #define KEYSPAN_USA49W_BAUDCLK (48000000L)
90 /* Some constants used to characterise each device. */
91 #define KEYSPAN_MAX_NUM_PORTS (4)
92 #define KEYSPAN_MAX_FLIPS (2)
95 * Device info for the Keyspan serial converter, used by the overall
96 * usb-serial probe function.
98 #define KEYSPAN_VENDOR_ID (0x06cd)
100 /* Product IDs for the products supported, pre-renumeration */
101 #define keyspan_usa18x_pre_product_id 0x0105
102 #define keyspan_usa19_pre_product_id 0x0103
103 #define keyspan_usa19qi_pre_product_id 0x010b
104 #define keyspan_mpr_pre_product_id 0x011b
105 #define keyspan_usa19qw_pre_product_id 0x0118
106 #define keyspan_usa19w_pre_product_id 0x0106
107 #define keyspan_usa28_pre_product_id 0x0101
108 #define keyspan_usa28x_pre_product_id 0x0102
109 #define keyspan_usa28xa_pre_product_id 0x0114
110 #define keyspan_usa28xb_pre_product_id 0x0113
111 #define keyspan_usa49w_pre_product_id 0x0109
112 #define keyspan_usa49wlc_pre_product_id 0x011a
115 * Product IDs post-renumeration. Note that the 28x and 28xb have the same
116 * id's post-renumeration but behave identically so it's not an issue. As
117 * such, the 28xb is not listed in any of the device tables.
119 #define keyspan_usa18x_product_id 0x0112
120 #define keyspan_usa19_product_id 0x0107
121 #define keyspan_usa19qi_product_id 0x010c
122 #define keyspan_usa19hs_product_id 0x0121
123 #define keyspan_mpr_product_id 0x011c
124 #define keyspan_usa19qw_product_id 0x0119
125 #define keyspan_usa19w_product_id 0x0108
126 #define keyspan_usa28_product_id 0x010f
127 #define keyspan_usa28x_product_id 0x0110
128 #define keyspan_usa28xa_product_id 0x0115
129 #define keyspan_usa28xb_product_id 0x0110
130 #define keyspan_usa28xg_product_id 0x0135
131 #define keyspan_usa49w_product_id 0x010a
132 #define keyspan_usa49wlc_product_id 0x012a
133 #define keyspan_usa49wg_product_id 0x0131
135 struct keyspan_device_details {
136 /* product ID value */
139 enum {msg_usa26, msg_usa28, msg_usa49, msg_usa90, msg_usa67} msg_format;
141 /* Number of physical ports */
144 /* 1 if endpoint flipping used on input, 0 if not */
147 /* 1 if endpoint flipping used on output, 0 if not */
148 int outdat_endp_flip;
151 * Table mapping input data endpoint IDs to physical port
152 * number and flip if used
154 int indat_endpoints[KEYSPAN_MAX_NUM_PORTS];
156 /* Same for output endpoints */
157 int outdat_endpoints[KEYSPAN_MAX_NUM_PORTS];
159 /* Input acknowledge endpoints */
160 int inack_endpoints[KEYSPAN_MAX_NUM_PORTS];
162 /* Output control endpoints */
163 int outcont_endpoints[KEYSPAN_MAX_NUM_PORTS];
165 /* Endpoint used for input status */
168 /* Endpoint used for input data 49WG only */
171 /* Endpoint used for global control functions */
172 int glocont_endpoint;
174 int (*calculate_baud_rate)(struct usb_serial_port *port,
175 u32 baud_rate, u32 baudclk,
176 u8 *rate_hi, u8 *rate_low, u8 *prescaler,
182 * Now for each device type we setup the device detail structure with the
183 * appropriate information (provided in Keyspan's documentation)
186 static const struct keyspan_device_details usa18x_device_details = {
187 .product_id = keyspan_usa18x_product_id,
188 .msg_format = msg_usa26,
190 .indat_endp_flip = 0,
191 .outdat_endp_flip = 1,
192 .indat_endpoints = {0x81},
193 .outdat_endpoints = {0x01},
194 .inack_endpoints = {0x85},
195 .outcont_endpoints = {0x05},
196 .instat_endpoint = 0x87,
197 .indat_endpoint = -1,
198 .glocont_endpoint = 0x07,
199 .calculate_baud_rate = keyspan_usa19w_calc_baud,
200 .baudclk = KEYSPAN_USA18X_BAUDCLK,
203 static const struct keyspan_device_details usa19_device_details = {
204 .product_id = keyspan_usa19_product_id,
205 .msg_format = msg_usa28,
207 .indat_endp_flip = 1,
208 .outdat_endp_flip = 1,
209 .indat_endpoints = {0x81},
210 .outdat_endpoints = {0x01},
211 .inack_endpoints = {0x83},
212 .outcont_endpoints = {0x03},
213 .instat_endpoint = 0x84,
214 .indat_endpoint = -1,
215 .glocont_endpoint = -1,
216 .calculate_baud_rate = keyspan_usa19_calc_baud,
217 .baudclk = KEYSPAN_USA19_BAUDCLK,
220 static const struct keyspan_device_details usa19qi_device_details = {
221 .product_id = keyspan_usa19qi_product_id,
222 .msg_format = msg_usa28,
224 .indat_endp_flip = 1,
225 .outdat_endp_flip = 1,
226 .indat_endpoints = {0x81},
227 .outdat_endpoints = {0x01},
228 .inack_endpoints = {0x83},
229 .outcont_endpoints = {0x03},
230 .instat_endpoint = 0x84,
231 .indat_endpoint = -1,
232 .glocont_endpoint = -1,
233 .calculate_baud_rate = keyspan_usa28_calc_baud,
234 .baudclk = KEYSPAN_USA19_BAUDCLK,
237 static const struct keyspan_device_details mpr_device_details = {
238 .product_id = keyspan_mpr_product_id,
239 .msg_format = msg_usa28,
241 .indat_endp_flip = 1,
242 .outdat_endp_flip = 1,
243 .indat_endpoints = {0x81},
244 .outdat_endpoints = {0x01},
245 .inack_endpoints = {0x83},
246 .outcont_endpoints = {0x03},
247 .instat_endpoint = 0x84,
248 .indat_endpoint = -1,
249 .glocont_endpoint = -1,
250 .calculate_baud_rate = keyspan_usa28_calc_baud,
251 .baudclk = KEYSPAN_USA19_BAUDCLK,
254 static const struct keyspan_device_details usa19qw_device_details = {
255 .product_id = keyspan_usa19qw_product_id,
256 .msg_format = msg_usa26,
258 .indat_endp_flip = 0,
259 .outdat_endp_flip = 1,
260 .indat_endpoints = {0x81},
261 .outdat_endpoints = {0x01},
262 .inack_endpoints = {0x85},
263 .outcont_endpoints = {0x05},
264 .instat_endpoint = 0x87,
265 .indat_endpoint = -1,
266 .glocont_endpoint = 0x07,
267 .calculate_baud_rate = keyspan_usa19w_calc_baud,
268 .baudclk = KEYSPAN_USA19W_BAUDCLK,
271 static const struct keyspan_device_details usa19w_device_details = {
272 .product_id = keyspan_usa19w_product_id,
273 .msg_format = msg_usa26,
275 .indat_endp_flip = 0,
276 .outdat_endp_flip = 1,
277 .indat_endpoints = {0x81},
278 .outdat_endpoints = {0x01},
279 .inack_endpoints = {0x85},
280 .outcont_endpoints = {0x05},
281 .instat_endpoint = 0x87,
282 .indat_endpoint = -1,
283 .glocont_endpoint = 0x07,
284 .calculate_baud_rate = keyspan_usa19w_calc_baud,
285 .baudclk = KEYSPAN_USA19W_BAUDCLK,
288 static const struct keyspan_device_details usa19hs_device_details = {
289 .product_id = keyspan_usa19hs_product_id,
290 .msg_format = msg_usa90,
292 .indat_endp_flip = 0,
293 .outdat_endp_flip = 0,
294 .indat_endpoints = {0x81},
295 .outdat_endpoints = {0x01},
296 .inack_endpoints = {-1},
297 .outcont_endpoints = {0x02},
298 .instat_endpoint = 0x82,
299 .indat_endpoint = -1,
300 .glocont_endpoint = -1,
301 .calculate_baud_rate = keyspan_usa19hs_calc_baud,
302 .baudclk = KEYSPAN_USA19HS_BAUDCLK,
305 static const struct keyspan_device_details usa28_device_details = {
306 .product_id = keyspan_usa28_product_id,
307 .msg_format = msg_usa28,
309 .indat_endp_flip = 1,
310 .outdat_endp_flip = 1,
311 .indat_endpoints = {0x81, 0x83},
312 .outdat_endpoints = {0x01, 0x03},
313 .inack_endpoints = {0x85, 0x86},
314 .outcont_endpoints = {0x05, 0x06},
315 .instat_endpoint = 0x87,
316 .indat_endpoint = -1,
317 .glocont_endpoint = 0x07,
318 .calculate_baud_rate = keyspan_usa28_calc_baud,
319 .baudclk = KEYSPAN_USA28_BAUDCLK,
322 static const struct keyspan_device_details usa28x_device_details = {
323 .product_id = keyspan_usa28x_product_id,
324 .msg_format = msg_usa26,
326 .indat_endp_flip = 0,
327 .outdat_endp_flip = 1,
328 .indat_endpoints = {0x81, 0x83},
329 .outdat_endpoints = {0x01, 0x03},
330 .inack_endpoints = {0x85, 0x86},
331 .outcont_endpoints = {0x05, 0x06},
332 .instat_endpoint = 0x87,
333 .indat_endpoint = -1,
334 .glocont_endpoint = 0x07,
335 .calculate_baud_rate = keyspan_usa19w_calc_baud,
336 .baudclk = KEYSPAN_USA28X_BAUDCLK,
339 static const struct keyspan_device_details usa28xa_device_details = {
340 .product_id = keyspan_usa28xa_product_id,
341 .msg_format = msg_usa26,
343 .indat_endp_flip = 0,
344 .outdat_endp_flip = 1,
345 .indat_endpoints = {0x81, 0x83},
346 .outdat_endpoints = {0x01, 0x03},
347 .inack_endpoints = {0x85, 0x86},
348 .outcont_endpoints = {0x05, 0x06},
349 .instat_endpoint = 0x87,
350 .indat_endpoint = -1,
351 .glocont_endpoint = 0x07,
352 .calculate_baud_rate = keyspan_usa19w_calc_baud,
353 .baudclk = KEYSPAN_USA28X_BAUDCLK,
356 static const struct keyspan_device_details usa28xg_device_details = {
357 .product_id = keyspan_usa28xg_product_id,
358 .msg_format = msg_usa67,
360 .indat_endp_flip = 0,
361 .outdat_endp_flip = 0,
362 .indat_endpoints = {0x84, 0x88},
363 .outdat_endpoints = {0x02, 0x06},
364 .inack_endpoints = {-1, -1},
365 .outcont_endpoints = {-1, -1},
366 .instat_endpoint = 0x81,
367 .indat_endpoint = -1,
368 .glocont_endpoint = 0x01,
369 .calculate_baud_rate = keyspan_usa19w_calc_baud,
370 .baudclk = KEYSPAN_USA28X_BAUDCLK,
373 * We don't need a separate entry for the usa28xb as it appears as a 28x
377 static const struct keyspan_device_details usa49w_device_details = {
378 .product_id = keyspan_usa49w_product_id,
379 .msg_format = msg_usa49,
381 .indat_endp_flip = 0,
382 .outdat_endp_flip = 0,
383 .indat_endpoints = {0x81, 0x82, 0x83, 0x84},
384 .outdat_endpoints = {0x01, 0x02, 0x03, 0x04},
385 .inack_endpoints = {-1, -1, -1, -1},
386 .outcont_endpoints = {-1, -1, -1, -1},
387 .instat_endpoint = 0x87,
388 .indat_endpoint = -1,
389 .glocont_endpoint = 0x07,
390 .calculate_baud_rate = keyspan_usa19w_calc_baud,
391 .baudclk = KEYSPAN_USA49W_BAUDCLK,
394 static const struct keyspan_device_details usa49wlc_device_details = {
395 .product_id = keyspan_usa49wlc_product_id,
396 .msg_format = msg_usa49,
398 .indat_endp_flip = 0,
399 .outdat_endp_flip = 0,
400 .indat_endpoints = {0x81, 0x82, 0x83, 0x84},
401 .outdat_endpoints = {0x01, 0x02, 0x03, 0x04},
402 .inack_endpoints = {-1, -1, -1, -1},
403 .outcont_endpoints = {-1, -1, -1, -1},
404 .instat_endpoint = 0x87,
405 .indat_endpoint = -1,
406 .glocont_endpoint = 0x07,
407 .calculate_baud_rate = keyspan_usa19w_calc_baud,
408 .baudclk = KEYSPAN_USA19W_BAUDCLK,
411 static const struct keyspan_device_details usa49wg_device_details = {
412 .product_id = keyspan_usa49wg_product_id,
413 .msg_format = msg_usa49,
415 .indat_endp_flip = 0,
416 .outdat_endp_flip = 0,
417 .indat_endpoints = {-1, -1, -1, -1}, /* single 'global' data in EP */
418 .outdat_endpoints = {0x01, 0x02, 0x04, 0x06},
419 .inack_endpoints = {-1, -1, -1, -1},
420 .outcont_endpoints = {-1, -1, -1, -1},
421 .instat_endpoint = 0x81,
422 .indat_endpoint = 0x88,
423 .glocont_endpoint = 0x00, /* uses control EP */
424 .calculate_baud_rate = keyspan_usa19w_calc_baud,
425 .baudclk = KEYSPAN_USA19W_BAUDCLK,
428 static const struct keyspan_device_details *keyspan_devices[] = {
429 &usa18x_device_details,
430 &usa19_device_details,
431 &usa19qi_device_details,
433 &usa19qw_device_details,
434 &usa19w_device_details,
435 &usa19hs_device_details,
436 &usa28_device_details,
437 &usa28x_device_details,
438 &usa28xa_device_details,
439 &usa28xg_device_details,
440 /* 28xb not required as it renumerates as a 28x */
441 &usa49w_device_details,
442 &usa49wlc_device_details,
443 &usa49wg_device_details,
447 static const struct usb_device_id keyspan_ids_combined[] = {
448 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa18x_pre_product_id) },
449 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa19_pre_product_id) },
450 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa19w_pre_product_id) },
451 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa19qi_pre_product_id) },
452 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa19qw_pre_product_id) },
453 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_mpr_pre_product_id) },
454 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa28_pre_product_id) },
455 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa28x_pre_product_id) },
456 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa28xa_pre_product_id) },
457 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa28xb_pre_product_id) },
458 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa49w_pre_product_id) },
459 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa49wlc_pre_product_id) },
460 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa18x_product_id) },
461 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa19_product_id) },
462 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa19w_product_id) },
463 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa19qi_product_id) },
464 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa19qw_product_id) },
465 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa19hs_product_id) },
466 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_mpr_product_id) },
467 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa28_product_id) },
468 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa28x_product_id) },
469 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa28xa_product_id) },
470 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa28xg_product_id) },
471 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa49w_product_id)},
472 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa49wlc_product_id)},
473 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa49wg_product_id)},
474 { } /* Terminating entry */
477 MODULE_DEVICE_TABLE(usb, keyspan_ids_combined);
479 /* usb_device_id table for the pre-firmware download keyspan devices */
480 static const struct usb_device_id keyspan_pre_ids[] = {
481 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa18x_pre_product_id) },
482 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa19_pre_product_id) },
483 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa19qi_pre_product_id) },
484 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa19qw_pre_product_id) },
485 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa19w_pre_product_id) },
486 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_mpr_pre_product_id) },
487 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa28_pre_product_id) },
488 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa28x_pre_product_id) },
489 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa28xa_pre_product_id) },
490 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa28xb_pre_product_id) },
491 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa49w_pre_product_id) },
492 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa49wlc_pre_product_id) },
493 { } /* Terminating entry */
496 static const struct usb_device_id keyspan_1port_ids[] = {
497 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa18x_product_id) },
498 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa19_product_id) },
499 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa19qi_product_id) },
500 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa19qw_product_id) },
501 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa19w_product_id) },
502 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa19hs_product_id) },
503 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_mpr_product_id) },
504 { } /* Terminating entry */
507 static const struct usb_device_id keyspan_2port_ids[] = {
508 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa28_product_id) },
509 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa28x_product_id) },
510 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa28xa_product_id) },
511 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa28xg_product_id) },
512 { } /* Terminating entry */
515 static const struct usb_device_id keyspan_4port_ids[] = {
516 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa49w_product_id) },
517 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa49wlc_product_id)},
518 { USB_DEVICE(KEYSPAN_VENDOR_ID, keyspan_usa49wg_product_id)},
519 { } /* Terminating entry */
522 #define INSTAT_BUFLEN 32
523 #define GLOCONT_BUFLEN 64
524 #define INDAT49W_BUFLEN 512
526 #define OUT_BUFLEN 64
527 #define INACK_BUFLEN 1
528 #define OUTCONT_BUFLEN 64
530 /* Per device and per port private data */
531 struct keyspan_serial_private {
532 const struct keyspan_device_details *device_details;
534 struct urb *instat_urb;
537 /* added to support 49wg, where data from all 4 ports comes in
538 on 1 EP and high-speed supported */
539 struct urb *indat_urb;
542 /* XXX this one probably will need a lock */
543 struct urb *glocont_urb;
545 char *ctrl_buf; /* for EP0 control message */
548 struct keyspan_port_private {
549 /* Keep track of which input & output endpoints to use */
553 /* Keep duplicate of device details in each port
554 structure as well - simplifies some of the
555 callback functions etc. */
556 const struct keyspan_device_details *device_details;
558 /* Input endpoints and buffer for this port */
559 struct urb *in_urbs[2];
561 /* Output endpoints and buffer for this port */
562 struct urb *out_urbs[2];
565 /* Input ack endpoint */
566 struct urb *inack_urb;
569 /* Output control endpoint */
570 struct urb *outcont_urb;
571 char *outcont_buffer;
573 /* Settings for the port */
577 unsigned int old_cflag;
578 enum {flow_none, flow_cts, flow_xon} flow_control;
579 int rts_state; /* Handshaking pins (outputs) */
581 int cts_state; /* Handshaking pins (inputs) */
587 unsigned long tx_start_time[2];
588 int resend_cont; /* need to resend control packet */
591 /* Include Keyspan message headers. All current Keyspan Adapters
592 make use of one of five message formats which are referred
593 to as USA-26, USA-28, USA-49, USA-90, USA-67 by Keyspan and
594 within this driver. */
595 #include "keyspan_usa26msg.h"
596 #include "keyspan_usa28msg.h"
597 #include "keyspan_usa49msg.h"
598 #include "keyspan_usa90msg.h"
599 #include "keyspan_usa67msg.h"
602 static void keyspan_break_ctl(struct tty_struct *tty, int break_state)
604 struct usb_serial_port *port = tty->driver_data;
605 struct keyspan_port_private *p_priv;
607 p_priv = usb_get_serial_port_data(port);
609 if (break_state == -1)
610 p_priv->break_on = 1;
612 p_priv->break_on = 0;
614 keyspan_send_setup(port, 0);
618 static void keyspan_set_termios(struct tty_struct *tty,
619 struct usb_serial_port *port, struct ktermios *old_termios)
621 int baud_rate, device_port;
622 struct keyspan_port_private *p_priv;
623 const struct keyspan_device_details *d_details;
626 p_priv = usb_get_serial_port_data(port);
627 d_details = p_priv->device_details;
628 cflag = tty->termios.c_cflag;
629 device_port = port->port_number;
631 /* Baud rate calculation takes baud rate as an integer
632 so other rates can be generated if desired. */
633 baud_rate = tty_get_baud_rate(tty);
634 /* If no match or invalid, don't change */
635 if (d_details->calculate_baud_rate(port, baud_rate, d_details->baudclk,
636 NULL, NULL, NULL, device_port) == KEYSPAN_BAUD_RATE_OK) {
637 /* FIXME - more to do here to ensure rate changes cleanly */
638 /* FIXME - calculate exact rate from divisor ? */
639 p_priv->baud = baud_rate;
641 baud_rate = tty_termios_baud_rate(old_termios);
643 tty_encode_baud_rate(tty, baud_rate, baud_rate);
644 /* set CTS/RTS handshake etc. */
645 p_priv->cflag = cflag;
646 p_priv->flow_control = (cflag & CRTSCTS) ? flow_cts : flow_none;
648 /* Mark/Space not supported */
649 tty->termios.c_cflag &= ~CMSPAR;
651 keyspan_send_setup(port, 0);
654 static int keyspan_tiocmget(struct tty_struct *tty)
656 struct usb_serial_port *port = tty->driver_data;
657 struct keyspan_port_private *p_priv = usb_get_serial_port_data(port);
660 value = ((p_priv->rts_state) ? TIOCM_RTS : 0) |
661 ((p_priv->dtr_state) ? TIOCM_DTR : 0) |
662 ((p_priv->cts_state) ? TIOCM_CTS : 0) |
663 ((p_priv->dsr_state) ? TIOCM_DSR : 0) |
664 ((p_priv->dcd_state) ? TIOCM_CAR : 0) |
665 ((p_priv->ri_state) ? TIOCM_RNG : 0);
670 static int keyspan_tiocmset(struct tty_struct *tty,
671 unsigned int set, unsigned int clear)
673 struct usb_serial_port *port = tty->driver_data;
674 struct keyspan_port_private *p_priv = usb_get_serial_port_data(port);
677 p_priv->rts_state = 1;
679 p_priv->dtr_state = 1;
680 if (clear & TIOCM_RTS)
681 p_priv->rts_state = 0;
682 if (clear & TIOCM_DTR)
683 p_priv->dtr_state = 0;
684 keyspan_send_setup(port, 0);
688 /* Write function is similar for the four protocols used
689 with only a minor change for usa90 (usa19hs) required */
690 static int keyspan_write(struct tty_struct *tty,
691 struct usb_serial_port *port, const unsigned char *buf, int count)
693 struct keyspan_port_private *p_priv;
694 const struct keyspan_device_details *d_details;
697 struct urb *this_urb;
698 int err, maxDataLen, dataOffset;
700 p_priv = usb_get_serial_port_data(port);
701 d_details = p_priv->device_details;
703 if (d_details->msg_format == msg_usa90) {
711 dev_dbg(&port->dev, "%s - %d chars, flip=%d\n", __func__, count,
714 for (left = count; left > 0; left -= todo) {
716 if (todo > maxDataLen)
719 flip = p_priv->out_flip;
721 /* Check we have a valid urb/endpoint before we use it... */
722 this_urb = p_priv->out_urbs[flip];
723 if (this_urb == NULL) {
724 /* no bulk out, so return 0 bytes written */
725 dev_dbg(&port->dev, "%s - no output urb :(\n", __func__);
729 dev_dbg(&port->dev, "%s - endpoint %x flip %d\n",
730 __func__, usb_pipeendpoint(this_urb->pipe), flip);
732 if (this_urb->status == -EINPROGRESS) {
733 if (time_before(jiffies,
734 p_priv->tx_start_time[flip] + 10 * HZ))
736 usb_unlink_urb(this_urb);
740 /* First byte in buffer is "last flag" (except for usa19hx)
741 - unused so for now so set to zero */
742 ((char *)this_urb->transfer_buffer)[0] = 0;
744 memcpy(this_urb->transfer_buffer + dataOffset, buf, todo);
747 /* send the data out the bulk port */
748 this_urb->transfer_buffer_length = todo + dataOffset;
750 err = usb_submit_urb(this_urb, GFP_ATOMIC);
752 dev_dbg(&port->dev, "usb_submit_urb(write bulk) failed (%d)\n", err);
753 p_priv->tx_start_time[flip] = jiffies;
755 /* Flip for next time if usa26 or usa28 interface
756 (not used on usa49) */
757 p_priv->out_flip = (flip + 1) & d_details->outdat_endp_flip;
763 static void usa26_indat_callback(struct urb *urb)
767 struct usb_serial_port *port;
768 unsigned char *data = urb->transfer_buffer;
769 int status = urb->status;
771 endpoint = usb_pipeendpoint(urb->pipe);
774 dev_dbg(&urb->dev->dev, "%s - nonzero status %d on endpoint %x\n",
775 __func__, status, endpoint);
780 if (urb->actual_length) {
781 /* 0x80 bit is error flag */
782 if ((data[0] & 0x80) == 0) {
783 /* no errors on individual bytes, only
784 possible overrun err */
785 if (data[0] & RXERROR_OVERRUN) {
786 tty_insert_flip_char(&port->port, 0,
789 for (i = 1; i < urb->actual_length ; ++i)
790 tty_insert_flip_char(&port->port, data[i],
793 /* some bytes had errors, every byte has status */
794 dev_dbg(&port->dev, "%s - RX error!!!!\n", __func__);
795 for (i = 0; i + 1 < urb->actual_length; i += 2) {
797 int flag = TTY_NORMAL;
799 if (stat & RXERROR_OVERRUN) {
800 tty_insert_flip_char(&port->port, 0,
803 /* XXX should handle break (0x10) */
804 if (stat & RXERROR_PARITY)
806 else if (stat & RXERROR_FRAMING)
809 tty_insert_flip_char(&port->port, data[i+1],
813 tty_flip_buffer_push(&port->port);
816 /* Resubmit urb so we continue receiving */
817 err = usb_submit_urb(urb, GFP_ATOMIC);
819 dev_dbg(&port->dev, "%s - resubmit read urb failed. (%d)\n", __func__, err);
822 /* Outdat handling is common for all devices */
823 static void usa2x_outdat_callback(struct urb *urb)
825 struct usb_serial_port *port;
826 struct keyspan_port_private *p_priv;
829 p_priv = usb_get_serial_port_data(port);
830 dev_dbg(&port->dev, "%s - urb %d\n", __func__, urb == p_priv->out_urbs[1]);
832 usb_serial_port_softint(port);
835 static void usa26_inack_callback(struct urb *urb)
839 static void usa26_outcont_callback(struct urb *urb)
841 struct usb_serial_port *port;
842 struct keyspan_port_private *p_priv;
845 p_priv = usb_get_serial_port_data(port);
847 if (p_priv->resend_cont) {
848 dev_dbg(&port->dev, "%s - sending setup\n", __func__);
849 keyspan_usa26_send_setup(port->serial, port,
850 p_priv->resend_cont - 1);
854 static void usa26_instat_callback(struct urb *urb)
856 unsigned char *data = urb->transfer_buffer;
857 struct keyspan_usa26_portStatusMessage *msg;
858 struct usb_serial *serial;
859 struct usb_serial_port *port;
860 struct keyspan_port_private *p_priv;
861 int old_dcd_state, err;
862 int status = urb->status;
864 serial = urb->context;
867 dev_dbg(&urb->dev->dev, "%s - nonzero status: %d\n",
871 if (urb->actual_length != 9) {
872 dev_dbg(&urb->dev->dev, "%s - %d byte report??\n", __func__, urb->actual_length);
876 msg = (struct keyspan_usa26_portStatusMessage *)data;
878 /* Check port number from message and retrieve private data */
879 if (msg->port >= serial->num_ports) {
880 dev_dbg(&urb->dev->dev, "%s - Unexpected port number %d\n", __func__, msg->port);
883 port = serial->port[msg->port];
884 p_priv = usb_get_serial_port_data(port);
888 /* Update handshaking pin state information */
889 old_dcd_state = p_priv->dcd_state;
890 p_priv->cts_state = ((msg->hskia_cts) ? 1 : 0);
891 p_priv->dsr_state = ((msg->dsr) ? 1 : 0);
892 p_priv->dcd_state = ((msg->gpia_dcd) ? 1 : 0);
893 p_priv->ri_state = ((msg->ri) ? 1 : 0);
895 if (old_dcd_state != p_priv->dcd_state)
896 tty_port_tty_hangup(&port->port, true);
898 /* Resubmit urb so we continue receiving */
899 err = usb_submit_urb(urb, GFP_ATOMIC);
901 dev_dbg(&port->dev, "%s - resubmit read urb failed. (%d)\n", __func__, err);
905 static void usa26_glocont_callback(struct urb *urb)
910 static void usa28_indat_callback(struct urb *urb)
913 struct usb_serial_port *port;
915 struct keyspan_port_private *p_priv;
916 int status = urb->status;
919 p_priv = usb_get_serial_port_data(port);
920 data = urb->transfer_buffer;
922 if (urb != p_priv->in_urbs[p_priv->in_flip])
927 dev_dbg(&urb->dev->dev, "%s - nonzero status %d on endpoint %x\n",
928 __func__, status, usb_pipeendpoint(urb->pipe));
933 p_priv = usb_get_serial_port_data(port);
934 data = urb->transfer_buffer;
936 if (urb->actual_length) {
937 tty_insert_flip_string(&port->port, data,
939 tty_flip_buffer_push(&port->port);
942 /* Resubmit urb so we continue receiving */
943 err = usb_submit_urb(urb, GFP_ATOMIC);
945 dev_dbg(&port->dev, "%s - resubmit read urb failed. (%d)\n",
947 p_priv->in_flip ^= 1;
949 urb = p_priv->in_urbs[p_priv->in_flip];
950 } while (urb->status != -EINPROGRESS);
953 static void usa28_inack_callback(struct urb *urb)
957 static void usa28_outcont_callback(struct urb *urb)
959 struct usb_serial_port *port;
960 struct keyspan_port_private *p_priv;
963 p_priv = usb_get_serial_port_data(port);
965 if (p_priv->resend_cont) {
966 dev_dbg(&port->dev, "%s - sending setup\n", __func__);
967 keyspan_usa28_send_setup(port->serial, port,
968 p_priv->resend_cont - 1);
972 static void usa28_instat_callback(struct urb *urb)
975 unsigned char *data = urb->transfer_buffer;
976 struct keyspan_usa28_portStatusMessage *msg;
977 struct usb_serial *serial;
978 struct usb_serial_port *port;
979 struct keyspan_port_private *p_priv;
981 int status = urb->status;
983 serial = urb->context;
986 dev_dbg(&urb->dev->dev, "%s - nonzero status: %d\n",
991 if (urb->actual_length != sizeof(struct keyspan_usa28_portStatusMessage)) {
992 dev_dbg(&urb->dev->dev, "%s - bad length %d\n", __func__, urb->actual_length);
996 msg = (struct keyspan_usa28_portStatusMessage *)data;
998 /* Check port number from message and retrieve private data */
999 if (msg->port >= serial->num_ports) {
1000 dev_dbg(&urb->dev->dev, "%s - Unexpected port number %d\n", __func__, msg->port);
1003 port = serial->port[msg->port];
1004 p_priv = usb_get_serial_port_data(port);
1008 /* Update handshaking pin state information */
1009 old_dcd_state = p_priv->dcd_state;
1010 p_priv->cts_state = ((msg->cts) ? 1 : 0);
1011 p_priv->dsr_state = ((msg->dsr) ? 1 : 0);
1012 p_priv->dcd_state = ((msg->dcd) ? 1 : 0);
1013 p_priv->ri_state = ((msg->ri) ? 1 : 0);
1015 if (old_dcd_state != p_priv->dcd_state && old_dcd_state)
1016 tty_port_tty_hangup(&port->port, true);
1018 /* Resubmit urb so we continue receiving */
1019 err = usb_submit_urb(urb, GFP_ATOMIC);
1021 dev_dbg(&port->dev, "%s - resubmit read urb failed. (%d)\n", __func__, err);
1025 static void usa28_glocont_callback(struct urb *urb)
1030 static void usa49_glocont_callback(struct urb *urb)
1032 struct usb_serial *serial;
1033 struct usb_serial_port *port;
1034 struct keyspan_port_private *p_priv;
1037 serial = urb->context;
1038 for (i = 0; i < serial->num_ports; ++i) {
1039 port = serial->port[i];
1040 p_priv = usb_get_serial_port_data(port);
1044 if (p_priv->resend_cont) {
1045 dev_dbg(&port->dev, "%s - sending setup\n", __func__);
1046 keyspan_usa49_send_setup(serial, port,
1047 p_priv->resend_cont - 1);
1053 /* This is actually called glostat in the Keyspan
1055 static void usa49_instat_callback(struct urb *urb)
1058 unsigned char *data = urb->transfer_buffer;
1059 struct keyspan_usa49_portStatusMessage *msg;
1060 struct usb_serial *serial;
1061 struct usb_serial_port *port;
1062 struct keyspan_port_private *p_priv;
1064 int status = urb->status;
1066 serial = urb->context;
1069 dev_dbg(&urb->dev->dev, "%s - nonzero status: %d\n",
1074 if (urb->actual_length !=
1075 sizeof(struct keyspan_usa49_portStatusMessage)) {
1076 dev_dbg(&urb->dev->dev, "%s - bad length %d\n", __func__, urb->actual_length);
1080 msg = (struct keyspan_usa49_portStatusMessage *)data;
1082 /* Check port number from message and retrieve private data */
1083 if (msg->portNumber >= serial->num_ports) {
1084 dev_dbg(&urb->dev->dev, "%s - Unexpected port number %d\n",
1085 __func__, msg->portNumber);
1088 port = serial->port[msg->portNumber];
1089 p_priv = usb_get_serial_port_data(port);
1093 /* Update handshaking pin state information */
1094 old_dcd_state = p_priv->dcd_state;
1095 p_priv->cts_state = ((msg->cts) ? 1 : 0);
1096 p_priv->dsr_state = ((msg->dsr) ? 1 : 0);
1097 p_priv->dcd_state = ((msg->dcd) ? 1 : 0);
1098 p_priv->ri_state = ((msg->ri) ? 1 : 0);
1100 if (old_dcd_state != p_priv->dcd_state && old_dcd_state)
1101 tty_port_tty_hangup(&port->port, true);
1103 /* Resubmit urb so we continue receiving */
1104 err = usb_submit_urb(urb, GFP_ATOMIC);
1106 dev_dbg(&port->dev, "%s - resubmit read urb failed. (%d)\n", __func__, err);
1110 static void usa49_inack_callback(struct urb *urb)
1114 static void usa49_indat_callback(struct urb *urb)
1118 struct usb_serial_port *port;
1119 unsigned char *data = urb->transfer_buffer;
1120 int status = urb->status;
1122 endpoint = usb_pipeendpoint(urb->pipe);
1125 dev_dbg(&urb->dev->dev, "%s - nonzero status %d on endpoint %x\n",
1126 __func__, status, endpoint);
1130 port = urb->context;
1131 if (urb->actual_length) {
1132 /* 0x80 bit is error flag */
1133 if ((data[0] & 0x80) == 0) {
1134 /* no error on any byte */
1135 tty_insert_flip_string(&port->port, data + 1,
1136 urb->actual_length - 1);
1138 /* some bytes had errors, every byte has status */
1139 for (i = 0; i + 1 < urb->actual_length; i += 2) {
1141 int flag = TTY_NORMAL;
1143 if (stat & RXERROR_OVERRUN) {
1144 tty_insert_flip_char(&port->port, 0,
1147 /* XXX should handle break (0x10) */
1148 if (stat & RXERROR_PARITY)
1150 else if (stat & RXERROR_FRAMING)
1153 tty_insert_flip_char(&port->port, data[i+1],
1157 tty_flip_buffer_push(&port->port);
1160 /* Resubmit urb so we continue receiving */
1161 err = usb_submit_urb(urb, GFP_ATOMIC);
1163 dev_dbg(&port->dev, "%s - resubmit read urb failed. (%d)\n", __func__, err);
1166 static void usa49wg_indat_callback(struct urb *urb)
1169 struct usb_serial *serial;
1170 struct usb_serial_port *port;
1171 unsigned char *data = urb->transfer_buffer;
1172 int status = urb->status;
1174 serial = urb->context;
1177 dev_dbg(&urb->dev->dev, "%s - nonzero status: %d\n",
1182 /* inbound data is in the form P#, len, status, data */
1186 while (i < urb->actual_length) {
1188 /* Check port number from message */
1189 if (data[i] >= serial->num_ports) {
1190 dev_dbg(&urb->dev->dev, "%s - Unexpected port number %d\n",
1194 port = serial->port[data[i++]];
1197 /* 0x80 bit is error flag */
1198 if ((data[i] & 0x80) == 0) {
1199 /* no error on any byte */
1201 for (x = 1; x < len && i < urb->actual_length; ++x)
1202 tty_insert_flip_char(&port->port,
1206 * some bytes had errors, every byte has status
1208 for (x = 0; x + 1 < len &&
1209 i + 1 < urb->actual_length; x += 2) {
1211 int flag = TTY_NORMAL;
1213 if (stat & RXERROR_OVERRUN) {
1214 tty_insert_flip_char(&port->port, 0,
1217 /* XXX should handle break (0x10) */
1218 if (stat & RXERROR_PARITY)
1220 else if (stat & RXERROR_FRAMING)
1223 tty_insert_flip_char(&port->port, data[i+1],
1228 tty_flip_buffer_push(&port->port);
1231 /* Resubmit urb so we continue receiving */
1232 err = usb_submit_urb(urb, GFP_ATOMIC);
1234 dev_dbg(&urb->dev->dev, "%s - resubmit read urb failed. (%d)\n", __func__, err);
1237 /* not used, usa-49 doesn't have per-port control endpoints */
1238 static void usa49_outcont_callback(struct urb *urb)
1242 static void usa90_indat_callback(struct urb *urb)
1246 struct usb_serial_port *port;
1247 struct keyspan_port_private *p_priv;
1248 unsigned char *data = urb->transfer_buffer;
1249 int status = urb->status;
1251 endpoint = usb_pipeendpoint(urb->pipe);
1254 dev_dbg(&urb->dev->dev, "%s - nonzero status %d on endpoint %x\n",
1255 __func__, status, endpoint);
1259 port = urb->context;
1260 p_priv = usb_get_serial_port_data(port);
1262 if (urb->actual_length) {
1263 /* if current mode is DMA, looks like usa28 format
1264 otherwise looks like usa26 data format */
1266 if (p_priv->baud > 57600)
1267 tty_insert_flip_string(&port->port, data,
1268 urb->actual_length);
1270 /* 0x80 bit is error flag */
1271 if ((data[0] & 0x80) == 0) {
1272 /* no errors on individual bytes, only
1273 possible overrun err*/
1274 if (data[0] & RXERROR_OVERRUN) {
1275 tty_insert_flip_char(&port->port, 0,
1278 for (i = 1; i < urb->actual_length ; ++i)
1279 tty_insert_flip_char(&port->port,
1280 data[i], TTY_NORMAL);
1282 /* some bytes had errors, every byte has status */
1283 dev_dbg(&port->dev, "%s - RX error!!!!\n", __func__);
1284 for (i = 0; i + 1 < urb->actual_length; i += 2) {
1286 int flag = TTY_NORMAL;
1288 if (stat & RXERROR_OVERRUN) {
1289 tty_insert_flip_char(
1293 /* XXX should handle break (0x10) */
1294 if (stat & RXERROR_PARITY)
1296 else if (stat & RXERROR_FRAMING)
1299 tty_insert_flip_char(&port->port,
1304 tty_flip_buffer_push(&port->port);
1307 /* Resubmit urb so we continue receiving */
1308 err = usb_submit_urb(urb, GFP_ATOMIC);
1310 dev_dbg(&port->dev, "%s - resubmit read urb failed. (%d)\n", __func__, err);
1314 static void usa90_instat_callback(struct urb *urb)
1316 unsigned char *data = urb->transfer_buffer;
1317 struct keyspan_usa90_portStatusMessage *msg;
1318 struct usb_serial *serial;
1319 struct usb_serial_port *port;
1320 struct keyspan_port_private *p_priv;
1321 int old_dcd_state, err;
1322 int status = urb->status;
1324 serial = urb->context;
1327 dev_dbg(&urb->dev->dev, "%s - nonzero status: %d\n",
1331 if (urb->actual_length < 14) {
1332 dev_dbg(&urb->dev->dev, "%s - %d byte report??\n", __func__, urb->actual_length);
1336 msg = (struct keyspan_usa90_portStatusMessage *)data;
1338 /* Now do something useful with the data */
1340 port = serial->port[0];
1341 p_priv = usb_get_serial_port_data(port);
1345 /* Update handshaking pin state information */
1346 old_dcd_state = p_priv->dcd_state;
1347 p_priv->cts_state = ((msg->cts) ? 1 : 0);
1348 p_priv->dsr_state = ((msg->dsr) ? 1 : 0);
1349 p_priv->dcd_state = ((msg->dcd) ? 1 : 0);
1350 p_priv->ri_state = ((msg->ri) ? 1 : 0);
1352 if (old_dcd_state != p_priv->dcd_state && old_dcd_state)
1353 tty_port_tty_hangup(&port->port, true);
1355 /* Resubmit urb so we continue receiving */
1356 err = usb_submit_urb(urb, GFP_ATOMIC);
1358 dev_dbg(&port->dev, "%s - resubmit read urb failed. (%d)\n", __func__, err);
1363 static void usa90_outcont_callback(struct urb *urb)
1365 struct usb_serial_port *port;
1366 struct keyspan_port_private *p_priv;
1368 port = urb->context;
1369 p_priv = usb_get_serial_port_data(port);
1371 if (p_priv->resend_cont) {
1372 dev_dbg(&urb->dev->dev, "%s - sending setup\n", __func__);
1373 keyspan_usa90_send_setup(port->serial, port,
1374 p_priv->resend_cont - 1);
1378 /* Status messages from the 28xg */
1379 static void usa67_instat_callback(struct urb *urb)
1382 unsigned char *data = urb->transfer_buffer;
1383 struct keyspan_usa67_portStatusMessage *msg;
1384 struct usb_serial *serial;
1385 struct usb_serial_port *port;
1386 struct keyspan_port_private *p_priv;
1388 int status = urb->status;
1390 serial = urb->context;
1393 dev_dbg(&urb->dev->dev, "%s - nonzero status: %d\n",
1398 if (urb->actual_length !=
1399 sizeof(struct keyspan_usa67_portStatusMessage)) {
1400 dev_dbg(&urb->dev->dev, "%s - bad length %d\n", __func__, urb->actual_length);
1405 /* Now do something useful with the data */
1406 msg = (struct keyspan_usa67_portStatusMessage *)data;
1408 /* Check port number from message and retrieve private data */
1409 if (msg->port >= serial->num_ports) {
1410 dev_dbg(&urb->dev->dev, "%s - Unexpected port number %d\n", __func__, msg->port);
1414 port = serial->port[msg->port];
1415 p_priv = usb_get_serial_port_data(port);
1419 /* Update handshaking pin state information */
1420 old_dcd_state = p_priv->dcd_state;
1421 p_priv->cts_state = ((msg->hskia_cts) ? 1 : 0);
1422 p_priv->dcd_state = ((msg->gpia_dcd) ? 1 : 0);
1424 if (old_dcd_state != p_priv->dcd_state && old_dcd_state)
1425 tty_port_tty_hangup(&port->port, true);
1427 /* Resubmit urb so we continue receiving */
1428 err = usb_submit_urb(urb, GFP_ATOMIC);
1430 dev_dbg(&port->dev, "%s - resubmit read urb failed. (%d)\n", __func__, err);
1433 static void usa67_glocont_callback(struct urb *urb)
1435 struct usb_serial *serial;
1436 struct usb_serial_port *port;
1437 struct keyspan_port_private *p_priv;
1440 serial = urb->context;
1441 for (i = 0; i < serial->num_ports; ++i) {
1442 port = serial->port[i];
1443 p_priv = usb_get_serial_port_data(port);
1447 if (p_priv->resend_cont) {
1448 dev_dbg(&port->dev, "%s - sending setup\n", __func__);
1449 keyspan_usa67_send_setup(serial, port,
1450 p_priv->resend_cont - 1);
1456 static unsigned int keyspan_write_room(struct tty_struct *tty)
1458 struct usb_serial_port *port = tty->driver_data;
1459 struct keyspan_port_private *p_priv;
1460 const struct keyspan_device_details *d_details;
1462 unsigned int data_len;
1463 struct urb *this_urb;
1465 p_priv = usb_get_serial_port_data(port);
1466 d_details = p_priv->device_details;
1468 /* FIXME: locking */
1469 if (d_details->msg_format == msg_usa90)
1474 flip = p_priv->out_flip;
1476 /* Check both endpoints to see if any are available. */
1477 this_urb = p_priv->out_urbs[flip];
1478 if (this_urb != NULL) {
1479 if (this_urb->status != -EINPROGRESS)
1481 flip = (flip + 1) & d_details->outdat_endp_flip;
1482 this_urb = p_priv->out_urbs[flip];
1483 if (this_urb != NULL) {
1484 if (this_urb->status != -EINPROGRESS)
1492 static int keyspan_open(struct tty_struct *tty, struct usb_serial_port *port)
1494 struct keyspan_port_private *p_priv;
1495 const struct keyspan_device_details *d_details;
1497 int baud_rate, device_port;
1499 unsigned int cflag = 0;
1501 p_priv = usb_get_serial_port_data(port);
1502 d_details = p_priv->device_details;
1504 /* Set some sane defaults */
1505 p_priv->rts_state = 1;
1506 p_priv->dtr_state = 1;
1507 p_priv->baud = 9600;
1509 /* force baud and lcr to be set on open */
1510 p_priv->old_baud = 0;
1511 p_priv->old_cflag = 0;
1513 p_priv->out_flip = 0;
1514 p_priv->in_flip = 0;
1516 /* Reset low level data toggle and start reading from endpoints */
1517 for (i = 0; i < 2; i++) {
1518 urb = p_priv->in_urbs[i];
1522 /* make sure endpoint data toggle is synchronized
1524 usb_clear_halt(urb->dev, urb->pipe);
1525 err = usb_submit_urb(urb, GFP_KERNEL);
1527 dev_dbg(&port->dev, "%s - submit urb %d failed (%d)\n", __func__, i, err);
1530 /* Reset low level data toggle on out endpoints */
1531 for (i = 0; i < 2; i++) {
1532 urb = p_priv->out_urbs[i];
1535 /* usb_settoggle(urb->dev, usb_pipeendpoint(urb->pipe),
1536 usb_pipeout(urb->pipe), 0); */
1539 /* get the terminal config for the setup message now so we don't
1540 * need to send 2 of them */
1542 device_port = port->port_number;
1544 cflag = tty->termios.c_cflag;
1545 /* Baud rate calculation takes baud rate as an integer
1546 so other rates can be generated if desired. */
1547 baud_rate = tty_get_baud_rate(tty);
1548 /* If no match or invalid, leave as default */
1550 && d_details->calculate_baud_rate(port, baud_rate, d_details->baudclk,
1551 NULL, NULL, NULL, device_port) == KEYSPAN_BAUD_RATE_OK) {
1552 p_priv->baud = baud_rate;
1555 /* set CTS/RTS handshake etc. */
1556 p_priv->cflag = cflag;
1557 p_priv->flow_control = (cflag & CRTSCTS) ? flow_cts : flow_none;
1559 keyspan_send_setup(port, 1);
1561 /* keyspan_set_termios(port, NULL); */
1566 static void keyspan_dtr_rts(struct usb_serial_port *port, int on)
1568 struct keyspan_port_private *p_priv = usb_get_serial_port_data(port);
1570 p_priv->rts_state = on;
1571 p_priv->dtr_state = on;
1572 keyspan_send_setup(port, 0);
1575 static void keyspan_close(struct usb_serial_port *port)
1578 struct keyspan_port_private *p_priv;
1580 p_priv = usb_get_serial_port_data(port);
1582 p_priv->rts_state = 0;
1583 p_priv->dtr_state = 0;
1585 keyspan_send_setup(port, 2);
1586 /* pilot-xfer seems to work best with this delay */
1589 p_priv->out_flip = 0;
1590 p_priv->in_flip = 0;
1592 usb_kill_urb(p_priv->inack_urb);
1593 for (i = 0; i < 2; i++) {
1594 usb_kill_urb(p_priv->in_urbs[i]);
1595 usb_kill_urb(p_priv->out_urbs[i]);
1599 /* download the firmware to a pre-renumeration device */
1600 static int keyspan_fake_startup(struct usb_serial *serial)
1604 dev_dbg(&serial->dev->dev, "Keyspan startup version %04x product %04x\n",
1605 le16_to_cpu(serial->dev->descriptor.bcdDevice),
1606 le16_to_cpu(serial->dev->descriptor.idProduct));
1608 if ((le16_to_cpu(serial->dev->descriptor.bcdDevice) & 0x8000)
1610 dev_dbg(&serial->dev->dev, "Firmware already loaded. Quitting.\n");
1614 /* Select firmware image on the basis of idProduct */
1615 switch (le16_to_cpu(serial->dev->descriptor.idProduct)) {
1616 case keyspan_usa28_pre_product_id:
1617 fw_name = "keyspan/usa28.fw";
1620 case keyspan_usa28x_pre_product_id:
1621 fw_name = "keyspan/usa28x.fw";
1624 case keyspan_usa28xa_pre_product_id:
1625 fw_name = "keyspan/usa28xa.fw";
1628 case keyspan_usa28xb_pre_product_id:
1629 fw_name = "keyspan/usa28xb.fw";
1632 case keyspan_usa19_pre_product_id:
1633 fw_name = "keyspan/usa19.fw";
1636 case keyspan_usa19qi_pre_product_id:
1637 fw_name = "keyspan/usa19qi.fw";
1640 case keyspan_mpr_pre_product_id:
1641 fw_name = "keyspan/mpr.fw";
1644 case keyspan_usa19qw_pre_product_id:
1645 fw_name = "keyspan/usa19qw.fw";
1648 case keyspan_usa18x_pre_product_id:
1649 fw_name = "keyspan/usa18x.fw";
1652 case keyspan_usa19w_pre_product_id:
1653 fw_name = "keyspan/usa19w.fw";
1656 case keyspan_usa49w_pre_product_id:
1657 fw_name = "keyspan/usa49w.fw";
1660 case keyspan_usa49wlc_pre_product_id:
1661 fw_name = "keyspan/usa49wlc.fw";
1665 dev_err(&serial->dev->dev, "Unknown product ID (%04x)\n",
1666 le16_to_cpu(serial->dev->descriptor.idProduct));
1670 dev_dbg(&serial->dev->dev, "Uploading Keyspan %s firmware.\n", fw_name);
1672 if (ezusb_fx1_ihex_firmware_download(serial->dev, fw_name) < 0) {
1673 dev_err(&serial->dev->dev, "failed to load firmware \"%s\"\n",
1678 /* after downloading firmware Renumeration will occur in a
1679 moment and the new device will bind to the real driver */
1681 /* we don't want this device to have a driver assigned to it. */
1685 /* Helper functions used by keyspan_setup_urbs */
1686 static struct usb_endpoint_descriptor const *find_ep(struct usb_serial const *serial,
1689 struct usb_host_interface *iface_desc;
1690 struct usb_endpoint_descriptor *ep;
1693 iface_desc = serial->interface->cur_altsetting;
1694 for (i = 0; i < iface_desc->desc.bNumEndpoints; ++i) {
1695 ep = &iface_desc->endpoint[i].desc;
1696 if (ep->bEndpointAddress == endpoint)
1699 dev_warn(&serial->interface->dev, "found no endpoint descriptor for endpoint %x\n",
1704 static struct urb *keyspan_setup_urb(struct usb_serial *serial, int endpoint,
1705 int dir, void *ctx, char *buf, int len,
1706 void (*callback)(struct urb *))
1709 struct usb_endpoint_descriptor const *ep_desc;
1710 char const *ep_type_name;
1713 return NULL; /* endpoint not needed */
1715 dev_dbg(&serial->interface->dev, "%s - alloc for endpoint %x\n",
1716 __func__, endpoint);
1717 urb = usb_alloc_urb(0, GFP_KERNEL); /* No ISO */
1721 if (endpoint == 0) {
1722 /* control EP filled in when used */
1726 ep_desc = find_ep(serial, endpoint);
1731 if (usb_endpoint_xfer_int(ep_desc)) {
1732 ep_type_name = "INT";
1733 usb_fill_int_urb(urb, serial->dev,
1734 usb_sndintpipe(serial->dev, endpoint) | dir,
1735 buf, len, callback, ctx,
1736 ep_desc->bInterval);
1737 } else if (usb_endpoint_xfer_bulk(ep_desc)) {
1738 ep_type_name = "BULK";
1739 usb_fill_bulk_urb(urb, serial->dev,
1740 usb_sndbulkpipe(serial->dev, endpoint) | dir,
1741 buf, len, callback, ctx);
1743 dev_warn(&serial->interface->dev,
1744 "unsupported endpoint type %x\n",
1745 usb_endpoint_type(ep_desc));
1750 dev_dbg(&serial->interface->dev, "%s - using urb %p for %s endpoint %x\n",
1751 __func__, urb, ep_type_name, endpoint);
1755 static struct callbacks {
1756 void (*instat_callback)(struct urb *);
1757 void (*glocont_callback)(struct urb *);
1758 void (*indat_callback)(struct urb *);
1759 void (*outdat_callback)(struct urb *);
1760 void (*inack_callback)(struct urb *);
1761 void (*outcont_callback)(struct urb *);
1762 } keyspan_callbacks[] = {
1764 /* msg_usa26 callbacks */
1765 .instat_callback = usa26_instat_callback,
1766 .glocont_callback = usa26_glocont_callback,
1767 .indat_callback = usa26_indat_callback,
1768 .outdat_callback = usa2x_outdat_callback,
1769 .inack_callback = usa26_inack_callback,
1770 .outcont_callback = usa26_outcont_callback,
1772 /* msg_usa28 callbacks */
1773 .instat_callback = usa28_instat_callback,
1774 .glocont_callback = usa28_glocont_callback,
1775 .indat_callback = usa28_indat_callback,
1776 .outdat_callback = usa2x_outdat_callback,
1777 .inack_callback = usa28_inack_callback,
1778 .outcont_callback = usa28_outcont_callback,
1780 /* msg_usa49 callbacks */
1781 .instat_callback = usa49_instat_callback,
1782 .glocont_callback = usa49_glocont_callback,
1783 .indat_callback = usa49_indat_callback,
1784 .outdat_callback = usa2x_outdat_callback,
1785 .inack_callback = usa49_inack_callback,
1786 .outcont_callback = usa49_outcont_callback,
1788 /* msg_usa90 callbacks */
1789 .instat_callback = usa90_instat_callback,
1790 .glocont_callback = usa28_glocont_callback,
1791 .indat_callback = usa90_indat_callback,
1792 .outdat_callback = usa2x_outdat_callback,
1793 .inack_callback = usa28_inack_callback,
1794 .outcont_callback = usa90_outcont_callback,
1796 /* msg_usa67 callbacks */
1797 .instat_callback = usa67_instat_callback,
1798 .glocont_callback = usa67_glocont_callback,
1799 .indat_callback = usa26_indat_callback,
1800 .outdat_callback = usa2x_outdat_callback,
1801 .inack_callback = usa26_inack_callback,
1802 .outcont_callback = usa26_outcont_callback,
1806 /* Generic setup urbs function that uses
1807 data in device_details */
1808 static void keyspan_setup_urbs(struct usb_serial *serial)
1810 struct keyspan_serial_private *s_priv;
1811 const struct keyspan_device_details *d_details;
1812 struct callbacks *cback;
1814 s_priv = usb_get_serial_data(serial);
1815 d_details = s_priv->device_details;
1817 /* Setup values for the various callback routines */
1818 cback = &keyspan_callbacks[d_details->msg_format];
1820 /* Allocate and set up urbs for each one that is in use,
1821 starting with instat endpoints */
1822 s_priv->instat_urb = keyspan_setup_urb
1823 (serial, d_details->instat_endpoint, USB_DIR_IN,
1824 serial, s_priv->instat_buf, INSTAT_BUFLEN,
1825 cback->instat_callback);
1827 s_priv->indat_urb = keyspan_setup_urb
1828 (serial, d_details->indat_endpoint, USB_DIR_IN,
1829 serial, s_priv->indat_buf, INDAT49W_BUFLEN,
1830 usa49wg_indat_callback);
1832 s_priv->glocont_urb = keyspan_setup_urb
1833 (serial, d_details->glocont_endpoint, USB_DIR_OUT,
1834 serial, s_priv->glocont_buf, GLOCONT_BUFLEN,
1835 cback->glocont_callback);
1838 /* usa19 function doesn't require prescaler */
1839 static int keyspan_usa19_calc_baud(struct usb_serial_port *port,
1840 u32 baud_rate, u32 baudclk, u8 *rate_hi,
1841 u8 *rate_low, u8 *prescaler, int portnum)
1843 u32 b16, /* baud rate times 16 (actual rate used internally) */
1845 cnt; /* inverse of divisor (programmed into 8051) */
1847 dev_dbg(&port->dev, "%s - %d.\n", __func__, baud_rate);
1849 /* prevent divide by zero... */
1850 b16 = baud_rate * 16L;
1852 return KEYSPAN_INVALID_BAUD_RATE;
1853 /* Any "standard" rate over 57k6 is marginal on the USA-19
1854 as we run out of divisor resolution. */
1855 if (baud_rate > 57600)
1856 return KEYSPAN_INVALID_BAUD_RATE;
1858 /* calculate the divisor and the counter (its inverse) */
1859 div = baudclk / b16;
1861 return KEYSPAN_INVALID_BAUD_RATE;
1866 return KEYSPAN_INVALID_BAUD_RATE;
1868 /* return the counter values if non-null */
1870 *rate_low = (u8) (cnt & 0xff);
1872 *rate_hi = (u8) ((cnt >> 8) & 0xff);
1873 if (rate_low && rate_hi)
1874 dev_dbg(&port->dev, "%s - %d %02x %02x.\n",
1875 __func__, baud_rate, *rate_hi, *rate_low);
1876 return KEYSPAN_BAUD_RATE_OK;
1879 /* usa19hs function doesn't require prescaler */
1880 static int keyspan_usa19hs_calc_baud(struct usb_serial_port *port,
1881 u32 baud_rate, u32 baudclk, u8 *rate_hi,
1882 u8 *rate_low, u8 *prescaler, int portnum)
1884 u32 b16, /* baud rate times 16 (actual rate used internally) */
1887 dev_dbg(&port->dev, "%s - %d.\n", __func__, baud_rate);
1889 /* prevent divide by zero... */
1890 b16 = baud_rate * 16L;
1892 return KEYSPAN_INVALID_BAUD_RATE;
1894 /* calculate the divisor */
1895 div = baudclk / b16;
1897 return KEYSPAN_INVALID_BAUD_RATE;
1900 return KEYSPAN_INVALID_BAUD_RATE;
1902 /* return the counter values if non-null */
1904 *rate_low = (u8) (div & 0xff);
1907 *rate_hi = (u8) ((div >> 8) & 0xff);
1909 if (rate_low && rate_hi)
1910 dev_dbg(&port->dev, "%s - %d %02x %02x.\n",
1911 __func__, baud_rate, *rate_hi, *rate_low);
1913 return KEYSPAN_BAUD_RATE_OK;
1916 static int keyspan_usa19w_calc_baud(struct usb_serial_port *port,
1917 u32 baud_rate, u32 baudclk, u8 *rate_hi,
1918 u8 *rate_low, u8 *prescaler, int portnum)
1920 u32 b16, /* baud rate times 16 (actual rate used internally) */
1921 clk, /* clock with 13/8 prescaler */
1922 div, /* divisor using 13/8 prescaler */
1923 res, /* resulting baud rate using 13/8 prescaler */
1924 diff, /* error using 13/8 prescaler */
1929 dev_dbg(&port->dev, "%s - %d.\n", __func__, baud_rate);
1931 /* prevent divide by zero */
1932 b16 = baud_rate * 16L;
1934 return KEYSPAN_INVALID_BAUD_RATE;
1936 /* Calculate prescaler by trying them all and looking
1939 /* start with largest possible difference */
1940 smallest_diff = 0xffffffff;
1942 /* 0 is an invalid prescaler, used as a flag */
1945 for (i = 8; i <= 0xff; ++i) {
1946 clk = (baudclk * 8) / (u32) i;
1953 diff = (res > b16) ? (res-b16) : (b16-res);
1955 if (diff < smallest_diff) {
1957 smallest_diff = diff;
1961 if (best_prescaler == 0)
1962 return KEYSPAN_INVALID_BAUD_RATE;
1964 clk = (baudclk * 8) / (u32) best_prescaler;
1967 /* return the divisor and prescaler if non-null */
1969 *rate_low = (u8) (div & 0xff);
1971 *rate_hi = (u8) ((div >> 8) & 0xff);
1973 *prescaler = best_prescaler;
1974 /* dev_dbg(&port->dev, "%s - %d %d\n", __func__, *prescaler, div); */
1976 return KEYSPAN_BAUD_RATE_OK;
1979 /* USA-28 supports different maximum baud rates on each port */
1980 static int keyspan_usa28_calc_baud(struct usb_serial_port *port,
1981 u32 baud_rate, u32 baudclk, u8 *rate_hi,
1982 u8 *rate_low, u8 *prescaler, int portnum)
1984 u32 b16, /* baud rate times 16 (actual rate used internally) */
1986 cnt; /* inverse of divisor (programmed into 8051) */
1988 dev_dbg(&port->dev, "%s - %d.\n", __func__, baud_rate);
1990 /* prevent divide by zero */
1991 b16 = baud_rate * 16L;
1993 return KEYSPAN_INVALID_BAUD_RATE;
1995 /* calculate the divisor and the counter (its inverse) */
1996 div = KEYSPAN_USA28_BAUDCLK / b16;
1998 return KEYSPAN_INVALID_BAUD_RATE;
2002 /* check for out of range, based on portnum,
2003 and return result */
2006 return KEYSPAN_INVALID_BAUD_RATE;
2010 return KEYSPAN_INVALID_BAUD_RATE;
2012 return KEYSPAN_INVALID_BAUD_RATE;
2015 /* return the counter values if not NULL
2016 (port 1 will ignore retHi) */
2018 *rate_low = (u8) (cnt & 0xff);
2020 *rate_hi = (u8) ((cnt >> 8) & 0xff);
2021 dev_dbg(&port->dev, "%s - %d OK.\n", __func__, baud_rate);
2022 return KEYSPAN_BAUD_RATE_OK;
2025 static int keyspan_usa26_send_setup(struct usb_serial *serial,
2026 struct usb_serial_port *port,
2029 struct keyspan_usa26_portControlMessage msg;
2030 struct keyspan_serial_private *s_priv;
2031 struct keyspan_port_private *p_priv;
2032 const struct keyspan_device_details *d_details;
2033 struct urb *this_urb;
2034 int device_port, err;
2036 dev_dbg(&port->dev, "%s reset=%d\n", __func__, reset_port);
2038 s_priv = usb_get_serial_data(serial);
2039 p_priv = usb_get_serial_port_data(port);
2040 d_details = s_priv->device_details;
2041 device_port = port->port_number;
2043 this_urb = p_priv->outcont_urb;
2045 /* Make sure we have an urb then send the message */
2046 if (this_urb == NULL) {
2047 dev_dbg(&port->dev, "%s - oops no urb.\n", __func__);
2051 dev_dbg(&port->dev, "%s - endpoint %x\n",
2052 __func__, usb_pipeendpoint(this_urb->pipe));
2054 /* Save reset port val for resend.
2055 Don't overwrite resend for open/close condition. */
2056 if ((reset_port + 1) > p_priv->resend_cont)
2057 p_priv->resend_cont = reset_port + 1;
2058 if (this_urb->status == -EINPROGRESS) {
2059 /* dev_dbg(&port->dev, "%s - already writing\n", __func__); */
2064 memset(&msg, 0, sizeof(struct keyspan_usa26_portControlMessage));
2066 /* Only set baud rate if it's changed */
2067 if (p_priv->old_baud != p_priv->baud) {
2068 p_priv->old_baud = p_priv->baud;
2069 msg.setClocking = 0xff;
2070 if (d_details->calculate_baud_rate(port, p_priv->baud, d_details->baudclk,
2071 &msg.baudHi, &msg.baudLo, &msg.prescaler,
2072 device_port) == KEYSPAN_INVALID_BAUD_RATE) {
2073 dev_dbg(&port->dev, "%s - Invalid baud rate %d requested, using 9600.\n",
2074 __func__, p_priv->baud);
2076 msg.baudHi = 125; /* Values for 9600 baud */
2079 msg.setPrescaler = 0xff;
2082 msg.lcr = (p_priv->cflag & CSTOPB) ? STOPBITS_678_2 : STOPBITS_5678_1;
2083 switch (p_priv->cflag & CSIZE) {
2085 msg.lcr |= USA_DATABITS_5;
2088 msg.lcr |= USA_DATABITS_6;
2091 msg.lcr |= USA_DATABITS_7;
2094 msg.lcr |= USA_DATABITS_8;
2097 if (p_priv->cflag & PARENB) {
2098 /* note USA_PARITY_NONE == 0 */
2099 msg.lcr |= (p_priv->cflag & PARODD) ?
2100 USA_PARITY_ODD : USA_PARITY_EVEN;
2104 msg.ctsFlowControl = (p_priv->flow_control == flow_cts);
2105 msg.xonFlowControl = 0;
2106 msg.setFlowControl = 0xff;
2107 msg.forwardingLength = 16;
2112 if (reset_port == 1) {
2121 msg.returnStatus = 0;
2122 msg.resetDataToggle = 0xff;
2126 else if (reset_port == 2) {
2135 msg.returnStatus = 0;
2136 msg.resetDataToggle = 0;
2139 /* Sending intermediate configs */
2141 msg._txOn = (!p_priv->break_on);
2144 msg.txBreak = (p_priv->break_on);
2149 msg.returnStatus = 0;
2150 msg.resetDataToggle = 0x0;
2153 /* Do handshaking outputs */
2154 msg.setTxTriState_setRts = 0xff;
2155 msg.txTriState_rts = p_priv->rts_state;
2157 msg.setHskoa_setDtr = 0xff;
2158 msg.hskoa_dtr = p_priv->dtr_state;
2160 p_priv->resend_cont = 0;
2161 memcpy(this_urb->transfer_buffer, &msg, sizeof(msg));
2163 /* send the data out the device on control endpoint */
2164 this_urb->transfer_buffer_length = sizeof(msg);
2166 err = usb_submit_urb(this_urb, GFP_ATOMIC);
2168 dev_dbg(&port->dev, "%s - usb_submit_urb(setup) failed (%d)\n", __func__, err);
2172 static int keyspan_usa28_send_setup(struct usb_serial *serial,
2173 struct usb_serial_port *port,
2176 struct keyspan_usa28_portControlMessage msg;
2177 struct keyspan_serial_private *s_priv;
2178 struct keyspan_port_private *p_priv;
2179 const struct keyspan_device_details *d_details;
2180 struct urb *this_urb;
2181 int device_port, err;
2183 s_priv = usb_get_serial_data(serial);
2184 p_priv = usb_get_serial_port_data(port);
2185 d_details = s_priv->device_details;
2186 device_port = port->port_number;
2188 /* only do something if we have a bulk out endpoint */
2189 this_urb = p_priv->outcont_urb;
2190 if (this_urb == NULL) {
2191 dev_dbg(&port->dev, "%s - oops no urb.\n", __func__);
2195 /* Save reset port val for resend.
2196 Don't overwrite resend for open/close condition. */
2197 if ((reset_port + 1) > p_priv->resend_cont)
2198 p_priv->resend_cont = reset_port + 1;
2199 if (this_urb->status == -EINPROGRESS) {
2200 dev_dbg(&port->dev, "%s already writing\n", __func__);
2205 memset(&msg, 0, sizeof(struct keyspan_usa28_portControlMessage));
2207 msg.setBaudRate = 1;
2208 if (d_details->calculate_baud_rate(port, p_priv->baud, d_details->baudclk,
2209 &msg.baudHi, &msg.baudLo, NULL,
2210 device_port) == KEYSPAN_INVALID_BAUD_RATE) {
2211 dev_dbg(&port->dev, "%s - Invalid baud rate requested %d.\n",
2212 __func__, p_priv->baud);
2214 msg.baudHi = 0xb2; /* Values for 9600 baud */
2217 /* If parity is enabled, we must calculate it ourselves. */
2218 msg.parity = 0; /* XXX for now */
2220 msg.ctsFlowControl = (p_priv->flow_control == flow_cts);
2221 msg.xonFlowControl = 0;
2223 /* Do handshaking outputs, DTR is inverted relative to RTS */
2224 msg.rts = p_priv->rts_state;
2225 msg.dtr = p_priv->dtr_state;
2227 msg.forwardingLength = 16;
2229 msg.breakThreshold = 45;
2233 /*msg.returnStatus = 1;
2234 msg.resetDataToggle = 0xff;*/
2236 if (reset_port == 1) {
2240 msg.txForceXoff = 0;
2246 msg.returnStatus = 0;
2247 msg.resetDataToggle = 0xff;
2250 else if (reset_port == 2) {
2254 msg.txForceXoff = 0;
2260 msg.returnStatus = 0;
2261 msg.resetDataToggle = 0;
2263 /* Sending intermediate configs */
2265 msg._txOn = (!p_priv->break_on);
2268 msg.txForceXoff = 0;
2269 msg.txBreak = (p_priv->break_on);
2274 msg.returnStatus = 0;
2275 msg.resetDataToggle = 0x0;
2278 p_priv->resend_cont = 0;
2279 memcpy(this_urb->transfer_buffer, &msg, sizeof(msg));
2281 /* send the data out the device on control endpoint */
2282 this_urb->transfer_buffer_length = sizeof(msg);
2284 err = usb_submit_urb(this_urb, GFP_ATOMIC);
2286 dev_dbg(&port->dev, "%s - usb_submit_urb(setup) failed\n", __func__);
2291 static int keyspan_usa49_send_setup(struct usb_serial *serial,
2292 struct usb_serial_port *port,
2295 struct keyspan_usa49_portControlMessage msg;
2296 struct usb_ctrlrequest *dr = NULL;
2297 struct keyspan_serial_private *s_priv;
2298 struct keyspan_port_private *p_priv;
2299 const struct keyspan_device_details *d_details;
2300 struct urb *this_urb;
2301 int err, device_port;
2303 s_priv = usb_get_serial_data(serial);
2304 p_priv = usb_get_serial_port_data(port);
2305 d_details = s_priv->device_details;
2307 this_urb = s_priv->glocont_urb;
2309 /* Work out which port within the device is being setup */
2310 device_port = port->port_number;
2312 /* Make sure we have an urb then send the message */
2313 if (this_urb == NULL) {
2314 dev_dbg(&port->dev, "%s - oops no urb for port.\n", __func__);
2318 dev_dbg(&port->dev, "%s - endpoint %x (%d)\n",
2319 __func__, usb_pipeendpoint(this_urb->pipe), device_port);
2321 /* Save reset port val for resend.
2322 Don't overwrite resend for open/close condition. */
2323 if ((reset_port + 1) > p_priv->resend_cont)
2324 p_priv->resend_cont = reset_port + 1;
2326 if (this_urb->status == -EINPROGRESS) {
2327 /* dev_dbg(&port->dev, "%s - already writing\n", __func__); */
2332 memset(&msg, 0, sizeof(struct keyspan_usa49_portControlMessage));
2334 msg.portNumber = device_port;
2336 /* Only set baud rate if it's changed */
2337 if (p_priv->old_baud != p_priv->baud) {
2338 p_priv->old_baud = p_priv->baud;
2339 msg.setClocking = 0xff;
2340 if (d_details->calculate_baud_rate(port, p_priv->baud, d_details->baudclk,
2341 &msg.baudHi, &msg.baudLo, &msg.prescaler,
2342 device_port) == KEYSPAN_INVALID_BAUD_RATE) {
2343 dev_dbg(&port->dev, "%s - Invalid baud rate %d requested, using 9600.\n",
2344 __func__, p_priv->baud);
2346 msg.baudHi = 125; /* Values for 9600 baud */
2349 /* msg.setPrescaler = 0xff; */
2352 msg.lcr = (p_priv->cflag & CSTOPB) ? STOPBITS_678_2 : STOPBITS_5678_1;
2353 switch (p_priv->cflag & CSIZE) {
2355 msg.lcr |= USA_DATABITS_5;
2358 msg.lcr |= USA_DATABITS_6;
2361 msg.lcr |= USA_DATABITS_7;
2364 msg.lcr |= USA_DATABITS_8;
2367 if (p_priv->cflag & PARENB) {
2368 /* note USA_PARITY_NONE == 0 */
2369 msg.lcr |= (p_priv->cflag & PARODD) ?
2370 USA_PARITY_ODD : USA_PARITY_EVEN;
2374 msg.ctsFlowControl = (p_priv->flow_control == flow_cts);
2375 msg.xonFlowControl = 0;
2376 msg.setFlowControl = 0xff;
2378 msg.forwardingLength = 16;
2383 if (reset_port == 1) {
2392 msg.returnStatus = 0;
2393 msg.resetDataToggle = 0xff;
2395 msg.disablePort = 0;
2398 else if (reset_port == 2) {
2407 msg.returnStatus = 0;
2408 msg.resetDataToggle = 0;
2410 msg.disablePort = 1;
2412 /* Sending intermediate configs */
2414 msg._txOn = (!p_priv->break_on);
2417 msg.txBreak = (p_priv->break_on);
2422 msg.returnStatus = 0;
2423 msg.resetDataToggle = 0x0;
2425 msg.disablePort = 0;
2428 /* Do handshaking outputs */
2430 msg.rts = p_priv->rts_state;
2433 msg.dtr = p_priv->dtr_state;
2435 p_priv->resend_cont = 0;
2437 /* if the device is a 49wg, we send control message on usb
2440 if (d_details->product_id == keyspan_usa49wg_product_id) {
2441 dr = (void *)(s_priv->ctrl_buf);
2442 dr->bRequestType = USB_TYPE_VENDOR | USB_DIR_OUT;
2443 dr->bRequest = 0xB0; /* 49wg control message */
2446 dr->wLength = cpu_to_le16(sizeof(msg));
2448 memcpy(s_priv->glocont_buf, &msg, sizeof(msg));
2450 usb_fill_control_urb(this_urb, serial->dev,
2451 usb_sndctrlpipe(serial->dev, 0),
2452 (unsigned char *)dr, s_priv->glocont_buf,
2453 sizeof(msg), usa49_glocont_callback, serial);
2456 memcpy(this_urb->transfer_buffer, &msg, sizeof(msg));
2458 /* send the data out the device on control endpoint */
2459 this_urb->transfer_buffer_length = sizeof(msg);
2461 err = usb_submit_urb(this_urb, GFP_ATOMIC);
2463 dev_dbg(&port->dev, "%s - usb_submit_urb(setup) failed (%d)\n", __func__, err);
2468 static int keyspan_usa90_send_setup(struct usb_serial *serial,
2469 struct usb_serial_port *port,
2472 struct keyspan_usa90_portControlMessage msg;
2473 struct keyspan_serial_private *s_priv;
2474 struct keyspan_port_private *p_priv;
2475 const struct keyspan_device_details *d_details;
2476 struct urb *this_urb;
2480 s_priv = usb_get_serial_data(serial);
2481 p_priv = usb_get_serial_port_data(port);
2482 d_details = s_priv->device_details;
2484 /* only do something if we have a bulk out endpoint */
2485 this_urb = p_priv->outcont_urb;
2486 if (this_urb == NULL) {
2487 dev_dbg(&port->dev, "%s - oops no urb.\n", __func__);
2491 /* Save reset port val for resend.
2492 Don't overwrite resend for open/close condition. */
2493 if ((reset_port + 1) > p_priv->resend_cont)
2494 p_priv->resend_cont = reset_port + 1;
2495 if (this_urb->status == -EINPROGRESS) {
2496 dev_dbg(&port->dev, "%s already writing\n", __func__);
2501 memset(&msg, 0, sizeof(struct keyspan_usa90_portControlMessage));
2503 /* Only set baud rate if it's changed */
2504 if (p_priv->old_baud != p_priv->baud) {
2505 p_priv->old_baud = p_priv->baud;
2506 msg.setClocking = 0x01;
2507 if (d_details->calculate_baud_rate(port, p_priv->baud, d_details->baudclk,
2508 &msg.baudHi, &msg.baudLo, &prescaler, 0) == KEYSPAN_INVALID_BAUD_RATE) {
2509 dev_dbg(&port->dev, "%s - Invalid baud rate %d requested, using 9600.\n",
2510 __func__, p_priv->baud);
2511 p_priv->baud = 9600;
2512 d_details->calculate_baud_rate(port, p_priv->baud, d_details->baudclk,
2513 &msg.baudHi, &msg.baudLo, &prescaler, 0);
2519 /* modes must always be correctly specified */
2520 if (p_priv->baud > 57600) {
2521 msg.rxMode = RXMODE_DMA;
2522 msg.txMode = TXMODE_DMA;
2524 msg.rxMode = RXMODE_BYHAND;
2525 msg.txMode = TXMODE_BYHAND;
2528 msg.lcr = (p_priv->cflag & CSTOPB) ? STOPBITS_678_2 : STOPBITS_5678_1;
2529 switch (p_priv->cflag & CSIZE) {
2531 msg.lcr |= USA_DATABITS_5;
2534 msg.lcr |= USA_DATABITS_6;
2537 msg.lcr |= USA_DATABITS_7;
2540 msg.lcr |= USA_DATABITS_8;
2543 if (p_priv->cflag & PARENB) {
2544 /* note USA_PARITY_NONE == 0 */
2545 msg.lcr |= (p_priv->cflag & PARODD) ?
2546 USA_PARITY_ODD : USA_PARITY_EVEN;
2548 if (p_priv->old_cflag != p_priv->cflag) {
2549 p_priv->old_cflag = p_priv->cflag;
2553 if (p_priv->flow_control == flow_cts)
2554 msg.txFlowControl = TXFLOW_CTS;
2555 msg.setTxFlowControl = 0x01;
2556 msg.setRxFlowControl = 0x01;
2558 msg.rxForwardingLength = 16;
2559 msg.rxForwardingTimeout = 16;
2560 msg.txAckSetting = 0;
2565 if (reset_port == 1) {
2566 msg.portEnabled = 1;
2568 msg.txBreak = (p_priv->break_on);
2571 else if (reset_port == 2)
2572 msg.portEnabled = 0;
2573 /* Sending intermediate configs */
2575 msg.portEnabled = 1;
2576 msg.txBreak = (p_priv->break_on);
2579 /* Do handshaking outputs */
2581 msg.rts = p_priv->rts_state;
2584 msg.dtr = p_priv->dtr_state;
2586 p_priv->resend_cont = 0;
2587 memcpy(this_urb->transfer_buffer, &msg, sizeof(msg));
2589 /* send the data out the device on control endpoint */
2590 this_urb->transfer_buffer_length = sizeof(msg);
2592 err = usb_submit_urb(this_urb, GFP_ATOMIC);
2594 dev_dbg(&port->dev, "%s - usb_submit_urb(setup) failed (%d)\n", __func__, err);
2598 static int keyspan_usa67_send_setup(struct usb_serial *serial,
2599 struct usb_serial_port *port,
2602 struct keyspan_usa67_portControlMessage msg;
2603 struct keyspan_serial_private *s_priv;
2604 struct keyspan_port_private *p_priv;
2605 const struct keyspan_device_details *d_details;
2606 struct urb *this_urb;
2607 int err, device_port;
2609 s_priv = usb_get_serial_data(serial);
2610 p_priv = usb_get_serial_port_data(port);
2611 d_details = s_priv->device_details;
2613 this_urb = s_priv->glocont_urb;
2615 /* Work out which port within the device is being setup */
2616 device_port = port->port_number;
2618 /* Make sure we have an urb then send the message */
2619 if (this_urb == NULL) {
2620 dev_dbg(&port->dev, "%s - oops no urb for port.\n", __func__);
2624 /* Save reset port val for resend.
2625 Don't overwrite resend for open/close condition. */
2626 if ((reset_port + 1) > p_priv->resend_cont)
2627 p_priv->resend_cont = reset_port + 1;
2628 if (this_urb->status == -EINPROGRESS) {
2629 /* dev_dbg(&port->dev, "%s - already writing\n", __func__); */
2634 memset(&msg, 0, sizeof(struct keyspan_usa67_portControlMessage));
2636 msg.port = device_port;
2638 /* Only set baud rate if it's changed */
2639 if (p_priv->old_baud != p_priv->baud) {
2640 p_priv->old_baud = p_priv->baud;
2641 msg.setClocking = 0xff;
2642 if (d_details->calculate_baud_rate(port, p_priv->baud, d_details->baudclk,
2643 &msg.baudHi, &msg.baudLo, &msg.prescaler,
2644 device_port) == KEYSPAN_INVALID_BAUD_RATE) {
2645 dev_dbg(&port->dev, "%s - Invalid baud rate %d requested, using 9600.\n",
2646 __func__, p_priv->baud);
2648 msg.baudHi = 125; /* Values for 9600 baud */
2651 msg.setPrescaler = 0xff;
2654 msg.lcr = (p_priv->cflag & CSTOPB) ? STOPBITS_678_2 : STOPBITS_5678_1;
2655 switch (p_priv->cflag & CSIZE) {
2657 msg.lcr |= USA_DATABITS_5;
2660 msg.lcr |= USA_DATABITS_6;
2663 msg.lcr |= USA_DATABITS_7;
2666 msg.lcr |= USA_DATABITS_8;
2669 if (p_priv->cflag & PARENB) {
2670 /* note USA_PARITY_NONE == 0 */
2671 msg.lcr |= (p_priv->cflag & PARODD) ?
2672 USA_PARITY_ODD : USA_PARITY_EVEN;
2676 msg.ctsFlowControl = (p_priv->flow_control == flow_cts);
2677 msg.xonFlowControl = 0;
2678 msg.setFlowControl = 0xff;
2679 msg.forwardingLength = 16;
2683 if (reset_port == 1) {
2693 msg.returnStatus = 0;
2694 msg.resetDataToggle = 0xff;
2695 } else if (reset_port == 2) {
2705 msg.returnStatus = 0;
2706 msg.resetDataToggle = 0;
2708 /* Sending intermediate configs */
2709 msg._txOn = (!p_priv->break_on);
2712 msg.txBreak = (p_priv->break_on);
2717 msg.returnStatus = 0;
2718 msg.resetDataToggle = 0x0;
2721 /* Do handshaking outputs */
2722 msg.setTxTriState_setRts = 0xff;
2723 msg.txTriState_rts = p_priv->rts_state;
2725 msg.setHskoa_setDtr = 0xff;
2726 msg.hskoa_dtr = p_priv->dtr_state;
2728 p_priv->resend_cont = 0;
2730 memcpy(this_urb->transfer_buffer, &msg, sizeof(msg));
2732 /* send the data out the device on control endpoint */
2733 this_urb->transfer_buffer_length = sizeof(msg);
2735 err = usb_submit_urb(this_urb, GFP_ATOMIC);
2737 dev_dbg(&port->dev, "%s - usb_submit_urb(setup) failed (%d)\n", __func__, err);
2741 static void keyspan_send_setup(struct usb_serial_port *port, int reset_port)
2743 struct usb_serial *serial = port->serial;
2744 struct keyspan_serial_private *s_priv;
2745 const struct keyspan_device_details *d_details;
2747 s_priv = usb_get_serial_data(serial);
2748 d_details = s_priv->device_details;
2750 switch (d_details->msg_format) {
2752 keyspan_usa26_send_setup(serial, port, reset_port);
2755 keyspan_usa28_send_setup(serial, port, reset_port);
2758 keyspan_usa49_send_setup(serial, port, reset_port);
2761 keyspan_usa90_send_setup(serial, port, reset_port);
2764 keyspan_usa67_send_setup(serial, port, reset_port);
2770 /* Gets called by the "real" driver (ie once firmware is loaded
2771 and renumeration has taken place. */
2772 static int keyspan_startup(struct usb_serial *serial)
2775 struct keyspan_serial_private *s_priv;
2776 const struct keyspan_device_details *d_details;
2778 for (i = 0; (d_details = keyspan_devices[i]) != NULL; ++i)
2779 if (d_details->product_id ==
2780 le16_to_cpu(serial->dev->descriptor.idProduct))
2782 if (d_details == NULL) {
2783 dev_err(&serial->dev->dev, "%s - unknown product id %x\n",
2784 __func__, le16_to_cpu(serial->dev->descriptor.idProduct));
2788 /* Setup private data for serial driver */
2789 s_priv = kzalloc(sizeof(struct keyspan_serial_private), GFP_KERNEL);
2793 s_priv->instat_buf = kzalloc(INSTAT_BUFLEN, GFP_KERNEL);
2794 if (!s_priv->instat_buf)
2795 goto err_instat_buf;
2797 s_priv->indat_buf = kzalloc(INDAT49W_BUFLEN, GFP_KERNEL);
2798 if (!s_priv->indat_buf)
2801 s_priv->glocont_buf = kzalloc(GLOCONT_BUFLEN, GFP_KERNEL);
2802 if (!s_priv->glocont_buf)
2803 goto err_glocont_buf;
2805 s_priv->ctrl_buf = kzalloc(sizeof(struct usb_ctrlrequest), GFP_KERNEL);
2806 if (!s_priv->ctrl_buf)
2809 s_priv->device_details = d_details;
2810 usb_set_serial_data(serial, s_priv);
2812 keyspan_setup_urbs(serial);
2814 if (s_priv->instat_urb != NULL) {
2815 err = usb_submit_urb(s_priv->instat_urb, GFP_KERNEL);
2817 dev_dbg(&serial->dev->dev, "%s - submit instat urb failed %d\n", __func__, err);
2819 if (s_priv->indat_urb != NULL) {
2820 err = usb_submit_urb(s_priv->indat_urb, GFP_KERNEL);
2822 dev_dbg(&serial->dev->dev, "%s - submit indat urb failed %d\n", __func__, err);
2828 kfree(s_priv->glocont_buf);
2830 kfree(s_priv->indat_buf);
2832 kfree(s_priv->instat_buf);
2839 static void keyspan_disconnect(struct usb_serial *serial)
2841 struct keyspan_serial_private *s_priv;
2843 s_priv = usb_get_serial_data(serial);
2845 usb_kill_urb(s_priv->instat_urb);
2846 usb_kill_urb(s_priv->glocont_urb);
2847 usb_kill_urb(s_priv->indat_urb);
2850 static void keyspan_release(struct usb_serial *serial)
2852 struct keyspan_serial_private *s_priv;
2854 s_priv = usb_get_serial_data(serial);
2856 /* Make sure to unlink the URBs submitted in attach. */
2857 usb_kill_urb(s_priv->instat_urb);
2858 usb_kill_urb(s_priv->indat_urb);
2860 usb_free_urb(s_priv->instat_urb);
2861 usb_free_urb(s_priv->indat_urb);
2862 usb_free_urb(s_priv->glocont_urb);
2864 kfree(s_priv->ctrl_buf);
2865 kfree(s_priv->glocont_buf);
2866 kfree(s_priv->indat_buf);
2867 kfree(s_priv->instat_buf);
2872 static int keyspan_port_probe(struct usb_serial_port *port)
2874 struct usb_serial *serial = port->serial;
2875 struct keyspan_serial_private *s_priv;
2876 struct keyspan_port_private *p_priv;
2877 const struct keyspan_device_details *d_details;
2878 struct callbacks *cback;
2883 s_priv = usb_get_serial_data(serial);
2884 d_details = s_priv->device_details;
2886 p_priv = kzalloc(sizeof(*p_priv), GFP_KERNEL);
2890 for (i = 0; i < ARRAY_SIZE(p_priv->in_buffer); ++i) {
2891 p_priv->in_buffer[i] = kzalloc(IN_BUFLEN, GFP_KERNEL);
2892 if (!p_priv->in_buffer[i])
2896 for (i = 0; i < ARRAY_SIZE(p_priv->out_buffer); ++i) {
2897 p_priv->out_buffer[i] = kzalloc(OUT_BUFLEN, GFP_KERNEL);
2898 if (!p_priv->out_buffer[i])
2899 goto err_out_buffer;
2902 p_priv->inack_buffer = kzalloc(INACK_BUFLEN, GFP_KERNEL);
2903 if (!p_priv->inack_buffer)
2904 goto err_inack_buffer;
2906 p_priv->outcont_buffer = kzalloc(OUTCONT_BUFLEN, GFP_KERNEL);
2907 if (!p_priv->outcont_buffer)
2908 goto err_outcont_buffer;
2910 p_priv->device_details = d_details;
2912 /* Setup values for the various callback routines */
2913 cback = &keyspan_callbacks[d_details->msg_format];
2915 port_num = port->port_number;
2917 /* Do indat endpoints first, once for each flip */
2918 endp = d_details->indat_endpoints[port_num];
2919 for (i = 0; i <= d_details->indat_endp_flip; ++i, ++endp) {
2920 p_priv->in_urbs[i] = keyspan_setup_urb(serial, endp,
2922 p_priv->in_buffer[i],
2924 cback->indat_callback);
2926 /* outdat endpoints also have flip */
2927 endp = d_details->outdat_endpoints[port_num];
2928 for (i = 0; i <= d_details->outdat_endp_flip; ++i, ++endp) {
2929 p_priv->out_urbs[i] = keyspan_setup_urb(serial, endp,
2931 p_priv->out_buffer[i],
2933 cback->outdat_callback);
2935 /* inack endpoint */
2936 p_priv->inack_urb = keyspan_setup_urb(serial,
2937 d_details->inack_endpoints[port_num],
2939 p_priv->inack_buffer,
2941 cback->inack_callback);
2942 /* outcont endpoint */
2943 p_priv->outcont_urb = keyspan_setup_urb(serial,
2944 d_details->outcont_endpoints[port_num],
2946 p_priv->outcont_buffer,
2948 cback->outcont_callback);
2950 usb_set_serial_port_data(port, p_priv);
2955 kfree(p_priv->inack_buffer);
2957 for (i = 0; i < ARRAY_SIZE(p_priv->out_buffer); ++i)
2958 kfree(p_priv->out_buffer[i]);
2960 for (i = 0; i < ARRAY_SIZE(p_priv->in_buffer); ++i)
2961 kfree(p_priv->in_buffer[i]);
2968 static void keyspan_port_remove(struct usb_serial_port *port)
2970 struct keyspan_port_private *p_priv;
2973 p_priv = usb_get_serial_port_data(port);
2975 usb_kill_urb(p_priv->inack_urb);
2976 usb_kill_urb(p_priv->outcont_urb);
2977 for (i = 0; i < 2; i++) {
2978 usb_kill_urb(p_priv->in_urbs[i]);
2979 usb_kill_urb(p_priv->out_urbs[i]);
2982 usb_free_urb(p_priv->inack_urb);
2983 usb_free_urb(p_priv->outcont_urb);
2984 for (i = 0; i < 2; i++) {
2985 usb_free_urb(p_priv->in_urbs[i]);
2986 usb_free_urb(p_priv->out_urbs[i]);
2989 kfree(p_priv->outcont_buffer);
2990 kfree(p_priv->inack_buffer);
2991 for (i = 0; i < ARRAY_SIZE(p_priv->out_buffer); ++i)
2992 kfree(p_priv->out_buffer[i]);
2993 for (i = 0; i < ARRAY_SIZE(p_priv->in_buffer); ++i)
2994 kfree(p_priv->in_buffer[i]);
2999 /* Structs for the devices, pre and post renumeration. */
3000 static struct usb_serial_driver keyspan_pre_device = {
3002 .owner = THIS_MODULE,
3003 .name = "keyspan_no_firm",
3005 .description = "Keyspan - (without firmware)",
3006 .id_table = keyspan_pre_ids,
3008 .attach = keyspan_fake_startup,
3011 static struct usb_serial_driver keyspan_1port_device = {
3013 .owner = THIS_MODULE,
3014 .name = "keyspan_1",
3016 .description = "Keyspan 1 port adapter",
3017 .id_table = keyspan_1port_ids,
3019 .open = keyspan_open,
3020 .close = keyspan_close,
3021 .dtr_rts = keyspan_dtr_rts,
3022 .write = keyspan_write,
3023 .write_room = keyspan_write_room,
3024 .set_termios = keyspan_set_termios,
3025 .break_ctl = keyspan_break_ctl,
3026 .tiocmget = keyspan_tiocmget,
3027 .tiocmset = keyspan_tiocmset,
3028 .attach = keyspan_startup,
3029 .disconnect = keyspan_disconnect,
3030 .release = keyspan_release,
3031 .port_probe = keyspan_port_probe,
3032 .port_remove = keyspan_port_remove,
3035 static struct usb_serial_driver keyspan_2port_device = {
3037 .owner = THIS_MODULE,
3038 .name = "keyspan_2",
3040 .description = "Keyspan 2 port adapter",
3041 .id_table = keyspan_2port_ids,
3043 .open = keyspan_open,
3044 .close = keyspan_close,
3045 .dtr_rts = keyspan_dtr_rts,
3046 .write = keyspan_write,
3047 .write_room = keyspan_write_room,
3048 .set_termios = keyspan_set_termios,
3049 .break_ctl = keyspan_break_ctl,
3050 .tiocmget = keyspan_tiocmget,
3051 .tiocmset = keyspan_tiocmset,
3052 .attach = keyspan_startup,
3053 .disconnect = keyspan_disconnect,
3054 .release = keyspan_release,
3055 .port_probe = keyspan_port_probe,
3056 .port_remove = keyspan_port_remove,
3059 static struct usb_serial_driver keyspan_4port_device = {
3061 .owner = THIS_MODULE,
3062 .name = "keyspan_4",
3064 .description = "Keyspan 4 port adapter",
3065 .id_table = keyspan_4port_ids,
3067 .open = keyspan_open,
3068 .close = keyspan_close,
3069 .dtr_rts = keyspan_dtr_rts,
3070 .write = keyspan_write,
3071 .write_room = keyspan_write_room,
3072 .set_termios = keyspan_set_termios,
3073 .break_ctl = keyspan_break_ctl,
3074 .tiocmget = keyspan_tiocmget,
3075 .tiocmset = keyspan_tiocmset,
3076 .attach = keyspan_startup,
3077 .disconnect = keyspan_disconnect,
3078 .release = keyspan_release,
3079 .port_probe = keyspan_port_probe,
3080 .port_remove = keyspan_port_remove,
3083 static struct usb_serial_driver * const serial_drivers[] = {
3084 &keyspan_pre_device, &keyspan_1port_device,
3085 &keyspan_2port_device, &keyspan_4port_device, NULL
3088 module_usb_serial_driver(serial_drivers, keyspan_ids_combined);
3090 MODULE_AUTHOR(DRIVER_AUTHOR);
3091 MODULE_DESCRIPTION(DRIVER_DESC);
3092 MODULE_LICENSE("GPL");
3094 MODULE_FIRMWARE("keyspan/usa28.fw");
3095 MODULE_FIRMWARE("keyspan/usa28x.fw");
3096 MODULE_FIRMWARE("keyspan/usa28xa.fw");
3097 MODULE_FIRMWARE("keyspan/usa28xb.fw");
3098 MODULE_FIRMWARE("keyspan/usa19.fw");
3099 MODULE_FIRMWARE("keyspan/usa19qi.fw");
3100 MODULE_FIRMWARE("keyspan/mpr.fw");
3101 MODULE_FIRMWARE("keyspan/usa19qw.fw");
3102 MODULE_FIRMWARE("keyspan/usa18x.fw");
3103 MODULE_FIRMWARE("keyspan/usa19w.fw");
3104 MODULE_FIRMWARE("keyspan/usa49w.fw");
3105 MODULE_FIRMWARE("keyspan/usa49wlc.fw");