aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/usb/serial/generic.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/usb/serial/generic.c')
-rw-r--r--drivers/usb/serial/generic.c68
1 files changed, 15 insertions, 53 deletions
diff --git a/drivers/usb/serial/generic.c b/drivers/usb/serial/generic.c
index 664deb63807..105a6d898ca 100644
--- a/drivers/usb/serial/generic.c
+++ b/drivers/usb/serial/generic.c
@@ -28,9 +28,6 @@ static int debug;
28 28
29#ifdef CONFIG_USB_SERIAL_GENERIC 29#ifdef CONFIG_USB_SERIAL_GENERIC
30 30
31static int generic_probe(struct usb_interface *interface,
32 const struct usb_device_id *id);
33
34static __u16 vendor = 0x05f9; 31static __u16 vendor = 0x05f9;
35static __u16 product = 0xffff; 32static __u16 product = 0xffff;
36 33
@@ -49,13 +46,6 @@ static const struct usb_device_id generic_serial_ids[] = {
49 {} 46 {}
50}; 47};
51 48
52static struct usb_driver generic_driver = {
53 .name = "usbserial_generic",
54 .probe = generic_probe,
55 .disconnect = usb_serial_disconnect,
56 .id_table = generic_serial_ids,
57};
58
59/* All of the device info needed for the Generic Serial Converter */ 49/* All of the device info needed for the Generic Serial Converter */
60struct usb_serial_driver usb_serial_generic_device = { 50struct usb_serial_driver usb_serial_generic_device = {
61 .driver = { 51 .driver = {
@@ -75,16 +65,6 @@ static struct usb_serial_driver * const serial_drivers[] = {
75 &usb_serial_generic_device, NULL 65 &usb_serial_generic_device, NULL
76}; 66};
77 67
78static int generic_probe(struct usb_interface *interface,
79 const struct usb_device_id *id)
80{
81 const struct usb_device_id *id_pattern;
82
83 id_pattern = usb_match_id(interface, generic_device_ids);
84 if (id_pattern != NULL)
85 return usb_serial_probe(interface, id);
86 return -ENODEV;
87}
88#endif 68#endif
89 69
90int usb_serial_generic_register(int _debug) 70int usb_serial_generic_register(int _debug)
@@ -99,7 +79,7 @@ int usb_serial_generic_register(int _debug)
99 USB_DEVICE_ID_MATCH_VENDOR | USB_DEVICE_ID_MATCH_PRODUCT; 79 USB_DEVICE_ID_MATCH_VENDOR | USB_DEVICE_ID_MATCH_PRODUCT;
100 80
101 /* register our generic driver with ourselves */ 81 /* register our generic driver with ourselves */
102 retval = usb_serial_register_drivers(&generic_driver, serial_drivers); 82 retval = usb_serial_register_drivers(serial_drivers, "usbserial_generic", generic_serial_ids);
103#endif 83#endif
104 return retval; 84 return retval;
105} 85}
@@ -108,7 +88,7 @@ void usb_serial_generic_deregister(void)
108{ 88{
109#ifdef CONFIG_USB_SERIAL_GENERIC 89#ifdef CONFIG_USB_SERIAL_GENERIC
110 /* remove our generic driver */ 90 /* remove our generic driver */
111 usb_serial_deregister_drivers(&generic_driver, serial_drivers); 91 usb_serial_deregister_drivers(serial_drivers);
112#endif 92#endif
113} 93}
114 94
@@ -117,8 +97,6 @@ int usb_serial_generic_open(struct tty_struct *tty, struct usb_serial_port *port
117 int result = 0; 97 int result = 0;
118 unsigned long flags; 98 unsigned long flags;
119 99
120 dbg("%s - port %d", __func__, port->number);
121
122 /* clear the throttle flags */ 100 /* clear the throttle flags */
123 spin_lock_irqsave(&port->lock, flags); 101 spin_lock_irqsave(&port->lock, flags);
124 port->throttled = 0; 102 port->throttled = 0;
@@ -139,12 +117,9 @@ static void generic_cleanup(struct usb_serial_port *port)
139 unsigned long flags; 117 unsigned long flags;
140 int i; 118 int i;
141 119
142 dbg("%s - port %d", __func__, port->number);
143
144 if (serial->dev) { 120 if (serial->dev) {
145 /* shutdown any bulk transfers that might be going on */ 121 /* shutdown any bulk transfers that might be going on */
146 if (port->bulk_out_size) { 122 if (port->bulk_out_size) {
147 usb_kill_urb(port->write_urb);
148 for (i = 0; i < ARRAY_SIZE(port->write_urbs); ++i) 123 for (i = 0; i < ARRAY_SIZE(port->write_urbs); ++i)
149 usb_kill_urb(port->write_urbs[i]); 124 usb_kill_urb(port->write_urbs[i]);
150 125
@@ -161,7 +136,6 @@ static void generic_cleanup(struct usb_serial_port *port)
161 136
162void usb_serial_generic_close(struct usb_serial_port *port) 137void usb_serial_generic_close(struct usb_serial_port *port)
163{ 138{
164 dbg("%s - port %d", __func__, port->number);
165 generic_cleanup(port); 139 generic_cleanup(port);
166} 140}
167EXPORT_SYMBOL_GPL(usb_serial_generic_close); 141EXPORT_SYMBOL_GPL(usb_serial_generic_close);
@@ -249,8 +223,6 @@ int usb_serial_generic_write(struct tty_struct *tty,
249{ 223{
250 int result; 224 int result;
251 225
252 dbg("%s - port %d", __func__, port->number);
253
254 /* only do something if we have a bulk out endpoint */ 226 /* only do something if we have a bulk out endpoint */
255 if (!port->bulk_out_size) 227 if (!port->bulk_out_size)
256 return -ENODEV; 228 return -ENODEV;
@@ -273,8 +245,6 @@ int usb_serial_generic_write_room(struct tty_struct *tty)
273 unsigned long flags; 245 unsigned long flags;
274 int room; 246 int room;
275 247
276 dbg("%s - port %d", __func__, port->number);
277
278 if (!port->bulk_out_size) 248 if (!port->bulk_out_size)
279 return 0; 249 return 0;
280 250
@@ -282,7 +252,7 @@ int usb_serial_generic_write_room(struct tty_struct *tty)
282 room = kfifo_avail(&port->write_fifo); 252 room = kfifo_avail(&port->write_fifo);
283 spin_unlock_irqrestore(&port->lock, flags); 253 spin_unlock_irqrestore(&port->lock, flags);
284 254
285 dbg("%s - returns %d", __func__, room); 255 dev_dbg(&port->dev, "%s - returns %d\n", __func__, room);
286 return room; 256 return room;
287} 257}
288 258
@@ -292,8 +262,6 @@ int usb_serial_generic_chars_in_buffer(struct tty_struct *tty)
292 unsigned long flags; 262 unsigned long flags;
293 int chars; 263 int chars;
294 264
295 dbg("%s - port %d", __func__, port->number);
296
297 if (!port->bulk_out_size) 265 if (!port->bulk_out_size)
298 return 0; 266 return 0;
299 267
@@ -301,7 +269,7 @@ int usb_serial_generic_chars_in_buffer(struct tty_struct *tty)
301 chars = kfifo_len(&port->write_fifo) + port->tx_bytes; 269 chars = kfifo_len(&port->write_fifo) + port->tx_bytes;
302 spin_unlock_irqrestore(&port->lock, flags); 270 spin_unlock_irqrestore(&port->lock, flags);
303 271
304 dbg("%s - returns %d", __func__, chars); 272 dev_dbg(&port->dev, "%s - returns %d\n", __func__, chars);
305 return chars; 273 return chars;
306} 274}
307 275
@@ -313,7 +281,8 @@ static int usb_serial_generic_submit_read_urb(struct usb_serial_port *port,
313 if (!test_and_clear_bit(index, &port->read_urbs_free)) 281 if (!test_and_clear_bit(index, &port->read_urbs_free))
314 return 0; 282 return 0;
315 283
316 dbg("%s - port %d, urb %d\n", __func__, port->number, index); 284 dev_dbg(&port->dev, "%s - port %d, urb %d\n", __func__,
285 port->number, index);
317 286
318 res = usb_submit_urb(port->read_urbs[index], mem_flags); 287 res = usb_submit_urb(port->read_urbs[index], mem_flags);
319 if (res) { 288 if (res) {
@@ -335,8 +304,6 @@ int usb_serial_generic_submit_read_urbs(struct usb_serial_port *port,
335 int res; 304 int res;
336 int i; 305 int i;
337 306
338 dbg("%s - port %d", __func__, port->number);
339
340 for (i = 0; i < ARRAY_SIZE(port->read_urbs); ++i) { 307 for (i = 0; i < ARRAY_SIZE(port->read_urbs); ++i) {
341 res = usb_serial_generic_submit_read_urb(port, i, mem_flags); 308 res = usb_serial_generic_submit_read_urb(port, i, mem_flags);
342 if (res) 309 if (res)
@@ -395,10 +362,12 @@ void usb_serial_generic_read_bulk_callback(struct urb *urb)
395 } 362 }
396 set_bit(i, &port->read_urbs_free); 363 set_bit(i, &port->read_urbs_free);
397 364
398 dbg("%s - port %d, urb %d, len %d\n", __func__, port->number, i, 365 dev_dbg(&port->dev, "%s - port %d, urb %d, len %d\n",
399 urb->actual_length); 366 __func__, port->number, i, urb->actual_length);
367
400 if (urb->status) { 368 if (urb->status) {
401 dbg("%s - non-zero urb status: %d\n", __func__, urb->status); 369 dev_dbg(&port->dev, "%s - non-zero urb status: %d\n",
370 __func__, urb->status);
402 return; 371 return;
403 } 372 }
404 373
@@ -424,8 +393,6 @@ void usb_serial_generic_write_bulk_callback(struct urb *urb)
424 int status = urb->status; 393 int status = urb->status;
425 int i; 394 int i;
426 395
427 dbg("%s - port %d", __func__, port->number);
428
429 for (i = 0; i < ARRAY_SIZE(port->write_urbs); ++i) 396 for (i = 0; i < ARRAY_SIZE(port->write_urbs); ++i)
430 if (port->write_urbs[i] == urb) 397 if (port->write_urbs[i] == urb)
431 break; 398 break;
@@ -436,7 +403,8 @@ void usb_serial_generic_write_bulk_callback(struct urb *urb)
436 spin_unlock_irqrestore(&port->lock, flags); 403 spin_unlock_irqrestore(&port->lock, flags);
437 404
438 if (status) { 405 if (status) {
439 dbg("%s - non-zero urb status: %d", __func__, status); 406 dev_dbg(&port->dev, "%s - non-zero urb status: %d\n",
407 __func__, status);
440 408
441 spin_lock_irqsave(&port->lock, flags); 409 spin_lock_irqsave(&port->lock, flags);
442 kfifo_reset_out(&port->write_fifo); 410 kfifo_reset_out(&port->write_fifo);
@@ -454,8 +422,6 @@ void usb_serial_generic_throttle(struct tty_struct *tty)
454 struct usb_serial_port *port = tty->driver_data; 422 struct usb_serial_port *port = tty->driver_data;
455 unsigned long flags; 423 unsigned long flags;
456 424
457 dbg("%s - port %d", __func__, port->number);
458
459 /* Set the throttle request flag. It will be picked up 425 /* Set the throttle request flag. It will be picked up
460 * by usb_serial_generic_read_bulk_callback(). */ 426 * by usb_serial_generic_read_bulk_callback(). */
461 spin_lock_irqsave(&port->lock, flags); 427 spin_lock_irqsave(&port->lock, flags);
@@ -469,8 +435,6 @@ void usb_serial_generic_unthrottle(struct tty_struct *tty)
469 struct usb_serial_port *port = tty->driver_data; 435 struct usb_serial_port *port = tty->driver_data;
470 int was_throttled; 436 int was_throttled;
471 437
472 dbg("%s - port %d", __func__, port->number);
473
474 /* Clear the throttle flags */ 438 /* Clear the throttle flags */
475 spin_lock_irq(&port->lock); 439 spin_lock_irq(&port->lock);
476 was_throttled = port->throttled; 440 was_throttled = port->throttled;
@@ -525,7 +489,8 @@ void usb_serial_handle_dcd_change(struct usb_serial_port *usb_port,
525{ 489{
526 struct tty_port *port = &usb_port->port; 490 struct tty_port *port = &usb_port->port;
527 491
528 dbg("%s - port %d, status %d", __func__, usb_port->number, status); 492 dev_dbg(&usb_port->dev, "%s - port %d, status %d\n", __func__,
493 usb_port->number, status);
529 494
530 if (status) 495 if (status)
531 wake_up_interruptible(&port->open_wait); 496 wake_up_interruptible(&port->open_wait);
@@ -566,8 +531,6 @@ void usb_serial_generic_disconnect(struct usb_serial *serial)
566{ 531{
567 int i; 532 int i;
568 533
569 dbg("%s", __func__);
570
571 /* stop reads and writes on all ports */ 534 /* stop reads and writes on all ports */
572 for (i = 0; i < serial->num_ports; ++i) 535 for (i = 0; i < serial->num_ports; ++i)
573 generic_cleanup(serial->port[i]); 536 generic_cleanup(serial->port[i]);
@@ -576,5 +539,4 @@ EXPORT_SYMBOL_GPL(usb_serial_generic_disconnect);
576 539
577void usb_serial_generic_release(struct usb_serial *serial) 540void usb_serial_generic_release(struct usb_serial *serial)
578{ 541{
579 dbg("%s", __func__);
580} 542}