usb: musb: cppi_dma: Clean up cppi structure
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>
This commit is contained in:
parent
ed232c0b4b
commit
03158f9015
|
@ -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
|
||||
|
|
|
@ -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 */
|
||||
|
||||
|
|
Loading…
Reference in New Issue
Block a user