aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlex A. Mihaylov <minimumlaw@rambler.ru>2013-04-14 23:29:35 -0400
committerJohn W. Linville <linville@tuxdriver.com>2013-04-22 15:06:44 -0400
commit7e9dafd873034dd64ababcb858be424c4780ae13 (patch)
tree4ba89b714b028f7d7b400b38c0ff601b43b5e1a5
parent3f524559cfb114339021afa139fc30aae1c9a878 (diff)
rt2x00: Fix transmit power troubles on some Ralink RT30xx cards
Some cards on Ralink RT30xx chipset not have correctly TX_MIXER_GAIN value in them EEPROM/EFUSE. In this case, we must use default value, but always used EEPROM/EFUSE value. As result we have tranmitt power range from -10dBm to +6dBm instead 0dBm to +16dBm. Correctly value in EEPROM/EFUSE is one or more for RT3070 and two or more for other RT30xx chips. Tested on Canyon CNP-WF518N1 usb Wi-Fi dongle and Jorjin WN8020 usb embedded Wi-Fi module. Signed-off-by: Alex A. Mihaylov <minimumlaw@rambler.ru> Cc: stable@vger.kernel.org Acked-by: Gertjan van Wingerde <gwingerde@gmail.com> Acked-by: Stanislaw Gruszka <sgruszka@redhat.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
-rw-r--r--drivers/net/wireless/rt2x00/rt2800lib.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/drivers/net/wireless/rt2x00/rt2800lib.c b/drivers/net/wireless/rt2x00/rt2800lib.c
index 72bbb962579f..6a167a28a688 100644
--- a/drivers/net/wireless/rt2x00/rt2800lib.c
+++ b/drivers/net/wireless/rt2x00/rt2800lib.c
@@ -5036,6 +5036,8 @@ static int rt2800_init_rfcsr(struct rt2x00_dev *rt2x00dev)
5036 5036
5037 if (!rt2x00_rt(rt2x00dev, RT5390) && 5037 if (!rt2x00_rt(rt2x00dev, RT5390) &&
5038 !rt2x00_rt(rt2x00dev, RT5392)) { 5038 !rt2x00_rt(rt2x00dev, RT5392)) {
5039 u8 min_gain = rt2x00_rt(rt2x00dev, RT3070) ? 1 : 2;
5040
5039 rt2800_rfcsr_read(rt2x00dev, 17, &rfcsr); 5041 rt2800_rfcsr_read(rt2x00dev, 17, &rfcsr);
5040 rt2x00_set_field8(&rfcsr, RFCSR17_TX_LO1_EN, 0); 5042 rt2x00_set_field8(&rfcsr, RFCSR17_TX_LO1_EN, 0);
5041 if (rt2x00_rt(rt2x00dev, RT3070) || 5043 if (rt2x00_rt(rt2x00dev, RT3070) ||
@@ -5046,8 +5048,10 @@ static int rt2800_init_rfcsr(struct rt2x00_dev *rt2x00dev)
5046 &rt2x00dev->cap_flags)) 5048 &rt2x00dev->cap_flags))
5047 rt2x00_set_field8(&rfcsr, RFCSR17_R, 1); 5049 rt2x00_set_field8(&rfcsr, RFCSR17_R, 1);
5048 } 5050 }
5049 rt2x00_set_field8(&rfcsr, RFCSR17_TXMIXER_GAIN, 5051 if (drv_data->txmixer_gain_24g >= min_gain) {
5050 drv_data->txmixer_gain_24g); 5052 rt2x00_set_field8(&rfcsr, RFCSR17_TXMIXER_GAIN,
5053 drv_data->txmixer_gain_24g);
5054 }
5051 rt2800_rfcsr_write(rt2x00dev, 17, rfcsr); 5055 rt2800_rfcsr_write(rt2x00dev, 17, rfcsr);
5052 } 5056 }
5053 5057