serial: sh-sci: Extract sci_dma_rx_chan_invalidate()
The cookies and channel pointer for the DMA receive channel are invalidated in two places, and one more is planned. Extract this functionality in a common helper. Signed-off-by: Geert Uytterhoeven <geert+renesas@glider.be> Reviewed-by: Simon Horman <horms+renesas@verge.net.au> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
833954a4e3
commit
11b3770d54
|
@ -1243,12 +1243,22 @@ static int sci_dma_rx_find_active(struct sci_port *s)
|
|||
return -1;
|
||||
}
|
||||
|
||||
static void sci_dma_rx_chan_invalidate(struct sci_port *s)
|
||||
{
|
||||
unsigned int i;
|
||||
|
||||
s->chan_rx = NULL;
|
||||
for (i = 0; i < ARRAY_SIZE(s->cookie_rx); i++)
|
||||
s->cookie_rx[i] = -EINVAL;
|
||||
s->active_rx = 0;
|
||||
}
|
||||
|
||||
static void sci_rx_dma_release(struct sci_port *s)
|
||||
{
|
||||
struct dma_chan *chan = s->chan_rx_saved;
|
||||
|
||||
s->chan_rx_saved = s->chan_rx = NULL;
|
||||
s->cookie_rx[0] = s->cookie_rx[1] = -EINVAL;
|
||||
s->chan_rx_saved = NULL;
|
||||
sci_dma_rx_chan_invalidate(s);
|
||||
dmaengine_terminate_sync(chan);
|
||||
dma_free_coherent(chan->device->dev, s->buf_len_rx * 2, s->rx_buf[0],
|
||||
sg_dma_address(&s->sg_rx[0]));
|
||||
|
@ -1367,10 +1377,7 @@ fail:
|
|||
spin_lock_irqsave(&port->lock, flags);
|
||||
if (i)
|
||||
dmaengine_terminate_async(chan);
|
||||
for (i = 0; i < 2; i++)
|
||||
s->cookie_rx[i] = -EINVAL;
|
||||
s->active_rx = 0;
|
||||
s->chan_rx = NULL;
|
||||
sci_dma_rx_chan_invalidate(s);
|
||||
sci_start_rx(port);
|
||||
if (!port_lock_held)
|
||||
spin_unlock_irqrestore(&port->lock, flags);
|
||||
|
|
Loading…
Reference in New Issue