Commit 9deba04d authored by Arik Nemtsov's avatar Arik Nemtsov Committed by Johannes Berg

mac80211: clarify TDLS Tx handling

Rename the flags used in the Tx path and add an explanation for the
reasons to drop, send directly or through the AP.
Signed-off-by: default avatarArik Nemtsov <arikx.nemtsov@intel.com>
Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
parent a46992b4
...@@ -1811,7 +1811,7 @@ netdev_tx_t ieee80211_subif_start_xmit(struct sk_buff *skb, ...@@ -1811,7 +1811,7 @@ netdev_tx_t ieee80211_subif_start_xmit(struct sk_buff *skb,
int nh_pos, h_pos; int nh_pos, h_pos;
struct sta_info *sta = NULL; struct sta_info *sta = NULL;
bool wme_sta = false, authorized = false, tdls_auth = false; bool wme_sta = false, authorized = false, tdls_auth = false;
bool tdls_direct = false; bool tdls_peer = false, tdls_setup_frame = false;
bool multicast; bool multicast;
u32 info_flags = 0; u32 info_flags = 0;
u16 info_id = 0; u16 info_id = 0;
...@@ -1953,8 +1953,6 @@ netdev_tx_t ieee80211_subif_start_xmit(struct sk_buff *skb, ...@@ -1953,8 +1953,6 @@ netdev_tx_t ieee80211_subif_start_xmit(struct sk_buff *skb,
#endif #endif
case NL80211_IFTYPE_STATION: case NL80211_IFTYPE_STATION:
if (sdata->wdev.wiphy->flags & WIPHY_FLAG_SUPPORTS_TDLS) { if (sdata->wdev.wiphy->flags & WIPHY_FLAG_SUPPORTS_TDLS) {
bool tdls_peer = false;
sta = sta_info_get(sdata, skb->data); sta = sta_info_get(sdata, skb->data);
if (sta) { if (sta) {
authorized = test_sta_flag(sta, authorized = test_sta_flag(sta,
...@@ -1966,21 +1964,24 @@ netdev_tx_t ieee80211_subif_start_xmit(struct sk_buff *skb, ...@@ -1966,21 +1964,24 @@ netdev_tx_t ieee80211_subif_start_xmit(struct sk_buff *skb,
WLAN_STA_TDLS_PEER_AUTH); WLAN_STA_TDLS_PEER_AUTH);
} }
/* if (tdls_peer)
* If the TDLS link is enabled, send everything tdls_setup_frame =
* directly. Otherwise, allow TDLS setup frames ethertype == ETH_P_TDLS &&
* to be transmitted indirectly. skb->len > 14 &&
*/ skb->data[14] == WLAN_TDLS_SNAP_RFTYPE;
tdls_direct = tdls_peer && (tdls_auth ||
!(ethertype == ETH_P_TDLS && skb->len > 14 &&
skb->data[14] == WLAN_TDLS_SNAP_RFTYPE));
} }
if (tdls_direct) { /*
/* link during setup - throw out frames to peer */ * TDLS link during setup - throw out frames to peer. We allow
if (!tdls_auth) * TDLS-setup frames to unauthorized peers for the special case
* of a link teardown after a TDLS sta is removed due to being
* unreachable.
*/
if (tdls_peer && !tdls_auth && !tdls_setup_frame)
goto fail_rcu; goto fail_rcu;
/* send direct packets to authorized TDLS peers */
if (tdls_peer && tdls_auth) {
/* DA SA BSSID */ /* DA SA BSSID */
memcpy(hdr.addr1, skb->data, ETH_ALEN); memcpy(hdr.addr1, skb->data, ETH_ALEN);
memcpy(hdr.addr2, skb->data + ETH_ALEN, ETH_ALEN); memcpy(hdr.addr2, skb->data + ETH_ALEN, ETH_ALEN);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment