aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
Diffstat (limited to 'net')
-rw-r--r--net/mac80211/tx.c23
1 files changed, 6 insertions, 17 deletions
diff --git a/net/mac80211/tx.c b/net/mac80211/tx.c
index 2d2f45ecca4d..3b807bcb8fc9 100644
--- a/net/mac80211/tx.c
+++ b/net/mac80211/tx.c
@@ -1719,7 +1719,7 @@ netdev_tx_t ieee80211_subif_start_xmit(struct sk_buff *skb,
1719 struct ieee80211_sub_if_data *sdata = IEEE80211_DEV_TO_SUB_IF(dev); 1719 struct ieee80211_sub_if_data *sdata = IEEE80211_DEV_TO_SUB_IF(dev);
1720 struct ieee80211_local *local = sdata->local; 1720 struct ieee80211_local *local = sdata->local;
1721 struct ieee80211_tx_info *info; 1721 struct ieee80211_tx_info *info;
1722 int ret = NETDEV_TX_BUSY, head_need; 1722 int head_need;
1723 u16 ethertype, hdrlen, meshhdrlen = 0; 1723 u16 ethertype, hdrlen, meshhdrlen = 0;
1724 __le16 fc; 1724 __le16 fc;
1725 struct ieee80211_hdr hdr; 1725 struct ieee80211_hdr hdr;
@@ -1735,10 +1735,8 @@ netdev_tx_t ieee80211_subif_start_xmit(struct sk_buff *skb,
1735 u32 info_flags = 0; 1735 u32 info_flags = 0;
1736 u16 info_id = 0; 1736 u16 info_id = 0;
1737 1737
1738 if (unlikely(skb->len < ETH_HLEN)) { 1738 if (unlikely(skb->len < ETH_HLEN))
1739 ret = NETDEV_TX_OK;
1740 goto fail; 1739 goto fail;
1741 }
1742 1740
1743 /* convert Ethernet header to proper 802.11 header (based on 1741 /* convert Ethernet header to proper 802.11 header (based on
1744 * operation mode) */ 1742 * operation mode) */
@@ -1786,7 +1784,6 @@ netdev_tx_t ieee80211_subif_start_xmit(struct sk_buff *skb,
1786 if (!sdata->u.mesh.mshcfg.dot11MeshTTL) { 1784 if (!sdata->u.mesh.mshcfg.dot11MeshTTL) {
1787 /* Do not send frames with mesh_ttl == 0 */ 1785 /* Do not send frames with mesh_ttl == 0 */
1788 sdata->u.mesh.mshstats.dropped_frames_ttl++; 1786 sdata->u.mesh.mshstats.dropped_frames_ttl++;
1789 ret = NETDEV_TX_OK;
1790 goto fail; 1787 goto fail;
1791 } 1788 }
1792 rcu_read_lock(); 1789 rcu_read_lock();
@@ -1879,10 +1876,8 @@ netdev_tx_t ieee80211_subif_start_xmit(struct sk_buff *skb,
1879 1876
1880 if (tdls_direct) { 1877 if (tdls_direct) {
1881 /* link during setup - throw out frames to peer */ 1878 /* link during setup - throw out frames to peer */
1882 if (!tdls_auth) { 1879 if (!tdls_auth)
1883 ret = NETDEV_TX_OK;
1884 goto fail; 1880 goto fail;
1885 }
1886 1881
1887 /* DA SA BSSID */ 1882 /* DA SA BSSID */
1888 memcpy(hdr.addr1, skb->data, ETH_ALEN); 1883 memcpy(hdr.addr1, skb->data, ETH_ALEN);
@@ -1916,7 +1911,6 @@ netdev_tx_t ieee80211_subif_start_xmit(struct sk_buff *skb,
1916 hdrlen = 24; 1911 hdrlen = 24;
1917 break; 1912 break;
1918 default: 1913 default:
1919 ret = NETDEV_TX_OK;
1920 goto fail; 1914 goto fail;
1921 } 1915 }
1922 1916
@@ -1961,7 +1955,6 @@ netdev_tx_t ieee80211_subif_start_xmit(struct sk_buff *skb,
1961 1955
1962 I802_DEBUG_INC(local->tx_handlers_drop_unauth_port); 1956 I802_DEBUG_INC(local->tx_handlers_drop_unauth_port);
1963 1957
1964 ret = NETDEV_TX_OK;
1965 goto fail; 1958 goto fail;
1966 } 1959 }
1967 1960
@@ -2016,10 +2009,8 @@ netdev_tx_t ieee80211_subif_start_xmit(struct sk_buff *skb,
2016 skb = skb_clone(skb, GFP_ATOMIC); 2009 skb = skb_clone(skb, GFP_ATOMIC);
2017 kfree_skb(tmp_skb); 2010 kfree_skb(tmp_skb);
2018 2011
2019 if (!skb) { 2012 if (!skb)
2020 ret = NETDEV_TX_OK;
2021 goto fail; 2013 goto fail;
2022 }
2023 } 2014 }
2024 2015
2025 hdr.frame_control = fc; 2016 hdr.frame_control = fc;
@@ -2122,10 +2113,8 @@ netdev_tx_t ieee80211_subif_start_xmit(struct sk_buff *skb,
2122 return NETDEV_TX_OK; 2113 return NETDEV_TX_OK;
2123 2114
2124 fail: 2115 fail:
2125 if (ret == NETDEV_TX_OK) 2116 dev_kfree_skb(skb);
2126 dev_kfree_skb(skb); 2117 return NETDEV_TX_OK;
2127
2128 return ret;
2129} 2118}
2130 2119
2131 2120