summaryrefslogtreecommitdiffstats
path: root/sys/net80211
diff options
context:
space:
mode:
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