aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/rt2x00/rt2800lib.c
diff options
context:
space:
mode:
authorGabor Juhos <juhosg@openwrt.org>2013-07-08 10:08:24 -0400
committerJohn W. Linville <linville@tuxdriver.com>2013-07-22 16:54:32 -0400
commitfc739cfe0f305647677edbf99a76d9ece96e3795 (patch)
tree4f321a971a6a685ad0bb8220d82880bc82482674 /drivers/net/wireless/rt2x00/rt2800lib.c
parent97aa03f15e83174df74aa468eea127c5cee480f0 (diff)
rt2x00: rt2800lib: fix default TX power values for RT3593
The TX power values in the EEPROM are using a different format for the RT3593 chip. The default TX power value uses bits 0..4 only. Bits 5..8 contains value for fine grained power control. Additionally, the lower and upper limits of the TX power values are the same for both bands. Improve the rt2800_txpower_to_dev function, in order to compute the correct default power values for the RT3593 chip as well. Signed-off-by: Gabor Juhos <juhosg@openwrt.org> Acked-by: Stanislaw Gruszka <stf_xl@wp.pl> Acked-by: Gertjan van Wingerde <gwingerde@gmail.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/rt2x00/rt2800lib.c')
-rw-r--r--drivers/net/wireless/rt2x00/rt2800lib.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/drivers/net/wireless/rt2x00/rt2800lib.c b/drivers/net/wireless/rt2x00/rt2800lib.c
index 1738a9d232c3..b11f0b06cc6d 100644
--- a/drivers/net/wireless/rt2x00/rt2800lib.c
+++ b/drivers/net/wireless/rt2x00/rt2800lib.c
@@ -2728,8 +2728,15 @@ static char rt2800_txpower_to_dev(struct rt2x00_dev *rt2x00dev,
2728 unsigned int channel, 2728 unsigned int channel,
2729 char txpower) 2729 char txpower)
2730{ 2730{
2731 if (rt2x00_rt(rt2x00dev, RT3593))
2732 txpower = rt2x00_get_field8(txpower, EEPROM_TXPOWER_ALC);
2733
2731 if (channel <= 14) 2734 if (channel <= 14)
2732 return clamp_t(char, txpower, MIN_G_TXPOWER, MAX_G_TXPOWER); 2735 return clamp_t(char, txpower, MIN_G_TXPOWER, MAX_G_TXPOWER);
2736
2737 if (rt2x00_rt(rt2x00dev, RT3593))
2738 return clamp_t(char, txpower, MIN_A_TXPOWER_3593,
2739 MAX_A_TXPOWER_3593);
2733 else 2740 else
2734 return clamp_t(char, txpower, MIN_A_TXPOWER, MAX_A_TXPOWER); 2741 return clamp_t(char, txpower, MIN_A_TXPOWER, MAX_A_TXPOWER);
2735} 2742}