aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/mv643xx_eth.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/mv643xx_eth.c')
-rw-r--r--drivers/net/mv643xx_eth.c27
1 files changed, 8 insertions, 19 deletions
diff --git a/drivers/net/mv643xx_eth.c b/drivers/net/mv643xx_eth.c
index b4850cf2a8ce..bd3ca470916b 100644
--- a/drivers/net/mv643xx_eth.c
+++ b/drivers/net/mv643xx_eth.c
@@ -631,11 +631,9 @@ static int mv643xx_eth_poll(struct napi_struct *napi, int budget)
631 for (i = 0; i < mp->txq_count; i++) 631 for (i = 0; i < mp->txq_count; i++)
632 txq_reclaim(mp->txq + i, 0); 632 txq_reclaim(mp->txq + i, 0);
633 633
634 if (netif_carrier_ok(mp->dev)) { 634 spin_lock_irq(&mp->lock);
635 spin_lock_irq(&mp->lock); 635 __txq_maybe_wake(mp->txq);
636 __txq_maybe_wake(mp->txq); 636 spin_unlock_irq(&mp->lock);
637 spin_unlock_irq(&mp->lock);
638 }
639 } 637 }
640#endif 638#endif
641 639
@@ -1765,7 +1763,6 @@ static void handle_link_event(struct mv643xx_eth_private *mp)
1765 printk(KERN_INFO "%s: link down\n", dev->name); 1763 printk(KERN_INFO "%s: link down\n", dev->name);
1766 1764
1767 netif_carrier_off(dev); 1765 netif_carrier_off(dev);
1768 netif_stop_queue(dev);
1769 1766
1770 for (i = 0; i < mp->txq_count; i++) { 1767 for (i = 0; i < mp->txq_count; i++) {
1771 struct tx_queue *txq = mp->txq + i; 1768 struct tx_queue *txq = mp->txq + i;
@@ -1799,10 +1796,8 @@ static void handle_link_event(struct mv643xx_eth_private *mp)
1799 speed, duplex ? "full" : "half", 1796 speed, duplex ? "full" : "half",
1800 fc ? "en" : "dis"); 1797 fc ? "en" : "dis");
1801 1798
1802 if (!netif_carrier_ok(dev)) { 1799 if (!netif_carrier_ok(dev))
1803 netif_carrier_on(dev); 1800 netif_carrier_on(dev);
1804 netif_wake_queue(dev);
1805 }
1806} 1801}
1807 1802
1808static irqreturn_t mv643xx_eth_irq(int irq, void *dev_id) 1803static irqreturn_t mv643xx_eth_irq(int irq, void *dev_id)
@@ -1851,11 +1846,9 @@ static irqreturn_t mv643xx_eth_irq(int irq, void *dev_id)
1851 * Enough space again in the primary TX queue for a 1846 * Enough space again in the primary TX queue for a
1852 * full packet? 1847 * full packet?
1853 */ 1848 */
1854 if (netif_carrier_ok(dev)) { 1849 spin_lock(&mp->lock);
1855 spin_lock(&mp->lock); 1850 __txq_maybe_wake(mp->txq);
1856 __txq_maybe_wake(mp->txq); 1851 spin_unlock(&mp->lock);
1857 spin_unlock(&mp->lock);
1858 }
1859 } 1852 }
1860 1853
1861 /* 1854 /*
@@ -2060,7 +2053,6 @@ static int mv643xx_eth_open(struct net_device *dev)
2060 } 2053 }
2061 2054
2062 netif_carrier_off(dev); 2055 netif_carrier_off(dev);
2063 netif_stop_queue(dev);
2064 2056
2065 port_start(mp); 2057 port_start(mp);
2066 2058
@@ -2123,7 +2115,6 @@ static int mv643xx_eth_stop(struct net_device *dev)
2123 del_timer_sync(&mp->rx_oom); 2115 del_timer_sync(&mp->rx_oom);
2124 2116
2125 netif_carrier_off(dev); 2117 netif_carrier_off(dev);
2126 netif_stop_queue(dev);
2127 2118
2128 free_irq(dev->irq, dev); 2119 free_irq(dev->irq, dev);
2129 2120
@@ -2184,11 +2175,9 @@ static void tx_timeout_task(struct work_struct *ugly)
2184 mp = container_of(ugly, struct mv643xx_eth_private, tx_timeout_task); 2175 mp = container_of(ugly, struct mv643xx_eth_private, tx_timeout_task);
2185 if (netif_running(mp->dev)) { 2176 if (netif_running(mp->dev)) {
2186 netif_stop_queue(mp->dev); 2177 netif_stop_queue(mp->dev);
2187
2188 port_reset(mp); 2178 port_reset(mp);
2189 port_start(mp); 2179 port_start(mp);
2190 2180 netif_wake_queue(mp->dev);
2191 __txq_maybe_wake(mp->txq);
2192 } 2181 }
2193} 2182}
2194 2183