On Sun, 14 May 2006, David S. Miller wrote: > From: Andrew Morton <[EMAIL PROTECTED]> > Date: Sun, 14 May 2006 03:10:34 -0700 > > > It's a bit sad to be taking a clone of a clone like this. > > Avoidable? > > Besides, clones of clones are illegal, if it's already a clone > you must make a copy. >
Heres a new version which does a copy instead of the clone to avoid the double cloning issue. -Thanks, Ranjit --- linux-2.6/net/sched/sch_generic.c 2006-05-10 12:34:52.000000000 -0700 +++ linux/net/sched/sch_generic.c 2006-05-15 13:49:09.000000000 -0700 @@ -136,8 +136,11 @@ if (!netif_queue_stopped(dev)) { int ret; + struct sk_buff *skbc = NULL; + /* Copy the skb so that we can trace it after + * a successful transmit. */ if (netdev_nit) - dev_queue_xmit_nit(skb, dev); + skbc = skb_copy(skb, GFP_ATOMIC); ret = dev->hard_start_xmit(skb, dev); if (ret == NETDEV_TX_OK) { @@ -145,9 +148,20 @@ dev->xmit_lock_owner = -1; spin_unlock(&dev->xmit_lock); } + if (skbc) { + /* transmit succeeded, + * trace the copy. */ + dev_queue_xmit_nit(skbc,dev); + kfree_skb(skbc); + } spin_lock(&dev->queue_lock); return -1; } + + /* Free copy if it exists */ + if (skbc) + kfree_skb(skbc); + if (ret == NETDEV_TX_LOCKED && nolock) { spin_lock(&dev->queue_lock); goto collision; - To unsubscribe from this list: send the line "unsubscribe netdev" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html