diff options
Diffstat (limited to 'drivers/usb/mon')
-rw-r--r-- | drivers/usb/mon/Makefile | 2 | ||||
-rw-r--r-- | drivers/usb/mon/mon_bin.c | 35 | ||||
-rw-r--r-- | drivers/usb/mon/mon_main.c | 2 | ||||
-rw-r--r-- | drivers/usb/mon/mon_stat.c | 1 | ||||
-rw-r--r-- | drivers/usb/mon/mon_text.c | 3 |
5 files changed, 35 insertions, 8 deletions
diff --git a/drivers/usb/mon/Makefile b/drivers/usb/mon/Makefile index 384b198faa7c..8ed24ab08698 100644 --- a/drivers/usb/mon/Makefile +++ b/drivers/usb/mon/Makefile | |||
@@ -2,6 +2,6 @@ | |||
2 | # Makefile for USB monitor | 2 | # Makefile for USB monitor |
3 | # | 3 | # |
4 | 4 | ||
5 | usbmon-objs := mon_main.o mon_stat.o mon_text.o mon_bin.o | 5 | usbmon-y := mon_main.o mon_stat.o mon_text.o mon_bin.o |
6 | 6 | ||
7 | obj-$(CONFIG_USB_MON) += usbmon.o | 7 | obj-$(CONFIG_USB_MON) += usbmon.o |
diff --git a/drivers/usb/mon/mon_bin.c b/drivers/usb/mon/mon_bin.c index 44cb37b5a4dc..a09dbd243eb3 100644 --- a/drivers/usb/mon/mon_bin.c +++ b/drivers/usb/mon/mon_bin.c | |||
@@ -15,7 +15,6 @@ | |||
15 | #include <linux/poll.h> | 15 | #include <linux/poll.h> |
16 | #include <linux/compat.h> | 16 | #include <linux/compat.h> |
17 | #include <linux/mm.h> | 17 | #include <linux/mm.h> |
18 | #include <linux/smp_lock.h> | ||
19 | #include <linux/scatterlist.h> | 18 | #include <linux/scatterlist.h> |
20 | #include <linux/slab.h> | 19 | #include <linux/slab.h> |
21 | 20 | ||
@@ -437,6 +436,28 @@ static unsigned int mon_bin_get_data(const struct mon_reader_bin *rp, | |||
437 | return length; | 436 | return length; |
438 | } | 437 | } |
439 | 438 | ||
439 | /* | ||
440 | * This is the look-ahead pass in case of 'C Zi', when actual_length cannot | ||
441 | * be used to determine the length of the whole contiguous buffer. | ||
442 | */ | ||
443 | static unsigned int mon_bin_collate_isodesc(const struct mon_reader_bin *rp, | ||
444 | struct urb *urb, unsigned int ndesc) | ||
445 | { | ||
446 | struct usb_iso_packet_descriptor *fp; | ||
447 | unsigned int length; | ||
448 | |||
449 | length = 0; | ||
450 | fp = urb->iso_frame_desc; | ||
451 | while (ndesc-- != 0) { | ||
452 | if (fp->actual_length != 0) { | ||
453 | if (fp->offset + fp->actual_length > length) | ||
454 | length = fp->offset + fp->actual_length; | ||
455 | } | ||
456 | fp++; | ||
457 | } | ||
458 | return length; | ||
459 | } | ||
460 | |||
440 | static void mon_bin_get_isodesc(const struct mon_reader_bin *rp, | 461 | static void mon_bin_get_isodesc(const struct mon_reader_bin *rp, |
441 | unsigned int offset, struct urb *urb, char ev_type, unsigned int ndesc) | 462 | unsigned int offset, struct urb *urb, char ev_type, unsigned int ndesc) |
442 | { | 463 | { |
@@ -479,6 +500,10 @@ static void mon_bin_event(struct mon_reader_bin *rp, struct urb *urb, | |||
479 | /* | 500 | /* |
480 | * Find the maximum allowable length, then allocate space. | 501 | * Find the maximum allowable length, then allocate space. |
481 | */ | 502 | */ |
503 | urb_length = (ev_type == 'S') ? | ||
504 | urb->transfer_buffer_length : urb->actual_length; | ||
505 | length = urb_length; | ||
506 | |||
482 | if (usb_endpoint_xfer_isoc(epd)) { | 507 | if (usb_endpoint_xfer_isoc(epd)) { |
483 | if (urb->number_of_packets < 0) { | 508 | if (urb->number_of_packets < 0) { |
484 | ndesc = 0; | 509 | ndesc = 0; |
@@ -487,14 +512,16 @@ static void mon_bin_event(struct mon_reader_bin *rp, struct urb *urb, | |||
487 | } else { | 512 | } else { |
488 | ndesc = urb->number_of_packets; | 513 | ndesc = urb->number_of_packets; |
489 | } | 514 | } |
515 | if (ev_type == 'C' && usb_urb_dir_in(urb)) | ||
516 | length = mon_bin_collate_isodesc(rp, urb, ndesc); | ||
490 | } else { | 517 | } else { |
491 | ndesc = 0; | 518 | ndesc = 0; |
492 | } | 519 | } |
493 | lendesc = ndesc*sizeof(struct mon_bin_isodesc); | 520 | lendesc = ndesc*sizeof(struct mon_bin_isodesc); |
494 | 521 | ||
495 | urb_length = (ev_type == 'S') ? | 522 | /* not an issue unless there's a subtle bug in a HCD somewhere */ |
496 | urb->transfer_buffer_length : urb->actual_length; | 523 | if (length >= urb->transfer_buffer_length) |
497 | length = urb_length; | 524 | length = urb->transfer_buffer_length; |
498 | 525 | ||
499 | if (length >= rp->b_size/5) | 526 | if (length >= rp->b_size/5) |
500 | length = rp->b_size/5; | 527 | length = rp->b_size/5; |
diff --git a/drivers/usb/mon/mon_main.c b/drivers/usb/mon/mon_main.c index 812dc288bb8c..10405119985c 100644 --- a/drivers/usb/mon/mon_main.c +++ b/drivers/usb/mon/mon_main.c | |||
@@ -90,7 +90,6 @@ static void mon_bus_submit(struct mon_bus *mbus, struct urb *urb) | |||
90 | r->rnf_submit(r->r_data, urb); | 90 | r->rnf_submit(r->r_data, urb); |
91 | } | 91 | } |
92 | spin_unlock_irqrestore(&mbus->lock, flags); | 92 | spin_unlock_irqrestore(&mbus->lock, flags); |
93 | return; | ||
94 | } | 93 | } |
95 | 94 | ||
96 | static void mon_submit(struct usb_bus *ubus, struct urb *urb) | 95 | static void mon_submit(struct usb_bus *ubus, struct urb *urb) |
@@ -117,7 +116,6 @@ static void mon_bus_submit_error(struct mon_bus *mbus, struct urb *urb, int erro | |||
117 | r->rnf_error(r->r_data, urb, error); | 116 | r->rnf_error(r->r_data, urb, error); |
118 | } | 117 | } |
119 | spin_unlock_irqrestore(&mbus->lock, flags); | 118 | spin_unlock_irqrestore(&mbus->lock, flags); |
120 | return; | ||
121 | } | 119 | } |
122 | 120 | ||
123 | static void mon_submit_error(struct usb_bus *ubus, struct urb *urb, int error) | 121 | static void mon_submit_error(struct usb_bus *ubus, struct urb *urb, int error) |
diff --git a/drivers/usb/mon/mon_stat.c b/drivers/usb/mon/mon_stat.c index 8ec94f15a738..e5ce42bd316e 100644 --- a/drivers/usb/mon/mon_stat.c +++ b/drivers/usb/mon/mon_stat.c | |||
@@ -11,7 +11,6 @@ | |||
11 | #include <linux/slab.h> | 11 | #include <linux/slab.h> |
12 | #include <linux/usb.h> | 12 | #include <linux/usb.h> |
13 | #include <linux/fs.h> | 13 | #include <linux/fs.h> |
14 | #include <linux/smp_lock.h> | ||
15 | #include <asm/uaccess.h> | 14 | #include <asm/uaccess.h> |
16 | 15 | ||
17 | #include "usb_mon.h" | 16 | #include "usb_mon.h" |
diff --git a/drivers/usb/mon/mon_text.c b/drivers/usb/mon/mon_text.c index a545d65f6e57..c302e1983c70 100644 --- a/drivers/usb/mon/mon_text.c +++ b/drivers/usb/mon/mon_text.c | |||
@@ -236,6 +236,9 @@ static void mon_text_event(struct mon_reader_text *rp, struct urb *urb, | |||
236 | fp++; | 236 | fp++; |
237 | dp++; | 237 | dp++; |
238 | } | 238 | } |
239 | /* Wasteful, but simple to understand: ISO 'C' is sparse. */ | ||
240 | if (ev_type == 'C') | ||
241 | ep->length = urb->transfer_buffer_length; | ||
239 | } | 242 | } |
240 | 243 | ||
241 | ep->setup_flag = mon_text_get_setup(ep, urb, ev_type, rp->r.m_bus); | 244 | ep->setup_flag = mon_text_get_setup(ep, urb, ev_type, rp->r.m_bus); |