diff options
author | David S. Miller <davem@davemloft.net> | 2014-05-16 16:41:53 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2014-05-16 16:41:53 -0400 |
commit | e0a1272cfacd53ff99c768b9e09b64cfdd77159c (patch) | |
tree | 702e57caf0fe830c9de5366ebf08c862e0a28ef6 | |
parent | bd508065749fcaa99f6eca927530d0d7e019224f (diff) | |
parent | 00b91c693e9da851385eed8c9492ac0b0d4e4896 (diff) |
Merge branch 'systemport-next'
Florian Fainelli says:
====================
net: systemport: DMA and MAC fixes
This patch series contains a critical fix in how the DMA unmapping of packet
is done, as well as a less critical fix in how we disable the Ethernet MAC
RX/TX functions.
====================
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | drivers/net/ethernet/broadcom/bcmsysport.c | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/drivers/net/ethernet/broadcom/bcmsysport.c b/drivers/net/ethernet/broadcom/bcmsysport.c index 8edc0980cdf5..d40c5b969e9e 100644 --- a/drivers/net/ethernet/broadcom/bcmsysport.c +++ b/drivers/net/ethernet/broadcom/bcmsysport.c | |||
@@ -479,7 +479,7 @@ static unsigned int bcm_sysport_desc_rx(struct bcm_sysport_priv *priv, | |||
479 | cb = &priv->rx_cbs[priv->rx_read_ptr]; | 479 | cb = &priv->rx_cbs[priv->rx_read_ptr]; |
480 | skb = cb->skb; | 480 | skb = cb->skb; |
481 | dma_unmap_single(kdev, dma_unmap_addr(cb, dma_addr), | 481 | dma_unmap_single(kdev, dma_unmap_addr(cb, dma_addr), |
482 | dma_unmap_len(cb, dma_len), DMA_FROM_DEVICE); | 482 | RX_BUF_LENGTH, DMA_FROM_DEVICE); |
483 | 483 | ||
484 | /* Extract the Receive Status Block prepended */ | 484 | /* Extract the Receive Status Block prepended */ |
485 | rsb = (struct rsb *)skb->data; | 485 | rsb = (struct rsb *)skb->data; |
@@ -1244,6 +1244,12 @@ static inline void umac_enable_set(struct bcm_sysport_priv *priv, | |||
1244 | else | 1244 | else |
1245 | reg &= ~(CMD_RX_EN | CMD_TX_EN); | 1245 | reg &= ~(CMD_RX_EN | CMD_TX_EN); |
1246 | umac_writel(priv, reg, UMAC_CMD); | 1246 | umac_writel(priv, reg, UMAC_CMD); |
1247 | |||
1248 | /* UniMAC stops on a packet boundary, wait for a full-sized packet | ||
1249 | * to be processed (1 msec). | ||
1250 | */ | ||
1251 | if (enable == 0) | ||
1252 | usleep_range(1000, 2000); | ||
1247 | } | 1253 | } |
1248 | 1254 | ||
1249 | static inline int umac_reset(struct bcm_sysport_priv *priv) | 1255 | static inline int umac_reset(struct bcm_sysport_priv *priv) |