usb/isp1760: Fix crash when unplugging bug
authorArvid Brodin <arvid.brodin@enea.com>
Mon, 7 Mar 2011 14:36:21 +0000 (15:36 +0100)
committerGreg Kroah-Hartman <gregkh@suse.de>
Mon, 7 Mar 2011 20:14:07 +0000 (12:14 -0800)
This fixes a problem with my previous patch series where there's a great
risk that the kernel will crash when unplugging interrupt devices from
the USB port. These lines must have got missing when I rebased the
patches from the older kernel I was working with to 2.6.37 and 2.6-next:

This fixes a bug where the kernel may crash if you unplug a USB device
that has active interrupt transfers.

Signed-off-by: Arvid Brodin <arvid.brodin@enea.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
drivers/usb/host/isp1760-hcd.c

index d2b674ace0be836c2ec2f44edff89956fcc0a24f..c7c1e0aa0b8ec5447039842e9191eb270b22bd65 100644 (file)
@@ -1624,14 +1624,14 @@ static int isp1760_urb_dequeue(struct usb_hcd *hcd, struct urb *urb, int status)
 
                        ptd_write(hcd->regs, reg_base, i, &ptd);
 
-                       qtd = ints->qtd;
+                       qtd = ints[i].qtd;
                        qh = ints[i].qh;
 
                        free_mem(hcd, qtd);
                        qtd = clean_up_qtdlist(qtd, qh);
 
-                       ints->qh = NULL;
-                       ints->qtd = NULL;
+                       ints[i].qh = NULL;
+                       ints[i].qtd = NULL;
 
                        isp1760_urb_done(hcd, urb);
                        if (qtd)
@@ -1655,7 +1655,6 @@ static int isp1760_urb_dequeue(struct usb_hcd *hcd, struct urb *urb, int status)
                        if (!qtd)
                                break;
                }
-               ints++;
        }
 
        spin_unlock_irqrestore(&priv->lock, flags);