usb: musb: cppi_dma: Clean up cppi structure
authorAlexandre Bailon <abailon@baylibre.com>
Tue, 7 Feb 2017 04:53:53 +0000 (22:53 -0600)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 9 Feb 2017 12:35:05 +0000 (13:35 +0100)
A pointer to musb is now present in the dma_controller structure.
Remove the one present in cppi structure.

Signed-off-by: Alexandre Bailon <abailon@baylibre.com>
Signed-off-by: Bin Liu <b-liu@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/usb/musb/cppi_dma.c
drivers/usb/musb/cppi_dma.h

index 1ae48e64e975867a6eb03afffa92260319595b06..c4fabe952ca6a34dd3cb5c1f938e9ecc80c470ba 100644 (file)
@@ -224,7 +224,7 @@ static void cppi_controller_stop(struct cppi *controller)
        int                     i;
        struct musb             *musb;
 
-       musb = controller->musb;
+       musb = controller->controller.musb;
 
        tibase = controller->tibase;
        /* DISABLE INDIVIDUAL CHANNEL Interrupts */
@@ -288,7 +288,7 @@ cppi_channel_allocate(struct dma_controller *c,
 
        controller = container_of(c, struct cppi, controller);
        tibase = controller->tibase;
-       musb = controller->musb;
+       musb = c->musb;
 
        /* ep0 doesn't use DMA; remember cppi indices are 0..N-1 */
        index = ep->epnum - 1;
@@ -336,7 +336,7 @@ static void cppi_channel_release(struct dma_channel *channel)
        c = container_of(channel, struct cppi_channel, channel);
        tibase = c->controller->tibase;
        if (!c->hw_ep)
-               musb_dbg(c->controller->musb,
+               musb_dbg(c->controller->controller.musb,
                        "releasing idle DMA channel %p", c);
        else if (!c->transmit)
                core_rxirq_enable(tibase, c->index + 1);
@@ -355,7 +355,7 @@ cppi_dump_rx(int level, struct cppi_channel *c, const char *tag)
 
        musb_ep_select(base, c->index + 1);
 
-       musb_dbg(c->controller->musb,
+       musb_dbg(c->controller->controller.musb,
                "RX DMA%d%s: %d left, csr %04x, "
                "%08x H%08x S%08x C%08x, "
                "B%08x L%08x %08x .. %08x",
@@ -385,7 +385,7 @@ cppi_dump_tx(int level, struct cppi_channel *c, const char *tag)
 
        musb_ep_select(base, c->index + 1);
 
-       musb_dbg(c->controller->musb,
+       musb_dbg(c->controller->controller.musb,
                "TX DMA%d%s: csr %04x, "
                "H%08x S%08x C%08x %08x, "
                "F%08x L%08x .. %08x",
@@ -954,7 +954,7 @@ static int cppi_channel_program(struct dma_channel *ch,
 
        cppi_ch = container_of(ch, struct cppi_channel, channel);
        controller = cppi_ch->controller;
-       musb = controller->musb;
+       musb = controller->controller.musb;
 
        switch (ch->status) {
        case MUSB_DMA_STATUS_BUS_ABORT:
@@ -1009,7 +1009,7 @@ static bool cppi_rx_scan(struct cppi *cppi, unsigned ch)
        int                             i;
        dma_addr_t                      safe2ack;
        void __iomem                    *regs = rx->hw_ep->regs;
-       struct musb                     *musb = cppi->musb;
+       struct musb                     *musb = cppi->controller.musb;
 
        cppi_dump_rx(6, rx, "/K");
 
@@ -1121,7 +1121,7 @@ static bool cppi_rx_scan(struct cppi *cppi, unsigned ch)
                 * setting it here "should" be racey, but seems to work
                 */
                csr = musb_readw(rx->hw_ep->regs, MUSB_RXCSR);
-               if (is_host_active(cppi->musb)
+               if (is_host_active(cppi->controller.musb)
                                && bd
                                && !(csr & MUSB_RXCSR_H_REQPKT)) {
                        csr |= MUSB_RXCSR_H_REQPKT;
@@ -1311,7 +1311,7 @@ cppi_dma_controller_create(struct musb *musb, void __iomem *mregs)
        controller->mregs = mregs;
        controller->tibase = mregs - DAVINCI_BASE_OFFSET;
 
-       controller->musb = musb;
+       controller->controller.musb = musb;
        controller->controller.channel_alloc = cppi_channel_allocate;
        controller->controller.channel_release = cppi_channel_release;
        controller->controller.channel_program = cppi_channel_program;
@@ -1323,7 +1323,7 @@ cppi_dma_controller_create(struct musb *musb, void __iomem *mregs)
 
        /* setup BufferPool */
        controller->pool = dma_pool_create("cppi",
-                       controller->musb->controller,
+                       controller->controller.musb->controller,
                        sizeof(struct cppi_descriptor),
                        CPPI_DESCRIPTOR_ALIGN, 0);
        if (!controller->pool) {
@@ -1357,7 +1357,7 @@ void cppi_dma_controller_destroy(struct dma_controller *c)
        cppi_controller_stop(cppi);
 
        if (cppi->irq)
-               free_irq(cppi->irq, cppi->musb);
+               free_irq(cppi->irq, cppi->controller.musb);
 
        /* assert:  caller stopped the controller first */
        dma_pool_destroy(cppi->pool);
@@ -1469,7 +1469,7 @@ static int cppi_channel_abort(struct dma_channel *channel)
                core_rxirq_disable(tibase, cppi_ch->index + 1);
 
                /* for host, ensure ReqPkt is never set again */
-               if (is_host_active(cppi_ch->controller->musb)) {
+               if (is_host_active(cppi_ch->controller->controller.musb)) {
                        value = musb_readl(tibase, DAVINCI_AUTOREQ_REG);
                        value &= ~((0x3) << (cppi_ch->index * 2));
                        musb_writel(tibase, DAVINCI_AUTOREQ_REG, value);
@@ -1478,7 +1478,7 @@ static int cppi_channel_abort(struct dma_channel *channel)
                csr = musb_readw(regs, MUSB_RXCSR);
 
                /* for host, clear (just) ReqPkt at end of current packet(s) */
-               if (is_host_active(cppi_ch->controller->musb)) {
+               if (is_host_active(cppi_ch->controller->controller.musb)) {
                        csr |= MUSB_RXCSR_H_WZC_BITS;
                        csr &= ~MUSB_RXCSR_H_REQPKT;
                } else
index 7fdfb71a8f098357de798c2937724e7beebb4d71..9bb7c5e45c85fc547b870c44bfbb0e37f434086c 100644 (file)
@@ -107,7 +107,6 @@ struct cppi_channel {
 /* CPPI DMA controller object */
 struct cppi {
        struct dma_controller           controller;
-       struct musb                     *musb;
        void __iomem                    *mregs;         /* Mentor regs */
        void __iomem                    *tibase;        /* TI/CPPI regs */