ath9k_hw: fix calculated runtime tx power limit
authorFelix Fietkau <nbd@openwrt.org>
Wed, 27 Jul 2011 13:01:04 +0000 (15:01 +0200)
committerJohn W. Linville <linville@tuxdriver.com>
Mon, 8 Aug 2011 20:04:16 +0000 (16:04 -0400)
Use the previously calculated maximum of all rates instead of just the one
from the lowest rate of the selected PHY mode.

Signed-off-by: Felix Fietkau <nbd@openwrt.org>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
drivers/net/wireless/ath/ath9k/ar9003_eeprom.c
drivers/net/wireless/ath/ath9k/eeprom_4k.c
drivers/net/wireless/ath/ath9k/eeprom_9287.c
drivers/net/wireless/ath/ath9k/eeprom_def.c

index d109c25417f4930b525ac43da631c4fe17c2ebdb..184abb6658e47eeaee1592ebf7483eb32f72dc3f 100644 (file)
@@ -4922,25 +4922,7 @@ static void ath9k_hw_ar9300_set_txpower(struct ath_hw *ah,
                        "TPC[%02d] 0x%08x\n", i, targetPowerValT2[i]);
        }
 
-       /*
-        * This is the TX power we send back to driver core,
-        * and it can use to pass to userspace to display our
-        * currently configured TX power setting.
-        *
-        * Since power is rate dependent, use one of the indices
-        * from the AR9300_Rates enum to select an entry from
-        * targetPowerValT2[] to report. Currently returns the
-        * power for HT40 MCS 0, HT20 MCS 0, or OFDM 6 Mbps
-        * as CCK power is less interesting (?).
-        */
-       i = ALL_TARGET_LEGACY_6_24; /* legacy */
-       if (IS_CHAN_HT40(chan))
-               i = ALL_TARGET_HT40_0_8_16; /* ht40 */
-       else if (IS_CHAN_HT20(chan))
-               i = ALL_TARGET_HT20_0_8_16; /* ht20 */
-
-       ah->txpower_limit = targetPowerValT2[i];
-       regulatory->max_power_level = targetPowerValT2[i];
+       ah->txpower_limit = regulatory->max_power_level;
 
        /* Write target power array to registers */
        ar9003_hw_tx_power_regwrite(ah, targetPowerValT2);
index bf64d67b44fec232589da6b7213588b1f1ddb256..abf40d3ed34434480df98e0bd2aa9b9a093e0cc8 100644 (file)
@@ -607,15 +607,6 @@ static void ath9k_hw_4k_set_txpower(struct ath_hw *ah,
        if (test)
            return;
 
-       /* Update regulatory */
-       i = rate6mb;
-       if (IS_CHAN_HT40(chan))
-               i = rateHt40_0;
-       else if (IS_CHAN_HT20(chan))
-               i = rateHt20_0;
-
-       regulatory->max_power_level = ratesArray[i];
-
        if (AR_SREV_9280_20_OR_LATER(ah)) {
                for (i = 0; i < Ar5416RateSize; i++)
                        ratesArray[i] -= AR5416_PWR_TABLE_OFFSET_DB * 2;
index a65d2a5deae1454bc3defd5b45392e16c812f1d4..604312cfe8cb046a435225868428d6c84424421c 100644 (file)
@@ -746,13 +746,6 @@ static void ath9k_hw_ar9287_set_txpower(struct ath_hw *ah,
        if (test)
                return;
 
-       if (IS_CHAN_2GHZ(chan))
-               i = rate1l;
-       else
-               i = rate6mb;
-
-       regulatory->max_power_level = ratesArray[i];
-
        if (AR_SREV_9280_20_OR_LATER(ah)) {
                for (i = 0; i < Ar5416RateSize; i++)
                        ratesArray[i] -= AR9287_PWR_TABLE_OFFSET_DB * 2;
index b665837635fc5a65d2f8751ec7aa115896192dc3..85057e074bfce3782498b273d859601758c7781d 100644 (file)
@@ -1167,17 +1167,6 @@ static void ath9k_hw_def_set_txpower(struct ath_hw *ah,
                        regulatory->max_power_level = ratesArray[i];
        }
 
-       if (!test) {
-               i = rate6mb;
-
-               if (IS_CHAN_HT40(chan))
-                       i = rateHt40_0;
-               else if (IS_CHAN_HT20(chan))
-                       i = rateHt20_0;
-
-               regulatory->max_power_level = ratesArray[i];
-       }
-
        switch(ar5416_get_ntxchains(ah->txchainmask)) {
        case 1:
                break;