From 54625965c4cae72bafa5bdd293e013ed3c6f7e15 Mon Sep 17 00:00:00 2001
From: Felix Fietkau <nbd@openwrt.org>
Date: Sat, 3 May 2014 18:38:24 +0000
Subject: [PATCH] mac80211: clean up vht capability processing

Signed-off-by: Felix Fietkau <nbd@openwrt.org>

SVN-Revision: 40683
---
 .../files/lib/netifd/wireless/mac80211.sh     | 64 +++++++------------
 1 file changed, 22 insertions(+), 42 deletions(-)

diff --git a/package/kernel/mac80211/files/lib/netifd/wireless/mac80211.sh b/package/kernel/mac80211/files/lib/netifd/wireless/mac80211.sh
index 4f859a73e7..1b7c5a65f2 100644
--- a/package/kernel/mac80211/files/lib/netifd/wireless/mac80211.sh
+++ b/package/kernel/mac80211/files/lib/netifd/wireless/mac80211.sh
@@ -184,42 +184,37 @@ mac80211_hostapd_setup_base() {
 				rx_antenna_pattern:1 \
 				tx_antenna_pattern:1 \
 				vht_max_mpdu:11454 \
-				vht_max_rx_stbc:4 \
+				rx_stbc:4 \
 				vht_link_adapt:3 \
 				vht160:2
 
 			append base_cfg "ieee80211ac=1" "$N"
-			vht_capab=""
 			vht_cap=0
 			for cap in $(iw phy "$phy" info | awk -F "[()]" '/VHT Capabilities/ { print $2 }'); do
 				vht_cap="$(($vht_cap | $cap))"
 			done
 
-			# boolean
-			[ "$((($vht_cap & 16) * $rxldpc))" -eq 16 ] && \
-				vht_capab="$vht_capab[RXLDPC]"
-			[ "$((($vht_cap & 32) * $short_gi_80))" -eq 32 ] && \
-				vht_capab="$vht_capab[SHORT-GI-80]"
-			[ "$((($vht_cap & 64) * $short_gi_160))" -eq 64 ] && \
-				vht_capab="$vht_capab[SHORT-GI-160]"
-			[ "$((($vht_cap & 128) * $tx_stbc_2by1))" -eq 128 ] && \
-				vht_capab="$vht_capab[TX-STBC-2BY1]"
-			[ "$((($vht_cap & 2048) * $su_beamformer))" -eq 2048 ] && \
-				vht_capab="$vht_capab[SU-BEAMFORMER]"
-			[ "$((($vht_cap & 4096) * $su_beamformee))" -eq 4096 ] && \
-				vht_capab="$vht_capab[SU-BEAMFORMEE]"
-			[ "$((($vht_cap & 524288) * $mu_beamformer))" -eq 524288 ] && \
-				vht_capab="$vht_capab[MU-BEAMFORMER]"
-			[ "$((($vht_cap & 1048576) * $mu_beamformee))" -eq 1048576 ] && \
-				vht_capab="$vht_capab[MU-BEAMFORMEE]"
-			[ "$((($vht_cap & 2097152) * $vht_txop_ps))" -eq 2097152 ] && \
-				vht_capab="$vht_capab[VHT-TXOP-PS]"
-			[ "$((($vht_cap & 4194304) * $htc_vht))" -eq 4194304 ] && \
-				vht_capab="$vht_capab[HTC-VHT]"
-			[ "$((($vht_cap & 268435456) * $rx_antenna_pattern))" -eq 268435456 ] && \
-				vht_capab="$vht_capab[RX-ANTENNA-PATTERN]"
-			[ "$((($vht_cap & 536870912) * $tx_antenna_pattern))" -eq 536870912 ] && \
-				vht_capab="$vht_capab[TX-ANTENNA-PATTERN]"
+			cap_rx_stbc=$((($vht_cap >> 8) & 7))
+			[ "$rx_stbc" -lt "$cap_rx_stbc" ] && cap_rx_stbc="$rx_stbc"
+			ht_cap_mask="$(( ($vht_cap & ~(0x700)) | ($cap_rx_stbc << 8) ))"
+
+			mac80211_add_capabilities vht_capab $vht_cap \
+				RXLDPC:0x10::$rxldpc \
+				SHORT-GI-80:0x20::$short_gi_80 \
+				SHORT-GI-160:0x40::$short_gi_160 \
+				TX-STBC-2BY1:0x80::$tx_stbc \
+				SU-BEAMFORMER:0x800::$su_beamformer \
+				SU-BEAMFORMEE:0x1000::$su_beamformee \
+				MU-BEAMFORMER:0x80000::$mu_beamformer \
+				MU-BEAMFORMEE:0x100000::$mu_beamformee \
+				VHT-TXOP-PS:0x200000::$vht_txop_ps \
+				HTC-VHT:0x400000::$htc_vht \
+				RX-ANTENNA-PATTERN:0x10000000::$rx_antenna_pattern \
+				TX-ANTENNA-PATTERN:0x20000000::$tx_antenna_pattern \
+				RX-STBC1:0x700:0x100:1 \
+				RX-STBC12:0x700:0x200:1 \
+				RX-STBC123:0x700:0x300:1 \
+				RX-STBC1234:0x700:0x400:1 \
 
 			# supported Channel widths
 			vht160_hw=0
@@ -239,21 +234,6 @@ mac80211_hostapd_setup_base() {
 			[ "$vht_max_mpdu_hw" != 3895 ] && \
 				vht_capab="$vht_capab[MAX-MPDU-$vht_max_mpdu_hw]"
 
-			# support for the reception of PPDUs using STBC
-			vht_max_rx_stbc_hw=0
-			[ "$(($vht_cap & 1792))" -ge 256 -a 1 -le "$vht_max_rx_stbc" ] && \
-				vht_max_rx_stbc_hw=1
-			[ "$(($vht_cap & 1792))" -ge 512 -a 2 -le "$vht_max_rx_stbc" ] && \
-				vht_max_rx_stbc_hw=2
-			[ "$(($vht_cap & 1792))" -ge 768 -a 3 -le "$vht_max_rx_stbc" ] && \
-				vht_max_rx_stbc_hw=3
-			[ "$(($vht_cap & 1792))" -ge 1024 -a 4 -le "$vht_max_rx_stbc" ] && \
-				vht_max_rx_stbc_hw=4
-			[ "$vht_max_rx_stbc_hw" = 1 ] && vht_capab="$vht_capab[RX-STBC-1]"
-			[ "$vht_max_rx_stbc_hw" = 2 ] && vht_capab="$vht_capab[RX-STBC-12]"
-			[ "$vht_max_rx_stbc_hw" = 3 ] && vht_capab="$vht_capab[RX-STBC-123]"
-			[ "$vht_max_rx_stbc_hw" = 4 ] && vht_capab="$vht_capab[RX-STBC-1234]"
-
 			# whether or not the STA supports link adaptation using VHT variant
 			vht_link_adapt_hw=0
 			[ "$(($vht_cap & 201326592))" -ge 134217728 -a 2 -le "$vht_link_adapt" ] && \
-- 
2.30.2