This patch removes dev->gso_skb as it is no longer necessary with
batching code.

cheers,
jamal


[NET_SCHED] kill dev->gso_skb
The batching code does what gso used to batch at the drivers.
There is no more need for gso_skb. If for whatever reason the
requeueing is a bad idea we are going to leave packets in dev->blist
(and still not need dev->gso_skb)

Signed-off-by: Jamal Hadi Salim <[EMAIL PROTECTED]>

---
commit c2916c550d228472ddcdd676c2689fa6c8ecfcc0
tree 5beaf197fd08a038d83501f405017f48712d0318
parent 9b4a8fb190278d388c0a622fb5529d184ac8c7dc
author Jamal Hadi Salim <[EMAIL PROTECTED]> Sun, 30 Sep 2007 14:38:58 -0400
committer Jamal Hadi Salim <[EMAIL PROTECTED]> Sun, 30 Sep 2007 14:38:58 -0400

 include/linux/netdevice.h |    3 ---
 net/sched/sch_generic.c   |   12 ------------
 2 files changed, 0 insertions(+), 15 deletions(-)

diff --git a/include/linux/netdevice.h b/include/linux/netdevice.h
index df1fb61..cea400a 100644
--- a/include/linux/netdevice.h
+++ b/include/linux/netdevice.h
@@ -577,9 +577,6 @@ struct net_device
        struct list_head        qdisc_list;
        unsigned long           tx_queue_len;   /* Max frames per queue allowed 
*/
 
-       /* Partially transmitted GSO packet. */
-       struct sk_buff          *gso_skb;
-
        /* ingress path synchronizer */
        spinlock_t              ingress_lock;
        struct Qdisc            *qdisc_ingress;
diff --git a/net/sched/sch_generic.c b/net/sched/sch_generic.c
index 86a3f9d..b4e1607 100644
--- a/net/sched/sch_generic.c
+++ b/net/sched/sch_generic.c
@@ -172,13 +172,6 @@ static int xmit_get_pkts(struct net_device *dev,
        struct sk_buff *skb;
        int count = dev->xmit_win;
 
-       if (count  && dev->gso_skb) {
-               skb = dev->gso_skb;
-               dev->gso_skb = NULL;
-               count -= xmit_count_skbs(skb);
-               __skb_queue_tail(pktlist, skb);
-       }
-
        while (count > 0) {
                skb = q->dequeue(q);
                if (!skb)
@@ -654,7 +647,6 @@ void dev_activate(struct net_device *dev)
 void dev_deactivate(struct net_device *dev)
 {
        struct Qdisc *qdisc;
-       struct sk_buff *skb;
 
        spin_lock_bh(&dev->queue_lock);
        qdisc = dev->qdisc;
@@ -662,15 +654,11 @@ void dev_deactivate(struct net_device *dev)
 
        qdisc_reset(qdisc);
 
-       skb = dev->gso_skb;
-       dev->gso_skb = NULL;
        if (!skb_queue_empty(&dev->blist))
                skb_queue_purge(&dev->blist);
        dev->xmit_win = 1;
        spin_unlock_bh(&dev->queue_lock);
 
-       kfree_skb(skb);
-
        dev_watchdog_down(dev);
 
        /* Wait for outstanding dev_queue_xmit calls. */

Reply via email to