drivers: net: ethernet: davinci_emac: use netif_wake_queue() while restarting tx...
authorMugunthan V N <mugunthanvnm@ti.com>
Wed, 27 Mar 2013 04:42:00 +0000 (04:42 +0000)
committerBen Hutchings <ben@decadent.org.uk>
Wed, 10 Apr 2013 02:20:13 +0000 (03:20 +0100)
commit 7e51cde276ca820d526c6c21cf8147df595a36bf upstream.

To restart tx queue use netif_wake_queue() intead of netif_start_queue()
so that net schedule will restart transmission immediately which will
increase network performance while doing huge data transfers.

Reported-by: Dan Franke <dan.franke@schneider-electric.com>
Suggested-by: Sriramakrishnan A G <srk@ti.com>
Signed-off-by: Mugunthan V N <mugunthanvnm@ti.com>
Acked-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
drivers/net/ethernet/ti/davinci_emac.c

index 22f2788..fd8115e 100644 (file)
@@ -1048,7 +1048,7 @@ static void emac_tx_handler(void *token, int len, int status)
        struct net_device       *ndev = skb->dev;
 
        if (unlikely(netif_queue_stopped(ndev)))
-               netif_start_queue(ndev);
+               netif_wake_queue(ndev);
        ndev->stats.tx_packets++;
        ndev->stats.tx_bytes += len;
        dev_kfree_skb_any(skb);