OSDN Git Service

usb: musb: core: add clear_ep_rxintr() to musb_platform_ops
authorBin Liu <b-liu@ti.com>
Wed, 4 Jan 2017 00:13:46 +0000 (18:13 -0600)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 12 Jan 2017 10:39:09 +0000 (11:39 +0100)
commit5de2dd7f1be18c1ee72c4aa4aeccb191982c1e7c
tree8c5d1174956a83249f3bf79a799ebe02ed623806
parent84fd8feb5bb50508ba336c7eaf2f377e0b241521
usb: musb: core: add clear_ep_rxintr() to musb_platform_ops

commit 6def85a396ce7796bd9f4561c6ae8138833f7a52 upstream.

During dma teardown for dequque urb, if musb load is high, musb might
generate bogus rx ep interrupt even when the rx fifo is flushed. In such
case any of the follow log messages could happen.

musb_host_rx 1853: BOGUS RX2 ready, csr 0000, count 0

musb_host_rx 1936: RX3 dma busy, csr 2020

As mentioned in the current inline comment, clearing ep interrupt in the
teardown path avoids the bogus interrupt.

Clearing ep interrupt is platform dependent, so this patch adds a
platform callback to allow glue driver to clear the ep interrupt.

This bug seems to be existing since the initial driver for musb support,
but I only validated the fix back to v4.1, so only cc stable for v4.1+.

Signed-off-by: Bin Liu <b-liu@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/usb/musb/musb_core.h
drivers/usb/musb/musb_host.c