summaryrefslogtreecommitdiff
path: root/drivers/usb/dwc3/gadget.c
diff options
context:
space:
mode:
authorFelipe Balbi <felipe.balbi@linux.intel.com>2016-03-11 10:51:52 +0200
committerFelipe Balbi <felipe.balbi@linux.intel.com>2016-03-29 09:30:31 +0300
commitf59dcab176293b646e1358144c93c58c3cda2813 (patch)
treeb61057df86df875d35a2b4b5dcf836226f659fde /drivers/usb/dwc3/gadget.c
parent9acdf4df2fc4680b08fa242b09717892cd687d4a (diff)
downloadlwn-f59dcab176293b646e1358144c93c58c3cda2813.tar.gz
lwn-f59dcab176293b646e1358144c93c58c3cda2813.zip
usb: dwc3: core: improve reset sequence
According to Synopsys Databook, we shouldn't be relying on GCTL.CORESOFTRESET bit as that's only for debugging purposes. Instead, let's use DCTL.CSFTRST if we're OTG or PERIPHERAL mode. Host side block will be reset by XHCI driver if necessary. Note that this reduces amount of time spent on dwc3_probe() by a long margin. We're still gonna wait for reset to finish for a long time (default to 1ms max), but tests show that the reset polling loop executed at most 19 times (modprobe dwc3 && modprobe -r dwc3 executed 1000 times in a row). Suggested-by: Mian Yousaf Kaukab <yousaf.kaukab@intel.com> Signed-off-by: Felipe Balbi <felipe.balbi@linux.intel.com>
Diffstat (limited to 'drivers/usb/dwc3/gadget.c')
0 files changed, 0 insertions, 0 deletions