UPSTREAM: usb: dwc3: core: improve reset sequence
authorFelipe Balbi <felipe.balbi@linux.intel.com>
Fri, 11 Mar 2016 08:51:52 +0000 (10:51 +0200)
committerHuang, Tao <huangtao@rock-chips.com>
Tue, 7 Jun 2016 06:18:05 +0000 (14:18 +0800)
commit71cc2e772156ea53af675f2c82d911bae47eca41
tree5d5edbec98658c6f98f1d2a344857666c9b3faeb
parentbb6cd1d5aa80b373ebf183426d233d4c09692ed9
UPSTREAM: 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).

Change-Id: Ie268d8fbe41dbe31e0070556dfd204ad51453c2f
Suggested-by: Mian Yousaf Kaukab <yousaf.kaukab@intel.com>
Signed-off-by: Felipe Balbi <felipe.balbi@linux.intel.com>
Signed-off-by: Wu Liang feng <wulf@rock-chips.com>
(cherry picked from commit f59dcab176293b646e1358144c93c58c3cda2813)
drivers/usb/dwc3/core.c