From: Haiyang Zhang Date: Thu, 1 Sep 2011 19:19:45 +0000 (-0700) Subject: staging: hv: fix counting of available buffer slots when send fails X-Git-Tag: v3.2-rc1~169^2^2~758 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=8a5f9edc4dd6c1f9fb2446a36e7cd44b79412271;p=users%2Fhch%2Fmisc.git staging: hv: fix counting of available buffer slots when send fails Because the number of available buffer slots doesn't decrease for failed sends, we should not call netvsc_xmit_completion(), which increase the count of available slots. In this failed case, just free the memory is enough. Signed-off-by: Haiyang Zhang Signed-off-by: K. Y. Srinivasan Signed-off-by: Greg Kroah-Hartman --- diff --git a/drivers/staging/hv/netvsc_drv.c b/drivers/staging/hv/netvsc_drv.c index b49a08f4ed5a..81e3c496e28e 100644 --- a/drivers/staging/hv/netvsc_drv.c +++ b/drivers/staging/hv/netvsc_drv.c @@ -190,7 +190,8 @@ static int netvsc_start_xmit(struct sk_buff *skb, struct net_device *net) } else { /* we are shutting down or bus overloaded, just drop packet */ net->stats.tx_dropped++; - netvsc_xmit_completion(packet); + kfree(packet); + dev_kfree_skb_any(skb); } return NETDEV_TX_OK;