aboutsummaryrefslogtreecommitdiff
path: root/tools/perf/scripts/python
diff options
context:
space:
mode:
authorDan Williams <[email protected]>2014-05-29 12:58:46 -0700
committerGreg Kroah-Hartman <[email protected]>2014-07-09 15:43:12 -0700
commit3cd12f91514da6893954de479dc60b16d3b381f4 (patch)
tree3209b05551050ac2e1da7f79ca96bc49298f9ac9 /tools/perf/scripts/python
parent51df62ff74b371866c1006dee887a8e42838c1f2 (diff)
usb: force warm reset to break link re-connect livelock
Resuming a powered down port sometimes results in the port state being stuck in the training sequence. hub 3-0:1.0: debounce: port 1: total 2000ms stable 0ms status 0x2e0 port1: can't get reconnection after setting port power on, status -110 hub 3-0:1.0: port 1 status 0000.02e0 after resume, -19 usb 3-1: can't resume, status -19 hub 3-0:1.0: logical disconnect on port 1 In the case above we wait for the port re-connect timeout of 2 seconds and observe that the port status is USB_SS_PORT_LS_POLLING (although it is likely toggling between this state and USB_SS_PORT_LS_RX_DETECT). This is indicative of a case where the device is failing to progress the link training state machine. It is resolved by issuing a warm reset to get the hub and device link state machines back in sync. hub 3-0:1.0: debounce: port 1: total 2000ms stable 0ms status 0x2e0 usb usb3: port1 usb_port_runtime_resume requires warm reset hub 3-0:1.0: port 1 not warm reset yet, waiting 50ms usb 3-1: reset SuperSpeed USB device number 2 using xhci_hcd After a reconnect timeout when we expect the device to be present, force a warm reset of the device. Note that we can not simply look at the link status to determine if a warm reset is required as any of the training states USB_SS_PORT_LS_POLLING, USB_SS_PORT_LS_RX_DETECT, or USB_SS_PORT_LS_COMP_MOD are valid states that do not indicate the need for warm reset by themselves. Cc: Alan Stern <[email protected]> Cc: Kukjin Kim <[email protected]> Cc: Vincent Palatin <[email protected]> Cc: Lan Tianyu <[email protected]> Cc: Ksenia Ragiadakou <[email protected]> Cc: Vivek Gautam <[email protected]> Cc: Douglas Anderson <[email protected]> Cc: Felipe Balbi <[email protected]> Cc: Sunil Joshi <[email protected]> Cc: Hans de Goede <[email protected]> Acked-by: Julius Werner <[email protected]> Signed-off-by: Dan Williams <[email protected]> Acked-by: Alan Stern <[email protected]> Signed-off-by: Greg Kroah-Hartman <[email protected]>
Diffstat (limited to 'tools/perf/scripts/python')
0 files changed, 0 insertions, 0 deletions