|
@@ -1160,6 +1160,24 @@ static void usbhsf_dma_complete(void *arg)
|
|
|
usbhs_pipe_number(pipe), ret);
|
|
|
}
|
|
|
|
|
|
+void usbhs_fifo_clear_dcp(struct usbhs_pipe *pipe)
|
|
|
+{
|
|
|
+ struct usbhs_priv *priv = usbhs_pipe_to_priv(pipe);
|
|
|
+ struct usbhs_fifo *fifo = usbhsf_get_cfifo(priv); /* CFIFO */
|
|
|
+
|
|
|
+ /* clear DCP FIFO of transmission */
|
|
|
+ if (usbhsf_fifo_select(pipe, fifo, 1) < 0)
|
|
|
+ return;
|
|
|
+ usbhsf_fifo_clear(pipe, fifo);
|
|
|
+ usbhsf_fifo_unselect(pipe, fifo);
|
|
|
+
|
|
|
+ /* clear DCP FIFO of reception */
|
|
|
+ if (usbhsf_fifo_select(pipe, fifo, 0) < 0)
|
|
|
+ return;
|
|
|
+ usbhsf_fifo_clear(pipe, fifo);
|
|
|
+ usbhsf_fifo_unselect(pipe, fifo);
|
|
|
+}
|
|
|
+
|
|
|
/*
|
|
|
* fifo init
|
|
|
*/
|