aboutsummaryrefslogtreecommitdiffstats
path: root/package/mac80211/patches/530-ath9k_fix_reported_signal_strength.patch
diff options
context:
space:
mode:
authorFelix Fietkau <nbd@openwrt.org>2011-04-20 18:14:35 +0000
committerFelix Fietkau <nbd@openwrt.org>2011-04-20 18:14:35 +0000
commitb7dc13b6a4fb30c354141ebba718e8dc8ebfdd37 (patch)
treef19cbced5cf203a403fd0ff0f146c034c8b79490 /package/mac80211/patches/530-ath9k_fix_reported_signal_strength.patch
parent6b1337376f13201edee43c9dcb5c29bfed7544f4 (diff)
downloadmaster-187ad058-b7dc13b6a4fb30c354141ebba718e8dc8ebfdd37.tar.gz
master-187ad058-b7dc13b6a4fb30c354141ebba718e8dc8ebfdd37.tar.bz2
master-187ad058-b7dc13b6a4fb30c354141ebba718e8dc8ebfdd37.zip
mac80211: update to wireless-testing 2011-04-19, contains several beacon related fixes for ath9k
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@26744 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/mac80211/patches/530-ath9k_fix_reported_signal_strength.patch')
-rw-r--r--package/mac80211/patches/530-ath9k_fix_reported_signal_strength.patch27
1 files changed, 27 insertions, 0 deletions
diff --git a/package/mac80211/patches/530-ath9k_fix_reported_signal_strength.patch b/package/mac80211/patches/530-ath9k_fix_reported_signal_strength.patch
new file mode 100644
index 0000000000..9e188fc627
--- /dev/null
+++ b/package/mac80211/patches/530-ath9k_fix_reported_signal_strength.patch
@@ -0,0 +1,27 @@
+--- a/drivers/net/wireless/ath/ath9k/recv.c
++++ b/drivers/net/wireless/ath/ath9k/recv.c
+@@ -956,6 +956,9 @@ static int ath9k_rx_skb_preprocess(struc
+ struct ieee80211_rx_status *rx_status,
+ bool *decrypt_error)
+ {
++ struct ath_hw *ah = common->ah;
++ int noise;
++
+ memset(rx_status, 0, sizeof(struct ieee80211_rx_status));
+
+ /*
+@@ -976,7 +979,13 @@ static int ath9k_rx_skb_preprocess(struc
+
+ rx_status->band = hw->conf.channel->band;
+ rx_status->freq = hw->conf.channel->center_freq;
+- rx_status->signal = ATH_DEFAULT_NOISE_FLOOR + rx_stats->rs_rssi;
++
++ if (ah->curchan && ah->curchan->noisefloor)
++ noise = ah->curchan->noisefloor;
++ else
++ noise = ATH_DEFAULT_NOISE_FLOOR;
++
++ rx_status->signal = noise + rx_stats->rs_rssi;
+ rx_status->antenna = rx_stats->rs_antenna;
+ rx_status->flag |= RX_FLAG_MACTIME_MPDU;
+