diff options
Diffstat (limited to 'drivers/usb/renesas_usbhs/fifo.c')
| -rw-r--r-- | drivers/usb/renesas_usbhs/fifo.c | 21 | 
1 files changed, 18 insertions, 3 deletions
| diff --git a/drivers/usb/renesas_usbhs/fifo.c b/drivers/usb/renesas_usbhs/fifo.c index 36e5b5c530bd..d95cd1a72b66 100644 --- a/drivers/usb/renesas_usbhs/fifo.c +++ b/drivers/usb/renesas_usbhs/fifo.c @@ -285,11 +285,26 @@ static void usbhsf_fifo_clear(struct usbhs_pipe *pipe,  			      struct usbhs_fifo *fifo)  {  	struct usbhs_priv *priv = usbhs_pipe_to_priv(pipe); +	int ret = 0; -	if (!usbhs_pipe_is_dcp(pipe)) -		usbhsf_fifo_barrier(priv, fifo); +	if (!usbhs_pipe_is_dcp(pipe)) { +		/* +		 * This driver checks the pipe condition first to avoid -EBUSY +		 * from usbhsf_fifo_barrier() with about 10 msec delay in +		 * the interrupt handler if the pipe is RX direction and empty. +		 */ +		if (usbhs_pipe_is_dir_in(pipe)) +			ret = usbhs_pipe_is_accessible(pipe); +		if (!ret) +			ret = usbhsf_fifo_barrier(priv, fifo); +	} -	usbhs_write(priv, fifo->ctr, BCLR); +	/* +	 * if non-DCP pipe, this driver should set BCLR when +	 * usbhsf_fifo_barrier() returns 0. +	 */ +	if (!ret) +		usbhs_write(priv, fifo->ctr, BCLR);  }  static int usbhsf_fifo_rcv_len(struct usbhs_priv *priv, | 
