net: bcmgenet: Ensure all TX/RX queues DMAs are disabled
commit 2b452550a203d88112eaf0ba9fc4b750a000b496 upstream.
Make sure that we disable each of the TX and RX queues in the TDMA and
RDMA control registers. This is a correctness change to be symmetrical
with the code that enables the TX and RX queues.
Tested-by: Maxime Ripard <maxime@cerno.tech>
Fixes: 1c1008c793
("net: bcmgenet: add main driver file")
Signed-off-by: Florian Fainelli <f.fainelli@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:

committed by
Greg Kroah-Hartman

parent
b9fa66072f
commit
846829e75d
@@ -3238,15 +3238,21 @@ static void bcmgenet_get_hw_addr(struct bcmgenet_priv *priv,
|
|||||||
/* Returns a reusable dma control register value */
|
/* Returns a reusable dma control register value */
|
||||||
static u32 bcmgenet_dma_disable(struct bcmgenet_priv *priv)
|
static u32 bcmgenet_dma_disable(struct bcmgenet_priv *priv)
|
||||||
{
|
{
|
||||||
|
unsigned int i;
|
||||||
u32 reg;
|
u32 reg;
|
||||||
u32 dma_ctrl;
|
u32 dma_ctrl;
|
||||||
|
|
||||||
/* disable DMA */
|
/* disable DMA */
|
||||||
dma_ctrl = 1 << (DESC_INDEX + DMA_RING_BUF_EN_SHIFT) | DMA_EN;
|
dma_ctrl = 1 << (DESC_INDEX + DMA_RING_BUF_EN_SHIFT) | DMA_EN;
|
||||||
|
for (i = 0; i < priv->hw_params->tx_queues; i++)
|
||||||
|
dma_ctrl |= (1 << (i + DMA_RING_BUF_EN_SHIFT));
|
||||||
reg = bcmgenet_tdma_readl(priv, DMA_CTRL);
|
reg = bcmgenet_tdma_readl(priv, DMA_CTRL);
|
||||||
reg &= ~dma_ctrl;
|
reg &= ~dma_ctrl;
|
||||||
bcmgenet_tdma_writel(priv, reg, DMA_CTRL);
|
bcmgenet_tdma_writel(priv, reg, DMA_CTRL);
|
||||||
|
|
||||||
|
dma_ctrl = 1 << (DESC_INDEX + DMA_RING_BUF_EN_SHIFT) | DMA_EN;
|
||||||
|
for (i = 0; i < priv->hw_params->rx_queues; i++)
|
||||||
|
dma_ctrl |= (1 << (i + DMA_RING_BUF_EN_SHIFT));
|
||||||
reg = bcmgenet_rdma_readl(priv, DMA_CTRL);
|
reg = bcmgenet_rdma_readl(priv, DMA_CTRL);
|
||||||
reg &= ~dma_ctrl;
|
reg &= ~dma_ctrl;
|
||||||
bcmgenet_rdma_writel(priv, reg, DMA_CTRL);
|
bcmgenet_rdma_writel(priv, reg, DMA_CTRL);
|
||||||
|
Reference in New Issue
Block a user