diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/net/ethernet/broadcom/tg3.c | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/drivers/net/ethernet/broadcom/tg3.c b/drivers/net/ethernet/broadcom/tg3.c index ba499489969a..dbb41c1923e6 100644 --- a/drivers/net/ethernet/broadcom/tg3.c +++ b/drivers/net/ethernet/broadcom/tg3.c | |||
@@ -8099,9 +8099,6 @@ static netdev_tx_t tg3_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
8099 | /* Sync BD data before updating mailbox */ | 8099 | /* Sync BD data before updating mailbox */ |
8100 | wmb(); | 8100 | wmb(); |
8101 | 8101 | ||
8102 | /* Packets are ready, update Tx producer idx local and on card. */ | ||
8103 | tw32_tx_mbox(tnapi->prodmbox, entry); | ||
8104 | |||
8105 | tnapi->tx_prod = entry; | 8102 | tnapi->tx_prod = entry; |
8106 | if (unlikely(tg3_tx_avail(tnapi) <= (MAX_SKB_FRAGS + 1))) { | 8103 | if (unlikely(tg3_tx_avail(tnapi) <= (MAX_SKB_FRAGS + 1))) { |
8107 | netif_tx_stop_queue(txq); | 8104 | netif_tx_stop_queue(txq); |
@@ -8116,7 +8113,12 @@ static netdev_tx_t tg3_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
8116 | netif_tx_wake_queue(txq); | 8113 | netif_tx_wake_queue(txq); |
8117 | } | 8114 | } |
8118 | 8115 | ||
8119 | mmiowb(); | 8116 | if (!skb->xmit_more || netif_xmit_stopped(txq)) { |
8117 | /* Packets are ready, update Tx producer idx on card. */ | ||
8118 | tw32_tx_mbox(tnapi->prodmbox, entry); | ||
8119 | mmiowb(); | ||
8120 | } | ||
8121 | |||
8120 | return NETDEV_TX_OK; | 8122 | return NETDEV_TX_OK; |
8121 | 8123 | ||
8122 | dma_error: | 8124 | dma_error: |