Commit bfa53e0e authored by Alexandre Bailon's avatar Alexandre Bailon Committed by Greg Kroah-Hartman

usb: musb: musb_cppi41: Fix the address of teardown and autoreq registers

The DA8xx and DSPS platforms don't use the same address for few registers.
On Da8xx, this is causing some issues (e.g. teardown that doesn't work).
Configure the address of the register during the init and use them instead
of constants.

Cc: stable@vger.kernel.org  # v4.12+
Reported-by: nsekhar@ti.com
Signed-off-by: default avatarAlexandre Bailon <abailon@baylibre.com>
Tested-by: default avatarSekhar Nori <nsekhar@ti.com>
Signed-off-by: default avatarBin Liu <b-liu@ti.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 0c3aae9b
...@@ -26,6 +26,9 @@ ...@@ -26,6 +26,9 @@
#define MUSB_DMA_NUM_CHANNELS 15 #define MUSB_DMA_NUM_CHANNELS 15
#define DA8XX_USB_AUTOREQ 0x14
#define DA8XX_USB_TEARDOWN 0x1c
struct cppi41_dma_controller { struct cppi41_dma_controller {
struct dma_controller controller; struct dma_controller controller;
struct cppi41_dma_channel rx_channel[MUSB_DMA_NUM_CHANNELS]; struct cppi41_dma_channel rx_channel[MUSB_DMA_NUM_CHANNELS];
...@@ -35,6 +38,9 @@ struct cppi41_dma_controller { ...@@ -35,6 +38,9 @@ struct cppi41_dma_controller {
u32 rx_mode; u32 rx_mode;
u32 tx_mode; u32 tx_mode;
u32 auto_req; u32 auto_req;
u32 tdown_reg;
u32 autoreq_reg;
}; };
static void save_rx_toggle(struct cppi41_dma_channel *cppi41_channel) static void save_rx_toggle(struct cppi41_dma_channel *cppi41_channel)
...@@ -364,8 +370,8 @@ static void cppi41_set_autoreq_mode(struct cppi41_dma_channel *cppi41_channel, ...@@ -364,8 +370,8 @@ static void cppi41_set_autoreq_mode(struct cppi41_dma_channel *cppi41_channel,
if (new_mode == old_mode) if (new_mode == old_mode)
return; return;
controller->auto_req = new_mode; controller->auto_req = new_mode;
musb_writel(controller->controller.musb->ctrl_base, USB_CTRL_AUTOREQ, musb_writel(controller->controller.musb->ctrl_base,
new_mode); controller->autoreq_reg, new_mode);
} }
static bool cppi41_configure_channel(struct dma_channel *channel, static bool cppi41_configure_channel(struct dma_channel *channel,
...@@ -581,12 +587,13 @@ static int cppi41_dma_channel_abort(struct dma_channel *channel) ...@@ -581,12 +587,13 @@ static int cppi41_dma_channel_abort(struct dma_channel *channel)
do { do {
if (is_tx) if (is_tx)
musb_writel(musb->ctrl_base, USB_TDOWN, tdbit); musb_writel(musb->ctrl_base, controller->tdown_reg,
tdbit);
ret = dmaengine_terminate_all(cppi41_channel->dc); ret = dmaengine_terminate_all(cppi41_channel->dc);
} while (ret == -EAGAIN); } while (ret == -EAGAIN);
if (is_tx) { if (is_tx) {
musb_writel(musb->ctrl_base, USB_TDOWN, tdbit); musb_writel(musb->ctrl_base, controller->tdown_reg, tdbit);
csr = musb_readw(epio, MUSB_TXCSR); csr = musb_readw(epio, MUSB_TXCSR);
if (csr & MUSB_TXCSR_TXPKTRDY) { if (csr & MUSB_TXCSR_TXPKTRDY) {
...@@ -727,6 +734,14 @@ cppi41_dma_controller_create(struct musb *musb, void __iomem *base) ...@@ -727,6 +734,14 @@ cppi41_dma_controller_create(struct musb *musb, void __iomem *base)
controller->controller.is_compatible = cppi41_is_compatible; controller->controller.is_compatible = cppi41_is_compatible;
controller->controller.musb = musb; controller->controller.musb = musb;
if (musb->io.quirks & MUSB_DA8XX) {
controller->tdown_reg = DA8XX_USB_TEARDOWN;
controller->autoreq_reg = DA8XX_USB_AUTOREQ;
} else {
controller->tdown_reg = USB_TDOWN;
controller->autoreq_reg = USB_CTRL_AUTOREQ;
}
ret = cppi41_dma_controller_start(controller); ret = cppi41_dma_controller_start(controller);
if (ret) if (ret)
goto plat_get_fail; goto plat_get_fail;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment