summaryrefslogtreecommitdiff
path: root/drivers/usb
diff options
context:
space:
mode:
authorKuninori Morimoto <kuninori.morimoto.gx@renesas.com>2011-05-11 16:00:09 +0900
committerGreg Kroah-Hartman <gregkh@suse.de>2011-05-11 15:17:01 -0700
commitc786e09c35924252ff219241e7027e340b77252d (patch)
tree0c72f99272e303024d8a3ea2b3592c5f777f39a8 /drivers/usb
parentfd5054c169d29747a44b4e1419ff47f57ae82dbc (diff)
usb: renesas_usbhs: fixup fifo disable
It was necessary to check pipe condition after disable fifo. Current driver checked it in a wrong place. Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/usb')
-rw-r--r--drivers/usb/renesas_usbhs/pipe.c29
1 files changed, 13 insertions, 16 deletions
diff --git a/drivers/usb/renesas_usbhs/pipe.c b/drivers/usb/renesas_usbhs/pipe.c
index 5897ddad05f2..bc4521c54261 100644
--- a/drivers/usb/renesas_usbhs/pipe.c
+++ b/drivers/usb/renesas_usbhs/pipe.c
@@ -183,7 +183,6 @@ static void usbhsp_pipe_select(struct usbhs_pipe *pipe)
static int usbhsp_pipe_barrier(struct usbhs_pipe *pipe)
{
struct usbhs_priv *priv = usbhsp_pipe_to_priv(pipe);
- struct device *dev = usbhs_priv_to_dev(priv);
int timeout = 1024;
u16 val;
@@ -206,6 +205,7 @@ static int usbhsp_pipe_barrier(struct usbhs_pipe *pipe)
* - "Pipe Control Registers Switching Procedure"
*/
usbhs_write(priv, CFIFOSEL, 0);
+ usbhs_fifo_disable(pipe);
do {
val = usbhsp_pipectrl_get(pipe);
@@ -217,21 +217,6 @@ static int usbhsp_pipe_barrier(struct usbhs_pipe *pipe)
} while (timeout--);
- /*
- * force NAK
- */
- timeout = 1024;
- usbhs_fifo_disable(pipe);
- do {
- val = usbhsp_pipectrl_get(pipe);
- val &= PBUSY;
- if (!val)
- return 0;
-
- } while (timeout--);
-
- dev_err(dev, "pipe barrier failed\n");
-
return -EBUSY;
}
@@ -270,10 +255,22 @@ static void __usbhsp_pid_try_nak_if_stall(struct usbhs_pipe *pipe)
void usbhs_fifo_disable(struct usbhs_pipe *pipe)
{
+ int timeout = 1024;
+ u16 val;
+
/* see "Pipe n Control Register" - "PID" */
__usbhsp_pid_try_nak_if_stall(pipe);
usbhsp_pipectrl_set(pipe, PID_MASK, PID_NAK);
+
+ do {
+ val = usbhsp_pipectrl_get(pipe);
+ val &= PBUSY;
+ if (!val)
+ break;
+
+ udelay(10);
+ } while (timeout--);
}
void usbhs_fifo_enable(struct usbhs_pipe *pipe)