summaryrefslogtreecommitdiffstats
path: root/sys/net80211
diff options
context:
space:
mode:
authoradrian <adrian@FreeBSD.org>2016-04-26 01:29:03 +0000
committeradrian <adrian@FreeBSD.org>2016-04-26 01:29:03 +0000
commit16ee478f132580fc8f1a7df88d421bad73acb3b8 (patch)
tree6244736a30f01659a22f2888e8e7cb28b0809b29 /sys/net80211
parent7cf304dd3d2d55db2ff545bb1844351c94791bc1 (diff)
downloadFreeBSD-src-16ee478f132580fc8f1a7df88d421bad73acb3b8.zip
FreeBSD-src-16ee478f132580fc8f1a7df88d421bad73acb3b8.tar.gz
[net80211] add STBC capability flags to iv_flags_ht.
This is in preparation for exposing configuring STBC flags up to ifconfig so STBC TX/RX can be configured at runtime. * Set the FHT_STBC flags for TX/RX if the HT capabilitiex exist * Clear the RX STBC HT capability flag when creating a HTCAP IE, so we only announce it if it's configured in the FHT flags. Tested: * AR9331 (carambola2), AP/STA modes
Diffstat (limited to 'sys/net80211')
-rw-r--r--sys/net80211/ieee80211_ht.c12
1 files changed, 12 insertions, 0 deletions
diff --git a/sys/net80211/ieee80211_ht.c b/sys/net80211/ieee80211_ht.c
index c4f61fe..d33b5c4 100644
--- a/sys/net80211/ieee80211_ht.c
+++ b/sys/net80211/ieee80211_ht.c
@@ -293,6 +293,11 @@ ieee80211_ht_vattach(struct ieee80211vap *vap)
vap->iv_flags_ht |= IEEE80211_FHT_AMSDU_RX;
if (vap->iv_htcaps & IEEE80211_HTC_AMSDU)
vap->iv_flags_ht |= IEEE80211_FHT_AMSDU_TX;
+
+ if (vap->iv_htcaps & IEEE80211_HTCAP_TXSTBC)
+ vap->iv_flags_ht |= IEEE80211_FHT_STBC_TX;
+ if (vap->iv_htcaps & IEEE80211_HTCAP_RXSTBC)
+ vap->iv_flags_ht |= IEEE80211_FHT_STBC_RX;
}
/* NB: disable default legacy WDS, too many issues right now */
if (vap->iv_flags_ext & IEEE80211_FEXT_WDSLEGACY)
@@ -2778,6 +2783,13 @@ ieee80211_add_htcap_body(uint8_t *frm, struct ieee80211_node *ni)
if ((vap->iv_flags_ht & IEEE80211_FHT_SHORTGI40) == 0 ||
(caps & IEEE80211_HTCAP_CHWIDTH40) == 0)
caps &= ~IEEE80211_HTCAP_SHORTGI40;
+
+ /* adjust STBC based on receive capabilities */
+ if ((vap->iv_flags_ht & IEEE80211_FHT_STBC_RX) == 0)
+ caps &= ~IEEE80211_HTCAP_RXSTBC;
+
+ /* XXX TODO: adjust LDPC based on receive capabilities */
+
ADDSHORT(frm, caps);
/* HT parameters */
OpenPOWER on IntegriCloud