summaryrefslogtreecommitdiff
path: root/package/madwifi/patches/372-queue_vif.patch
blob: f6903ea2af7cc6c67e6d07578da3d3cdd7e80e3a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
--- a/net80211/ieee80211_input.c
+++ b/net80211/ieee80211_input.c
@@ -1201,6 +1201,7 @@
 		}
 		if (skb1 != NULL) {
 			struct ieee80211_node *ni_tmp;
+			int ret;
 			skb1->dev = dev;
 			skb_reset_mac_header(skb1);
 			skb_set_network_header(skb1, sizeof(struct ether_header));
@@ -1208,7 +1209,12 @@
 			skb1->protocol = __constant_htons(ETH_P_802_2);
 			/* XXX insert vlan tag before queue it? */
 			ni_tmp = SKB_CB(skb1)->ni; /* remember node so we can free it */
-			if (dev_queue_xmit(skb1) == NET_XMIT_DROP) {
+			ret = dev->hard_start_xmit(skb1, dev);
+
+			if (ret == NETDEV_TX_BUSY)
+				ieee80211_dev_kfree_skb(&skb1);
+
+			if (ret != NETDEV_TX_OK) {
 				/* If queue dropped the packet because device was
 				 * too busy */
 				vap->iv_devstats.tx_dropped++;
--- a/net80211/ieee80211_output.c
+++ b/net80211/ieee80211_output.c
@@ -333,9 +333,10 @@
 	/* Dispatch the packet to the parent device */
 	skb->dev = vap->iv_ic->ic_dev;
 
-	if (dev_queue_xmit(skb) == NET_XMIT_DROP)
+	if (netif_queue_stopped(skb->dev))
+		ieee80211_dev_kfree_skb(&skb);
+	else if (dev_queue_xmit(skb) == NET_XMIT_DROP)
 		vap->iv_devstats.tx_dropped++;
-
 }
 
 /*