aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/ethernet/ti
diff options
context:
space:
mode:
authorMarkus Pargmann <mpa@pengutronix.de>2013-10-13 15:17:01 -0400
committerDavid S. Miller <davem@davemloft.net>2013-10-17 15:48:14 -0400
commitdbbd2ad89bb1f86b94b23bb2e56d4935717f9b94 (patch)
treec44747aa07f81d6eb8ff94e3bfc4c2972f40fd90 /drivers/net/ethernet/ti
parent60e66fee56b2256dcb1dc2ea1b2ddcb6e273857d (diff)
net/ethernet: cpsw: Bugfix interrupts before enabling napi
If interrupts happen before napi_enable was called, the driver will not work as expected. Network transmissions are impossible in this state. This bug can be reproduced easily by restarting the network interface in a loop. After some time any network transmissions on the network interface will fail. This patch fixes the bug by enabling napi before enabling the network interface interrupts. Signed-off-by: Markus Pargmann <mpa@pengutronix.de> Acked-by: Peter Korsgaard <jacmet@sunsite.dk> Acked-by: Mugunthan V N <mugunthanvnm@ti.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ethernet/ti')
-rw-r--r--drivers/net/ethernet/ti/cpsw.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/net/ethernet/ti/cpsw.c b/drivers/net/ethernet/ti/cpsw.c
index 804846eb5fc2..fccd9d4d4ae0 100644
--- a/drivers/net/ethernet/ti/cpsw.c
+++ b/drivers/net/ethernet/ti/cpsw.c
@@ -1169,9 +1169,9 @@ static int cpsw_ndo_open(struct net_device *ndev)
1169 } 1169 }
1170 } 1170 }
1171 1171
1172 napi_enable(&priv->napi);
1172 cpdma_ctlr_start(priv->dma); 1173 cpdma_ctlr_start(priv->dma);
1173 cpsw_intr_enable(priv); 1174 cpsw_intr_enable(priv);
1174 napi_enable(&priv->napi);
1175 cpdma_ctlr_eoi(priv->dma, CPDMA_EOI_RX); 1175 cpdma_ctlr_eoi(priv->dma, CPDMA_EOI_RX);
1176 cpdma_ctlr_eoi(priv->dma, CPDMA_EOI_TX); 1176 cpdma_ctlr_eoi(priv->dma, CPDMA_EOI_TX);
1177 1177