1 /* 2 Keyspan USB to Serial Converter driver 3 4 (C) Copyright (C) 2000-2001 Hugh Blemings <hugh@blemings.org> 5 (C) Copyright (C) 2002 Greg Kroah-Hartman <greg@kroah.com> 6 7 This program is free software; you can redistribute it and/or modify 8 it under the terms of the GNU General Public License as published by 9 the Free Software Foundation; either version 2 of the License, or 10 (at your option) any later version. 11 12 See http://misc.nu/hugh/keyspan.html for more information. 13 14 Code in this driver inspired by and in a number of places taken 15 from Brian Warner's original Keyspan-PDA driver. 16 17 This driver has been put together with the support of Innosys, Inc. 18 and Keyspan, Inc the manufacturers of the Keyspan USB-serial products. 19 Thanks Guys :) 20 21 Thanks to Paulus for miscellaneous tidy ups, some largish chunks 22 of much nicer and/or completely new code and (perhaps most uniquely) 23 having the patience to sit down and explain why and where he'd changed 24 stuff. 25 26 Tip 'o the hat to IBM (and previously Linuxcare :) for supporting 27 staff in their work on open source projects. 28 29 Change History 30 31 2003sep04 LPM (Keyspan) add support for new single port product USA19HS. 32 Improve setup message handling for all devices. 33 34 Wed Feb 19 22:00:00 PST 2003 (Jeffrey S. Laing <keyspan@jsl.com>) 35 Merged the current (1/31/03) Keyspan code with the current (2.4.21-pre4) 36 Linux source tree. The Linux tree lacked support for the 49WLC and 37 others. The Keyspan patches didn't work with the current kernel. 38 39 2003jan30 LPM add support for the 49WLC and MPR 40 41 Wed Apr 25 12:00:00 PST 2002 (Keyspan) 42 Started with Hugh Blemings' code dated Jan 17, 2002. All adapters 43 now supported (including QI and QW). Modified port open, port 44 close, and send setup() logic to fix various data and endpoint 45 synchronization bugs and device LED status bugs. Changed keyspan_ 46 write_room() to accurately return transmit buffer availability. 47 Changed forwardingLength from 1 to 16 for all adapters. 48 49 Fri Oct 12 16:45:00 EST 2001 50 Preliminary USA-19QI and USA-28 support (both test OK for me, YMMV) 51 52 Wed Apr 25 12:00:00 PST 2002 (Keyspan) 53 Started with Hugh Blemings' code dated Jan 17, 2002. All adapters 54 now supported (including QI and QW). Modified port open, port 55 close, and send setup() logic to fix various data and endpoint 56 synchronization bugs and device LED status bugs. Changed keyspan_ 57 write_room() to accurately return transmit buffer availability. 58 Changed forwardingLength from 1 to 16 for all adapters. 59 60 Fri Oct 12 16:45:00 EST 2001 61 Preliminary USA-19QI and USA-28 support (both test OK for me, YMMV) 62 63 Mon Oct 8 14:29:00 EST 2001 hugh 64 Fixed bug that prevented mulitport devices operating correctly 65 if they weren't the first unit attached. 66 67 Sat Oct 6 12:31:21 EST 2001 hugh 68 Added support for USA-28XA and -28XB, misc cleanups, break support 69 for usa26 based models thanks to David Gibson. 70 71 Thu May 31 11:56:42 PDT 2001 gkh 72 switched from using spinlock to a semaphore 73 74 (04/08/2001) gb 75 Identify version on module load. 76 77 (11/01/2000) Adam J. Richter 78 usb_device_id table support. 79 80 Tue Oct 10 23:15:33 EST 2000 Hugh 81 Merged Paul's changes with my USA-49W mods. Work in progress 82 still... 83 84 Wed Jul 19 14:00:42 EST 2000 gkh 85 Added module_init and module_exit functions to handle the fact that 86 this driver is a loadable module now. 87 88 Tue Jul 18 16:14:52 EST 2000 Hugh 89 Basic character input/output for USA-19 now mostly works, 90 fixed at 9600 baud for the moment. 91 92 Sat Jul 8 11:11:48 EST 2000 Hugh 93 First public release - nothing works except the firmware upload. 94 Tested on PPC and x86 architectures, seems to behave... 95 */ 96 97 98 #include <linux/kernel.h> 99 #include <linux/jiffies.h> 100 #include <linux/errno.h> 101 #include <linux/init.h> 102 #include <linux/slab.h> 103 #include <linux/tty.h> 104 #include <linux/tty_driver.h> 105 #include <linux/tty_flip.h> 106 #include <linux/module.h> 107 #include <linux/spinlock.h> 108 #include <linux/firmware.h> 109 #include <linux/ihex.h> 110 #include <linux/uaccess.h> 111 #include <linux/usb.h> 112 #include <linux/usb/serial.h> 113 #include "keyspan.h" 114 115 static int debug; 116 117 /* 118 * Version Information 119 */ 120 #define DRIVER_VERSION "v1.1.5" 121 #define DRIVER_AUTHOR "Hugh Blemings <hugh@misc.nu" 122 #define DRIVER_DESC "Keyspan USB to Serial Converter Driver" 123 124 #define INSTAT_BUFLEN 32 125 #define GLOCONT_BUFLEN 64 126 #define INDAT49W_BUFLEN 512 127 128 /* Per device and per port private data */ 129 struct keyspan_serial_private { 130 const struct keyspan_device_details *device_details; 131 132 struct urb *instat_urb; 133 char instat_buf[INSTAT_BUFLEN]; 134 135 /* added to support 49wg, where data from all 4 ports comes in 136 on 1 EP and high-speed supported */ 137 struct urb *indat_urb; 138 char indat_buf[INDAT49W_BUFLEN]; 139 140 /* XXX this one probably will need a lock */ 141 struct urb *glocont_urb; 142 char glocont_buf[GLOCONT_BUFLEN]; 143 char ctrl_buf[8]; /* for EP0 control message */ 144 }; 145 146 struct keyspan_port_private { 147 /* Keep track of which input & output endpoints to use */ 148 int in_flip; 149 int out_flip; 150 151 /* Keep duplicate of device details in each port 152 structure as well - simplifies some of the 153 callback functions etc. */ 154 const struct keyspan_device_details *device_details; 155 156 /* Input endpoints and buffer for this port */ 157 struct urb *in_urbs[2]; 158 char in_buffer[2][64]; 159 /* Output endpoints and buffer for this port */ 160 struct urb *out_urbs[2]; 161 char out_buffer[2][64]; 162 163 /* Input ack endpoint */ 164 struct urb *inack_urb; 165 char inack_buffer[1]; 166 167 /* Output control endpoint */ 168 struct urb *outcont_urb; 169 char outcont_buffer[64]; 170 171 /* Settings for the port */ 172 int baud; 173 int old_baud; 174 unsigned int cflag; 175 unsigned int old_cflag; 176 enum {flow_none, flow_cts, flow_xon} flow_control; 177 int rts_state; /* Handshaking pins (outputs) */ 178 int dtr_state; 179 int cts_state; /* Handshaking pins (inputs) */ 180 int dsr_state; 181 int dcd_state; 182 int ri_state; 183 int break_on; 184 185 unsigned long tx_start_time[2]; 186 int resend_cont; /* need to resend control packet */ 187 }; 188 189 /* Include Keyspan message headers. All current Keyspan Adapters 190 make use of one of five message formats which are referred 191 to as USA-26, USA-28, USA-49, USA-90, USA-67 by Keyspan and 192 within this driver. */ 193 #include "keyspan_usa26msg.h" 194 #include "keyspan_usa28msg.h" 195 #include "keyspan_usa49msg.h" 196 #include "keyspan_usa90msg.h" 197 #include "keyspan_usa67msg.h" 198 199 200 /* Functions used by new usb-serial code. */ 201 static int __init keyspan_init(void) 202 { 203 int retval; 204 retval = usb_serial_register(&keyspan_pre_device); 205 if (retval) 206 goto failed_pre_device_register; 207 retval = usb_serial_register(&keyspan_1port_device); 208 if (retval) 209 goto failed_1port_device_register; 210 retval = usb_serial_register(&keyspan_2port_device); 211 if (retval) 212 goto failed_2port_device_register; 213 retval = usb_serial_register(&keyspan_4port_device); 214 if (retval) 215 goto failed_4port_device_register; 216 retval = usb_register(&keyspan_driver); 217 if (retval) 218 goto failed_usb_register; 219 220 printk(KERN_INFO KBUILD_MODNAME ": " DRIVER_VERSION ":" 221 DRIVER_DESC "\n"); 222 223 return 0; 224 failed_usb_register: 225 usb_serial_deregister(&keyspan_4port_device); 226 failed_4port_device_register: 227 usb_serial_deregister(&keyspan_2port_device); 228 failed_2port_device_register: 229 usb_serial_deregister(&keyspan_1port_device); 230 failed_1port_device_register: 231 usb_serial_deregister(&keyspan_pre_device); 232 failed_pre_device_register: 233 return retval; 234 } 235 236 static void __exit keyspan_exit(void) 237 { 238 usb_deregister(&keyspan_driver); 239 usb_serial_deregister(&keyspan_pre_device); 240 usb_serial_deregister(&keyspan_1port_device); 241 usb_serial_deregister(&keyspan_2port_device); 242 usb_serial_deregister(&keyspan_4port_device); 243 } 244 245 module_init(keyspan_init); 246 module_exit(keyspan_exit); 247 248 static void keyspan_break_ctl(struct tty_struct *tty, int break_state) 249 { 250 struct usb_serial_port *port = tty->driver_data; 251 struct keyspan_port_private *p_priv; 252 253 dbg("%s", __func__); 254 255 p_priv = usb_get_serial_port_data(port); 256 257 if (break_state == -1) 258 p_priv->break_on = 1; 259 else 260 p_priv->break_on = 0; 261 262 keyspan_send_setup(port, 0); 263 } 264 265 266 static void keyspan_set_termios(struct tty_struct *tty, 267 struct usb_serial_port *port, struct ktermios *old_termios) 268 { 269 int baud_rate, device_port; 270 struct keyspan_port_private *p_priv; 271 const struct keyspan_device_details *d_details; 272 unsigned int cflag; 273 274 dbg("%s", __func__); 275 276 p_priv = usb_get_serial_port_data(port); 277 d_details = p_priv->device_details; 278 cflag = tty->termios->c_cflag; 279 device_port = port->number - port->serial->minor; 280 281 /* Baud rate calculation takes baud rate as an integer 282 so other rates can be generated if desired. */ 283 baud_rate = tty_get_baud_rate(tty); 284 /* If no match or invalid, don't change */ 285 if (d_details->calculate_baud_rate(baud_rate, d_details->baudclk, 286 NULL, NULL, NULL, device_port) == KEYSPAN_BAUD_RATE_OK) { 287 /* FIXME - more to do here to ensure rate changes cleanly */ 288 /* FIXME - calcuate exact rate from divisor ? */ 289 p_priv->baud = baud_rate; 290 } else 291 baud_rate = tty_termios_baud_rate(old_termios); 292 293 tty_encode_baud_rate(tty, baud_rate, baud_rate); 294 /* set CTS/RTS handshake etc. */ 295 p_priv->cflag = cflag; 296 p_priv->flow_control = (cflag & CRTSCTS)? flow_cts: flow_none; 297 298 /* Mark/Space not supported */ 299 tty->termios->c_cflag &= ~CMSPAR; 300 301 keyspan_send_setup(port, 0); 302 } 303 304 static int keyspan_tiocmget(struct tty_struct *tty, struct file *file) 305 { 306 struct usb_serial_port *port = tty->driver_data; 307 struct keyspan_port_private *p_priv = usb_get_serial_port_data(port); 308 unsigned int value; 309 310 value = ((p_priv->rts_state) ? TIOCM_RTS : 0) | 311 ((p_priv->dtr_state) ? TIOCM_DTR : 0) | 312 ((p_priv->cts_state) ? TIOCM_CTS : 0) | 313 ((p_priv->dsr_state) ? TIOCM_DSR : 0) | 314 ((p_priv->dcd_state) ? TIOCM_CAR : 0) | 315 ((p_priv->ri_state) ? TIOCM_RNG : 0); 316 317 return value; 318 } 319 320 static int keyspan_tiocmset(struct tty_struct *tty, struct file *file, 321 unsigned int set, unsigned int clear) 322 { 323 struct usb_serial_port *port = tty->driver_data; 324 struct keyspan_port_private *p_priv = usb_get_serial_port_data(port); 325 326 if (set & TIOCM_RTS) 327 p_priv->rts_state = 1; 328 if (set & TIOCM_DTR) 329 p_priv->dtr_state = 1; 330 if (clear & TIOCM_RTS) 331 p_priv->rts_state = 0; 332 if (clear & TIOCM_DTR) 333 p_priv->dtr_state = 0; 334 keyspan_send_setup(port, 0); 335 return 0; 336 } 337 338 /* Write function is similar for the four protocols used 339 with only a minor change for usa90 (usa19hs) required */ 340 static int keyspan_write(struct tty_struct *tty, 341 struct usb_serial_port *port, const unsigned char *buf, int count) 342 { 343 struct keyspan_port_private *p_priv; 344 const struct keyspan_device_details *d_details; 345 int flip; 346 int left, todo; 347 struct urb *this_urb; 348 int err, maxDataLen, dataOffset; 349 350 p_priv = usb_get_serial_port_data(port); 351 d_details = p_priv->device_details; 352 353 if (d_details->msg_format == msg_usa90) { 354 maxDataLen = 64; 355 dataOffset = 0; 356 } else { 357 maxDataLen = 63; 358 dataOffset = 1; 359 } 360 361 dbg("%s - for port %d (%d chars), flip=%d", 362 __func__, port->number, count, p_priv->out_flip); 363 364 for (left = count; left > 0; left -= todo) { 365 todo = left; 366 if (todo > maxDataLen) 367 todo = maxDataLen; 368 369 flip = p_priv->out_flip; 370 371 /* Check we have a valid urb/endpoint before we use it... */ 372 this_urb = p_priv->out_urbs[flip]; 373 if (this_urb == NULL) { 374 /* no bulk out, so return 0 bytes written */ 375 dbg("%s - no output urb :(", __func__); 376 return count; 377 } 378 379 dbg("%s - endpoint %d flip %d", 380 __func__, usb_pipeendpoint(this_urb->pipe), flip); 381 382 if (this_urb->status == -EINPROGRESS) { 383 if (time_before(jiffies, 384 p_priv->tx_start_time[flip] + 10 * HZ)) 385 break; 386 usb_unlink_urb(this_urb); 387 break; 388 } 389 390 /* First byte in buffer is "last flag" (except for usa19hx) 391 - unused so for now so set to zero */ 392 ((char *)this_urb->transfer_buffer)[0] = 0; 393 394 memcpy(this_urb->transfer_buffer + dataOffset, buf, todo); 395 buf += todo; 396 397 /* send the data out the bulk port */ 398 this_urb->transfer_buffer_length = todo + dataOffset; 399 400 this_urb->dev = port->serial->dev; 401 err = usb_submit_urb(this_urb, GFP_ATOMIC); 402 if (err != 0) 403 dbg("usb_submit_urb(write bulk) failed (%d)", err); 404 p_priv->tx_start_time[flip] = jiffies; 405 406 /* Flip for next time if usa26 or usa28 interface 407 (not used on usa49) */ 408 p_priv->out_flip = (flip + 1) & d_details->outdat_endp_flip; 409 } 410 411 return count - left; 412 } 413 414 static void usa26_indat_callback(struct urb *urb) 415 { 416 int i, err; 417 int endpoint; 418 struct usb_serial_port *port; 419 struct tty_struct *tty; 420 unsigned char *data = urb->transfer_buffer; 421 int status = urb->status; 422 423 dbg("%s", __func__); 424 425 endpoint = usb_pipeendpoint(urb->pipe); 426 427 if (status) { 428 dbg("%s - nonzero status: %x on endpoint %d.", 429 __func__, status, endpoint); 430 return; 431 } 432 433 port = urb->context; 434 tty = tty_port_tty_get(&port->port); 435 if (tty && urb->actual_length) { 436 /* 0x80 bit is error flag */ 437 if ((data[0] & 0x80) == 0) { 438 /* no errors on individual bytes, only 439 possible overrun err */ 440 if (data[0] & RXERROR_OVERRUN) 441 err = TTY_OVERRUN; 442 else 443 err = 0; 444 for (i = 1; i < urb->actual_length ; ++i) 445 tty_insert_flip_char(tty, data[i], err); 446 } else { 447 /* some bytes had errors, every byte has status */ 448 dbg("%s - RX error!!!!", __func__); 449 for (i = 0; i + 1 < urb->actual_length; i += 2) { 450 int stat = data[i], flag = 0; 451 if (stat & RXERROR_OVERRUN) 452 flag |= TTY_OVERRUN; 453 if (stat & RXERROR_FRAMING) 454 flag |= TTY_FRAME; 455 if (stat & RXERROR_PARITY) 456 flag |= TTY_PARITY; 457 /* XXX should handle break (0x10) */ 458 tty_insert_flip_char(tty, data[i+1], flag); 459 } 460 } 461 tty_flip_buffer_push(tty); 462 } 463 tty_kref_put(tty); 464 465 /* Resubmit urb so we continue receiving */ 466 urb->dev = port->serial->dev; 467 if (port->port.count) { 468 err = usb_submit_urb(urb, GFP_ATOMIC); 469 if (err != 0) 470 dbg("%s - resubmit read urb failed. (%d)", 471 __func__, err); 472 } 473 return; 474 } 475 476 /* Outdat handling is common for all devices */ 477 static void usa2x_outdat_callback(struct urb *urb) 478 { 479 struct usb_serial_port *port; 480 struct keyspan_port_private *p_priv; 481 482 port = urb->context; 483 p_priv = usb_get_serial_port_data(port); 484 dbg("%s - urb %d", __func__, urb == p_priv->out_urbs[1]); 485 486 if (port->port.count) 487 usb_serial_port_softint(port); 488 } 489 490 static void usa26_inack_callback(struct urb *urb) 491 { 492 dbg("%s", __func__); 493 494 } 495 496 static void usa26_outcont_callback(struct urb *urb) 497 { 498 struct usb_serial_port *port; 499 struct keyspan_port_private *p_priv; 500 501 port = urb->context; 502 p_priv = usb_get_serial_port_data(port); 503 504 if (p_priv->resend_cont) { 505 dbg("%s - sending setup", __func__); 506 keyspan_usa26_send_setup(port->serial, port, 507 p_priv->resend_cont - 1); 508 } 509 } 510 511 static void usa26_instat_callback(struct urb *urb) 512 { 513 unsigned char *data = urb->transfer_buffer; 514 struct keyspan_usa26_portStatusMessage *msg; 515 struct usb_serial *serial; 516 struct usb_serial_port *port; 517 struct keyspan_port_private *p_priv; 518 struct tty_struct *tty; 519 int old_dcd_state, err; 520 int status = urb->status; 521 522 serial = urb->context; 523 524 if (status) { 525 dbg("%s - nonzero status: %x", __func__, status); 526 return; 527 } 528 if (urb->actual_length != 9) { 529 dbg("%s - %d byte report??", __func__, urb->actual_length); 530 goto exit; 531 } 532 533 msg = (struct keyspan_usa26_portStatusMessage *)data; 534 535 #if 0 536 dbg("%s - port status: port %d cts %d dcd %d dsr %d ri %d toff %d txoff %d rxen %d cr %d", 537 __func__, msg->port, msg->hskia_cts, msg->gpia_dcd, msg->dsr, msg->ri, msg->_txOff, 538 msg->_txXoff, msg->rxEnabled, msg->controlResponse); 539 #endif 540 541 /* Now do something useful with the data */ 542 543 544 /* Check port number from message and retrieve private data */ 545 if (msg->port >= serial->num_ports) { 546 dbg("%s - Unexpected port number %d", __func__, msg->port); 547 goto exit; 548 } 549 port = serial->port[msg->port]; 550 p_priv = usb_get_serial_port_data(port); 551 552 /* Update handshaking pin state information */ 553 old_dcd_state = p_priv->dcd_state; 554 p_priv->cts_state = ((msg->hskia_cts) ? 1 : 0); 555 p_priv->dsr_state = ((msg->dsr) ? 1 : 0); 556 p_priv->dcd_state = ((msg->gpia_dcd) ? 1 : 0); 557 p_priv->ri_state = ((msg->ri) ? 1 : 0); 558 559 if (old_dcd_state != p_priv->dcd_state) { 560 tty = tty_port_tty_get(&port->port); 561 if (tty && !C_CLOCAL(tty)) 562 tty_hangup(tty); 563 tty_kref_put(tty); 564 } 565 566 /* Resubmit urb so we continue receiving */ 567 urb->dev = serial->dev; 568 err = usb_submit_urb(urb, GFP_ATOMIC); 569 if (err != 0) 570 dbg("%s - resubmit read urb failed. (%d)", __func__, err); 571 exit: ; 572 } 573 574 static void usa26_glocont_callback(struct urb *urb) 575 { 576 dbg("%s", __func__); 577 } 578 579 580 static void usa28_indat_callback(struct urb *urb) 581 { 582 int err; 583 struct usb_serial_port *port; 584 struct tty_struct *tty; 585 unsigned char *data; 586 struct keyspan_port_private *p_priv; 587 int status = urb->status; 588 589 dbg("%s", __func__); 590 591 port = urb->context; 592 p_priv = usb_get_serial_port_data(port); 593 data = urb->transfer_buffer; 594 595 if (urb != p_priv->in_urbs[p_priv->in_flip]) 596 return; 597 598 do { 599 if (status) { 600 dbg("%s - nonzero status: %x on endpoint %d.", 601 __func__, status, usb_pipeendpoint(urb->pipe)); 602 return; 603 } 604 605 port = urb->context; 606 p_priv = usb_get_serial_port_data(port); 607 data = urb->transfer_buffer; 608 609 tty =tty_port_tty_get(&port->port); 610 if (tty && urb->actual_length) { 611 tty_insert_flip_string(tty, data, urb->actual_length); 612 tty_flip_buffer_push(tty); 613 } 614 tty_kref_put(tty); 615 616 /* Resubmit urb so we continue receiving */ 617 urb->dev = port->serial->dev; 618 if (port->port.count) { 619 err = usb_submit_urb(urb, GFP_ATOMIC); 620 if (err != 0) 621 dbg("%s - resubmit read urb failed. (%d)", 622 __func__, err); 623 } 624 p_priv->in_flip ^= 1; 625 626 urb = p_priv->in_urbs[p_priv->in_flip]; 627 } while (urb->status != -EINPROGRESS); 628 } 629 630 static void usa28_inack_callback(struct urb *urb) 631 { 632 dbg("%s", __func__); 633 } 634 635 static void usa28_outcont_callback(struct urb *urb) 636 { 637 struct usb_serial_port *port; 638 struct keyspan_port_private *p_priv; 639 640 port = urb->context; 641 p_priv = usb_get_serial_port_data(port); 642 643 if (p_priv->resend_cont) { 644 dbg("%s - sending setup", __func__); 645 keyspan_usa28_send_setup(port->serial, port, 646 p_priv->resend_cont - 1); 647 } 648 } 649 650 static void usa28_instat_callback(struct urb *urb) 651 { 652 int err; 653 unsigned char *data = urb->transfer_buffer; 654 struct keyspan_usa28_portStatusMessage *msg; 655 struct usb_serial *serial; 656 struct usb_serial_port *port; 657 struct keyspan_port_private *p_priv; 658 struct tty_struct *tty; 659 int old_dcd_state; 660 int status = urb->status; 661 662 serial = urb->context; 663 664 if (status) { 665 dbg("%s - nonzero status: %x", __func__, status); 666 return; 667 } 668 669 if (urb->actual_length != sizeof(struct keyspan_usa28_portStatusMessage)) { 670 dbg("%s - bad length %d", __func__, urb->actual_length); 671 goto exit; 672 } 673 674 /*dbg("%s %x %x %x %x %x %x %x %x %x %x %x %x", __func__ 675 data[0], data[1], data[2], data[3], data[4], data[5], 676 data[6], data[7], data[8], data[9], data[10], data[11]);*/ 677 678 /* Now do something useful with the data */ 679 msg = (struct keyspan_usa28_portStatusMessage *)data; 680 681 /* Check port number from message and retrieve private data */ 682 if (msg->port >= serial->num_ports) { 683 dbg("%s - Unexpected port number %d", __func__, msg->port); 684 goto exit; 685 } 686 port = serial->port[msg->port]; 687 p_priv = usb_get_serial_port_data(port); 688 689 /* Update handshaking pin state information */ 690 old_dcd_state = p_priv->dcd_state; 691 p_priv->cts_state = ((msg->cts) ? 1 : 0); 692 p_priv->dsr_state = ((msg->dsr) ? 1 : 0); 693 p_priv->dcd_state = ((msg->dcd) ? 1 : 0); 694 p_priv->ri_state = ((msg->ri) ? 1 : 0); 695 696 if( old_dcd_state != p_priv->dcd_state && old_dcd_state) { 697 tty = tty_port_tty_get(&port->port); 698 if (tty && !C_CLOCAL(tty)) 699 tty_hangup(tty); 700 tty_kref_put(tty); 701 } 702 703 /* Resubmit urb so we continue receiving */ 704 urb->dev = serial->dev; 705 err = usb_submit_urb(urb, GFP_ATOMIC); 706 if (err != 0) 707 dbg("%s - resubmit read urb failed. (%d)", __func__, err); 708 exit: ; 709 } 710 711 static void usa28_glocont_callback(struct urb *urb) 712 { 713 dbg("%s", __func__); 714 } 715 716 717 static void usa49_glocont_callback(struct urb *urb) 718 { 719 struct usb_serial *serial; 720 struct usb_serial_port *port; 721 struct keyspan_port_private *p_priv; 722 int i; 723 724 dbg("%s", __func__); 725 726 serial = urb->context; 727 for (i = 0; i < serial->num_ports; ++i) { 728 port = serial->port[i]; 729 p_priv = usb_get_serial_port_data(port); 730 731 if (p_priv->resend_cont) { 732 dbg("%s - sending setup", __func__); 733 keyspan_usa49_send_setup(serial, port, 734 p_priv->resend_cont - 1); 735 break; 736 } 737 } 738 } 739 740 /* This is actually called glostat in the Keyspan 741 doco */ 742 static void usa49_instat_callback(struct urb *urb) 743 { 744 int err; 745 unsigned char *data = urb->transfer_buffer; 746 struct keyspan_usa49_portStatusMessage *msg; 747 struct usb_serial *serial; 748 struct usb_serial_port *port; 749 struct keyspan_port_private *p_priv; 750 int old_dcd_state; 751 int status = urb->status; 752 753 dbg("%s", __func__); 754 755 serial = urb->context; 756 757 if (status) { 758 dbg("%s - nonzero status: %x", __func__, status); 759 return; 760 } 761 762 if (urb->actual_length != 763 sizeof(struct keyspan_usa49_portStatusMessage)) { 764 dbg("%s - bad length %d", __func__, urb->actual_length); 765 goto exit; 766 } 767 768 /*dbg(" %x %x %x %x %x %x %x %x %x %x %x", __func__, 769 data[0], data[1], data[2], data[3], data[4], data[5], 770 data[6], data[7], data[8], data[9], data[10]);*/ 771 772 /* Now do something useful with the data */ 773 msg = (struct keyspan_usa49_portStatusMessage *)data; 774 775 /* Check port number from message and retrieve private data */ 776 if (msg->portNumber >= serial->num_ports) { 777 dbg("%s - Unexpected port number %d", 778 __func__, msg->portNumber); 779 goto exit; 780 } 781 port = serial->port[msg->portNumber]; 782 p_priv = usb_get_serial_port_data(port); 783 784 /* Update handshaking pin state information */ 785 old_dcd_state = p_priv->dcd_state; 786 p_priv->cts_state = ((msg->cts) ? 1 : 0); 787 p_priv->dsr_state = ((msg->dsr) ? 1 : 0); 788 p_priv->dcd_state = ((msg->dcd) ? 1 : 0); 789 p_priv->ri_state = ((msg->ri) ? 1 : 0); 790 791 if (old_dcd_state != p_priv->dcd_state && old_dcd_state) { 792 struct tty_struct *tty = tty_port_tty_get(&port->port); 793 if (tty && !C_CLOCAL(tty)) 794 tty_hangup(tty); 795 tty_kref_put(tty); 796 } 797 798 /* Resubmit urb so we continue receiving */ 799 urb->dev = serial->dev; 800 801 err = usb_submit_urb(urb, GFP_ATOMIC); 802 if (err != 0) 803 dbg("%s - resubmit read urb failed. (%d)", __func__, err); 804 exit: ; 805 } 806 807 static void usa49_inack_callback(struct urb *urb) 808 { 809 dbg("%s", __func__); 810 } 811 812 static void usa49_indat_callback(struct urb *urb) 813 { 814 int i, err; 815 int endpoint; 816 struct usb_serial_port *port; 817 struct tty_struct *tty; 818 unsigned char *data = urb->transfer_buffer; 819 int status = urb->status; 820 821 dbg("%s", __func__); 822 823 endpoint = usb_pipeendpoint(urb->pipe); 824 825 if (status) { 826 dbg("%s - nonzero status: %x on endpoint %d.", __func__, 827 status, endpoint); 828 return; 829 } 830 831 port = urb->context; 832 tty = tty_port_tty_get(&port->port); 833 if (tty && urb->actual_length) { 834 /* 0x80 bit is error flag */ 835 if ((data[0] & 0x80) == 0) { 836 /* no error on any byte */ 837 tty_insert_flip_string(tty, data + 1, 838 urb->actual_length - 1); 839 } else { 840 /* some bytes had errors, every byte has status */ 841 for (i = 0; i + 1 < urb->actual_length; i += 2) { 842 int stat = data[i], flag = 0; 843 if (stat & RXERROR_OVERRUN) 844 flag |= TTY_OVERRUN; 845 if (stat & RXERROR_FRAMING) 846 flag |= TTY_FRAME; 847 if (stat & RXERROR_PARITY) 848 flag |= TTY_PARITY; 849 /* XXX should handle break (0x10) */ 850 tty_insert_flip_char(tty, data[i+1], flag); 851 } 852 } 853 tty_flip_buffer_push(tty); 854 } 855 tty_kref_put(tty); 856 857 /* Resubmit urb so we continue receiving */ 858 urb->dev = port->serial->dev; 859 if (port->port.count) { 860 err = usb_submit_urb(urb, GFP_ATOMIC); 861 if (err != 0) 862 dbg("%s - resubmit read urb failed. (%d)", 863 __func__, err); 864 } 865 } 866 867 static void usa49wg_indat_callback(struct urb *urb) 868 { 869 int i, len, x, err; 870 struct usb_serial *serial; 871 struct usb_serial_port *port; 872 struct tty_struct *tty; 873 unsigned char *data = urb->transfer_buffer; 874 int status = urb->status; 875 876 dbg("%s", __func__); 877 878 serial = urb->context; 879 880 if (status) { 881 dbg("%s - nonzero status: %x", __func__, status); 882 return; 883 } 884 885 /* inbound data is in the form P#, len, status, data */ 886 i = 0; 887 len = 0; 888 889 if (urb->actual_length) { 890 while (i < urb->actual_length) { 891 892 /* Check port number from message*/ 893 if (data[i] >= serial->num_ports) { 894 dbg("%s - Unexpected port number %d", 895 __func__, data[i]); 896 return; 897 } 898 port = serial->port[data[i++]]; 899 tty = tty_port_tty_get(&port->port); 900 len = data[i++]; 901 902 /* 0x80 bit is error flag */ 903 if ((data[i] & 0x80) == 0) { 904 /* no error on any byte */ 905 i++; 906 for (x = 1; x < len ; ++x) 907 if (port->port.count) 908 tty_insert_flip_char(tty, 909 data[i++], 0); 910 else 911 i++; 912 } else { 913 /* 914 * some bytes had errors, every byte has status 915 */ 916 for (x = 0; x + 1 < len; x += 2) { 917 int stat = data[i], flag = 0; 918 if (stat & RXERROR_OVERRUN) 919 flag |= TTY_OVERRUN; 920 if (stat & RXERROR_FRAMING) 921 flag |= TTY_FRAME; 922 if (stat & RXERROR_PARITY) 923 flag |= TTY_PARITY; 924 /* XXX should handle break (0x10) */ 925 if (port->port.count) 926 tty_insert_flip_char(tty, 927 data[i+1], flag); 928 i += 2; 929 } 930 } 931 if (port->port.count) 932 tty_flip_buffer_push(tty); 933 tty_kref_put(tty); 934 } 935 } 936 937 /* Resubmit urb so we continue receiving */ 938 urb->dev = serial->dev; 939 940 err = usb_submit_urb(urb, GFP_ATOMIC); 941 if (err != 0) 942 dbg("%s - resubmit read urb failed. (%d)", __func__, err); 943 } 944 945 /* not used, usa-49 doesn't have per-port control endpoints */ 946 static void usa49_outcont_callback(struct urb *urb) 947 { 948 dbg("%s", __func__); 949 } 950 951 static void usa90_indat_callback(struct urb *urb) 952 { 953 int i, err; 954 int endpoint; 955 struct usb_serial_port *port; 956 struct keyspan_port_private *p_priv; 957 struct tty_struct *tty; 958 unsigned char *data = urb->transfer_buffer; 959 int status = urb->status; 960 961 dbg("%s", __func__); 962 963 endpoint = usb_pipeendpoint(urb->pipe); 964 965 if (status) { 966 dbg("%s - nonzero status: %x on endpoint %d.", 967 __func__, status, endpoint); 968 return; 969 } 970 971 port = urb->context; 972 p_priv = usb_get_serial_port_data(port); 973 974 if (urb->actual_length) { 975 tty = tty_port_tty_get(&port->port); 976 /* if current mode is DMA, looks like usa28 format 977 otherwise looks like usa26 data format */ 978 979 if (p_priv->baud > 57600) 980 tty_insert_flip_string(tty, data, urb->actual_length); 981 else { 982 /* 0x80 bit is error flag */ 983 if ((data[0] & 0x80) == 0) { 984 /* no errors on individual bytes, only 985 possible overrun err*/ 986 if (data[0] & RXERROR_OVERRUN) 987 err = TTY_OVERRUN; 988 else 989 err = 0; 990 for (i = 1; i < urb->actual_length ; ++i) 991 tty_insert_flip_char(tty, data[i], 992 err); 993 } else { 994 /* some bytes had errors, every byte has status */ 995 dbg("%s - RX error!!!!", __func__); 996 for (i = 0; i + 1 < urb->actual_length; i += 2) { 997 int stat = data[i], flag = 0; 998 if (stat & RXERROR_OVERRUN) 999 flag |= TTY_OVERRUN; 1000 if (stat & RXERROR_FRAMING) 1001 flag |= TTY_FRAME; 1002 if (stat & RXERROR_PARITY) 1003 flag |= TTY_PARITY; 1004 /* XXX should handle break (0x10) */ 1005 tty_insert_flip_char(tty, data[i+1], 1006 flag); 1007 } 1008 } 1009 } 1010 tty_flip_buffer_push(tty); 1011 tty_kref_put(tty); 1012 } 1013 1014 /* Resubmit urb so we continue receiving */ 1015 urb->dev = port->serial->dev; 1016 if (port->port.count) { 1017 err = usb_submit_urb(urb, GFP_ATOMIC); 1018 if (err != 0) 1019 dbg("%s - resubmit read urb failed. (%d)", 1020 __func__, err); 1021 } 1022 return; 1023 } 1024 1025 1026 static void usa90_instat_callback(struct urb *urb) 1027 { 1028 unsigned char *data = urb->transfer_buffer; 1029 struct keyspan_usa90_portStatusMessage *msg; 1030 struct usb_serial *serial; 1031 struct usb_serial_port *port; 1032 struct keyspan_port_private *p_priv; 1033 struct tty_struct *tty; 1034 int old_dcd_state, err; 1035 int status = urb->status; 1036 1037 serial = urb->context; 1038 1039 if (status) { 1040 dbg("%s - nonzero status: %x", __func__, status); 1041 return; 1042 } 1043 if (urb->actual_length < 14) { 1044 dbg("%s - %d byte report??", __func__, urb->actual_length); 1045 goto exit; 1046 } 1047 1048 msg = (struct keyspan_usa90_portStatusMessage *)data; 1049 1050 /* Now do something useful with the data */ 1051 1052 port = serial->port[0]; 1053 p_priv = usb_get_serial_port_data(port); 1054 1055 /* Update handshaking pin state information */ 1056 old_dcd_state = p_priv->dcd_state; 1057 p_priv->cts_state = ((msg->cts) ? 1 : 0); 1058 p_priv->dsr_state = ((msg->dsr) ? 1 : 0); 1059 p_priv->dcd_state = ((msg->dcd) ? 1 : 0); 1060 p_priv->ri_state = ((msg->ri) ? 1 : 0); 1061 1062 if (old_dcd_state != p_priv->dcd_state && old_dcd_state) { 1063 tty = tty_port_tty_get(&port->port); 1064 if (tty && !C_CLOCAL(tty)) 1065 tty_hangup(tty); 1066 tty_kref_put(tty); 1067 } 1068 1069 /* Resubmit urb so we continue receiving */ 1070 urb->dev = serial->dev; 1071 err = usb_submit_urb(urb, GFP_ATOMIC); 1072 if (err != 0) 1073 dbg("%s - resubmit read urb failed. (%d)", __func__, err); 1074 exit: 1075 ; 1076 } 1077 1078 static void usa90_outcont_callback(struct urb *urb) 1079 { 1080 struct usb_serial_port *port; 1081 struct keyspan_port_private *p_priv; 1082 1083 port = urb->context; 1084 p_priv = usb_get_serial_port_data(port); 1085 1086 if (p_priv->resend_cont) { 1087 dbg("%s - sending setup", __func__); 1088 keyspan_usa90_send_setup(port->serial, port, 1089 p_priv->resend_cont - 1); 1090 } 1091 } 1092 1093 /* Status messages from the 28xg */ 1094 static void usa67_instat_callback(struct urb *urb) 1095 { 1096 int err; 1097 unsigned char *data = urb->transfer_buffer; 1098 struct keyspan_usa67_portStatusMessage *msg; 1099 struct usb_serial *serial; 1100 struct usb_serial_port *port; 1101 struct keyspan_port_private *p_priv; 1102 int old_dcd_state; 1103 int status = urb->status; 1104 1105 dbg("%s", __func__); 1106 1107 serial = urb->context; 1108 1109 if (status) { 1110 dbg("%s - nonzero status: %x", __func__, status); 1111 return; 1112 } 1113 1114 if (urb->actual_length != 1115 sizeof(struct keyspan_usa67_portStatusMessage)) { 1116 dbg("%s - bad length %d", __func__, urb->actual_length); 1117 return; 1118 } 1119 1120 1121 /* Now do something useful with the data */ 1122 msg = (struct keyspan_usa67_portStatusMessage *)data; 1123 1124 /* Check port number from message and retrieve private data */ 1125 if (msg->port >= serial->num_ports) { 1126 dbg("%s - Unexpected port number %d", __func__, msg->port); 1127 return; 1128 } 1129 1130 port = serial->port[msg->port]; 1131 p_priv = usb_get_serial_port_data(port); 1132 1133 /* Update handshaking pin state information */ 1134 old_dcd_state = p_priv->dcd_state; 1135 p_priv->cts_state = ((msg->hskia_cts) ? 1 : 0); 1136 p_priv->dcd_state = ((msg->gpia_dcd) ? 1 : 0); 1137 1138 if (old_dcd_state != p_priv->dcd_state && old_dcd_state) { 1139 struct tty_struct *tty = tty_port_tty_get(&port->port); 1140 if (tty && !C_CLOCAL(tty)) 1141 tty_hangup(tty); 1142 tty_kref_put(tty); 1143 } 1144 1145 /* Resubmit urb so we continue receiving */ 1146 urb->dev = serial->dev; 1147 err = usb_submit_urb(urb, GFP_ATOMIC); 1148 if (err != 0) 1149 dbg("%s - resubmit read urb failed. (%d)", __func__, err); 1150 } 1151 1152 static void usa67_glocont_callback(struct urb *urb) 1153 { 1154 struct usb_serial *serial; 1155 struct usb_serial_port *port; 1156 struct keyspan_port_private *p_priv; 1157 int i; 1158 1159 dbg("%s", __func__); 1160 1161 serial = urb->context; 1162 for (i = 0; i < serial->num_ports; ++i) { 1163 port = serial->port[i]; 1164 p_priv = usb_get_serial_port_data(port); 1165 1166 if (p_priv->resend_cont) { 1167 dbg("%s - sending setup", __func__); 1168 keyspan_usa67_send_setup(serial, port, 1169 p_priv->resend_cont - 1); 1170 break; 1171 } 1172 } 1173 } 1174 1175 static int keyspan_write_room(struct tty_struct *tty) 1176 { 1177 struct usb_serial_port *port = tty->driver_data; 1178 struct keyspan_port_private *p_priv; 1179 const struct keyspan_device_details *d_details; 1180 int flip; 1181 int data_len; 1182 struct urb *this_urb; 1183 1184 dbg("%s", __func__); 1185 p_priv = usb_get_serial_port_data(port); 1186 d_details = p_priv->device_details; 1187 1188 /* FIXME: locking */ 1189 if (d_details->msg_format == msg_usa90) 1190 data_len = 64; 1191 else 1192 data_len = 63; 1193 1194 flip = p_priv->out_flip; 1195 1196 /* Check both endpoints to see if any are available. */ 1197 this_urb = p_priv->out_urbs[flip]; 1198 if (this_urb != NULL) { 1199 if (this_urb->status != -EINPROGRESS) 1200 return data_len; 1201 flip = (flip + 1) & d_details->outdat_endp_flip; 1202 this_urb = p_priv->out_urbs[flip]; 1203 if (this_urb != NULL) { 1204 if (this_urb->status != -EINPROGRESS) 1205 return data_len; 1206 } 1207 } 1208 return 0; 1209 } 1210 1211 1212 static int keyspan_open(struct tty_struct *tty, struct usb_serial_port *port) 1213 { 1214 struct keyspan_port_private *p_priv; 1215 struct keyspan_serial_private *s_priv; 1216 struct usb_serial *serial = port->serial; 1217 const struct keyspan_device_details *d_details; 1218 int i, err; 1219 int baud_rate, device_port; 1220 struct urb *urb; 1221 unsigned int cflag = 0; 1222 1223 s_priv = usb_get_serial_data(serial); 1224 p_priv = usb_get_serial_port_data(port); 1225 d_details = p_priv->device_details; 1226 1227 dbg("%s - port%d.", __func__, port->number); 1228 1229 /* Set some sane defaults */ 1230 p_priv->rts_state = 1; 1231 p_priv->dtr_state = 1; 1232 p_priv->baud = 9600; 1233 1234 /* force baud and lcr to be set on open */ 1235 p_priv->old_baud = 0; 1236 p_priv->old_cflag = 0; 1237 1238 p_priv->out_flip = 0; 1239 p_priv->in_flip = 0; 1240 1241 /* Reset low level data toggle and start reading from endpoints */ 1242 for (i = 0; i < 2; i++) { 1243 urb = p_priv->in_urbs[i]; 1244 if (urb == NULL) 1245 continue; 1246 urb->dev = serial->dev; 1247 1248 /* make sure endpoint data toggle is synchronized 1249 with the device */ 1250 usb_clear_halt(urb->dev, urb->pipe); 1251 err = usb_submit_urb(urb, GFP_KERNEL); 1252 if (err != 0) 1253 dbg("%s - submit urb %d failed (%d)", 1254 __func__, i, err); 1255 } 1256 1257 /* Reset low level data toggle on out endpoints */ 1258 for (i = 0; i < 2; i++) { 1259 urb = p_priv->out_urbs[i]; 1260 if (urb == NULL) 1261 continue; 1262 urb->dev = serial->dev; 1263 /* usb_settoggle(urb->dev, usb_pipeendpoint(urb->pipe), 1264 usb_pipeout(urb->pipe), 0); */ 1265 } 1266 1267 /* get the terminal config for the setup message now so we don't 1268 * need to send 2 of them */ 1269 1270 device_port = port->number - port->serial->minor; 1271 if (tty) { 1272 cflag = tty->termios->c_cflag; 1273 /* Baud rate calculation takes baud rate as an integer 1274 so other rates can be generated if desired. */ 1275 baud_rate = tty_get_baud_rate(tty); 1276 /* If no match or invalid, leave as default */ 1277 if (baud_rate >= 0 1278 && d_details->calculate_baud_rate(baud_rate, d_details->baudclk, 1279 NULL, NULL, NULL, device_port) == KEYSPAN_BAUD_RATE_OK) { 1280 p_priv->baud = baud_rate; 1281 } 1282 } 1283 /* set CTS/RTS handshake etc. */ 1284 p_priv->cflag = cflag; 1285 p_priv->flow_control = (cflag & CRTSCTS)? flow_cts: flow_none; 1286 1287 keyspan_send_setup(port, 1); 1288 /* mdelay(100); */ 1289 /* keyspan_set_termios(port, NULL); */ 1290 1291 return 0; 1292 } 1293 1294 static inline void stop_urb(struct urb *urb) 1295 { 1296 if (urb && urb->status == -EINPROGRESS) 1297 usb_kill_urb(urb); 1298 } 1299 1300 static void keyspan_dtr_rts(struct usb_serial_port *port, int on) 1301 { 1302 struct keyspan_port_private *p_priv = usb_get_serial_port_data(port); 1303 1304 p_priv->rts_state = on; 1305 p_priv->dtr_state = on; 1306 keyspan_send_setup(port, 0); 1307 } 1308 1309 static void keyspan_close(struct usb_serial_port *port) 1310 { 1311 int i; 1312 struct usb_serial *serial = port->serial; 1313 struct keyspan_serial_private *s_priv; 1314 struct keyspan_port_private *p_priv; 1315 1316 dbg("%s", __func__); 1317 s_priv = usb_get_serial_data(serial); 1318 p_priv = usb_get_serial_port_data(port); 1319 1320 p_priv->rts_state = 0; 1321 p_priv->dtr_state = 0; 1322 1323 if (serial->dev) { 1324 keyspan_send_setup(port, 2); 1325 /* pilot-xfer seems to work best with this delay */ 1326 mdelay(100); 1327 /* keyspan_set_termios(port, NULL); */ 1328 } 1329 1330 /*while (p_priv->outcont_urb->status == -EINPROGRESS) { 1331 dbg("%s - urb in progress", __func__); 1332 }*/ 1333 1334 p_priv->out_flip = 0; 1335 p_priv->in_flip = 0; 1336 1337 if (serial->dev) { 1338 /* Stop reading/writing urbs */ 1339 stop_urb(p_priv->inack_urb); 1340 /* stop_urb(p_priv->outcont_urb); */ 1341 for (i = 0; i < 2; i++) { 1342 stop_urb(p_priv->in_urbs[i]); 1343 stop_urb(p_priv->out_urbs[i]); 1344 } 1345 } 1346 } 1347 1348 /* download the firmware to a pre-renumeration device */ 1349 static int keyspan_fake_startup(struct usb_serial *serial) 1350 { 1351 int response; 1352 const struct ihex_binrec *record; 1353 char *fw_name; 1354 const struct firmware *fw; 1355 1356 dbg("Keyspan startup version %04x product %04x", 1357 le16_to_cpu(serial->dev->descriptor.bcdDevice), 1358 le16_to_cpu(serial->dev->descriptor.idProduct)); 1359 1360 if ((le16_to_cpu(serial->dev->descriptor.bcdDevice) & 0x8000) 1361 != 0x8000) { 1362 dbg("Firmware already loaded. Quitting."); 1363 return 1; 1364 } 1365 1366 /* Select firmware image on the basis of idProduct */ 1367 switch (le16_to_cpu(serial->dev->descriptor.idProduct)) { 1368 case keyspan_usa28_pre_product_id: 1369 fw_name = "keyspan/usa28.fw"; 1370 break; 1371 1372 case keyspan_usa28x_pre_product_id: 1373 fw_name = "keyspan/usa28x.fw"; 1374 break; 1375 1376 case keyspan_usa28xa_pre_product_id: 1377 fw_name = "keyspan/usa28xa.fw"; 1378 break; 1379 1380 case keyspan_usa28xb_pre_product_id: 1381 fw_name = "keyspan/usa28xb.fw"; 1382 break; 1383 1384 case keyspan_usa19_pre_product_id: 1385 fw_name = "keyspan/usa19.fw"; 1386 break; 1387 1388 case keyspan_usa19qi_pre_product_id: 1389 fw_name = "keyspan/usa19qi.fw"; 1390 break; 1391 1392 case keyspan_mpr_pre_product_id: 1393 fw_name = "keyspan/mpr.fw"; 1394 break; 1395 1396 case keyspan_usa19qw_pre_product_id: 1397 fw_name = "keyspan/usa19qw.fw"; 1398 break; 1399 1400 case keyspan_usa18x_pre_product_id: 1401 fw_name = "keyspan/usa18x.fw"; 1402 break; 1403 1404 case keyspan_usa19w_pre_product_id: 1405 fw_name = "keyspan/usa19w.fw"; 1406 break; 1407 1408 case keyspan_usa49w_pre_product_id: 1409 fw_name = "keyspan/usa49w.fw"; 1410 break; 1411 1412 case keyspan_usa49wlc_pre_product_id: 1413 fw_name = "keyspan/usa49wlc.fw"; 1414 break; 1415 1416 default: 1417 dev_err(&serial->dev->dev, "Unknown product ID (%04x)\n", 1418 le16_to_cpu(serial->dev->descriptor.idProduct)); 1419 return 1; 1420 } 1421 1422 if (request_ihex_firmware(&fw, fw_name, &serial->dev->dev)) { 1423 dev_err(&serial->dev->dev, "Required keyspan firmware image (%s) unavailable.\n", fw_name); 1424 return(1); 1425 } 1426 1427 dbg("Uploading Keyspan %s firmware.", fw_name); 1428 1429 /* download the firmware image */ 1430 response = ezusb_set_reset(serial, 1); 1431 1432 record = (const struct ihex_binrec *)fw->data; 1433 1434 while (record) { 1435 response = ezusb_writememory(serial, be32_to_cpu(record->addr), 1436 (unsigned char *)record->data, 1437 be16_to_cpu(record->len), 0xa0); 1438 if (response < 0) { 1439 dev_err(&serial->dev->dev, "ezusb_writememory failed for Keyspan firmware (%d %04X %p %d)\n", 1440 response, be32_to_cpu(record->addr), 1441 record->data, be16_to_cpu(record->len)); 1442 break; 1443 } 1444 record = ihex_next_binrec(record); 1445 } 1446 release_firmware(fw); 1447 /* bring device out of reset. Renumeration will occur in a 1448 moment and the new device will bind to the real driver */ 1449 response = ezusb_set_reset(serial, 0); 1450 1451 /* we don't want this device to have a driver assigned to it. */ 1452 return 1; 1453 } 1454 1455 /* Helper functions used by keyspan_setup_urbs */ 1456 static struct usb_endpoint_descriptor const *find_ep(struct usb_serial const *serial, 1457 int endpoint) 1458 { 1459 struct usb_host_interface *iface_desc; 1460 struct usb_endpoint_descriptor *ep; 1461 int i; 1462 1463 iface_desc = serial->interface->cur_altsetting; 1464 for (i = 0; i < iface_desc->desc.bNumEndpoints; ++i) { 1465 ep = &iface_desc->endpoint[i].desc; 1466 if (ep->bEndpointAddress == endpoint) 1467 return ep; 1468 } 1469 dev_warn(&serial->interface->dev, "found no endpoint descriptor for " 1470 "endpoint %x\n", endpoint); 1471 return NULL; 1472 } 1473 1474 static struct urb *keyspan_setup_urb(struct usb_serial *serial, int endpoint, 1475 int dir, void *ctx, char *buf, int len, 1476 void (*callback)(struct urb *)) 1477 { 1478 struct urb *urb; 1479 struct usb_endpoint_descriptor const *ep_desc; 1480 char const *ep_type_name; 1481 1482 if (endpoint == -1) 1483 return NULL; /* endpoint not needed */ 1484 1485 dbg("%s - alloc for endpoint %d.", __func__, endpoint); 1486 urb = usb_alloc_urb(0, GFP_KERNEL); /* No ISO */ 1487 if (urb == NULL) { 1488 dbg("%s - alloc for endpoint %d failed.", __func__, endpoint); 1489 return NULL; 1490 } 1491 1492 if (endpoint == 0) { 1493 /* control EP filled in when used */ 1494 return urb; 1495 } 1496 1497 ep_desc = find_ep(serial, endpoint); 1498 if (!ep_desc) { 1499 /* leak the urb, something's wrong and the callers don't care */ 1500 return urb; 1501 } 1502 if (usb_endpoint_xfer_int(ep_desc)) { 1503 ep_type_name = "INT"; 1504 usb_fill_int_urb(urb, serial->dev, 1505 usb_sndintpipe(serial->dev, endpoint) | dir, 1506 buf, len, callback, ctx, 1507 ep_desc->bInterval); 1508 } else if (usb_endpoint_xfer_bulk(ep_desc)) { 1509 ep_type_name = "BULK"; 1510 usb_fill_bulk_urb(urb, serial->dev, 1511 usb_sndbulkpipe(serial->dev, endpoint) | dir, 1512 buf, len, callback, ctx); 1513 } else { 1514 dev_warn(&serial->interface->dev, 1515 "unsupported endpoint type %x\n", 1516 usb_endpoint_type(ep_desc)); 1517 usb_free_urb(urb); 1518 return NULL; 1519 } 1520 1521 dbg("%s - using urb %p for %s endpoint %x", 1522 __func__, urb, ep_type_name, endpoint); 1523 return urb; 1524 } 1525 1526 static struct callbacks { 1527 void (*instat_callback)(struct urb *); 1528 void (*glocont_callback)(struct urb *); 1529 void (*indat_callback)(struct urb *); 1530 void (*outdat_callback)(struct urb *); 1531 void (*inack_callback)(struct urb *); 1532 void (*outcont_callback)(struct urb *); 1533 } keyspan_callbacks[] = { 1534 { 1535 /* msg_usa26 callbacks */ 1536 .instat_callback = usa26_instat_callback, 1537 .glocont_callback = usa26_glocont_callback, 1538 .indat_callback = usa26_indat_callback, 1539 .outdat_callback = usa2x_outdat_callback, 1540 .inack_callback = usa26_inack_callback, 1541 .outcont_callback = usa26_outcont_callback, 1542 }, { 1543 /* msg_usa28 callbacks */ 1544 .instat_callback = usa28_instat_callback, 1545 .glocont_callback = usa28_glocont_callback, 1546 .indat_callback = usa28_indat_callback, 1547 .outdat_callback = usa2x_outdat_callback, 1548 .inack_callback = usa28_inack_callback, 1549 .outcont_callback = usa28_outcont_callback, 1550 }, { 1551 /* msg_usa49 callbacks */ 1552 .instat_callback = usa49_instat_callback, 1553 .glocont_callback = usa49_glocont_callback, 1554 .indat_callback = usa49_indat_callback, 1555 .outdat_callback = usa2x_outdat_callback, 1556 .inack_callback = usa49_inack_callback, 1557 .outcont_callback = usa49_outcont_callback, 1558 }, { 1559 /* msg_usa90 callbacks */ 1560 .instat_callback = usa90_instat_callback, 1561 .glocont_callback = usa28_glocont_callback, 1562 .indat_callback = usa90_indat_callback, 1563 .outdat_callback = usa2x_outdat_callback, 1564 .inack_callback = usa28_inack_callback, 1565 .outcont_callback = usa90_outcont_callback, 1566 }, { 1567 /* msg_usa67 callbacks */ 1568 .instat_callback = usa67_instat_callback, 1569 .glocont_callback = usa67_glocont_callback, 1570 .indat_callback = usa26_indat_callback, 1571 .outdat_callback = usa2x_outdat_callback, 1572 .inack_callback = usa26_inack_callback, 1573 .outcont_callback = usa26_outcont_callback, 1574 } 1575 }; 1576 1577 /* Generic setup urbs function that uses 1578 data in device_details */ 1579 static void keyspan_setup_urbs(struct usb_serial *serial) 1580 { 1581 int i, j; 1582 struct keyspan_serial_private *s_priv; 1583 const struct keyspan_device_details *d_details; 1584 struct usb_serial_port *port; 1585 struct keyspan_port_private *p_priv; 1586 struct callbacks *cback; 1587 int endp; 1588 1589 dbg("%s", __func__); 1590 1591 s_priv = usb_get_serial_data(serial); 1592 d_details = s_priv->device_details; 1593 1594 /* Setup values for the various callback routines */ 1595 cback = &keyspan_callbacks[d_details->msg_format]; 1596 1597 /* Allocate and set up urbs for each one that is in use, 1598 starting with instat endpoints */ 1599 s_priv->instat_urb = keyspan_setup_urb 1600 (serial, d_details->instat_endpoint, USB_DIR_IN, 1601 serial, s_priv->instat_buf, INSTAT_BUFLEN, 1602 cback->instat_callback); 1603 1604 s_priv->indat_urb = keyspan_setup_urb 1605 (serial, d_details->indat_endpoint, USB_DIR_IN, 1606 serial, s_priv->indat_buf, INDAT49W_BUFLEN, 1607 usa49wg_indat_callback); 1608 1609 s_priv->glocont_urb = keyspan_setup_urb 1610 (serial, d_details->glocont_endpoint, USB_DIR_OUT, 1611 serial, s_priv->glocont_buf, GLOCONT_BUFLEN, 1612 cback->glocont_callback); 1613 1614 /* Setup endpoints for each port specific thing */ 1615 for (i = 0; i < d_details->num_ports; i++) { 1616 port = serial->port[i]; 1617 p_priv = usb_get_serial_port_data(port); 1618 1619 /* Do indat endpoints first, once for each flip */ 1620 endp = d_details->indat_endpoints[i]; 1621 for (j = 0; j <= d_details->indat_endp_flip; ++j, ++endp) { 1622 p_priv->in_urbs[j] = keyspan_setup_urb 1623 (serial, endp, USB_DIR_IN, port, 1624 p_priv->in_buffer[j], 64, 1625 cback->indat_callback); 1626 } 1627 for (; j < 2; ++j) 1628 p_priv->in_urbs[j] = NULL; 1629 1630 /* outdat endpoints also have flip */ 1631 endp = d_details->outdat_endpoints[i]; 1632 for (j = 0; j <= d_details->outdat_endp_flip; ++j, ++endp) { 1633 p_priv->out_urbs[j] = keyspan_setup_urb 1634 (serial, endp, USB_DIR_OUT, port, 1635 p_priv->out_buffer[j], 64, 1636 cback->outdat_callback); 1637 } 1638 for (; j < 2; ++j) 1639 p_priv->out_urbs[j] = NULL; 1640 1641 /* inack endpoint */ 1642 p_priv->inack_urb = keyspan_setup_urb 1643 (serial, d_details->inack_endpoints[i], USB_DIR_IN, 1644 port, p_priv->inack_buffer, 1, cback->inack_callback); 1645 1646 /* outcont endpoint */ 1647 p_priv->outcont_urb = keyspan_setup_urb 1648 (serial, d_details->outcont_endpoints[i], USB_DIR_OUT, 1649 port, p_priv->outcont_buffer, 64, 1650 cback->outcont_callback); 1651 } 1652 } 1653 1654 /* usa19 function doesn't require prescaler */ 1655 static int keyspan_usa19_calc_baud(u32 baud_rate, u32 baudclk, u8 *rate_hi, 1656 u8 *rate_low, u8 *prescaler, int portnum) 1657 { 1658 u32 b16, /* baud rate times 16 (actual rate used internally) */ 1659 div, /* divisor */ 1660 cnt; /* inverse of divisor (programmed into 8051) */ 1661 1662 dbg("%s - %d.", __func__, baud_rate); 1663 1664 /* prevent divide by zero... */ 1665 b16 = baud_rate * 16L; 1666 if (b16 == 0) 1667 return KEYSPAN_INVALID_BAUD_RATE; 1668 /* Any "standard" rate over 57k6 is marginal on the USA-19 1669 as we run out of divisor resolution. */ 1670 if (baud_rate > 57600) 1671 return KEYSPAN_INVALID_BAUD_RATE; 1672 1673 /* calculate the divisor and the counter (its inverse) */ 1674 div = baudclk / b16; 1675 if (div == 0) 1676 return KEYSPAN_INVALID_BAUD_RATE; 1677 else 1678 cnt = 0 - div; 1679 1680 if (div > 0xffff) 1681 return KEYSPAN_INVALID_BAUD_RATE; 1682 1683 /* return the counter values if non-null */ 1684 if (rate_low) 1685 *rate_low = (u8) (cnt & 0xff); 1686 if (rate_hi) 1687 *rate_hi = (u8) ((cnt >> 8) & 0xff); 1688 if (rate_low && rate_hi) 1689 dbg("%s - %d %02x %02x.", 1690 __func__, baud_rate, *rate_hi, *rate_low); 1691 return KEYSPAN_BAUD_RATE_OK; 1692 } 1693 1694 /* usa19hs function doesn't require prescaler */ 1695 static int keyspan_usa19hs_calc_baud(u32 baud_rate, u32 baudclk, u8 *rate_hi, 1696 u8 *rate_low, u8 *prescaler, int portnum) 1697 { 1698 u32 b16, /* baud rate times 16 (actual rate used internally) */ 1699 div; /* divisor */ 1700 1701 dbg("%s - %d.", __func__, baud_rate); 1702 1703 /* prevent divide by zero... */ 1704 b16 = baud_rate * 16L; 1705 if (b16 == 0) 1706 return KEYSPAN_INVALID_BAUD_RATE; 1707 1708 /* calculate the divisor */ 1709 div = baudclk / b16; 1710 if (div == 0) 1711 return KEYSPAN_INVALID_BAUD_RATE; 1712 1713 if (div > 0xffff) 1714 return KEYSPAN_INVALID_BAUD_RATE; 1715 1716 /* return the counter values if non-null */ 1717 if (rate_low) 1718 *rate_low = (u8) (div & 0xff); 1719 1720 if (rate_hi) 1721 *rate_hi = (u8) ((div >> 8) & 0xff); 1722 1723 if (rate_low && rate_hi) 1724 dbg("%s - %d %02x %02x.", 1725 __func__, baud_rate, *rate_hi, *rate_low); 1726 1727 return KEYSPAN_BAUD_RATE_OK; 1728 } 1729 1730 static int keyspan_usa19w_calc_baud(u32 baud_rate, u32 baudclk, u8 *rate_hi, 1731 u8 *rate_low, u8 *prescaler, int portnum) 1732 { 1733 u32 b16, /* baud rate times 16 (actual rate used internally) */ 1734 clk, /* clock with 13/8 prescaler */ 1735 div, /* divisor using 13/8 prescaler */ 1736 res, /* resulting baud rate using 13/8 prescaler */ 1737 diff, /* error using 13/8 prescaler */ 1738 smallest_diff; 1739 u8 best_prescaler; 1740 int i; 1741 1742 dbg("%s - %d.", __func__, baud_rate); 1743 1744 /* prevent divide by zero */ 1745 b16 = baud_rate * 16L; 1746 if (b16 == 0) 1747 return KEYSPAN_INVALID_BAUD_RATE; 1748 1749 /* Calculate prescaler by trying them all and looking 1750 for best fit */ 1751 1752 /* start with largest possible difference */ 1753 smallest_diff = 0xffffffff; 1754 1755 /* 0 is an invalid prescaler, used as a flag */ 1756 best_prescaler = 0; 1757 1758 for (i = 8; i <= 0xff; ++i) { 1759 clk = (baudclk * 8) / (u32) i; 1760 1761 div = clk / b16; 1762 if (div == 0) 1763 continue; 1764 1765 res = clk / div; 1766 diff = (res > b16) ? (res-b16) : (b16-res); 1767 1768 if (diff < smallest_diff) { 1769 best_prescaler = i; 1770 smallest_diff = diff; 1771 } 1772 } 1773 1774 if (best_prescaler == 0) 1775 return KEYSPAN_INVALID_BAUD_RATE; 1776 1777 clk = (baudclk * 8) / (u32) best_prescaler; 1778 div = clk / b16; 1779 1780 /* return the divisor and prescaler if non-null */ 1781 if (rate_low) 1782 *rate_low = (u8) (div & 0xff); 1783 if (rate_hi) 1784 *rate_hi = (u8) ((div >> 8) & 0xff); 1785 if (prescaler) { 1786 *prescaler = best_prescaler; 1787 /* dbg("%s - %d %d", __func__, *prescaler, div); */ 1788 } 1789 return KEYSPAN_BAUD_RATE_OK; 1790 } 1791 1792 /* USA-28 supports different maximum baud rates on each port */ 1793 static int keyspan_usa28_calc_baud(u32 baud_rate, u32 baudclk, u8 *rate_hi, 1794 u8 *rate_low, u8 *prescaler, int portnum) 1795 { 1796 u32 b16, /* baud rate times 16 (actual rate used internally) */ 1797 div, /* divisor */ 1798 cnt; /* inverse of divisor (programmed into 8051) */ 1799 1800 dbg("%s - %d.", __func__, baud_rate); 1801 1802 /* prevent divide by zero */ 1803 b16 = baud_rate * 16L; 1804 if (b16 == 0) 1805 return KEYSPAN_INVALID_BAUD_RATE; 1806 1807 /* calculate the divisor and the counter (its inverse) */ 1808 div = KEYSPAN_USA28_BAUDCLK / b16; 1809 if (div == 0) 1810 return KEYSPAN_INVALID_BAUD_RATE; 1811 else 1812 cnt = 0 - div; 1813 1814 /* check for out of range, based on portnum, 1815 and return result */ 1816 if (portnum == 0) { 1817 if (div > 0xffff) 1818 return KEYSPAN_INVALID_BAUD_RATE; 1819 } else { 1820 if (portnum == 1) { 1821 if (div > 0xff) 1822 return KEYSPAN_INVALID_BAUD_RATE; 1823 } else 1824 return KEYSPAN_INVALID_BAUD_RATE; 1825 } 1826 1827 /* return the counter values if not NULL 1828 (port 1 will ignore retHi) */ 1829 if (rate_low) 1830 *rate_low = (u8) (cnt & 0xff); 1831 if (rate_hi) 1832 *rate_hi = (u8) ((cnt >> 8) & 0xff); 1833 dbg("%s - %d OK.", __func__, baud_rate); 1834 return KEYSPAN_BAUD_RATE_OK; 1835 } 1836 1837 static int keyspan_usa26_send_setup(struct usb_serial *serial, 1838 struct usb_serial_port *port, 1839 int reset_port) 1840 { 1841 struct keyspan_usa26_portControlMessage msg; 1842 struct keyspan_serial_private *s_priv; 1843 struct keyspan_port_private *p_priv; 1844 const struct keyspan_device_details *d_details; 1845 int outcont_urb; 1846 struct urb *this_urb; 1847 int device_port, err; 1848 1849 dbg("%s reset=%d", __func__, reset_port); 1850 1851 s_priv = usb_get_serial_data(serial); 1852 p_priv = usb_get_serial_port_data(port); 1853 d_details = s_priv->device_details; 1854 device_port = port->number - port->serial->minor; 1855 1856 outcont_urb = d_details->outcont_endpoints[port->number]; 1857 this_urb = p_priv->outcont_urb; 1858 1859 dbg("%s - endpoint %d", __func__, usb_pipeendpoint(this_urb->pipe)); 1860 1861 /* Make sure we have an urb then send the message */ 1862 if (this_urb == NULL) { 1863 dbg("%s - oops no urb.", __func__); 1864 return -1; 1865 } 1866 1867 /* Save reset port val for resend. 1868 Don't overwrite resend for open/close condition. */ 1869 if ((reset_port + 1) > p_priv->resend_cont) 1870 p_priv->resend_cont = reset_port + 1; 1871 if (this_urb->status == -EINPROGRESS) { 1872 /* dbg("%s - already writing", __func__); */ 1873 mdelay(5); 1874 return -1; 1875 } 1876 1877 memset(&msg, 0, sizeof(struct keyspan_usa26_portControlMessage)); 1878 1879 /* Only set baud rate if it's changed */ 1880 if (p_priv->old_baud != p_priv->baud) { 1881 p_priv->old_baud = p_priv->baud; 1882 msg.setClocking = 0xff; 1883 if (d_details->calculate_baud_rate 1884 (p_priv->baud, d_details->baudclk, &msg.baudHi, 1885 &msg.baudLo, &msg.prescaler, device_port) == KEYSPAN_INVALID_BAUD_RATE) { 1886 dbg("%s - Invalid baud rate %d requested, using 9600.", 1887 __func__, p_priv->baud); 1888 msg.baudLo = 0; 1889 msg.baudHi = 125; /* Values for 9600 baud */ 1890 msg.prescaler = 10; 1891 } 1892 msg.setPrescaler = 0xff; 1893 } 1894 1895 msg.lcr = (p_priv->cflag & CSTOPB)? STOPBITS_678_2: STOPBITS_5678_1; 1896 switch (p_priv->cflag & CSIZE) { 1897 case CS5: 1898 msg.lcr |= USA_DATABITS_5; 1899 break; 1900 case CS6: 1901 msg.lcr |= USA_DATABITS_6; 1902 break; 1903 case CS7: 1904 msg.lcr |= USA_DATABITS_7; 1905 break; 1906 case CS8: 1907 msg.lcr |= USA_DATABITS_8; 1908 break; 1909 } 1910 if (p_priv->cflag & PARENB) { 1911 /* note USA_PARITY_NONE == 0 */ 1912 msg.lcr |= (p_priv->cflag & PARODD)? 1913 USA_PARITY_ODD : USA_PARITY_EVEN; 1914 } 1915 msg.setLcr = 0xff; 1916 1917 msg.ctsFlowControl = (p_priv->flow_control == flow_cts); 1918 msg.xonFlowControl = 0; 1919 msg.setFlowControl = 0xff; 1920 msg.forwardingLength = 16; 1921 msg.xonChar = 17; 1922 msg.xoffChar = 19; 1923 1924 /* Opening port */ 1925 if (reset_port == 1) { 1926 msg._txOn = 1; 1927 msg._txOff = 0; 1928 msg.txFlush = 0; 1929 msg.txBreak = 0; 1930 msg.rxOn = 1; 1931 msg.rxOff = 0; 1932 msg.rxFlush = 1; 1933 msg.rxForward = 0; 1934 msg.returnStatus = 0; 1935 msg.resetDataToggle = 0xff; 1936 } 1937 1938 /* Closing port */ 1939 else if (reset_port == 2) { 1940 msg._txOn = 0; 1941 msg._txOff = 1; 1942 msg.txFlush = 0; 1943 msg.txBreak = 0; 1944 msg.rxOn = 0; 1945 msg.rxOff = 1; 1946 msg.rxFlush = 1; 1947 msg.rxForward = 0; 1948 msg.returnStatus = 0; 1949 msg.resetDataToggle = 0; 1950 } 1951 1952 /* Sending intermediate configs */ 1953 else { 1954 msg._txOn = (!p_priv->break_on); 1955 msg._txOff = 0; 1956 msg.txFlush = 0; 1957 msg.txBreak = (p_priv->break_on); 1958 msg.rxOn = 0; 1959 msg.rxOff = 0; 1960 msg.rxFlush = 0; 1961 msg.rxForward = 0; 1962 msg.returnStatus = 0; 1963 msg.resetDataToggle = 0x0; 1964 } 1965 1966 /* Do handshaking outputs */ 1967 msg.setTxTriState_setRts = 0xff; 1968 msg.txTriState_rts = p_priv->rts_state; 1969 1970 msg.setHskoa_setDtr = 0xff; 1971 msg.hskoa_dtr = p_priv->dtr_state; 1972 1973 p_priv->resend_cont = 0; 1974 memcpy(this_urb->transfer_buffer, &msg, sizeof(msg)); 1975 1976 /* send the data out the device on control endpoint */ 1977 this_urb->transfer_buffer_length = sizeof(msg); 1978 1979 this_urb->dev = serial->dev; 1980 err = usb_submit_urb(this_urb, GFP_ATOMIC); 1981 if (err != 0) 1982 dbg("%s - usb_submit_urb(setup) failed (%d)", __func__, err); 1983 #if 0 1984 else { 1985 dbg("%s - usb_submit_urb(%d) OK %d bytes (end %d)", __func__ 1986 outcont_urb, this_urb->transfer_buffer_length, 1987 usb_pipeendpoint(this_urb->pipe)); 1988 } 1989 #endif 1990 1991 return 0; 1992 } 1993 1994 static int keyspan_usa28_send_setup(struct usb_serial *serial, 1995 struct usb_serial_port *port, 1996 int reset_port) 1997 { 1998 struct keyspan_usa28_portControlMessage msg; 1999 struct keyspan_serial_private *s_priv; 2000 struct keyspan_port_private *p_priv; 2001 const struct keyspan_device_details *d_details; 2002 struct urb *this_urb; 2003 int device_port, err; 2004 2005 dbg("%s", __func__); 2006 2007 s_priv = usb_get_serial_data(serial); 2008 p_priv = usb_get_serial_port_data(port); 2009 d_details = s_priv->device_details; 2010 device_port = port->number - port->serial->minor; 2011 2012 /* only do something if we have a bulk out endpoint */ 2013 this_urb = p_priv->outcont_urb; 2014 if (this_urb == NULL) { 2015 dbg("%s - oops no urb.", __func__); 2016 return -1; 2017 } 2018 2019 /* Save reset port val for resend. 2020 Don't overwrite resend for open/close condition. */ 2021 if ((reset_port + 1) > p_priv->resend_cont) 2022 p_priv->resend_cont = reset_port + 1; 2023 if (this_urb->status == -EINPROGRESS) { 2024 dbg("%s already writing", __func__); 2025 mdelay(5); 2026 return -1; 2027 } 2028 2029 memset(&msg, 0, sizeof(struct keyspan_usa28_portControlMessage)); 2030 2031 msg.setBaudRate = 1; 2032 if (d_details->calculate_baud_rate(p_priv->baud, d_details->baudclk, 2033 &msg.baudHi, &msg.baudLo, NULL, device_port) == KEYSPAN_INVALID_BAUD_RATE) { 2034 dbg("%s - Invalid baud rate requested %d.", 2035 __func__, p_priv->baud); 2036 msg.baudLo = 0xff; 2037 msg.baudHi = 0xb2; /* Values for 9600 baud */ 2038 } 2039 2040 /* If parity is enabled, we must calculate it ourselves. */ 2041 msg.parity = 0; /* XXX for now */ 2042 2043 msg.ctsFlowControl = (p_priv->flow_control == flow_cts); 2044 msg.xonFlowControl = 0; 2045 2046 /* Do handshaking outputs, DTR is inverted relative to RTS */ 2047 msg.rts = p_priv->rts_state; 2048 msg.dtr = p_priv->dtr_state; 2049 2050 msg.forwardingLength = 16; 2051 msg.forwardMs = 10; 2052 msg.breakThreshold = 45; 2053 msg.xonChar = 17; 2054 msg.xoffChar = 19; 2055 2056 /*msg.returnStatus = 1; 2057 msg.resetDataToggle = 0xff;*/ 2058 /* Opening port */ 2059 if (reset_port == 1) { 2060 msg._txOn = 1; 2061 msg._txOff = 0; 2062 msg.txFlush = 0; 2063 msg.txForceXoff = 0; 2064 msg.txBreak = 0; 2065 msg.rxOn = 1; 2066 msg.rxOff = 0; 2067 msg.rxFlush = 1; 2068 msg.rxForward = 0; 2069 msg.returnStatus = 0; 2070 msg.resetDataToggle = 0xff; 2071 } 2072 /* Closing port */ 2073 else if (reset_port == 2) { 2074 msg._txOn = 0; 2075 msg._txOff = 1; 2076 msg.txFlush = 0; 2077 msg.txForceXoff = 0; 2078 msg.txBreak = 0; 2079 msg.rxOn = 0; 2080 msg.rxOff = 1; 2081 msg.rxFlush = 1; 2082 msg.rxForward = 0; 2083 msg.returnStatus = 0; 2084 msg.resetDataToggle = 0; 2085 } 2086 /* Sending intermediate configs */ 2087 else { 2088 msg._txOn = (!p_priv->break_on); 2089 msg._txOff = 0; 2090 msg.txFlush = 0; 2091 msg.txForceXoff = 0; 2092 msg.txBreak = (p_priv->break_on); 2093 msg.rxOn = 0; 2094 msg.rxOff = 0; 2095 msg.rxFlush = 0; 2096 msg.rxForward = 0; 2097 msg.returnStatus = 0; 2098 msg.resetDataToggle = 0x0; 2099 } 2100 2101 p_priv->resend_cont = 0; 2102 memcpy(this_urb->transfer_buffer, &msg, sizeof(msg)); 2103 2104 /* send the data out the device on control endpoint */ 2105 this_urb->transfer_buffer_length = sizeof(msg); 2106 2107 this_urb->dev = serial->dev; 2108 err = usb_submit_urb(this_urb, GFP_ATOMIC); 2109 if (err != 0) 2110 dbg("%s - usb_submit_urb(setup) failed", __func__); 2111 #if 0 2112 else { 2113 dbg("%s - usb_submit_urb(setup) OK %d bytes", __func__, 2114 this_urb->transfer_buffer_length); 2115 } 2116 #endif 2117 2118 return 0; 2119 } 2120 2121 static int keyspan_usa49_send_setup(struct usb_serial *serial, 2122 struct usb_serial_port *port, 2123 int reset_port) 2124 { 2125 struct keyspan_usa49_portControlMessage msg; 2126 struct usb_ctrlrequest *dr = NULL; 2127 struct keyspan_serial_private *s_priv; 2128 struct keyspan_port_private *p_priv; 2129 const struct keyspan_device_details *d_details; 2130 struct urb *this_urb; 2131 int err, device_port; 2132 2133 dbg("%s", __func__); 2134 2135 s_priv = usb_get_serial_data(serial); 2136 p_priv = usb_get_serial_port_data(port); 2137 d_details = s_priv->device_details; 2138 2139 this_urb = s_priv->glocont_urb; 2140 2141 /* Work out which port within the device is being setup */ 2142 device_port = port->number - port->serial->minor; 2143 2144 dbg("%s - endpoint %d port %d (%d)", 2145 __func__, usb_pipeendpoint(this_urb->pipe), 2146 port->number, device_port); 2147 2148 /* Make sure we have an urb then send the message */ 2149 if (this_urb == NULL) { 2150 dbg("%s - oops no urb for port %d.", __func__, port->number); 2151 return -1; 2152 } 2153 2154 /* Save reset port val for resend. 2155 Don't overwrite resend for open/close condition. */ 2156 if ((reset_port + 1) > p_priv->resend_cont) 2157 p_priv->resend_cont = reset_port + 1; 2158 2159 if (this_urb->status == -EINPROGRESS) { 2160 /* dbg("%s - already writing", __func__); */ 2161 mdelay(5); 2162 return -1; 2163 } 2164 2165 memset(&msg, 0, sizeof(struct keyspan_usa49_portControlMessage)); 2166 2167 /*msg.portNumber = port->number;*/ 2168 msg.portNumber = device_port; 2169 2170 /* Only set baud rate if it's changed */ 2171 if (p_priv->old_baud != p_priv->baud) { 2172 p_priv->old_baud = p_priv->baud; 2173 msg.setClocking = 0xff; 2174 if (d_details->calculate_baud_rate 2175 (p_priv->baud, d_details->baudclk, &msg.baudHi, 2176 &msg.baudLo, &msg.prescaler, device_port) == KEYSPAN_INVALID_BAUD_RATE) { 2177 dbg("%s - Invalid baud rate %d requested, using 9600.", 2178 __func__, p_priv->baud); 2179 msg.baudLo = 0; 2180 msg.baudHi = 125; /* Values for 9600 baud */ 2181 msg.prescaler = 10; 2182 } 2183 /* msg.setPrescaler = 0xff; */ 2184 } 2185 2186 msg.lcr = (p_priv->cflag & CSTOPB)? STOPBITS_678_2: STOPBITS_5678_1; 2187 switch (p_priv->cflag & CSIZE) { 2188 case CS5: 2189 msg.lcr |= USA_DATABITS_5; 2190 break; 2191 case CS6: 2192 msg.lcr |= USA_DATABITS_6; 2193 break; 2194 case CS7: 2195 msg.lcr |= USA_DATABITS_7; 2196 break; 2197 case CS8: 2198 msg.lcr |= USA_DATABITS_8; 2199 break; 2200 } 2201 if (p_priv->cflag & PARENB) { 2202 /* note USA_PARITY_NONE == 0 */ 2203 msg.lcr |= (p_priv->cflag & PARODD)? 2204 USA_PARITY_ODD : USA_PARITY_EVEN; 2205 } 2206 msg.setLcr = 0xff; 2207 2208 msg.ctsFlowControl = (p_priv->flow_control == flow_cts); 2209 msg.xonFlowControl = 0; 2210 msg.setFlowControl = 0xff; 2211 2212 msg.forwardingLength = 16; 2213 msg.xonChar = 17; 2214 msg.xoffChar = 19; 2215 2216 /* Opening port */ 2217 if (reset_port == 1) { 2218 msg._txOn = 1; 2219 msg._txOff = 0; 2220 msg.txFlush = 0; 2221 msg.txBreak = 0; 2222 msg.rxOn = 1; 2223 msg.rxOff = 0; 2224 msg.rxFlush = 1; 2225 msg.rxForward = 0; 2226 msg.returnStatus = 0; 2227 msg.resetDataToggle = 0xff; 2228 msg.enablePort = 1; 2229 msg.disablePort = 0; 2230 } 2231 /* Closing port */ 2232 else if (reset_port == 2) { 2233 msg._txOn = 0; 2234 msg._txOff = 1; 2235 msg.txFlush = 0; 2236 msg.txBreak = 0; 2237 msg.rxOn = 0; 2238 msg.rxOff = 1; 2239 msg.rxFlush = 1; 2240 msg.rxForward = 0; 2241 msg.returnStatus = 0; 2242 msg.resetDataToggle = 0; 2243 msg.enablePort = 0; 2244 msg.disablePort = 1; 2245 } 2246 /* Sending intermediate configs */ 2247 else { 2248 msg._txOn = (!p_priv->break_on); 2249 msg._txOff = 0; 2250 msg.txFlush = 0; 2251 msg.txBreak = (p_priv->break_on); 2252 msg.rxOn = 0; 2253 msg.rxOff = 0; 2254 msg.rxFlush = 0; 2255 msg.rxForward = 0; 2256 msg.returnStatus = 0; 2257 msg.resetDataToggle = 0x0; 2258 msg.enablePort = 0; 2259 msg.disablePort = 0; 2260 } 2261 2262 /* Do handshaking outputs */ 2263 msg.setRts = 0xff; 2264 msg.rts = p_priv->rts_state; 2265 2266 msg.setDtr = 0xff; 2267 msg.dtr = p_priv->dtr_state; 2268 2269 p_priv->resend_cont = 0; 2270 2271 /* if the device is a 49wg, we send control message on usb 2272 control EP 0 */ 2273 2274 if (d_details->product_id == keyspan_usa49wg_product_id) { 2275 dr = (void *)(s_priv->ctrl_buf); 2276 dr->bRequestType = USB_TYPE_VENDOR | USB_DIR_OUT; 2277 dr->bRequest = 0xB0; /* 49wg control message */; 2278 dr->wValue = 0; 2279 dr->wIndex = 0; 2280 dr->wLength = cpu_to_le16(sizeof(msg)); 2281 2282 memcpy(s_priv->glocont_buf, &msg, sizeof(msg)); 2283 2284 usb_fill_control_urb(this_urb, serial->dev, 2285 usb_sndctrlpipe(serial->dev, 0), 2286 (unsigned char *)dr, s_priv->glocont_buf, 2287 sizeof(msg), usa49_glocont_callback, serial); 2288 2289 } else { 2290 memcpy(this_urb->transfer_buffer, &msg, sizeof(msg)); 2291 2292 /* send the data out the device on control endpoint */ 2293 this_urb->transfer_buffer_length = sizeof(msg); 2294 2295 this_urb->dev = serial->dev; 2296 } 2297 err = usb_submit_urb(this_urb, GFP_ATOMIC); 2298 if (err != 0) 2299 dbg("%s - usb_submit_urb(setup) failed (%d)", __func__, err); 2300 #if 0 2301 else { 2302 dbg("%s - usb_submit_urb(%d) OK %d bytes (end %d)", __func__, 2303 outcont_urb, this_urb->transfer_buffer_length, 2304 usb_pipeendpoint(this_urb->pipe)); 2305 } 2306 #endif 2307 2308 return 0; 2309 } 2310 2311 static int keyspan_usa90_send_setup(struct usb_serial *serial, 2312 struct usb_serial_port *port, 2313 int reset_port) 2314 { 2315 struct keyspan_usa90_portControlMessage msg; 2316 struct keyspan_serial_private *s_priv; 2317 struct keyspan_port_private *p_priv; 2318 const struct keyspan_device_details *d_details; 2319 struct urb *this_urb; 2320 int err; 2321 u8 prescaler; 2322 2323 dbg("%s", __func__); 2324 2325 s_priv = usb_get_serial_data(serial); 2326 p_priv = usb_get_serial_port_data(port); 2327 d_details = s_priv->device_details; 2328 2329 /* only do something if we have a bulk out endpoint */ 2330 this_urb = p_priv->outcont_urb; 2331 if (this_urb == NULL) { 2332 dbg("%s - oops no urb.", __func__); 2333 return -1; 2334 } 2335 2336 /* Save reset port val for resend. 2337 Don't overwrite resend for open/close condition. */ 2338 if ((reset_port + 1) > p_priv->resend_cont) 2339 p_priv->resend_cont = reset_port + 1; 2340 if (this_urb->status == -EINPROGRESS) { 2341 dbg("%s already writing", __func__); 2342 mdelay(5); 2343 return -1; 2344 } 2345 2346 memset(&msg, 0, sizeof(struct keyspan_usa90_portControlMessage)); 2347 2348 /* Only set baud rate if it's changed */ 2349 if (p_priv->old_baud != p_priv->baud) { 2350 p_priv->old_baud = p_priv->baud; 2351 msg.setClocking = 0x01; 2352 if (d_details->calculate_baud_rate 2353 (p_priv->baud, d_details->baudclk, &msg.baudHi, 2354 &msg.baudLo, &prescaler, 0) == KEYSPAN_INVALID_BAUD_RATE) { 2355 dbg("%s - Invalid baud rate %d requested, using 9600.", 2356 __func__, p_priv->baud); 2357 p_priv->baud = 9600; 2358 d_details->calculate_baud_rate(p_priv->baud, d_details->baudclk, 2359 &msg.baudHi, &msg.baudLo, &prescaler, 0); 2360 } 2361 msg.setRxMode = 1; 2362 msg.setTxMode = 1; 2363 } 2364 2365 /* modes must always be correctly specified */ 2366 if (p_priv->baud > 57600) { 2367 msg.rxMode = RXMODE_DMA; 2368 msg.txMode = TXMODE_DMA; 2369 } else { 2370 msg.rxMode = RXMODE_BYHAND; 2371 msg.txMode = TXMODE_BYHAND; 2372 } 2373 2374 msg.lcr = (p_priv->cflag & CSTOPB)? STOPBITS_678_2: STOPBITS_5678_1; 2375 switch (p_priv->cflag & CSIZE) { 2376 case CS5: 2377 msg.lcr |= USA_DATABITS_5; 2378 break; 2379 case CS6: 2380 msg.lcr |= USA_DATABITS_6; 2381 break; 2382 case CS7: 2383 msg.lcr |= USA_DATABITS_7; 2384 break; 2385 case CS8: 2386 msg.lcr |= USA_DATABITS_8; 2387 break; 2388 } 2389 if (p_priv->cflag & PARENB) { 2390 /* note USA_PARITY_NONE == 0 */ 2391 msg.lcr |= (p_priv->cflag & PARODD)? 2392 USA_PARITY_ODD : USA_PARITY_EVEN; 2393 } 2394 if (p_priv->old_cflag != p_priv->cflag) { 2395 p_priv->old_cflag = p_priv->cflag; 2396 msg.setLcr = 0x01; 2397 } 2398 2399 if (p_priv->flow_control == flow_cts) 2400 msg.txFlowControl = TXFLOW_CTS; 2401 msg.setTxFlowControl = 0x01; 2402 msg.setRxFlowControl = 0x01; 2403 2404 msg.rxForwardingLength = 16; 2405 msg.rxForwardingTimeout = 16; 2406 msg.txAckSetting = 0; 2407 msg.xonChar = 17; 2408 msg.xoffChar = 19; 2409 2410 /* Opening port */ 2411 if (reset_port == 1) { 2412 msg.portEnabled = 1; 2413 msg.rxFlush = 1; 2414 msg.txBreak = (p_priv->break_on); 2415 } 2416 /* Closing port */ 2417 else if (reset_port == 2) 2418 msg.portEnabled = 0; 2419 /* Sending intermediate configs */ 2420 else { 2421 if (port->port.count) 2422 msg.portEnabled = 1; 2423 msg.txBreak = (p_priv->break_on); 2424 } 2425 2426 /* Do handshaking outputs */ 2427 msg.setRts = 0x01; 2428 msg.rts = p_priv->rts_state; 2429 2430 msg.setDtr = 0x01; 2431 msg.dtr = p_priv->dtr_state; 2432 2433 p_priv->resend_cont = 0; 2434 memcpy(this_urb->transfer_buffer, &msg, sizeof(msg)); 2435 2436 /* send the data out the device on control endpoint */ 2437 this_urb->transfer_buffer_length = sizeof(msg); 2438 2439 this_urb->dev = serial->dev; 2440 err = usb_submit_urb(this_urb, GFP_ATOMIC); 2441 if (err != 0) 2442 dbg("%s - usb_submit_urb(setup) failed (%d)", __func__, err); 2443 return 0; 2444 } 2445 2446 static int keyspan_usa67_send_setup(struct usb_serial *serial, 2447 struct usb_serial_port *port, 2448 int reset_port) 2449 { 2450 struct keyspan_usa67_portControlMessage msg; 2451 struct keyspan_serial_private *s_priv; 2452 struct keyspan_port_private *p_priv; 2453 const struct keyspan_device_details *d_details; 2454 struct urb *this_urb; 2455 int err, device_port; 2456 2457 dbg("%s", __func__); 2458 2459 s_priv = usb_get_serial_data(serial); 2460 p_priv = usb_get_serial_port_data(port); 2461 d_details = s_priv->device_details; 2462 2463 this_urb = s_priv->glocont_urb; 2464 2465 /* Work out which port within the device is being setup */ 2466 device_port = port->number - port->serial->minor; 2467 2468 /* Make sure we have an urb then send the message */ 2469 if (this_urb == NULL) { 2470 dbg("%s - oops no urb for port %d.", __func__, 2471 port->number); 2472 return -1; 2473 } 2474 2475 /* Save reset port val for resend. 2476 Don't overwrite resend for open/close condition. */ 2477 if ((reset_port + 1) > p_priv->resend_cont) 2478 p_priv->resend_cont = reset_port + 1; 2479 if (this_urb->status == -EINPROGRESS) { 2480 /* dbg("%s - already writing", __func__); */ 2481 mdelay(5); 2482 return -1; 2483 } 2484 2485 memset(&msg, 0, sizeof(struct keyspan_usa67_portControlMessage)); 2486 2487 msg.port = device_port; 2488 2489 /* Only set baud rate if it's changed */ 2490 if (p_priv->old_baud != p_priv->baud) { 2491 p_priv->old_baud = p_priv->baud; 2492 msg.setClocking = 0xff; 2493 if (d_details->calculate_baud_rate 2494 (p_priv->baud, d_details->baudclk, &msg.baudHi, 2495 &msg.baudLo, &msg.prescaler, device_port) == KEYSPAN_INVALID_BAUD_RATE) { 2496 dbg("%s - Invalid baud rate %d requested, using 9600.", 2497 __func__, p_priv->baud); 2498 msg.baudLo = 0; 2499 msg.baudHi = 125; /* Values for 9600 baud */ 2500 msg.prescaler = 10; 2501 } 2502 msg.setPrescaler = 0xff; 2503 } 2504 2505 msg.lcr = (p_priv->cflag & CSTOPB) ? STOPBITS_678_2 : STOPBITS_5678_1; 2506 switch (p_priv->cflag & CSIZE) { 2507 case CS5: 2508 msg.lcr |= USA_DATABITS_5; 2509 break; 2510 case CS6: 2511 msg.lcr |= USA_DATABITS_6; 2512 break; 2513 case CS7: 2514 msg.lcr |= USA_DATABITS_7; 2515 break; 2516 case CS8: 2517 msg.lcr |= USA_DATABITS_8; 2518 break; 2519 } 2520 if (p_priv->cflag & PARENB) { 2521 /* note USA_PARITY_NONE == 0 */ 2522 msg.lcr |= (p_priv->cflag & PARODD)? 2523 USA_PARITY_ODD : USA_PARITY_EVEN; 2524 } 2525 msg.setLcr = 0xff; 2526 2527 msg.ctsFlowControl = (p_priv->flow_control == flow_cts); 2528 msg.xonFlowControl = 0; 2529 msg.setFlowControl = 0xff; 2530 msg.forwardingLength = 16; 2531 msg.xonChar = 17; 2532 msg.xoffChar = 19; 2533 2534 if (reset_port == 1) { 2535 /* Opening port */ 2536 msg._txOn = 1; 2537 msg._txOff = 0; 2538 msg.txFlush = 0; 2539 msg.txBreak = 0; 2540 msg.rxOn = 1; 2541 msg.rxOff = 0; 2542 msg.rxFlush = 1; 2543 msg.rxForward = 0; 2544 msg.returnStatus = 0; 2545 msg.resetDataToggle = 0xff; 2546 } else if (reset_port == 2) { 2547 /* Closing port */ 2548 msg._txOn = 0; 2549 msg._txOff = 1; 2550 msg.txFlush = 0; 2551 msg.txBreak = 0; 2552 msg.rxOn = 0; 2553 msg.rxOff = 1; 2554 msg.rxFlush = 1; 2555 msg.rxForward = 0; 2556 msg.returnStatus = 0; 2557 msg.resetDataToggle = 0; 2558 } else { 2559 /* Sending intermediate configs */ 2560 msg._txOn = (!p_priv->break_on); 2561 msg._txOff = 0; 2562 msg.txFlush = 0; 2563 msg.txBreak = (p_priv->break_on); 2564 msg.rxOn = 0; 2565 msg.rxOff = 0; 2566 msg.rxFlush = 0; 2567 msg.rxForward = 0; 2568 msg.returnStatus = 0; 2569 msg.resetDataToggle = 0x0; 2570 } 2571 2572 /* Do handshaking outputs */ 2573 msg.setTxTriState_setRts = 0xff; 2574 msg.txTriState_rts = p_priv->rts_state; 2575 2576 msg.setHskoa_setDtr = 0xff; 2577 msg.hskoa_dtr = p_priv->dtr_state; 2578 2579 p_priv->resend_cont = 0; 2580 2581 memcpy(this_urb->transfer_buffer, &msg, sizeof(msg)); 2582 2583 /* send the data out the device on control endpoint */ 2584 this_urb->transfer_buffer_length = sizeof(msg); 2585 this_urb->dev = serial->dev; 2586 2587 err = usb_submit_urb(this_urb, GFP_ATOMIC); 2588 if (err != 0) 2589 dbg("%s - usb_submit_urb(setup) failed (%d)", __func__, 2590 err); 2591 return 0; 2592 } 2593 2594 static void keyspan_send_setup(struct usb_serial_port *port, int reset_port) 2595 { 2596 struct usb_serial *serial = port->serial; 2597 struct keyspan_serial_private *s_priv; 2598 const struct keyspan_device_details *d_details; 2599 2600 dbg("%s", __func__); 2601 2602 s_priv = usb_get_serial_data(serial); 2603 d_details = s_priv->device_details; 2604 2605 switch (d_details->msg_format) { 2606 case msg_usa26: 2607 keyspan_usa26_send_setup(serial, port, reset_port); 2608 break; 2609 case msg_usa28: 2610 keyspan_usa28_send_setup(serial, port, reset_port); 2611 break; 2612 case msg_usa49: 2613 keyspan_usa49_send_setup(serial, port, reset_port); 2614 break; 2615 case msg_usa90: 2616 keyspan_usa90_send_setup(serial, port, reset_port); 2617 break; 2618 case msg_usa67: 2619 keyspan_usa67_send_setup(serial, port, reset_port); 2620 break; 2621 } 2622 } 2623 2624 2625 /* Gets called by the "real" driver (ie once firmware is loaded 2626 and renumeration has taken place. */ 2627 static int keyspan_startup(struct usb_serial *serial) 2628 { 2629 int i, err; 2630 struct usb_serial_port *port; 2631 struct keyspan_serial_private *s_priv; 2632 struct keyspan_port_private *p_priv; 2633 const struct keyspan_device_details *d_details; 2634 2635 dbg("%s", __func__); 2636 2637 for (i = 0; (d_details = keyspan_devices[i]) != NULL; ++i) 2638 if (d_details->product_id == 2639 le16_to_cpu(serial->dev->descriptor.idProduct)) 2640 break; 2641 if (d_details == NULL) { 2642 dev_err(&serial->dev->dev, "%s - unknown product id %x\n", 2643 __func__, le16_to_cpu(serial->dev->descriptor.idProduct)); 2644 return 1; 2645 } 2646 2647 /* Setup private data for serial driver */ 2648 s_priv = kzalloc(sizeof(struct keyspan_serial_private), GFP_KERNEL); 2649 if (!s_priv) { 2650 dbg("%s - kmalloc for keyspan_serial_private failed.", 2651 __func__); 2652 return -ENOMEM; 2653 } 2654 2655 s_priv->device_details = d_details; 2656 usb_set_serial_data(serial, s_priv); 2657 2658 /* Now setup per port private data */ 2659 for (i = 0; i < serial->num_ports; i++) { 2660 port = serial->port[i]; 2661 p_priv = kzalloc(sizeof(struct keyspan_port_private), 2662 GFP_KERNEL); 2663 if (!p_priv) { 2664 dbg("%s - kmalloc for keyspan_port_private (%d) failed!.", __func__, i); 2665 return 1; 2666 } 2667 p_priv->device_details = d_details; 2668 usb_set_serial_port_data(port, p_priv); 2669 } 2670 2671 keyspan_setup_urbs(serial); 2672 2673 if (s_priv->instat_urb != NULL) { 2674 s_priv->instat_urb->dev = serial->dev; 2675 err = usb_submit_urb(s_priv->instat_urb, GFP_KERNEL); 2676 if (err != 0) 2677 dbg("%s - submit instat urb failed %d", __func__, 2678 err); 2679 } 2680 if (s_priv->indat_urb != NULL) { 2681 s_priv->indat_urb->dev = serial->dev; 2682 err = usb_submit_urb(s_priv->indat_urb, GFP_KERNEL); 2683 if (err != 0) 2684 dbg("%s - submit indat urb failed %d", __func__, 2685 err); 2686 } 2687 2688 return 0; 2689 } 2690 2691 static void keyspan_disconnect(struct usb_serial *serial) 2692 { 2693 int i, j; 2694 struct usb_serial_port *port; 2695 struct keyspan_serial_private *s_priv; 2696 struct keyspan_port_private *p_priv; 2697 2698 dbg("%s", __func__); 2699 2700 s_priv = usb_get_serial_data(serial); 2701 2702 /* Stop reading/writing urbs */ 2703 stop_urb(s_priv->instat_urb); 2704 stop_urb(s_priv->glocont_urb); 2705 stop_urb(s_priv->indat_urb); 2706 for (i = 0; i < serial->num_ports; ++i) { 2707 port = serial->port[i]; 2708 p_priv = usb_get_serial_port_data(port); 2709 stop_urb(p_priv->inack_urb); 2710 stop_urb(p_priv->outcont_urb); 2711 for (j = 0; j < 2; j++) { 2712 stop_urb(p_priv->in_urbs[j]); 2713 stop_urb(p_priv->out_urbs[j]); 2714 } 2715 } 2716 2717 /* Now free them */ 2718 usb_free_urb(s_priv->instat_urb); 2719 usb_free_urb(s_priv->indat_urb); 2720 usb_free_urb(s_priv->glocont_urb); 2721 for (i = 0; i < serial->num_ports; ++i) { 2722 port = serial->port[i]; 2723 p_priv = usb_get_serial_port_data(port); 2724 usb_free_urb(p_priv->inack_urb); 2725 usb_free_urb(p_priv->outcont_urb); 2726 for (j = 0; j < 2; j++) { 2727 usb_free_urb(p_priv->in_urbs[j]); 2728 usb_free_urb(p_priv->out_urbs[j]); 2729 } 2730 } 2731 } 2732 2733 static void keyspan_release(struct usb_serial *serial) 2734 { 2735 int i; 2736 struct usb_serial_port *port; 2737 struct keyspan_serial_private *s_priv; 2738 2739 dbg("%s", __func__); 2740 2741 s_priv = usb_get_serial_data(serial); 2742 2743 /* dbg("Freeing serial->private."); */ 2744 kfree(s_priv); 2745 2746 /* dbg("Freeing port->private."); */ 2747 /* Now free per port private data */ 2748 for (i = 0; i < serial->num_ports; i++) { 2749 port = serial->port[i]; 2750 kfree(usb_get_serial_port_data(port)); 2751 } 2752 } 2753 2754 MODULE_AUTHOR(DRIVER_AUTHOR); 2755 MODULE_DESCRIPTION(DRIVER_DESC); 2756 MODULE_LICENSE("GPL"); 2757 2758 MODULE_FIRMWARE("keyspan/usa28.fw"); 2759 MODULE_FIRMWARE("keyspan/usa28x.fw"); 2760 MODULE_FIRMWARE("keyspan/usa28xa.fw"); 2761 MODULE_FIRMWARE("keyspan/usa28xb.fw"); 2762 MODULE_FIRMWARE("keyspan/usa19.fw"); 2763 MODULE_FIRMWARE("keyspan/usa19qi.fw"); 2764 MODULE_FIRMWARE("keyspan/mpr.fw"); 2765 MODULE_FIRMWARE("keyspan/usa19qw.fw"); 2766 MODULE_FIRMWARE("keyspan/usa18x.fw"); 2767 MODULE_FIRMWARE("keyspan/usa19w.fw"); 2768 MODULE_FIRMWARE("keyspan/usa49w.fw"); 2769 MODULE_FIRMWARE("keyspan/usa49wlc.fw"); 2770 2771 module_param(debug, bool, S_IRUGO | S_IWUSR); 2772 MODULE_PARM_DESC(debug, "Debug enabled or not"); 2773 2774