Commit 76840406 authored by Zhuang Jin Can's avatar Zhuang Jin Can Committed by Sasha Levin

xhci: prevent bus_suspend if SS port resuming in phase 1

[ Upstream commit fac4271d ]

When the link is just waken, it's in Resume state, and driver sets PLS to
U0. This refers to Phase 1. Phase 2 refers to when the link has completed
the transition from Resume state to U0.

With the fix of xhci: report U3 when link is in resume state, it also
exposes an issue that usb3 roothub and controller can suspend right
after phase 1, and this causes a hard hang in controller.

To fix the issue, we need to prevent usb3 bus suspend if any port is
resuming in phase 1.

[merge separate USB2 and USB3 port resume checking to one -Mathias]
Cc: <stable@vger.kernel.org>
Signed-off-by: default avatarZhuang Jin Can <jin.can.zhuang@intel.com>
Signed-off-by: default avatarMathias Nyman <mathias.nyman@linux.intel.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarSasha Levin <sasha.levin@oracle.com>
parent ad418404
...@@ -484,10 +484,13 @@ static void xhci_hub_report_usb3_link_state(struct xhci_hcd *xhci, ...@@ -484,10 +484,13 @@ static void xhci_hub_report_usb3_link_state(struct xhci_hcd *xhci,
u32 pls = status_reg & PORT_PLS_MASK; u32 pls = status_reg & PORT_PLS_MASK;
/* resume state is a xHCI internal state. /* resume state is a xHCI internal state.
* Do not report it to usb core. * Do not report it to usb core, instead, pretend to be U3,
* thus usb core knows it's not ready for transfer
*/ */
if (pls == XDEV_RESUME) if (pls == XDEV_RESUME) {
*status |= USB_SS_PORT_LS_U3;
return; return;
}
/* When the CAS bit is set then warm reset /* When the CAS bit is set then warm reset
* should be performed on port * should be performed on port
......
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