Commit 79731cbd authored by Thomas Pugliese's avatar Thomas Pugliese Committed by Greg Kroah-Hartman

USB: WUSBCORE: fix leak of urb in wa_xfer_destroy.

The check to free the URB was the opposite of the correct case.  This
patch removes the check altogether since the ptr will be NULL if the URB
was not allocated.  Also use usb_free_urb instead of usb_put_urb.
Signed-off-by: default avatarThomas Pugliese <thomas.pugliese@gmail.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 11b1bf81
...@@ -166,8 +166,8 @@ static inline void wa_xfer_init(struct wa_xfer *xfer) ...@@ -166,8 +166,8 @@ static inline void wa_xfer_init(struct wa_xfer *xfer)
/* /*
* Destroy a transfer structure * Destroy a transfer structure
* *
* Note that the xfer->seg[index] thingies follow the URB life cycle, * Note that freeing xfer->seg[cnt]->urb will free the containing
* so we need to put them, not free them. * xfer->seg[cnt] memory that was allocated by __wa_xfer_setup_segs.
*/ */
static void wa_xfer_destroy(struct kref *_xfer) static void wa_xfer_destroy(struct kref *_xfer)
{ {
...@@ -175,9 +175,8 @@ static void wa_xfer_destroy(struct kref *_xfer) ...@@ -175,9 +175,8 @@ static void wa_xfer_destroy(struct kref *_xfer)
if (xfer->seg) { if (xfer->seg) {
unsigned cnt; unsigned cnt;
for (cnt = 0; cnt < xfer->segs; cnt++) { for (cnt = 0; cnt < xfer->segs; cnt++) {
if (xfer->is_inbound) usb_free_urb(xfer->seg[cnt]->dto_urb);
usb_put_urb(xfer->seg[cnt]->dto_urb); usb_free_urb(&xfer->seg[cnt]->urb);
usb_put_urb(&xfer->seg[cnt]->urb);
} }
} }
kfree(xfer); kfree(xfer);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment