mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-01 18:24:23 +08:00
xhci: give command abortion one more chance before killing xhci
We want to give the command abortion an additional try to stop the command ring before we completely hose xhci. Cc: <stable@vger.kernel.org> Tested-by: Vincent Pelletier <plr.vincent@gmail.com> Signed-off-by: Mathias Nyman <mathias.nyman@linux.intel.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
ff30cbc8da
commit
a6809ffd16
@ -302,6 +302,15 @@ static int xhci_abort_cmd_ring(struct xhci_hcd *xhci)
|
|||||||
ret = xhci_handshake(&xhci->op_regs->cmd_ring,
|
ret = xhci_handshake(&xhci->op_regs->cmd_ring,
|
||||||
CMD_RING_RUNNING, 0, 5 * 1000 * 1000);
|
CMD_RING_RUNNING, 0, 5 * 1000 * 1000);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
|
/* we are about to kill xhci, give it one more chance */
|
||||||
|
xhci_write_64(xhci, temp_64 | CMD_RING_ABORT,
|
||||||
|
&xhci->op_regs->cmd_ring);
|
||||||
|
udelay(1000);
|
||||||
|
ret = xhci_handshake(&xhci->op_regs->cmd_ring,
|
||||||
|
CMD_RING_RUNNING, 0, 3 * 1000 * 1000);
|
||||||
|
if (ret == 0)
|
||||||
|
return 0;
|
||||||
|
|
||||||
xhci_err(xhci, "Stopped the command ring failed, "
|
xhci_err(xhci, "Stopped the command ring failed, "
|
||||||
"maybe the host is dead\n");
|
"maybe the host is dead\n");
|
||||||
xhci->xhc_state |= XHCI_STATE_DYING;
|
xhci->xhc_state |= XHCI_STATE_DYING;
|
||||||
|
Loading…
Reference in New Issue
Block a user