ath9k: split up and adjust rc cleanup patch according to upstream feedback, also...
authorFelix Fietkau <nbd@openwrt.org>
Wed, 18 Nov 2009 03:48:55 +0000 (03:48 +0000)
committerFelix Fietkau <nbd@openwrt.org>
Wed, 18 Nov 2009 03:48:55 +0000 (03:48 +0000)
SVN-Revision: 18444

package/mac80211/patches/560-ath9k_rate_control_api.patch
package/mac80211/patches/561-ath9k_rc_table_cleanup.patch [new file with mode: 0644]

index 13ada5da0db132eca8a5feb6498fce5f6376b7fc..5769d305ad28039e4b10bea14005e03b0cf98c64 100644 (file)
 --- a/drivers/net/wireless/ath/ath9k/rc.c
 +++ b/drivers/net/wireless/ath/ath9k/rc.c
-@@ -19,133 +19,92 @@
+@@ -19,6 +19,7 @@
  
  static const struct ath_rate_table ar5416_11na_ratetable = {
        42,
 +      8, /* MCS start */
        {
                { VALID, VALID, WLAN_RC_PHY_OFDM, 6000, /* 6 Mb */
--                      5400, 0x0b, 0x00, 12,
--                      0, 0, 0, 0, 0, 0 },
-+                      5400, 0, 12, 0, 0, 0, 0, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */
--                      7800,  0x0f, 0x00, 18,
--                      0, 1, 1, 1, 1, 0 },
-+                      7800,  1, 18, 0, 1, 1, 1, 1 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */
--                      10000, 0x0a, 0x00, 24,
--                      2, 2, 2, 2, 2, 0 },
-+                      10000, 2, 24, 2, 2, 2, 2, 2 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */
--                      13900, 0x0e, 0x00, 36,
--                      2,  3, 3, 3, 3, 0 },
-+                      13900, 3, 36, 2, 3, 3, 3, 3 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */
--                      17300, 0x09, 0x00, 48,
--                      4,  4, 4, 4, 4, 0 },
-+                      17300, 4, 48, 4, 4, 4, 4, 4 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */
--                      23000, 0x0d, 0x00, 72,
--                      4,  5, 5, 5, 5, 0 },
-+                      23000, 5, 72, 4, 5, 5, 5, 5 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */
--                      27400, 0x08, 0x00, 96,
--                      4,  6, 6, 6, 6, 0 },
-+                      27400, 6, 96, 4, 6, 6, 6, 6 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */
--                      29300, 0x0c, 0x00, 108,
--                      4,  7, 7, 7, 7, 0 },
-+                      29300, 7, 108, 4, 7, 7, 7, 7 },
-               { VALID_2040, VALID_2040, WLAN_RC_PHY_HT_20_SS, 6500, /* 6.5 Mb */
--                      6400, 0x80, 0x00, 0,
--                      0, 8, 24, 8, 24, 3216 },
-+                      6400, 0, 0, 0, 8, 24, 8, 24 },
-               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 13000, /* 13 Mb */
--                      12700, 0x81, 0x00, 1,
--                      2, 9, 25, 9, 25, 6434 },
-+                      12700, 1, 1, 2, 9, 25, 9, 25 },
-               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 19500, /* 19.5 Mb */
--                      18800, 0x82, 0x00, 2,
--                      2, 10, 26, 10, 26, 9650 },
-+                      18800, 2, 2, 2, 10, 26, 10, 26 },
-               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 26000, /* 26 Mb */
--                      25000, 0x83, 0x00, 3,
--                      4,  11, 27, 11, 27, 12868 },
-+                      25000, 3, 3, 4, 11, 27, 11, 27 },
-               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 39000, /* 39 Mb */
--                      36700, 0x84, 0x00, 4,
--                      4,  12, 28, 12, 28, 19304 },
-+                      36700, 4, 4, 4, 12, 28, 12, 28 },
-               { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 52000, /* 52 Mb */
--                      48100, 0x85, 0x00, 5,
--                      4,  13, 29, 13, 29, 25740 },
-+                      48100, 5, 5, 4, 13, 29, 13, 29 },
-               { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 58500, /* 58.5 Mb */
--                      53500, 0x86, 0x00, 6,
--                      4,  14, 30, 14, 30,  28956 },
-+                      53500, 6, 6, 4, 14, 30, 14, 30 },
-               { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 65000, /* 65 Mb */
--                      59000, 0x87, 0x00, 7,
--                      4,  15, 31, 15, 32, 32180 },
-+                      59000, 7, 7, 4, 15, 31, 15, 32 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 13000, /* 13 Mb */
--                      12700, 0x88, 0x00,
--                      8, 3, 16, 33, 16, 33, 6430 },
-+                      12700, 8, 8, 3, 16, 33, 16, 33 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 26000, /* 26 Mb */
--                      24800, 0x89, 0x00, 9,
--                      2, 17, 34, 17, 34, 12860 },
-+                      24800, 9, 9, 2, 17, 34, 17, 34 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 39000, /* 39 Mb */
--                      36600, 0x8a, 0x00, 10,
--                      2, 18, 35, 18, 35, 19300 },
-+                      36600, 10, 10, 2, 18, 35, 18, 35 },
-               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 52000, /* 52 Mb */
--                      48100, 0x8b, 0x00, 11,
--                      4,  19, 36, 19, 36, 25736 },
-+                      48100, 11, 11, 4, 19, 36, 19, 36 },
-               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 78000, /* 78 Mb */
--                      69500, 0x8c, 0x00, 12,
--                      4,  20, 37, 20, 37, 38600 },
-+                      69500, 12, 12, 4, 20, 37, 20, 37 },
-               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 104000, /* 104 Mb */
--                      89500, 0x8d, 0x00, 13,
--                      4,  21, 38, 21, 38, 51472 },
-+                      89500, 13, 13, 4, 21, 38, 21, 38 },
-               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 117000, /* 117 Mb */
--                      98900, 0x8e, 0x00, 14,
--                      4,  22, 39, 22, 39, 57890 },
-+                      98900, 14, 14, 4, 22, 39, 22, 39 },
-               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 130000, /* 130 Mb */
--                      108300, 0x8f, 0x00, 15,
--                      4,  23, 40, 23, 41, 64320 },
-+                      108300, 15, 15, 4, 23, 40, 23, 41 },
-               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 13500, /* 13.5 Mb */
--                      13200, 0x80, 0x00, 0,
--                      0, 8, 24, 24, 24, 6684 },
-+                      13200, 0, 0, 0, 8, 24, 24, 24 },
-               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 27500, /* 27.0 Mb */
--                      25900, 0x81, 0x00, 1,
--                      2, 9, 25, 25, 25, 13368 },
-+                      25900, 1, 1, 2, 9, 25, 25, 25 },
-               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 40500, /* 40.5 Mb */
--                      38600, 0x82, 0x00, 2,
--                      2, 10, 26, 26, 26, 20052 },
-+                      38600, 2, 2, 2, 10, 26, 26, 26 },
-               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 54000, /* 54 Mb */
--                      49800, 0x83, 0x00, 3,
--                      4,  11, 27, 27, 27, 26738 },
-+                      49800, 3, 3, 4, 11, 27, 27, 27 },
-               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 81500, /* 81 Mb */
--                      72200, 0x84, 0x00, 4,
--                      4,  12, 28, 28, 28, 40104 },
-+                      72200, 4, 4, 4, 12, 28, 28, 28 },
-               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 108000, /* 108 Mb */
--                      92900, 0x85, 0x00, 5,
--                      4,  13, 29, 29, 29, 53476 },
-+                      92900, 5, 5, 4, 13, 29, 29, 29 },
-               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 121500, /* 121.5 Mb */
--                      102700, 0x86, 0x00, 6,
--                      4,  14, 30, 30, 30, 60156 },
-+                      102700, 6, 6, 4, 14, 30, 30, 30 },
-               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 135000, /* 135 Mb */
--                      112000, 0x87, 0x00, 7,
--                      4,  15, 31, 32, 32, 66840 },
-+                      112000, 7, 7, 4, 15, 31, 32, 32 },
-               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS_HGI, 150000, /* 150 Mb */
--                      122000, 0x87, 0x00, 7,
--                      4,  15, 31, 32, 32, 74200 },
-+                      122000, 7, 7, 4, 15, 31, 32, 32 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 27000, /* 27 Mb */
--                      25800, 0x88, 0x00, 8,
--                      0, 16, 33, 33, 33, 13360 },
-+                      25800, 8, 8, 0, 16, 33, 33, 33 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 54000, /* 54 Mb */
--                      49800, 0x89, 0x00, 9,
--                      2, 17, 34, 34, 34, 26720 },
-+                      49800, 9, 9, 2, 17, 34, 34, 34 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 81000, /* 81 Mb */
--                      71900, 0x8a, 0x00, 10,
--                      2, 18, 35, 35, 35, 40080 },
-+                      71900, 10, 10, 2, 18, 35, 35, 35 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 108000, /* 108 Mb */
--                      92500, 0x8b, 0x00, 11,
--                      4,  19, 36, 36, 36, 53440 },
-+                      92500, 11, 11, 4, 19, 36, 36, 36 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 162000, /* 162 Mb */
--                      130300, 0x8c, 0x00, 12,
--                      4,  20, 37, 37, 37, 80160 },
-+                      130300, 12, 12, 4, 20, 37, 37, 37 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 216000, /* 216 Mb */
--                      162800, 0x8d, 0x00, 13,
--                      4,  21, 38, 38, 38, 106880 },
-+                      162800, 13, 13, 4, 21, 38, 38, 38 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 243000, /* 243 Mb */
--                      178200, 0x8e, 0x00, 14,
--                      4,  22, 39, 39, 39, 120240 },
-+                      178200, 14, 14, 4, 22, 39, 39, 39 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 270000, /* 270 Mb */
--                      192100, 0x8f, 0x00, 15,
--                      4,  23, 40, 41, 41, 133600 },
-+                      192100, 15, 15, 4, 23, 40, 41, 41 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS_HGI, 300000, /* 300 Mb */
--                      207000, 0x8f, 0x00, 15,
--                      4,  23, 40, 41, 41, 148400 },
-+                      207000, 15, 15, 4, 23, 40, 41, 41 },
-       },
-       50,  /* probe interval */
-       WLAN_RC_HT_FLAG,  /* Phy rates allowed initially */
-@@ -156,177 +115,125 @@ static const struct ath_rate_table ar541
+                       5400, 0x0b, 0x00, 12,
+@@ -156,6 +157,7 @@ static const struct ath_rate_table ar541
  
  static const struct ath_rate_table ar5416_11ng_ratetable = {
        46,
 +      12, /* MCS start */
        {
                { VALID_ALL, VALID_ALL, WLAN_RC_PHY_CCK, 1000, /* 1 Mb */
--                      900, 0x1b, 0x00, 2,
--                      0, 0, 0, 0, 0, 0 },
-+                      900, 0, 2, 0, 0, 0, 0, 0 },
-               { VALID_ALL, VALID_ALL, WLAN_RC_PHY_CCK, 2000, /* 2 Mb */
--                      1900, 0x1a, 0x04, 4,
--                      1, 1, 1, 1, 1, 0 },
-+                      1900, 1, 4, 1, 1, 1, 1, 1 },
-               { VALID_ALL, VALID_ALL, WLAN_RC_PHY_CCK, 5500, /* 5.5 Mb */
--                      4900, 0x19, 0x04, 11,
--                      2, 2, 2, 2, 2, 0 },
-+                      4900, 2, 11, 2, 2, 2, 2, 2 },
-               { VALID_ALL, VALID_ALL, WLAN_RC_PHY_CCK, 11000, /* 11 Mb */
--                      8100, 0x18, 0x04, 22,
--                      3, 3, 3, 3, 3, 0 },
-+                      8100, 3, 22, 3, 3, 3, 3, 3 },
-               { INVALID, INVALID, WLAN_RC_PHY_OFDM, 6000, /* 6 Mb */
--                      5400, 0x0b, 0x00, 12,
--                      4, 4, 4, 4, 4, 0 },
-+                      5400, 4, 12, 4, 4, 4, 4, 4 },
-               { INVALID, INVALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */
--                      7800, 0x0f, 0x00, 18,
--                      4, 5, 5, 5, 5, 0 },
-+                      7800, 5, 18, 4, 5, 5, 5, 5 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */
--                      10100, 0x0a, 0x00, 24,
--                      6, 6, 6, 6, 6, 0 },
-+                      10100, 6, 24, 6, 6, 6, 6, 6 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */
--                      14100,  0x0e, 0x00, 36,
--                      6, 7, 7, 7, 7, 0 },
-+                      14100, 7, 36, 6, 7, 7, 7, 7 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */
--                      17700, 0x09, 0x00, 48,
--                      8,  8, 8, 8, 8, 0 },
-+                      17700, 8, 48, 8, 8, 8, 8, 8 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */
--                      23700, 0x0d, 0x00, 72,
--                      8,  9, 9, 9, 9, 0 },
-+                      23700, 9, 72, 8, 9, 9, 9, 9 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */
--                      27400, 0x08, 0x00, 96,
--                      8,  10, 10, 10, 10, 0 },
-+                      27400, 10, 96, 8, 10, 10, 10, 10 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */
--                      30900, 0x0c, 0x00, 108,
--                      8,  11, 11, 11, 11, 0 },
-+                      30900, 11, 108, 8, 11, 11, 11, 11 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_20_SS, 6500, /* 6.5 Mb */
--                      6400, 0x80, 0x00, 0,
--                      4, 12, 28, 12, 28, 3216 },
-+                      6400, 0, 0, 4, 12, 28, 12, 28 },
-               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 13000, /* 13 Mb */
--                      12700, 0x81, 0x00, 1,
--                      6, 13, 29, 13, 29, 6434 },
-+                      12700, 1, 1, 6, 13, 29, 13, 29 },
-               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 19500, /* 19.5 Mb */
--                      18800, 0x82, 0x00, 2,
--                      6, 14, 30, 14, 30, 9650 },
-+                      18800, 2, 2, 6, 14, 30, 14, 30 },
-               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 26000, /* 26 Mb */
--                      25000, 0x83, 0x00, 3,
--                      8,  15, 31, 15, 31, 12868 },
-+                      25000, 3, 3, 8, 15, 31, 15, 31 },
-               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 39000, /* 39 Mb */
--                      36700, 0x84, 0x00, 4,
--                      8,  16, 32, 16, 32, 19304 },
-+                      36700, 4, 4, 8, 16, 32, 16, 32 },
-               { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 52000, /* 52 Mb */
--                      48100, 0x85, 0x00, 5,
--                      8,  17, 33, 17, 33, 25740 },
-+                      48100, 5, 5, 8, 17, 33, 17, 33 },
-               { INVALID,  VALID_20, WLAN_RC_PHY_HT_20_SS, 58500, /* 58.5 Mb */
--                      53500, 0x86, 0x00, 6,
--                      8,  18, 34, 18, 34, 28956 },
-+                      53500, 6, 6, 8, 18, 34, 18, 34 },
-               { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 65000, /* 65 Mb */
--                      59000, 0x87, 0x00, 7,
--                      8,  19, 35, 19, 36, 32180 },
-+                      59000, 7, 7, 8, 19, 35, 19, 36 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 13000, /* 13 Mb */
--                      12700, 0x88, 0x00, 8,
--                      4, 20, 37, 20, 37, 6430 },
-+                      12700, 8, 8, 4, 20, 37, 20, 37 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 26000, /* 26 Mb */
--                      24800, 0x89, 0x00, 9,
--                      6, 21, 38, 21, 38, 12860 },
-+                      24800, 9, 9, 6, 21, 38, 21, 38 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 39000, /* 39 Mb */
--                      36600, 0x8a, 0x00, 10,
--                      6, 22, 39, 22, 39, 19300 },
-+                      36600, 10, 10, 6, 22, 39, 22, 39 },
-               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 52000, /* 52 Mb */
--                      48100, 0x8b, 0x00, 11,
--                      8,  23, 40, 23, 40, 25736 },
-+                      48100, 11, 11, 8, 23, 40, 23, 40 },
-               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 78000, /* 78 Mb */
--                      69500, 0x8c, 0x00, 12,
--                      8,  24, 41, 24, 41, 38600 },
-+                      69500, 12, 12, 8, 24, 41, 24, 41 },
-               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 104000, /* 104 Mb */
--                      89500, 0x8d, 0x00, 13,
--                      8,  25, 42, 25, 42, 51472 },
-+                      89500, 13, 13, 8, 25, 42, 25, 42 },
-               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 117000, /* 117 Mb */
--                      98900, 0x8e, 0x00, 14,
--                      8,  26, 43, 26, 44, 57890 },
-+                      98900, 14, 14, 8, 26, 43, 26, 44 },
-               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 130000, /* 130 Mb */
--                      108300, 0x8f, 0x00, 15,
--                      8,  27, 44, 27, 45, 64320 },
-+                      108300, 15, 15, 8, 27, 44, 27, 45 },
-               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 13500, /* 13.5 Mb */
--                      13200, 0x80, 0x00, 0,
--                      8, 12, 28, 28, 28, 6684 },
-+                      13200, 0, 0, 8, 12, 28, 28, 28 },
-               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 27500, /* 27.0 Mb */
--                      25900, 0x81, 0x00, 1,
--                      8, 13, 29, 29, 29, 13368 },
-+                      25900, 1, 1, 8, 13, 29, 29, 29 },
-               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 40500, /* 40.5 Mb */
--                      38600, 0x82, 0x00, 2,
--                      8, 14, 30, 30, 30, 20052 },
-+                      38600, 2, 2, 8, 14, 30, 30, 30 },
-               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 54000, /* 54 Mb */
--                      49800, 0x83, 0x00, 3,
--                      8,  15, 31, 31, 31, 26738 },
-+                      49800, 3, 3, 8,  15, 31, 31, 31 },
-               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 81500, /* 81 Mb */
--                      72200, 0x84, 0x00, 4,
--                      8,  16, 32, 32, 32, 40104 },
-+                      72200, 4, 4, 8, 16, 32, 32, 32 },
-               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 108000, /* 108 Mb */
--                      92900, 0x85, 0x00, 5,
--                      8,  17, 33, 33, 33, 53476 },
-+                      92900, 5, 5, 8, 17, 33, 33, 33 },
-               { INVALID,  VALID_40, WLAN_RC_PHY_HT_40_SS, 121500, /* 121.5 Mb */
--                      102700, 0x86, 0x00, 6,
--                      8,  18, 34, 34, 34, 60156 },
-+                      102700, 6, 6, 8, 18, 34, 34, 34 },
-               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 135000, /* 135 Mb */
--                      112000, 0x87, 0x00, 7,
--                      8,  19, 35, 36, 36, 66840 },
-+                      112000, 7, 7, 8, 19, 35, 36, 36 },
-               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS_HGI, 150000, /* 150 Mb */
--                      122000, 0x87, 0x00, 7,
--                      8,  19, 35, 36, 36, 74200 },
-+                      122000, 7, 7, 8, 19, 35, 36, 36 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 27000, /* 27 Mb */
--                      25800, 0x88, 0x00, 8,
--                      8, 20, 37, 37, 37, 13360 },
-+                      25800, 8, 8, 8, 20, 37, 37, 37 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 54000, /* 54 Mb */
--                      49800, 0x89, 0x00, 9,
--                      8, 21, 38, 38, 38, 26720 },
-+                      49800, 9, 9, 8, 21, 38, 38, 38 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 81000, /* 81 Mb */
--                      71900, 0x8a, 0x00, 10,
--                      8, 22, 39, 39, 39, 40080 },
-+                      71900, 10, 10, 8, 22, 39, 39, 39 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 108000, /* 108 Mb */
--                      92500, 0x8b, 0x00, 11,
--                      8,  23, 40, 40, 40, 53440 },
-+                      92500, 11, 11, 8, 23, 40, 40, 40 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 162000, /* 162 Mb */
--                      130300, 0x8c, 0x00, 12,
--                      8,  24, 41, 41, 41, 80160 },
-+                      130300, 12, 12, 8, 24, 41, 41, 41 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 216000, /* 216 Mb */
--                      162800, 0x8d, 0x00, 13,
--                      8,  25, 42, 42, 42, 106880 },
-+                      162800, 13, 13, 8, 25, 42, 42, 42 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 243000, /* 243 Mb */
--                      178200, 0x8e, 0x00, 14,
--                      8,  26, 43, 43, 43, 120240 },
-+                      178200, 14, 14, 8, 26, 43, 43, 43 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 270000, /* 270 Mb */
--                      192100, 0x8f, 0x00, 15,
--                      8,  27, 44, 45, 45, 133600 },
-+                      192100, 15, 15, 8, 27, 44, 45, 45 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS_HGI, 300000, /* 300 Mb */
--                      207000, 0x8f, 0x00, 15,
--                      8,  27, 44, 45, 45, 148400 },
--              },
-+                      207000, 15, 15, 8, 27, 44, 45, 45 },
-+      },
-       50,  /* probe interval */
-       WLAN_RC_HT_FLAG,  /* Phy rates allowed initially */
- };
+                       900, 0x1b, 0x00, 2,
+@@ -302,6 +304,7 @@ static const struct ath_rate_table ar541
  
  static const struct ath_rate_table ar5416_11a_ratetable = {
        8,
 +      0,
        {
                { VALID, VALID, WLAN_RC_PHY_OFDM, 6000, /* 6 Mb */
--                      5400, 0x0b, 0x00, (0x80|12),
--                      0, 0, 0 },
-+                      5400, 0, 12, 0, 0, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */
--                      7800, 0x0f, 0x00, 18,
--                      0, 1, 0 },
-+                      7800,  1, 18, 0, 1, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */
--                      10000, 0x0a, 0x00, (0x80|24),
--                      2, 2, 0 },
-+                      10000, 2, 24, 2, 2, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */
--                      13900, 0x0e, 0x00, 36,
--                      2, 3, 0 },
-+                      13900, 3, 36, 2, 3, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */
--                      17300, 0x09, 0x00, (0x80|48),
--                      4,  4, 0 },
-+                      17300, 4, 48, 4, 4, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */
--                      23000, 0x0d, 0x00, 72,
--                      4,  5, 0 },
-+                      23000, 5, 72, 4, 5, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */
--                      27400, 0x08, 0x00, 96,
--                      4,  6, 0 },
-+                      27400, 6, 96, 4, 6, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */
--                      29300, 0x0c, 0x00, 108,
--                      4,  7, 0 },
-+                      29300, 7, 108, 4, 7, 0 },
-       },
-       50,  /* probe interval */
-       0,   /* Phy rates allowed initially */
-@@ -334,48 +241,51 @@ static const struct ath_rate_table ar541
+                       5400, 0x0b, 0x00, (0x80|12),
+@@ -334,6 +337,7 @@ static const struct ath_rate_table ar541
  
  static const struct ath_rate_table ar5416_11g_ratetable = {
        12,
 +      0,
        {
                { VALID, VALID, WLAN_RC_PHY_CCK, 1000, /* 1 Mb */
--                      900, 0x1b, 0x00, 2,
--                      0, 0, 0 },
-+                      900, 0, 2, 0, 0, 0 },
-               { VALID, VALID, WLAN_RC_PHY_CCK, 2000, /* 2 Mb */
--                      1900, 0x1a, 0x04, 4,
--                      1, 1, 0 },
-+                      1900, 1, 4, 1, 1, 0 },
-               { VALID, VALID, WLAN_RC_PHY_CCK, 5500, /* 5.5 Mb */
--                      4900, 0x19, 0x04, 11,
--                      2, 2, 0 },
-+                      4900, 2, 11, 2, 2, 0 },
-               { VALID, VALID, WLAN_RC_PHY_CCK, 11000, /* 11 Mb */
--                      8100, 0x18, 0x04, 22,
--                      3, 3, 0 },
-+                      8100, 3, 22, 3, 3, 0 },
-               { INVALID, INVALID, WLAN_RC_PHY_OFDM, 6000, /* 6 Mb */
--                      5400, 0x0b, 0x00, 12,
--                      4, 4, 0 },
-+                      5400, 4, 12, 4, 4, 0 },
-               { INVALID, INVALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */
--                      7800, 0x0f, 0x00, 18,
--                      4, 5, 0 },
-+                      7800, 5, 18, 4, 5, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */
--                      10000, 0x0a, 0x00, 24,
--                      6, 6, 0 },
-+                      10000, 6, 24, 6, 6, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */
--                      13900, 0x0e, 0x00, 36,
--                      6, 7, 0 },
-+                      13900, 7, 36, 6, 7, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */
--                      17300, 0x09, 0x00, 48,
--                      8,  8, 0 },
-+                      17300, 8, 48, 8, 8, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */
--                      23000, 0x0d, 0x00, 72,
--                      8,  9, 0 },
-+                      23000, 9, 72, 8, 9, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */
--                      27400, 0x08, 0x00, 96,
--                      8,  10, 0 },
-+                      27400, 10, 96, 8, 10, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */
--                      29300, 0x0c, 0x00, 108,
--                      8,  11, 0 },
-+                      29300, 11, 108, 8, 11, 0 },
-       },
-       50,  /* probe interval */
+                       900, 0x1b, 0x00, 2,
+@@ -376,6 +380,20 @@ static const struct ath_rate_table ar541
        0,   /* Phy rates allowed initially */
  };
  
  static inline int8_t median(int8_t a, int8_t b, int8_t c)
  {
        if (a >= b) {
-@@ -534,7 +444,7 @@ static u8 ath_rc_setvalid_rates(struct a
+@@ -534,7 +552,7 @@ static u8 ath_rc_setvalid_rates(struct a
                         * capflag matches one of the validity
                         * (VALID/VALID_20/VALID_40) flags */
  
                            ((valid & WLAN_RC_CAP_MODE(capflag)) ==
                             WLAN_RC_CAP_MODE(capflag)) &&
                            !WLAN_RC_PHY_HT(phy)) {
-@@ -576,8 +486,7 @@ static u8 ath_rc_setvalid_htrates(struct
+@@ -576,8 +594,7 @@ static u8 ath_rc_setvalid_htrates(struct
                        u8 rate = rateset->rs_rates[i];
                        u8 dot11rate = rate_table->info[j].dot11rate;
  
                            !WLAN_RC_PHY_HT_VALID(valid, capflag))
                                continue;
  
-@@ -696,18 +605,20 @@ static void ath_rc_rate_set_series(const
+@@ -696,18 +713,20 @@ static void ath_rc_rate_set_series(const
                                   u8 tries, u8 rix, int rtsctsenable)
  {
        rate->count = tries;
  }
  
  static void ath_rc_rate_set_rtscts(struct ath_softc *sc,
-@@ -720,7 +631,7 @@ static void ath_rc_rate_set_rtscts(struc
+@@ -720,7 +739,7 @@ static void ath_rc_rate_set_rtscts(struc
        /* get the cix for the lowest valid rix */
        for (i = 3; i >= 0; i--) {
                if (rates[i].count && (rates[i].idx >= 0)) {
                        break;
                }
        }
-@@ -1080,15 +991,19 @@ static int ath_rc_get_rateindex(const st
+@@ -1080,15 +1099,19 @@ static int ath_rc_get_rateindex(const st
  {
        int rix;
  
  
        return rix;
  }
-@@ -1183,7 +1098,9 @@ struct ath_rate_table *ath_choose_rate_t
+@@ -1183,7 +1206,9 @@ struct ath_rate_table *ath_choose_rate_t
  
        ath_print(common, ATH_DBG_CONFIG,
                  "Choosing rate table for mode: %d\n", mode);
  }
  
  static void ath_rc_init(struct ath_softc *sc,
-@@ -1197,12 +1114,6 @@ static void ath_rc_init(struct ath_softc
+@@ -1197,12 +1222,6 @@ static void ath_rc_init(struct ath_softc
        u8 *ht_mcs = (u8 *)&ath_rc_priv->neg_ht_rates;
        u8 i, j, k, hi = 0, hthi = 0;
  
        /* Initial rate table size. Will change depending
         * on the working rate set */
        ath_rc_priv->rate_table_size = RATE_TABLE_SIZE;
-@@ -1357,7 +1268,8 @@ static void ath_tx_status(void *priv, st
+@@ -1357,7 +1376,8 @@ static void ath_tx_status(void *priv, st
                }
        }
  
  }
  
  static void ath_rate_init(void *priv, struct ieee80211_supported_band *sband,
-@@ -1365,7 +1277,7 @@ static void ath_rate_init(void *priv, st
+@@ -1365,7 +1385,7 @@ static void ath_rate_init(void *priv, st
  {
        struct ath_softc *sc = priv;
        struct ath_rate_priv *ath_rc_priv = priv_sta;
        bool is_cw40, is_sgi40;
        int i, j = 0;
  
-@@ -1397,11 +1309,9 @@ static void ath_rate_init(void *priv, st
+@@ -1397,11 +1417,9 @@ static void ath_rate_init(void *priv, st
            (sc->sc_ah->opmode == NL80211_IFTYPE_MESH_POINT) ||
            (sc->sc_ah->opmode == NL80211_IFTYPE_ADHOC)) {
                rate_table = ath_choose_rate_table(sc, sband->band,
        }
  
        ath_rc_priv->ht_cap = ath_rc_build_ht_caps(sc, sta, is_cw40, is_sgi40);
-@@ -1445,6 +1355,7 @@ static void ath_rate_update(void *priv, 
+@@ -1445,6 +1463,7 @@ static void ath_rate_update(void *priv, 
                        ath_print(ath9k_hw_common(sc->sc_ah), ATH_DBG_CONFIG,
                                  "Operating HT Bandwidth changed to: %d\n",
                                  sc->hw->conf.channel_type);
                }
        }
  }
-@@ -1497,26 +1408,6 @@ static struct rate_control_ops ath_rate_
+@@ -1497,26 +1516,6 @@ static struct rate_control_ops ath_rate_
        .free_sta = ath_rate_free_sta,
  };
  
        }
  
        /* set dur_update_en for l-sig computation except for PS-Poll frames */
+@@ -1925,8 +1967,10 @@ static void ath_tx_rc_status(struct ath_
+               }
+       }
+-      for (i = tx_rateindex + 1; i < hw->max_rates; i++)
++      for (i = tx_rateindex + 1; i < hw->max_rates; i++) {
+               tx_info->status.rates[i].count = 0;
++              tx_info->status.rates[i].idx = -1;
++      }
+       tx_info->status.rates[tx_rateindex].count = bf->bf_retries + 1;
+ }
 --- a/drivers/net/wireless/ath/ath9k/ath9k.h
 +++ b/drivers/net/wireless/ath/ath9k/ath9k.h
 @@ -21,7 +21,6 @@
        struct ath_led radio_led;
 --- a/drivers/net/wireless/ath/ath9k/main.c
 +++ b/drivers/net/wireless/ath/ath9k/main.c
-@@ -105,37 +105,71 @@ static struct ieee80211_channel ath9k_5g
+@@ -105,37 +105,55 @@ static struct ieee80211_channel ath9k_5g
        CHAN5G(5825, 37), /* Channel 165 */
  };
  
++/* Atheros hardware rate code addition for short premble */
++#define SHPCHECK(__hw_rate, __flags) \
++      ((__flags & IEEE80211_RATE_SHORT_PREAMBLE) ? (__hw_rate | 0x04 ) : 0)
++
++#define RATE(_bitrate, _hw_rate, _flags) {              \
++      .bitrate        = (_bitrate),                   \
++      .flags          = (_flags),                     \
++      .hw_value       = (_hw_rate),                   \
++      .hw_value_short = (SHPCHECK(_hw_rate, _flags))  \
++}
++
 +static struct ieee80211_rate ath9k_legacy_rates[] = {
-+      { .bitrate = 10,
-+        .hw_value = 0x1b,
-+        .flags = 0 },
-+      { .bitrate = 20,
-+        .hw_value = 0x1a,
-+        .hw_value_short = 0x1a | 0x04,
-+        .flags = IEEE80211_RATE_SHORT_PREAMBLE },
-+      { .bitrate = 55,
-+        .hw_value = 0x19,
-+        .hw_value_short = 0x19 | 0x04,
-+        .flags = IEEE80211_RATE_SHORT_PREAMBLE },
-+      { .bitrate = 110,
-+        .hw_value = 0x18,
-+        .hw_value_short = 0x18 | 0x4,
-+        .flags = IEEE80211_RATE_SHORT_PREAMBLE },
-+      { .bitrate = 60,
-+        .hw_value = 0x0b,
-+        .flags = 0 },
-+      { .bitrate = 90,
-+        .hw_value = 0x0f,
-+        .flags = 0 },
-+      { .bitrate = 120,
-+        .hw_value = 0x0a,
-+        .flags = 0 },
-+      { .bitrate = 180,
-+        .hw_value = 0x0e,
-+        .flags = 0 },
-+      { .bitrate = 240,
-+        .hw_value = 0x09,
-+        .flags = 0 },
-+      { .bitrate = 360,
-+        .hw_value = 0x0d,
-+        .flags = 0 },
-+      { .bitrate = 480,
-+        .hw_value = 0x08,
-+        .flags = 0 },
-+      { .bitrate = 540,
-+        .hw_value = 0x0c,
-+        .flags = 0 },
++      RATE(10, 0x1b, 0),
++      RATE(20, 0x1a, IEEE80211_RATE_SHORT_PREAMBLE),
++      RATE(55, 0x19, IEEE80211_RATE_SHORT_PREAMBLE),
++      RATE(110, 0x18, IEEE80211_RATE_SHORT_PREAMBLE),
++      RATE(60, 0x0b, 0),
++      RATE(90, 0x0f, 0),
++      RATE(120, 0x0a, 0),
++      RATE(180, 0x0e, 0),
++      RATE(240, 0x09, 0),
++      RATE(360, 0x0d, 0),
++      RATE(480, 0x08, 0),
++      RATE(540, 0x0c, 0),
 +};
 +
  static void ath_cache_conf_rate(struct ath_softc *sc,
                break;
        default:
                BUG_ON(1);
-@@ -191,51 +225,6 @@ static u8 parse_mpdudensity(u8 mpdudensi
+@@ -191,51 +209,6 @@ static u8 parse_mpdudensity(u8 mpdudensi
        }
  }
  
  static struct ath9k_channel *ath_get_curchannel(struct ath_softc *sc,
                                                struct ieee80211_hw *hw)
  {
-@@ -1713,12 +1702,6 @@ static int ath_init_softc(u16 devid, str
+@@ -1713,12 +1686,6 @@ static int ath_init_softc(u16 devid, str
        /* default to MONITOR mode */
        sc->sc_ah->opmode = NL80211_IFTYPE_MONITOR;
  
        /*
         * Allocate hardware transmit queues: one queue for
         * beacon frames and one data queue for each QoS
-@@ -1839,19 +1822,22 @@ static int ath_init_softc(u16 devid, str
+@@ -1839,19 +1806,22 @@ static int ath_init_softc(u16 devid, str
        /* setup channels and rates */
  
        sc->sbands[IEEE80211_BAND_2GHZ].channels = ath9k_2ghz_chantable;
        struct {
                int valid;
                int valid_single_stream;
-@@ -111,14 +112,12 @@ struct ath_rate_table {
-               u32 ratekbps;
-               u32 user_ratekbps;
-               u8 ratecode;
--              u8 short_preamble;
-               u8 dot11rate;
-               u8 ctrl_rate;
-               u8 base_index;
-               u8 cw40index;
-               u8 sgi_index;
-               u8 ht_index;
--              u32 max_4ms_framelen;
-       } info[RATE_TABLE_SIZE];
-       u32 probe_interval;
-       u8 initial_ratemax;
-@@ -179,8 +178,6 @@ enum ath9k_internal_frame_type {
+@@ -179,8 +180,6 @@ enum ath9k_internal_frame_type {
        ATH9K_INT_UNPAUSE
  };
  
  
 -      rt = sc->cur_rate_table;
 -      rate = rt->info[0].ratecode;
-+      sband = &sc->sbands[sc->hw->conf.channel->band];
++      sband = &sc->sbands[common->hw->conf.channel->band];
 +      rate = sband->bitrates[0].hw_value;
        if (sc->sc_flags & SC_OP_PREAMBLE_SHORT)
 -              rate |= rt->info[0].short_preamble;
diff --git a/package/mac80211/patches/561-ath9k_rc_table_cleanup.patch b/package/mac80211/patches/561-ath9k_rc_table_cleanup.patch
new file mode 100644 (file)
index 0000000..64bf9a6
--- /dev/null
@@ -0,0 +1,477 @@
+--- a/drivers/net/wireless/ath/ath9k/rc.h
++++ b/drivers/net/wireless/ath/ath9k/rc.h
+@@ -112,14 +112,12 @@ struct ath_rate_table {
+               u32 ratekbps;
+               u32 user_ratekbps;
+               u8 ratecode;
+-              u8 short_preamble;
+               u8 dot11rate;
+               u8 ctrl_rate;
+               u8 base_index;
+               u8 cw40index;
+               u8 sgi_index;
+               u8 ht_index;
+-              u32 max_4ms_framelen;
+       } info[RATE_TABLE_SIZE];
+       u32 probe_interval;
+       u8 initial_ratemax;
+--- a/drivers/net/wireless/ath/ath9k/rc.c
++++ b/drivers/net/wireless/ath/ath9k/rc.c
+@@ -22,131 +22,89 @@ static const struct ath_rate_table ar541
+       8, /* MCS start */
+       {
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 6000, /* 6 Mb */
+-                      5400, 0x0b, 0x00, 12,
+-                      0, 0, 0, 0, 0, 0 },
++                      5400, 0, 12, 0, 0, 0, 0, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */
+-                      7800,  0x0f, 0x00, 18,
+-                      0, 1, 1, 1, 1, 0 },
++                      7800,  1, 18, 0, 1, 1, 1, 1 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */
+-                      10000, 0x0a, 0x00, 24,
+-                      2, 2, 2, 2, 2, 0 },
++                      10000, 2, 24, 2, 2, 2, 2, 2 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */
+-                      13900, 0x0e, 0x00, 36,
+-                      2,  3, 3, 3, 3, 0 },
++                      13900, 3, 36, 2, 3, 3, 3, 3 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */
+-                      17300, 0x09, 0x00, 48,
+-                      4,  4, 4, 4, 4, 0 },
++                      17300, 4, 48, 4, 4, 4, 4, 4 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */
+-                      23000, 0x0d, 0x00, 72,
+-                      4,  5, 5, 5, 5, 0 },
++                      23000, 5, 72, 4, 5, 5, 5, 5 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */
+-                      27400, 0x08, 0x00, 96,
+-                      4,  6, 6, 6, 6, 0 },
++                      27400, 6, 96, 4, 6, 6, 6, 6 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */
+-                      29300, 0x0c, 0x00, 108,
+-                      4,  7, 7, 7, 7, 0 },
++                      29300, 7, 108, 4, 7, 7, 7, 7 },
+               { VALID_2040, VALID_2040, WLAN_RC_PHY_HT_20_SS, 6500, /* 6.5 Mb */
+-                      6400, 0x80, 0x00, 0,
+-                      0, 8, 24, 8, 24, 3216 },
++                      6400, 0, 0, 0, 8, 24, 8, 24 },
+               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 13000, /* 13 Mb */
+-                      12700, 0x81, 0x00, 1,
+-                      2, 9, 25, 9, 25, 6434 },
++                      12700, 1, 1, 2, 9, 25, 9, 25 },
+               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 19500, /* 19.5 Mb */
+-                      18800, 0x82, 0x00, 2,
+-                      2, 10, 26, 10, 26, 9650 },
++                      18800, 2, 2, 2, 10, 26, 10, 26 },
+               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 26000, /* 26 Mb */
+-                      25000, 0x83, 0x00, 3,
+-                      4,  11, 27, 11, 27, 12868 },
++                      25000, 3, 3, 4, 11, 27, 11, 27 },
+               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 39000, /* 39 Mb */
+-                      36700, 0x84, 0x00, 4,
+-                      4,  12, 28, 12, 28, 19304 },
++                      36700, 4, 4, 4, 12, 28, 12, 28 },
+               { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 52000, /* 52 Mb */
+-                      48100, 0x85, 0x00, 5,
+-                      4,  13, 29, 13, 29, 25740 },
++                      48100, 5, 5, 4, 13, 29, 13, 29 },
+               { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 58500, /* 58.5 Mb */
+-                      53500, 0x86, 0x00, 6,
+-                      4,  14, 30, 14, 30,  28956 },
++                      53500, 6, 6, 4, 14, 30, 14, 30 },
+               { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 65000, /* 65 Mb */
+-                      59000, 0x87, 0x00, 7,
+-                      4,  15, 31, 15, 32, 32180 },
++                      59000, 7, 7, 4, 15, 31, 15, 32 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 13000, /* 13 Mb */
+-                      12700, 0x88, 0x00,
+-                      8, 3, 16, 33, 16, 33, 6430 },
++                      12700, 8, 8, 3, 16, 33, 16, 33 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 26000, /* 26 Mb */
+-                      24800, 0x89, 0x00, 9,
+-                      2, 17, 34, 17, 34, 12860 },
++                      24800, 9, 9, 2, 17, 34, 17, 34 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 39000, /* 39 Mb */
+-                      36600, 0x8a, 0x00, 10,
+-                      2, 18, 35, 18, 35, 19300 },
++                      36600, 10, 10, 2, 18, 35, 18, 35 },
+               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 52000, /* 52 Mb */
+-                      48100, 0x8b, 0x00, 11,
+-                      4,  19, 36, 19, 36, 25736 },
++                      48100, 11, 11, 4, 19, 36, 19, 36 },
+               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 78000, /* 78 Mb */
+-                      69500, 0x8c, 0x00, 12,
+-                      4,  20, 37, 20, 37, 38600 },
++                      69500, 12, 12, 4, 20, 37, 20, 37 },
+               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 104000, /* 104 Mb */
+-                      89500, 0x8d, 0x00, 13,
+-                      4,  21, 38, 21, 38, 51472 },
++                      89500, 13, 13, 4, 21, 38, 21, 38 },
+               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 117000, /* 117 Mb */
+-                      98900, 0x8e, 0x00, 14,
+-                      4,  22, 39, 22, 39, 57890 },
++                      98900, 14, 14, 4, 22, 39, 22, 39 },
+               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 130000, /* 130 Mb */
+-                      108300, 0x8f, 0x00, 15,
+-                      4,  23, 40, 23, 41, 64320 },
++                      108300, 15, 15, 4, 23, 40, 23, 41 },
+               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 13500, /* 13.5 Mb */
+-                      13200, 0x80, 0x00, 0,
+-                      0, 8, 24, 24, 24, 6684 },
++                      13200, 0, 0, 0, 8, 24, 24, 24 },
+               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 27500, /* 27.0 Mb */
+-                      25900, 0x81, 0x00, 1,
+-                      2, 9, 25, 25, 25, 13368 },
++                      25900, 1, 1, 2, 9, 25, 25, 25 },
+               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 40500, /* 40.5 Mb */
+-                      38600, 0x82, 0x00, 2,
+-                      2, 10, 26, 26, 26, 20052 },
++                      38600, 2, 2, 2, 10, 26, 26, 26 },
+               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 54000, /* 54 Mb */
+-                      49800, 0x83, 0x00, 3,
+-                      4,  11, 27, 27, 27, 26738 },
++                      49800, 3, 3, 4, 11, 27, 27, 27 },
+               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 81500, /* 81 Mb */
+-                      72200, 0x84, 0x00, 4,
+-                      4,  12, 28, 28, 28, 40104 },
++                      72200, 4, 4, 4, 12, 28, 28, 28 },
+               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 108000, /* 108 Mb */
+-                      92900, 0x85, 0x00, 5,
+-                      4,  13, 29, 29, 29, 53476 },
++                      92900, 5, 5, 4, 13, 29, 29, 29 },
+               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 121500, /* 121.5 Mb */
+-                      102700, 0x86, 0x00, 6,
+-                      4,  14, 30, 30, 30, 60156 },
++                      102700, 6, 6, 4, 14, 30, 30, 30 },
+               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 135000, /* 135 Mb */
+-                      112000, 0x87, 0x00, 7,
+-                      4,  15, 31, 32, 32, 66840 },
++                      112000, 7, 7, 4, 15, 31, 32, 32 },
+               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS_HGI, 150000, /* 150 Mb */
+-                      122000, 0x87, 0x00, 7,
+-                      4,  15, 31, 32, 32, 74200 },
++                      122000, 7, 7, 4, 15, 31, 32, 32 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 27000, /* 27 Mb */
+-                      25800, 0x88, 0x00, 8,
+-                      0, 16, 33, 33, 33, 13360 },
++                      25800, 8, 8, 0, 16, 33, 33, 33 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 54000, /* 54 Mb */
+-                      49800, 0x89, 0x00, 9,
+-                      2, 17, 34, 34, 34, 26720 },
++                      49800, 9, 9, 2, 17, 34, 34, 34 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 81000, /* 81 Mb */
+-                      71900, 0x8a, 0x00, 10,
+-                      2, 18, 35, 35, 35, 40080 },
++                      71900, 10, 10, 2, 18, 35, 35, 35 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 108000, /* 108 Mb */
+-                      92500, 0x8b, 0x00, 11,
+-                      4,  19, 36, 36, 36, 53440 },
++                      92500, 11, 11, 4, 19, 36, 36, 36 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 162000, /* 162 Mb */
+-                      130300, 0x8c, 0x00, 12,
+-                      4,  20, 37, 37, 37, 80160 },
++                      130300, 12, 12, 4, 20, 37, 37, 37 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 216000, /* 216 Mb */
+-                      162800, 0x8d, 0x00, 13,
+-                      4,  21, 38, 38, 38, 106880 },
++                      162800, 13, 13, 4, 21, 38, 38, 38 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 243000, /* 243 Mb */
+-                      178200, 0x8e, 0x00, 14,
+-                      4,  22, 39, 39, 39, 120240 },
++                      178200, 14, 14, 4, 22, 39, 39, 39 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 270000, /* 270 Mb */
+-                      192100, 0x8f, 0x00, 15,
+-                      4,  23, 40, 41, 41, 133600 },
++                      192100, 15, 15, 4, 23, 40, 41, 41 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS_HGI, 300000, /* 300 Mb */
+-                      207000, 0x8f, 0x00, 15,
+-                      4,  23, 40, 41, 41, 148400 },
++                      207000, 15, 15, 4, 23, 40, 41, 41 },
+       },
+       50,  /* probe interval */
+       WLAN_RC_HT_FLAG,  /* Phy rates allowed initially */
+@@ -160,144 +118,98 @@ static const struct ath_rate_table ar541
+       12, /* MCS start */
+       {
+               { VALID_ALL, VALID_ALL, WLAN_RC_PHY_CCK, 1000, /* 1 Mb */
+-                      900, 0x1b, 0x00, 2,
+-                      0, 0, 0, 0, 0, 0 },
++                      900, 0, 2, 0, 0, 0, 0, 0 },
+               { VALID_ALL, VALID_ALL, WLAN_RC_PHY_CCK, 2000, /* 2 Mb */
+-                      1900, 0x1a, 0x04, 4,
+-                      1, 1, 1, 1, 1, 0 },
++                      1900, 1, 4, 1, 1, 1, 1, 1 },
+               { VALID_ALL, VALID_ALL, WLAN_RC_PHY_CCK, 5500, /* 5.5 Mb */
+-                      4900, 0x19, 0x04, 11,
+-                      2, 2, 2, 2, 2, 0 },
++                      4900, 2, 11, 2, 2, 2, 2, 2 },
+               { VALID_ALL, VALID_ALL, WLAN_RC_PHY_CCK, 11000, /* 11 Mb */
+-                      8100, 0x18, 0x04, 22,
+-                      3, 3, 3, 3, 3, 0 },
++                      8100, 3, 22, 3, 3, 3, 3, 3 },
+               { INVALID, INVALID, WLAN_RC_PHY_OFDM, 6000, /* 6 Mb */
+-                      5400, 0x0b, 0x00, 12,
+-                      4, 4, 4, 4, 4, 0 },
++                      5400, 4, 12, 4, 4, 4, 4, 4 },
+               { INVALID, INVALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */
+-                      7800, 0x0f, 0x00, 18,
+-                      4, 5, 5, 5, 5, 0 },
++                      7800, 5, 18, 4, 5, 5, 5, 5 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */
+-                      10100, 0x0a, 0x00, 24,
+-                      6, 6, 6, 6, 6, 0 },
++                      10100, 6, 24, 6, 6, 6, 6, 6 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */
+-                      14100,  0x0e, 0x00, 36,
+-                      6, 7, 7, 7, 7, 0 },
++                      14100, 7, 36, 6, 7, 7, 7, 7 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */
+-                      17700, 0x09, 0x00, 48,
+-                      8,  8, 8, 8, 8, 0 },
++                      17700, 8, 48, 8, 8, 8, 8, 8 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */
+-                      23700, 0x0d, 0x00, 72,
+-                      8,  9, 9, 9, 9, 0 },
++                      23700, 9, 72, 8, 9, 9, 9, 9 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */
+-                      27400, 0x08, 0x00, 96,
+-                      8,  10, 10, 10, 10, 0 },
++                      27400, 10, 96, 8, 10, 10, 10, 10 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */
+-                      30900, 0x0c, 0x00, 108,
+-                      8,  11, 11, 11, 11, 0 },
++                      30900, 11, 108, 8, 11, 11, 11, 11 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_20_SS, 6500, /* 6.5 Mb */
+-                      6400, 0x80, 0x00, 0,
+-                      4, 12, 28, 12, 28, 3216 },
++                      6400, 0, 0, 4, 12, 28, 12, 28 },
+               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 13000, /* 13 Mb */
+-                      12700, 0x81, 0x00, 1,
+-                      6, 13, 29, 13, 29, 6434 },
++                      12700, 1, 1, 6, 13, 29, 13, 29 },
+               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 19500, /* 19.5 Mb */
+-                      18800, 0x82, 0x00, 2,
+-                      6, 14, 30, 14, 30, 9650 },
++                      18800, 2, 2, 6, 14, 30, 14, 30 },
+               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 26000, /* 26 Mb */
+-                      25000, 0x83, 0x00, 3,
+-                      8,  15, 31, 15, 31, 12868 },
++                      25000, 3, 3, 8, 15, 31, 15, 31 },
+               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 39000, /* 39 Mb */
+-                      36700, 0x84, 0x00, 4,
+-                      8,  16, 32, 16, 32, 19304 },
++                      36700, 4, 4, 8, 16, 32, 16, 32 },
+               { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 52000, /* 52 Mb */
+-                      48100, 0x85, 0x00, 5,
+-                      8,  17, 33, 17, 33, 25740 },
++                      48100, 5, 5, 8, 17, 33, 17, 33 },
+               { INVALID,  VALID_20, WLAN_RC_PHY_HT_20_SS, 58500, /* 58.5 Mb */
+-                      53500, 0x86, 0x00, 6,
+-                      8,  18, 34, 18, 34, 28956 },
++                      53500, 6, 6, 8, 18, 34, 18, 34 },
+               { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 65000, /* 65 Mb */
+-                      59000, 0x87, 0x00, 7,
+-                      8,  19, 35, 19, 36, 32180 },
++                      59000, 7, 7, 8, 19, 35, 19, 36 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 13000, /* 13 Mb */
+-                      12700, 0x88, 0x00, 8,
+-                      4, 20, 37, 20, 37, 6430 },
++                      12700, 8, 8, 4, 20, 37, 20, 37 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 26000, /* 26 Mb */
+-                      24800, 0x89, 0x00, 9,
+-                      6, 21, 38, 21, 38, 12860 },
++                      24800, 9, 9, 6, 21, 38, 21, 38 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 39000, /* 39 Mb */
+-                      36600, 0x8a, 0x00, 10,
+-                      6, 22, 39, 22, 39, 19300 },
++                      36600, 10, 10, 6, 22, 39, 22, 39 },
+               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 52000, /* 52 Mb */
+-                      48100, 0x8b, 0x00, 11,
+-                      8,  23, 40, 23, 40, 25736 },
++                      48100, 11, 11, 8, 23, 40, 23, 40 },
+               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 78000, /* 78 Mb */
+-                      69500, 0x8c, 0x00, 12,
+-                      8,  24, 41, 24, 41, 38600 },
++                      69500, 12, 12, 8, 24, 41, 24, 41 },
+               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 104000, /* 104 Mb */
+-                      89500, 0x8d, 0x00, 13,
+-                      8,  25, 42, 25, 42, 51472 },
++                      89500, 13, 13, 8, 25, 42, 25, 42 },
+               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 117000, /* 117 Mb */
+-                      98900, 0x8e, 0x00, 14,
+-                      8,  26, 43, 26, 44, 57890 },
++                      98900, 14, 14, 8, 26, 43, 26, 44 },
+               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 130000, /* 130 Mb */
+-                      108300, 0x8f, 0x00, 15,
+-                      8,  27, 44, 27, 45, 64320 },
++                      108300, 15, 15, 8, 27, 44, 27, 45 },
+               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 13500, /* 13.5 Mb */
+-                      13200, 0x80, 0x00, 0,
+-                      8, 12, 28, 28, 28, 6684 },
++                      13200, 0, 0, 8, 12, 28, 28, 28 },
+               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 27500, /* 27.0 Mb */
+-                      25900, 0x81, 0x00, 1,
+-                      8, 13, 29, 29, 29, 13368 },
++                      25900, 1, 1, 8, 13, 29, 29, 29 },
+               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 40500, /* 40.5 Mb */
+-                      38600, 0x82, 0x00, 2,
+-                      8, 14, 30, 30, 30, 20052 },
++                      38600, 2, 2, 8, 14, 30, 30, 30 },
+               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 54000, /* 54 Mb */
+-                      49800, 0x83, 0x00, 3,
+-                      8,  15, 31, 31, 31, 26738 },
++                      49800, 3, 3, 8,  15, 31, 31, 31 },
+               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 81500, /* 81 Mb */
+-                      72200, 0x84, 0x00, 4,
+-                      8,  16, 32, 32, 32, 40104 },
++                      72200, 4, 4, 8, 16, 32, 32, 32 },
+               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 108000, /* 108 Mb */
+-                      92900, 0x85, 0x00, 5,
+-                      8,  17, 33, 33, 33, 53476 },
++                      92900, 5, 5, 8, 17, 33, 33, 33 },
+               { INVALID,  VALID_40, WLAN_RC_PHY_HT_40_SS, 121500, /* 121.5 Mb */
+-                      102700, 0x86, 0x00, 6,
+-                      8,  18, 34, 34, 34, 60156 },
++                      102700, 6, 6, 8, 18, 34, 34, 34 },
+               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 135000, /* 135 Mb */
+-                      112000, 0x87, 0x00, 7,
+-                      8,  19, 35, 36, 36, 66840 },
++                      112000, 7, 7, 8, 19, 35, 36, 36 },
+               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS_HGI, 150000, /* 150 Mb */
+-                      122000, 0x87, 0x00, 7,
+-                      8,  19, 35, 36, 36, 74200 },
++                      122000, 7, 7, 8, 19, 35, 36, 36 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 27000, /* 27 Mb */
+-                      25800, 0x88, 0x00, 8,
+-                      8, 20, 37, 37, 37, 13360 },
++                      25800, 8, 8, 8, 20, 37, 37, 37 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 54000, /* 54 Mb */
+-                      49800, 0x89, 0x00, 9,
+-                      8, 21, 38, 38, 38, 26720 },
++                      49800, 9, 9, 8, 21, 38, 38, 38 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 81000, /* 81 Mb */
+-                      71900, 0x8a, 0x00, 10,
+-                      8, 22, 39, 39, 39, 40080 },
++                      71900, 10, 10, 8, 22, 39, 39, 39 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 108000, /* 108 Mb */
+-                      92500, 0x8b, 0x00, 11,
+-                      8,  23, 40, 40, 40, 53440 },
++                      92500, 11, 11, 8, 23, 40, 40, 40 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 162000, /* 162 Mb */
+-                      130300, 0x8c, 0x00, 12,
+-                      8,  24, 41, 41, 41, 80160 },
++                      130300, 12, 12, 8, 24, 41, 41, 41 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 216000, /* 216 Mb */
+-                      162800, 0x8d, 0x00, 13,
+-                      8,  25, 42, 42, 42, 106880 },
++                      162800, 13, 13, 8, 25, 42, 42, 42 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 243000, /* 243 Mb */
+-                      178200, 0x8e, 0x00, 14,
+-                      8,  26, 43, 43, 43, 120240 },
++                      178200, 14, 14, 8, 26, 43, 43, 43 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 270000, /* 270 Mb */
+-                      192100, 0x8f, 0x00, 15,
+-                      8,  27, 44, 45, 45, 133600 },
++                      192100, 15, 15, 8, 27, 44, 45, 45 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS_HGI, 300000, /* 300 Mb */
+-                      207000, 0x8f, 0x00, 15,
+-                      8,  27, 44, 45, 45, 148400 },
+-              },
++                      207000, 15, 15, 8, 27, 44, 45, 45 },
++      },
+       50,  /* probe interval */
+       WLAN_RC_HT_FLAG,  /* Phy rates allowed initially */
+ };
+@@ -307,29 +219,21 @@ static const struct ath_rate_table ar541
+       0,
+       {
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 6000, /* 6 Mb */
+-                      5400, 0x0b, 0x00, (0x80|12),
+-                      0, 0, 0 },
++                      5400, 0, 12, 0, 0, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */
+-                      7800, 0x0f, 0x00, 18,
+-                      0, 1, 0 },
++                      7800,  1, 18, 0, 1, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */
+-                      10000, 0x0a, 0x00, (0x80|24),
+-                      2, 2, 0 },
++                      10000, 2, 24, 2, 2, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */
+-                      13900, 0x0e, 0x00, 36,
+-                      2, 3, 0 },
++                      13900, 3, 36, 2, 3, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */
+-                      17300, 0x09, 0x00, (0x80|48),
+-                      4,  4, 0 },
++                      17300, 4, 48, 4, 4, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */
+-                      23000, 0x0d, 0x00, 72,
+-                      4,  5, 0 },
++                      23000, 5, 72, 4, 5, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */
+-                      27400, 0x08, 0x00, 96,
+-                      4,  6, 0 },
++                      27400, 6, 96, 4, 6, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */
+-                      29300, 0x0c, 0x00, 108,
+-                      4,  7, 0 },
++                      29300, 7, 108, 4, 7, 0 },
+       },
+       50,  /* probe interval */
+       0,   /* Phy rates allowed initially */
+@@ -340,41 +244,29 @@ static const struct ath_rate_table ar541
+       0,
+       {
+               { VALID, VALID, WLAN_RC_PHY_CCK, 1000, /* 1 Mb */
+-                      900, 0x1b, 0x00, 2,
+-                      0, 0, 0 },
++                      900, 0, 2, 0, 0, 0 },
+               { VALID, VALID, WLAN_RC_PHY_CCK, 2000, /* 2 Mb */
+-                      1900, 0x1a, 0x04, 4,
+-                      1, 1, 0 },
++                      1900, 1, 4, 1, 1, 0 },
+               { VALID, VALID, WLAN_RC_PHY_CCK, 5500, /* 5.5 Mb */
+-                      4900, 0x19, 0x04, 11,
+-                      2, 2, 0 },
++                      4900, 2, 11, 2, 2, 0 },
+               { VALID, VALID, WLAN_RC_PHY_CCK, 11000, /* 11 Mb */
+-                      8100, 0x18, 0x04, 22,
+-                      3, 3, 0 },
++                      8100, 3, 22, 3, 3, 0 },
+               { INVALID, INVALID, WLAN_RC_PHY_OFDM, 6000, /* 6 Mb */
+-                      5400, 0x0b, 0x00, 12,
+-                      4, 4, 0 },
++                      5400, 4, 12, 4, 4, 0 },
+               { INVALID, INVALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */
+-                      7800, 0x0f, 0x00, 18,
+-                      4, 5, 0 },
++                      7800, 5, 18, 4, 5, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */
+-                      10000, 0x0a, 0x00, 24,
+-                      6, 6, 0 },
++                      10000, 6, 24, 6, 6, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */
+-                      13900, 0x0e, 0x00, 36,
+-                      6, 7, 0 },
++                      13900, 7, 36, 6, 7, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */
+-                      17300, 0x09, 0x00, 48,
+-                      8,  8, 0 },
++                      17300, 8, 48, 8, 8, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */
+-                      23000, 0x0d, 0x00, 72,
+-                      8,  9, 0 },
++                      23000, 9, 72, 8, 9, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */
+-                      27400, 0x08, 0x00, 96,
+-                      8,  10, 0 },
++                      27400, 10, 96, 8, 10, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */
+-                      29300, 0x0c, 0x00, 108,
+-                      8,  11, 0 },
++                      29300, 11, 108, 8, 11, 0 },
+       },
+       50,  /* probe interval */
+       0,   /* Phy rates allowed initially */