usb: host: max3421-hcd: Correctly abort a USB request.
commit 0d2ada05227881f3d0722ca2364e3f7a860a301f upstream. If the current USB request was aborted, the spi thread would not respond to any further requests. This is because the "curr_urb" pointer would not become NULL, so no further requests would be taken off the queue. The solution here is to set the "urb_done" flag, as this will cause the correct handling of the URB. Also clear interrupts that should only be expected if an URB is in progress. Fixes: 2d53139f3162 ("Add support for using a MAX3421E chip as a host driver.") Cc: stable <stable@kernel.org> Signed-off-by: Mark Tomlinson <mark.tomlinson@alliedtelesis.co.nz> Link: https://lore.kernel.org/r/20241124221430.1106080-1-mark.tomlinson@alliedtelesis.co.nz Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
b0777ecd9e
commit
73420703cc
1 changed files with 11 additions and 5 deletions
|
@ -785,6 +785,11 @@ max3421_check_unlink(struct usb_hcd *hcd)
|
||||||
retval = 1;
|
retval = 1;
|
||||||
dev_dbg(&spi->dev, "%s: URB %p unlinked=%d",
|
dev_dbg(&spi->dev, "%s: URB %p unlinked=%d",
|
||||||
__func__, urb, urb->unlinked);
|
__func__, urb, urb->unlinked);
|
||||||
|
if (urb == max3421_hcd->curr_urb) {
|
||||||
|
max3421_hcd->urb_done = 1;
|
||||||
|
max3421_hcd->hien &= ~(BIT(MAX3421_HI_HXFRDN_BIT) |
|
||||||
|
BIT(MAX3421_HI_RCVDAV_BIT));
|
||||||
|
} else {
|
||||||
usb_hcd_unlink_urb_from_ep(hcd, urb);
|
usb_hcd_unlink_urb_from_ep(hcd, urb);
|
||||||
spin_unlock_irqrestore(&max3421_hcd->lock,
|
spin_unlock_irqrestore(&max3421_hcd->lock,
|
||||||
flags);
|
flags);
|
||||||
|
@ -793,6 +798,7 @@ max3421_check_unlink(struct usb_hcd *hcd)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
spin_unlock_irqrestore(&max3421_hcd->lock, flags);
|
spin_unlock_irqrestore(&max3421_hcd->lock, flags);
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue