ppp: Fix race condition with queue start/stop
[deliverable/linux.git] / drivers / net / ppp / ppp_generic.c
index 159da2905fe979dbdf03a4c065b72ed75ea9592c..21d7151fb0ab3ea03c93208cf6d0c2749d1b825b 100644 (file)
@@ -968,7 +968,6 @@ ppp_start_xmit(struct sk_buff *skb, struct net_device *dev)
        proto = npindex_to_proto[npi];
        put_unaligned_be16(proto, pp);
 
-       netif_stop_queue(dev);
        skb_queue_tail(&ppp->file.xq, skb);
        ppp_xmit_process(ppp);
        return NETDEV_TX_OK;
@@ -1063,6 +1062,8 @@ ppp_xmit_process(struct ppp *ppp)
                   code that we can accept some more. */
                if (!ppp->xmit_pending && !skb_peek(&ppp->file.xq))
                        netif_wake_queue(ppp->dev);
+               else
+                       netif_stop_queue(ppp->dev);
        }
        ppp_xmit_unlock(ppp);
 }
This page took 0.029638 seconds and 5 git commands to generate.