diff options
author | Sonic Zhang <sonic.zhang@analog.com> | 2015-01-30 00:49:32 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2015-02-02 02:14:24 -0500 |
commit | b2dec116fb9f3d8c7dd2e878fa1b9b88262985f7 (patch) | |
tree | 300096119db985fb0c103ed1d890520d595b7415 /drivers/net/ethernet/stmicro | |
parent | 3051fa617a3bb753185341a2040eaa454a54669e (diff) |
stmmac: DMA threshold mode or SF mode can be different among multiple device instance
- In tx_hard_error_bump_tc interrupt, tc should be bumped only when current
device instance is in DMA threshold mode. Check per device xstats.threshold
other than global tc.
- Set per device xstats.threshold to SF_DMA_MODE when current device
instance is set to SF mode.
v2-changes:
- fix ident style
Signed-off-by: Sonic Zhang <sonic.zhang@analog.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ethernet/stmicro')
-rw-r--r-- | drivers/net/ethernet/stmicro/stmmac/stmmac_main.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c index 9c11c4d0f3fd..55e89b3838f1 100644 --- a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c +++ b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c | |||
@@ -1288,7 +1288,7 @@ static void stmmac_dma_operation_mode(struct stmmac_priv *priv) | |||
1288 | * that needs to not insert csum in the TDES. | 1288 | * that needs to not insert csum in the TDES. |
1289 | */ | 1289 | */ |
1290 | priv->hw->dma->dma_mode(priv->ioaddr, SF_DMA_MODE, SF_DMA_MODE); | 1290 | priv->hw->dma->dma_mode(priv->ioaddr, SF_DMA_MODE, SF_DMA_MODE); |
1291 | tc = SF_DMA_MODE; | 1291 | priv->xstats.threshold = SF_DMA_MODE; |
1292 | } else | 1292 | } else |
1293 | priv->hw->dma->dma_mode(priv->ioaddr, tc, SF_DMA_MODE); | 1293 | priv->hw->dma->dma_mode(priv->ioaddr, tc, SF_DMA_MODE); |
1294 | } | 1294 | } |
@@ -1452,7 +1452,8 @@ static void stmmac_dma_interrupt(struct stmmac_priv *priv) | |||
1452 | } | 1452 | } |
1453 | if (unlikely(status & tx_hard_error_bump_tc)) { | 1453 | if (unlikely(status & tx_hard_error_bump_tc)) { |
1454 | /* Try to bump up the dma threshold on this failure */ | 1454 | /* Try to bump up the dma threshold on this failure */ |
1455 | if (unlikely(tc != SF_DMA_MODE) && (tc <= 256)) { | 1455 | if (unlikely(priv->xstats.threshold != SF_DMA_MODE) && |
1456 | (tc <= 256)) { | ||
1456 | tc += 64; | 1457 | tc += 64; |
1457 | if (priv->plat->force_thresh_dma_mode) | 1458 | if (priv->plat->force_thresh_dma_mode) |
1458 | priv->hw->dma->dma_mode(priv->ioaddr, tc, tc); | 1459 | priv->hw->dma->dma_mode(priv->ioaddr, tc, tc); |