Commit 7508f5d9 authored by Jérôme Pouiller's avatar Jérôme Pouiller Committed by Greg Kroah-Hartman

staging: wfx: fix (future) TDLS support

The device does not expect that the AP to have a link-id. However, TDLS
peers should have a a link-id.

The driver does not yet declare itself as supporting TDLS.
Notwithstanding, fix the code in anticipation of the support of TDLS.
Signed-off-by: default avatarJérôme Pouiller <jerome.pouiller@silabs.com>
Link: https://lore.kernel.org/r/20200427134031.323403-2-Jerome.Pouiller@silabs.comSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 2405c856
...@@ -384,9 +384,8 @@ int wfx_sta_add(struct ieee80211_hw *hw, struct ieee80211_vif *vif, ...@@ -384,9 +384,8 @@ int wfx_sta_add(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
spin_lock_init(&sta_priv->lock); spin_lock_init(&sta_priv->lock);
sta_priv->vif_id = wvif->id; sta_priv->vif_id = wvif->id;
// FIXME: in station mode, the current API interprets new link-id as a // In station mode, the firmware interprets new link-id as a TDLS peer.
// tdls peer. if (vif->type == NL80211_IFTYPE_STATION && !sta->tdls)
if (vif->type == NL80211_IFTYPE_STATION)
return 0; return 0;
sta_priv->link_id = ffz(wvif->link_id_map); sta_priv->link_id = ffz(wvif->link_id_map);
wvif->link_id_map |= BIT(sta_priv->link_id); wvif->link_id_map |= BIT(sta_priv->link_id);
...@@ -408,8 +407,8 @@ int wfx_sta_remove(struct ieee80211_hw *hw, struct ieee80211_vif *vif, ...@@ -408,8 +407,8 @@ int wfx_sta_remove(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
if (sta_priv->buffered[i]) if (sta_priv->buffered[i])
dev_warn(wvif->wdev->dev, "release station while %d pending frame on queue %d", dev_warn(wvif->wdev->dev, "release station while %d pending frame on queue %d",
sta_priv->buffered[i], i); sta_priv->buffered[i], i);
// FIXME: see note in wfx_sta_add() // See note in wfx_sta_add()
if (vif->type == NL80211_IFTYPE_STATION) if (!sta_priv->link_id)
return 0; return 0;
// FIXME add a mutex? // FIXME add a mutex?
hif_map_link(wvif, sta->addr, 1, sta_priv->link_id); hif_map_link(wvif, sta->addr, 1, sta_priv->link_id);
......
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