serial: sh-sci: Extract sci_dma_rx_chan_invalidate()
[ Upstream commit 11b3770d54b28dcd905155a6d4aa551187ff00eb ] 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> Stable-dep-of: aae20f6e34cd ("serial: sh-sci: protect invalidating RXDMA on shutdown") Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
bc14bb3ef3
commit
82b6263b33
@ -1248,12 +1248,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]));
|
||||
@ -1372,10 +1382,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…
x
Reference in New Issue
Block a user