mac80211: update to compat-wireless 2009-11-21
authorFelix Fietkau <nbd@openwrt.org>
Sun, 22 Nov 2009 07:13:30 +0000 (07:13 +0000)
committerFelix Fietkau <nbd@openwrt.org>
Sun, 22 Nov 2009 07:13:30 +0000 (07:13 +0000)
SVN-Revision: 18465

20 files changed:
package/mac80211/Makefile
package/mac80211/patches/002-disable_rfkill.patch
package/mac80211/patches/010-b43_config.patch
package/mac80211/patches/011-move_ar9170_usb_compat_code.patch
package/mac80211/patches/012-remove_rfkill.patch
package/mac80211/patches/403-ath9k-fix-invalid-mac-address-handling.patch
package/mac80211/patches/404-ath_regd_optional.patch
package/mac80211/patches/406-ath9k-set-AH_USE_EEPROM-only-if-no-platform-data-present.patch
package/mac80211/patches/500-4addr_bcast_fix.patch [deleted file]
package/mac80211/patches/500-ath9k_rate_control_api.patch [new file with mode: 0644]
package/mac80211/patches/501-ath9k_rc_table_cleanup.patch [new file with mode: 0644]
package/mac80211/patches/510-ath_use_gfp_dma.patch [new file with mode: 0644]
package/mac80211/patches/510-nl80211_vlan_add_fix.patch [deleted file]
package/mac80211/patches/520-driver_flags.patch [deleted file]
package/mac80211/patches/530-ath9k_cleanup.patch [deleted file]
package/mac80211/patches/540-monitor_tx_status.patch [deleted file]
package/mac80211/patches/550-ath9k_rx_fix.patch [deleted file]
package/mac80211/patches/560-ath9k_rate_control_api.patch [deleted file]
package/mac80211/patches/561-ath9k_rc_table_cleanup.patch [deleted file]
package/mac80211/patches/570-ath_use_gfp_dma.patch [deleted file]

index d28e08d3adea867130fefcbc82ef7f19758e7d34..aef79373d7ef2f66cf4e496a76c07a89221406f7 100644 (file)
@@ -10,12 +10,12 @@ include $(INCLUDE_DIR)/kernel.mk
 
 PKG_NAME:=mac80211
 
-PKG_VERSION:=2009-11-13
-PKG_RELEASE:=2
+PKG_VERSION:=2009-11-21
+PKG_RELEASE:=1
 PKG_SOURCE_URL:= \
        http://www.orbit-lab.org/kernel/compat-wireless-2.6/2009/11 \
        http://wireless.kernel.org/download/compat-wireless-2.6
-PKG_MD5SUM:=920c3bcfd1b4cd6079a8f9db4afe4e4f
+PKG_MD5SUM:=00e80559cddaa160605098572f5c58b8
 
 PKG_SOURCE:=compat-wireless-$(PKG_VERSION).tar.bz2
 PKG_BUILD_DIR:=$(KERNEL_BUILD_DIR)/compat-wireless-$(PKG_VERSION)
index 3aab629702110914b193fa6d554f92300c388246..c935fddf3505aacd6e14aa03879df731408e8703 100644 (file)
@@ -1,42 +1,6 @@
 --- a/config.mk
 +++ b/config.mk
-@@ -147,7 +147,7 @@ ifneq ($(CONFIG_PCI),)
- CONFIG_ATH5K=m
- # CONFIG_ATH5K_DEBUG=y
--CONFIG_ATH5K_RFKILL=y
-+# CONFIG_ATH5K_RFKILL=y
- CONFIG_ATH9K_HW=m
- CONFIG_ATH9K=m
- # Note: once ath9k_htc is added we'll have to move
-@@ -159,7 +159,7 @@ CONFIG_ATH9K_COMMON=m
- CONFIG_IWLWIFI=m
- CONFIG_IWLWIFI_LEDS=y
--CONFIG_IWLWIFI_RFKILL=y
-+# CONFIG_IWLWIFI_RFKILL=y
- CONFIG_IWLWIFI_SPECTRUM_MEASUREMENT=y
- # CONFIG_IWLWIFI_DEBUG=y
- # CONFIG_IWLWIFI_DEBUGFS=y
-@@ -179,7 +179,7 @@ CONFIG_B43_PCMCIA=y
- endif
- CONFIG_B43_PIO=y
- CONFIG_B43_LEDS=y
--CONFIG_B43_RFKILL=y
-+# CONFIG_B43_RFKILL=y
- CONFIG_B43_PHY_LP=y
- # CONFIG_B43_DEBUG=y
- # CONFIG_B43_FORCE_PIO=y
-@@ -189,7 +189,7 @@ CONFIG_B43LEGACY_HWRNG=y
- CONFIG_B43LEGACY_PCI_AUTOSELECT=y
- CONFIG_B43LEGACY_PCICORE_AUTOSELECT=y
- CONFIG_B43LEGACY_LEDS=y
--CONFIG_B43LEGACY_RFKILL=y
-+# CONFIG_B43LEGACY_RFKILL=y
- # CONFIG_B43LEGACY_DEBUG=y
- CONFIG_B43LEGACY_DMA=y
- CONFIG_B43LEGACY_PIO=y
-@@ -422,8 +422,8 @@ endif
+@@ -421,8 +421,8 @@ endif
  # We need the backported rfkill module on kernel < 2.6.31.
  # In more recent kernel versions use the in kernel rfkill module.
  ifdef CONFIG_COMPAT_WIRELESS_31
index 9074ee787446f0e114734adf2a7743f715a91e8e..8c5253550a4acba2f04cf639558f5c5d20d8bd45 100644 (file)
@@ -1,6 +1,6 @@
 --- a/config.mk
 +++ b/config.mk
-@@ -160,12 +160,12 @@ CONFIG_B43_HWRNG=y
+@@ -160,9 +160,9 @@ CONFIG_B43_HWRNG=y
  CONFIG_B43_PCI_AUTOSELECT=y
  CONFIG_B43_PCICORE_AUTOSELECT=y
  ifneq ($(CONFIG_PCMCIA),)
 -CONFIG_B43_PIO=y
 +# CONFIG_B43_PIO=y
  CONFIG_B43_LEDS=y
- # CONFIG_B43_RFKILL=y
--CONFIG_B43_PHY_LP=y
-+# CONFIG_B43_PHY_LP=y
+ CONFIG_B43_PHY_LP=y
  # CONFIG_B43_DEBUG=y
- # CONFIG_B43_FORCE_PIO=y
-@@ -219,8 +219,8 @@ CONFIG_SSB_PCIHOST_POSSIBLE=y
+@@ -217,8 +217,8 @@ CONFIG_SSB_PCIHOST_POSSIBLE=y
  CONFIG_SSB_PCIHOST=y
  CONFIG_SSB_B43_PCI_BRIDGE=y
  ifneq ($(CONFIG_PCMCIA),)
index 036d56301fcc25b741199694f7b73be90037e9fd..52b90b004da86e552c2aa51fe496b88474a93289 100644 (file)
@@ -1,6 +1,6 @@
 --- a/drivers/net/wireless/ath/ar9170/usb.c
 +++ b/drivers/net/wireless/ath/ar9170/usb.c
-@@ -98,6 +98,225 @@ static struct usb_device_id ar9170_usb_i
+@@ -100,6 +100,225 @@ static struct usb_device_id ar9170_usb_i
  };
  MODULE_DEVICE_TABLE(usb, ar9170_usb_ids);
  
index 53262edd0b00774d3b43910b1d1904d7e6177d46..a47168a05cf5eb30db9b0f70e504dccd7315d629 100644 (file)
@@ -22,7 +22,7 @@
  #include <linux/rfkill_backport.h>
 --- a/include/linux/rfkill_backport.h
 +++ b/include/linux/rfkill_backport.h
-@@ -146,7 +146,7 @@ struct rfkill_ops {
+@@ -149,7 +149,7 @@ struct rfkill_ops {
        int     (*set_block)(void *data, bool blocked);
  };
  
index 1780fc7b31fa750b3bacd3f41d2cb6056c12050c..687d9e4775348110a6a9521f6879e0e96a6cc5fd 100644 (file)
@@ -8,7 +8,7 @@
  #include <asm/unaligned.h>
  
  #include "hw.h"
-@@ -494,8 +495,18 @@ static int ath9k_hw_init_macaddr(struct 
+@@ -489,8 +490,18 @@ static int ath9k_hw_init_macaddr(struct 
                common->macaddr[2 * i] = eeval >> 8;
                common->macaddr[2 * i + 1] = eeval & 0xff;
        }
index 58ed4bdbebfe7598bd57addc056626c1fec1b452..a5413697ba3ad12d834868b4ea97dbecce280603 100644 (file)
@@ -10,7 +10,7 @@
  #include "regd_common.h"
  
  /*
-@@ -588,3 +591,5 @@ u32 ath_regd_get_band_ctl(struct ath_reg
+@@ -587,3 +590,5 @@ u32 ath_regd_get_band_ctl(struct ath_reg
        }
  }
  EXPORT_SYMBOL(ath_regd_get_band_ctl);
index 8beb224c9105cf223edc04ffa6531fc58c70de5c..734dea0306b3d3548c64bf87d70c285f6d496aa8 100644 (file)
@@ -1,6 +1,6 @@
 --- a/drivers/net/wireless/ath/ath9k/hw.c
 +++ b/drivers/net/wireless/ath/ath9k/hw.c
-@@ -433,11 +433,8 @@ static void ath9k_hw_init_defaults(struc
+@@ -431,11 +431,8 @@ static void ath9k_hw_init_defaults(struc
        ah->hw_version.magic = AR5416_MAGIC;
        ah->hw_version.subvendorid = 0;
  
diff --git a/package/mac80211/patches/500-4addr_bcast_fix.patch b/package/mac80211/patches/500-4addr_bcast_fix.patch
deleted file mode 100644 (file)
index 3143aaf..0000000
+++ /dev/null
@@ -1,11 +0,0 @@
---- a/net/mac80211/rx.c
-+++ b/net/mac80211/rx.c
-@@ -1236,7 +1236,7 @@ ieee80211_deliver_skb(struct ieee80211_r
-       if ((sdata->vif.type == NL80211_IFTYPE_AP ||
-            sdata->vif.type == NL80211_IFTYPE_AP_VLAN) &&
-           !(sdata->flags & IEEE80211_SDATA_DONT_BRIDGE_PACKETS) &&
--          (rx->flags & IEEE80211_RX_RA_MATCH)) {
-+          (rx->flags & IEEE80211_RX_RA_MATCH) && !rx->sdata->use_4addr) {
-               if (is_multicast_ether_addr(ehdr->h_dest)) {
-                       /*
-                        * send multicast frames both to higher layers in
diff --git a/package/mac80211/patches/500-ath9k_rate_control_api.patch b/package/mac80211/patches/500-ath9k_rate_control_api.patch
new file mode 100644 (file)
index 0000000..fe476cb
--- /dev/null
@@ -0,0 +1,1244 @@
+--- a/drivers/net/wireless/ath/ath9k/rc.c
++++ b/drivers/net/wireless/ath/ath9k/rc.c
+@@ -19,132 +19,133 @@
+ 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,
++                      5400, 0, 0x00, 12,
+                       0, 0, 0, 0, 0, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */
+-                      7800,  0x0f, 0x00, 18,
++                      7800,  1, 0x00, 18,
+                       0, 1, 1, 1, 1, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */
+-                      10000, 0x0a, 0x00, 24,
++                      10000, 2, 0x00, 24,
+                       2, 2, 2, 2, 2, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */
+-                      13900, 0x0e, 0x00, 36,
++                      13900, 3, 0x00, 36,
+                       2,  3, 3, 3, 3, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */
+-                      17300, 0x09, 0x00, 48,
++                      17300, 4, 0x00, 48,
+                       4,  4, 4, 4, 4, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */
+-                      23000, 0x0d, 0x00, 72,
++                      23000, 5, 0x00, 72,
+                       4,  5, 5, 5, 5, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */
+-                      27400, 0x08, 0x00, 96,
++                      27400, 6, 0x00, 96,
+                       4,  6, 6, 6, 6, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */
+-                      29300, 0x0c, 0x00, 108,
++                      29300, 7, 0x00, 108,
+                       4,  7, 7, 7, 7, 0 },
+               { VALID_2040, VALID_2040, WLAN_RC_PHY_HT_20_SS, 6500, /* 6.5 Mb */
+-                      6400, 0x80, 0x00, 0,
++                      6400, 0, 0x00, 0,
+                       0, 8, 24, 8, 24, 3216 },
+               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 13000, /* 13 Mb */
+-                      12700, 0x81, 0x00, 1,
++                      12700, 1, 0x00, 1,
+                       2, 9, 25, 9, 25, 6434 },
+               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 19500, /* 19.5 Mb */
+-                      18800, 0x82, 0x00, 2,
++                      18800, 2, 0x00, 2,
+                       2, 10, 26, 10, 26, 9650 },
+               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 26000, /* 26 Mb */
+-                      25000, 0x83, 0x00, 3,
++                      25000, 3, 0x00, 3,
+                       4,  11, 27, 11, 27, 12868 },
+               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 39000, /* 39 Mb */
+-                      36700, 0x84, 0x00, 4,
++                      36700, 4, 0x00, 4,
+                       4,  12, 28, 12, 28, 19304 },
+               { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 52000, /* 52 Mb */
+-                      48100, 0x85, 0x00, 5,
++                      48100, 5, 0x00, 5,
+                       4,  13, 29, 13, 29, 25740 },
+               { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 58500, /* 58.5 Mb */
+-                      53500, 0x86, 0x00, 6,
++                      53500, 6, 0x00, 6,
+                       4,  14, 30, 14, 30,  28956 },
+               { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 65000, /* 65 Mb */
+-                      59000, 0x87, 0x00, 7,
++                      59000, 7, 0x00, 7,
+                       4,  15, 31, 15, 32, 32180 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 13000, /* 13 Mb */
+-                      12700, 0x88, 0x00,
++                      12700, 8, 0x00,
+                       8, 3, 16, 33, 16, 33, 6430 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 26000, /* 26 Mb */
+-                      24800, 0x89, 0x00, 9,
++                      24800, 9, 0x00, 9,
+                       2, 17, 34, 17, 34, 12860 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 39000, /* 39 Mb */
+-                      36600, 0x8a, 0x00, 10,
++                      36600, 10, 0x00, 10,
+                       2, 18, 35, 18, 35, 19300 },
+               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 52000, /* 52 Mb */
+-                      48100, 0x8b, 0x00, 11,
++                      48100, 11, 0x00, 11,
+                       4,  19, 36, 19, 36, 25736 },
+               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 78000, /* 78 Mb */
+-                      69500, 0x8c, 0x00, 12,
++                      69500, 12, 0x00, 12,
+                       4,  20, 37, 20, 37, 38600 },
+               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 104000, /* 104 Mb */
+-                      89500, 0x8d, 0x00, 13,
++                      89500, 13, 0x00, 13,
+                       4,  21, 38, 21, 38, 51472 },
+               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 117000, /* 117 Mb */
+-                      98900, 0x8e, 0x00, 14,
++                      98900, 14, 0x00, 14,
+                       4,  22, 39, 22, 39, 57890 },
+               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 130000, /* 130 Mb */
+-                      108300, 0x8f, 0x00, 15,
++                      108300, 15, 0x00, 15,
+                       4,  23, 40, 23, 41, 64320 },
+               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 13500, /* 13.5 Mb */
+-                      13200, 0x80, 0x00, 0,
++                      13200, 0, 0x00, 0,
+                       0, 8, 24, 24, 24, 6684 },
+               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 27500, /* 27.0 Mb */
+-                      25900, 0x81, 0x00, 1,
++                      25900, 1, 0x00, 1,
+                       2, 9, 25, 25, 25, 13368 },
+               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 40500, /* 40.5 Mb */
+-                      38600, 0x82, 0x00, 2,
++                      38600, 2, 0x00, 2,
+                       2, 10, 26, 26, 26, 20052 },
+               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 54000, /* 54 Mb */
+-                      49800, 0x83, 0x00, 3,
++                      49800, 3, 0x00, 3,
+                       4,  11, 27, 27, 27, 26738 },
+               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 81500, /* 81 Mb */
+-                      72200, 0x84, 0x00, 4,
++                      72200, 4, 0x00, 4,
+                       4,  12, 28, 28, 28, 40104 },
+               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 108000, /* 108 Mb */
+-                      92900, 0x85, 0x00, 5,
++                      92900, 5, 0x00, 5,
+                       4,  13, 29, 29, 29, 53476 },
+               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 121500, /* 121.5 Mb */
+-                      102700, 0x86, 0x00, 6,
++                      102700, 6, 0x00, 6,
+                       4,  14, 30, 30, 30, 60156 },
+               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 135000, /* 135 Mb */
+-                      112000, 0x87, 0x00, 7,
++                      112000, 7, 0x00, 7,
+                       4,  15, 31, 32, 32, 66840 },
+               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS_HGI, 150000, /* 150 Mb */
+-                      122000, 0x87, 0x00, 7,
++                      122000, 7, 0x00, 7,
+                       4,  15, 31, 32, 32, 74200 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 27000, /* 27 Mb */
+-                      25800, 0x88, 0x00, 8,
++                      25800, 8, 0x00, 8,
+                       0, 16, 33, 33, 33, 13360 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 54000, /* 54 Mb */
+-                      49800, 0x89, 0x00, 9,
++                      49800, 9, 0x00, 9,
+                       2, 17, 34, 34, 34, 26720 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 81000, /* 81 Mb */
+-                      71900, 0x8a, 0x00, 10,
++                      71900, 10, 0x00, 10,
+                       2, 18, 35, 35, 35, 40080 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 108000, /* 108 Mb */
+-                      92500, 0x8b, 0x00, 11,
++                      92500, 11, 0x00, 11,
+                       4,  19, 36, 36, 36, 53440 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 162000, /* 162 Mb */
+-                      130300, 0x8c, 0x00, 12,
++                      130300, 12, 0x00, 12,
+                       4,  20, 37, 37, 37, 80160 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 216000, /* 216 Mb */
+-                      162800, 0x8d, 0x00, 13,
++                      162800, 13, 0x00, 13,
+                       4,  21, 38, 38, 38, 106880 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 243000, /* 243 Mb */
+-                      178200, 0x8e, 0x00, 14,
++                      178200, 14, 0x00, 14,
+                       4,  22, 39, 39, 39, 120240 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 270000, /* 270 Mb */
+-                      192100, 0x8f, 0x00, 15,
++                      192100, 15, 0x00, 15,
+                       4,  23, 40, 41, 41, 133600 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS_HGI, 300000, /* 300 Mb */
+-                      207000, 0x8f, 0x00, 15,
++                      207000, 15, 0x00, 15,
+                       4,  23, 40, 41, 41, 148400 },
+       },
+       50,  /* probe interval */
+@@ -156,144 +157,145 @@ 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,
++                      900, 0, 0x00, 2,
+                       0, 0, 0, 0, 0, 0 },
+               { VALID_ALL, VALID_ALL, WLAN_RC_PHY_CCK, 2000, /* 2 Mb */
+-                      1900, 0x1a, 0x04, 4,
++                      1900, 1, 0x04, 4,
+                       1, 1, 1, 1, 1, 0 },
+               { VALID_ALL, VALID_ALL, WLAN_RC_PHY_CCK, 5500, /* 5.5 Mb */
+-                      4900, 0x19, 0x04, 11,
++                      4900, 2, 0x04, 11,
+                       2, 2, 2, 2, 2, 0 },
+               { VALID_ALL, VALID_ALL, WLAN_RC_PHY_CCK, 11000, /* 11 Mb */
+-                      8100, 0x18, 0x04, 22,
++                      8100, 3, 0x04, 22,
+                       3, 3, 3, 3, 3, 0 },
+               { INVALID, INVALID, WLAN_RC_PHY_OFDM, 6000, /* 6 Mb */
+-                      5400, 0x0b, 0x00, 12,
++                      5400, 4, 0x00, 12,
+                       4, 4, 4, 4, 4, 0 },
+               { INVALID, INVALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */
+-                      7800, 0x0f, 0x00, 18,
++                      7800, 5, 0x00, 18,
+                       4, 5, 5, 5, 5, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */
+-                      10100, 0x0a, 0x00, 24,
++                      10100, 6, 0x00, 24,
+                       6, 6, 6, 6, 6, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */
+-                      14100,  0x0e, 0x00, 36,
++                      14100, 7, 0x00, 36,
+                       6, 7, 7, 7, 7, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */
+-                      17700, 0x09, 0x00, 48,
++                      17700, 8, 0x00, 48,
+                       8,  8, 8, 8, 8, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */
+-                      23700, 0x0d, 0x00, 72,
++                      23700, 9, 0x00, 72,
+                       8,  9, 9, 9, 9, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */
+-                      27400, 0x08, 0x00, 96,
++                      27400, 10, 0x00, 96,
+                       8,  10, 10, 10, 10, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */
+-                      30900, 0x0c, 0x00, 108,
++                      30900, 11, 0x00, 108,
+                       8,  11, 11, 11, 11, 0 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_20_SS, 6500, /* 6.5 Mb */
+-                      6400, 0x80, 0x00, 0,
++                      6400, 0, 0x00, 0,
+                       4, 12, 28, 12, 28, 3216 },
+               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 13000, /* 13 Mb */
+-                      12700, 0x81, 0x00, 1,
++                      12700, 1, 0x00, 1,
+                       6, 13, 29, 13, 29, 6434 },
+               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 19500, /* 19.5 Mb */
+-                      18800, 0x82, 0x00, 2,
++                      18800, 2, 0x00, 2,
+                       6, 14, 30, 14, 30, 9650 },
+               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 26000, /* 26 Mb */
+-                      25000, 0x83, 0x00, 3,
++                      25000, 3, 0x00, 3,
+                       8,  15, 31, 15, 31, 12868 },
+               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 39000, /* 39 Mb */
+-                      36700, 0x84, 0x00, 4,
++                      36700, 4, 0x00, 4,
+                       8,  16, 32, 16, 32, 19304 },
+               { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 52000, /* 52 Mb */
+-                      48100, 0x85, 0x00, 5,
++                      48100, 5, 0x00, 5,
+                       8,  17, 33, 17, 33, 25740 },
+               { INVALID,  VALID_20, WLAN_RC_PHY_HT_20_SS, 58500, /* 58.5 Mb */
+-                      53500, 0x86, 0x00, 6,
++                      53500, 6, 0x00, 6,
+                       8,  18, 34, 18, 34, 28956 },
+               { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 65000, /* 65 Mb */
+-                      59000, 0x87, 0x00, 7,
++                      59000, 7, 0x00, 7,
+                       8,  19, 35, 19, 36, 32180 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 13000, /* 13 Mb */
+-                      12700, 0x88, 0x00, 8,
++                      12700, 8, 0x00, 8,
+                       4, 20, 37, 20, 37, 6430 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 26000, /* 26 Mb */
+-                      24800, 0x89, 0x00, 9,
++                      24800, 9, 0x00, 9,
+                       6, 21, 38, 21, 38, 12860 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 39000, /* 39 Mb */
+-                      36600, 0x8a, 0x00, 10,
++                      36600, 10, 0x00, 10,
+                       6, 22, 39, 22, 39, 19300 },
+               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 52000, /* 52 Mb */
+-                      48100, 0x8b, 0x00, 11,
++                      48100, 11, 0x00, 11,
+                       8,  23, 40, 23, 40, 25736 },
+               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 78000, /* 78 Mb */
+-                      69500, 0x8c, 0x00, 12,
++                      69500, 12, 0x00, 12,
+                       8,  24, 41, 24, 41, 38600 },
+               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 104000, /* 104 Mb */
+-                      89500, 0x8d, 0x00, 13,
++                      89500, 13, 0x00, 13,
+                       8,  25, 42, 25, 42, 51472 },
+               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 117000, /* 117 Mb */
+-                      98900, 0x8e, 0x00, 14,
++                      98900, 14, 0x00, 14,
+                       8,  26, 43, 26, 44, 57890 },
+               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 130000, /* 130 Mb */
+-                      108300, 0x8f, 0x00, 15,
++                      108300, 15, 0x00, 15,
+                       8,  27, 44, 27, 45, 64320 },
+               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 13500, /* 13.5 Mb */
+-                      13200, 0x80, 0x00, 0,
++                      13200, 0, 0x00, 0,
+                       8, 12, 28, 28, 28, 6684 },
+               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 27500, /* 27.0 Mb */
+-                      25900, 0x81, 0x00, 1,
++                      25900, 1, 0x00, 1,
+                       8, 13, 29, 29, 29, 13368 },
+               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 40500, /* 40.5 Mb */
+-                      38600, 0x82, 0x00, 2,
++                      38600, 2, 0x00, 2,
+                       8, 14, 30, 30, 30, 20052 },
+               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 54000, /* 54 Mb */
+-                      49800, 0x83, 0x00, 3,
++                      49800, 3, 0x00, 3,
+                       8,  15, 31, 31, 31, 26738 },
+               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 81500, /* 81 Mb */
+-                      72200, 0x84, 0x00, 4,
++                      72200, 4, 0x00, 4,
+                       8,  16, 32, 32, 32, 40104 },
+               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 108000, /* 108 Mb */
+-                      92900, 0x85, 0x00, 5,
++                      92900, 5, 0x00, 5,
+                       8,  17, 33, 33, 33, 53476 },
+               { INVALID,  VALID_40, WLAN_RC_PHY_HT_40_SS, 121500, /* 121.5 Mb */
+-                      102700, 0x86, 0x00, 6,
++                      102700, 6, 0x00, 6,
+                       8,  18, 34, 34, 34, 60156 },
+               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 135000, /* 135 Mb */
+-                      112000, 0x87, 0x00, 7,
++                      112000, 7, 0x00, 7,
+                       8,  19, 35, 36, 36, 66840 },
+               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS_HGI, 150000, /* 150 Mb */
+-                      122000, 0x87, 0x00, 7,
++                      122000, 7, 0x00, 7,
+                       8,  19, 35, 36, 36, 74200 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 27000, /* 27 Mb */
+-                      25800, 0x88, 0x00, 8,
++                      25800, 8, 0x00, 8,
+                       8, 20, 37, 37, 37, 13360 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 54000, /* 54 Mb */
+-                      49800, 0x89, 0x00, 9,
++                      49800, 9, 0x00, 9,
+                       8, 21, 38, 38, 38, 26720 },
+               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 81000, /* 81 Mb */
+-                      71900, 0x8a, 0x00, 10,
++                      71900, 10, 0x00, 10,
+                       8, 22, 39, 39, 39, 40080 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 108000, /* 108 Mb */
+-                      92500, 0x8b, 0x00, 11,
++                      92500, 11, 0x00, 11,
+                       8,  23, 40, 40, 40, 53440 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 162000, /* 162 Mb */
+-                      130300, 0x8c, 0x00, 12,
++                      130300, 12, 0x00, 12,
+                       8,  24, 41, 41, 41, 80160 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 216000, /* 216 Mb */
+-                      162800, 0x8d, 0x00, 13,
++                      162800, 13, 0x00, 13,
+                       8,  25, 42, 42, 42, 106880 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 243000, /* 243 Mb */
+-                      178200, 0x8e, 0x00, 14,
++                      178200, 14, 0x00, 14,
+                       8,  26, 43, 43, 43, 120240 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 270000, /* 270 Mb */
+-                      192100, 0x8f, 0x00, 15,
++                      192100, 15, 0x00, 15,
+                       8,  27, 44, 45, 45, 133600 },
+               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS_HGI, 300000, /* 300 Mb */
+-                      207000, 0x8f, 0x00, 15,
++                      207000, 15, 0x00, 15,
+                       8,  27, 44, 45, 45, 148400 },
+               },
+       50,  /* probe interval */
+@@ -302,30 +304,31 @@ 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),
++                      5400, 0, 0x00, 12,
+                       0, 0, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */
+-                      7800, 0x0f, 0x00, 18,
++                      7800, 1, 0x00, 18,
+                       0, 1, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */
+-                      10000, 0x0a, 0x00, (0x80|24),
++                      10000, 2, 0x00, 24,
+                       2, 2, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */
+-                      13900, 0x0e, 0x00, 36,
++                      13900, 3, 0x00, 36,
+                       2, 3, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */
+-                      17300, 0x09, 0x00, (0x80|48),
++                      17300, 4, 0x00, 48,
+                       4,  4, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */
+-                      23000, 0x0d, 0x00, 72,
++                      23000, 5, 0x00, 72,
+                       4,  5, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */
+-                      27400, 0x08, 0x00, 96,
++                      27400, 6, 0x00, 96,
+                       4,  6, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */
+-                      29300, 0x0c, 0x00, 108,
++                      29300, 7, 0x00, 108,
+                       4,  7, 0 },
+       },
+       50,  /* probe interval */
+@@ -334,48 +337,63 @@ 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,
++                      900, 0, 0x00, 2,
+                       0, 0, 0 },
+               { VALID, VALID, WLAN_RC_PHY_CCK, 2000, /* 2 Mb */
+-                      1900, 0x1a, 0x04, 4,
++                      1900, 1, 0x04, 4,
+                       1, 1, 0 },
+               { VALID, VALID, WLAN_RC_PHY_CCK, 5500, /* 5.5 Mb */
+-                      4900, 0x19, 0x04, 11,
++                      4900, 2, 0x04, 11,
+                       2, 2, 0 },
+               { VALID, VALID, WLAN_RC_PHY_CCK, 11000, /* 11 Mb */
+-                      8100, 0x18, 0x04, 22,
++                      8100, 3, 0x04, 22,
+                       3, 3, 0 },
+               { INVALID, INVALID, WLAN_RC_PHY_OFDM, 6000, /* 6 Mb */
+-                      5400, 0x0b, 0x00, 12,
++                      5400, 4, 0x00, 12,
+                       4, 4, 0 },
+               { INVALID, INVALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */
+-                      7800, 0x0f, 0x00, 18,
++                      7800, 5, 0x00, 18,
+                       4, 5, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */
+-                      10000, 0x0a, 0x00, 24,
++                      10000, 6, 0x00, 24,
+                       6, 6, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */
+-                      13900, 0x0e, 0x00, 36,
++                      13900, 7, 0x00, 36,
+                       6, 7, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */
+-                      17300, 0x09, 0x00, 48,
++                      17300, 8, 0x00, 48,
+                       8,  8, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */
+-                      23000, 0x0d, 0x00, 72,
++                      23000, 9, 0x00, 72,
+                       8,  9, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */
+-                      27400, 0x08, 0x00, 96,
++                      27400, 10, 0x00, 96,
+                       8,  10, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */
+-                      29300, 0x0c, 0x00, 108,
++                      29300, 11, 0x00, 108,
+                       8,  11, 0 },
+       },
+       50,  /* probe interval */
+       0,   /* Phy rates allowed initially */
+ };
++static const struct ath_rate_table *hw_rate_table[ATH9K_MODE_MAX] = {
++      [ATH9K_MODE_11A] = &ar5416_11a_ratetable,
++      [ATH9K_MODE_11G] = &ar5416_11g_ratetable,
++      [ATH9K_MODE_11NA_HT20] = &ar5416_11na_ratetable,
++      [ATH9K_MODE_11NG_HT20] = &ar5416_11ng_ratetable,
++      [ATH9K_MODE_11NA_HT40PLUS] = &ar5416_11na_ratetable,
++      [ATH9K_MODE_11NA_HT40MINUS] = &ar5416_11na_ratetable,
++      [ATH9K_MODE_11NG_HT40PLUS] = &ar5416_11ng_ratetable,
++      [ATH9K_MODE_11NG_HT40MINUS] = &ar5416_11ng_ratetable,
++};
++
++static int ath_rc_get_rateindex(const struct ath_rate_table *rate_table,
++                              struct ieee80211_tx_rate *rate);
++
+ static inline int8_t median(int8_t a, int8_t b, int8_t c)
+ {
+       if (a >= b) {
+@@ -534,7 +552,7 @@ static u8 ath_rc_setvalid_rates(struct a
+                        * capflag matches one of the validity
+                        * (VALID/VALID_20/VALID_40) flags */
+-                      if (((rate & 0x7F) == (dot11rate & 0x7F)) &&
++                      if ((rate == dot11rate) &&
+                           ((valid & WLAN_RC_CAP_MODE(capflag)) ==
+                            WLAN_RC_CAP_MODE(capflag)) &&
+                           !WLAN_RC_PHY_HT(phy)) {
+@@ -576,8 +594,7 @@ static u8 ath_rc_setvalid_htrates(struct
+                       u8 rate = rateset->rs_rates[i];
+                       u8 dot11rate = rate_table->info[j].dot11rate;
+-                      if (((rate & 0x7F) != (dot11rate & 0x7F)) ||
+-                          !WLAN_RC_PHY_HT(phy) ||
++                      if ((rate != dot11rate) || !WLAN_RC_PHY_HT(phy) ||
+                           !WLAN_RC_PHY_HT_VALID(valid, capflag))
+                               continue;
+@@ -696,18 +713,20 @@ static void ath_rc_rate_set_series(const
+                                  u8 tries, u8 rix, int rtsctsenable)
+ {
+       rate->count = tries;
+-      rate->idx = rix;
++      rate->idx = rate_table->info[rix].ratecode;
+       if (txrc->short_preamble)
+               rate->flags |= IEEE80211_TX_RC_USE_SHORT_PREAMBLE;
+       if (txrc->rts || rtsctsenable)
+               rate->flags |= IEEE80211_TX_RC_USE_RTS_CTS;
+-      if (WLAN_RC_PHY_40(rate_table->info[rix].phy))
+-              rate->flags |= IEEE80211_TX_RC_40_MHZ_WIDTH;
+-      if (WLAN_RC_PHY_SGI(rate_table->info[rix].phy))
+-              rate->flags |= IEEE80211_TX_RC_SHORT_GI;
+-      if (WLAN_RC_PHY_HT(rate_table->info[rix].phy))
++
++      if (WLAN_RC_PHY_HT(rate_table->info[rix].phy)) {
+               rate->flags |= IEEE80211_TX_RC_MCS;
++              if (WLAN_RC_PHY_40(rate_table->info[rix].phy))
++                      rate->flags |= IEEE80211_TX_RC_40_MHZ_WIDTH;
++              if (WLAN_RC_PHY_SGI(rate_table->info[rix].phy))
++                      rate->flags |= IEEE80211_TX_RC_SHORT_GI;
++      }
+ }
+ static void ath_rc_rate_set_rtscts(struct ath_softc *sc,
+@@ -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)) {
+-                      rix = rates[i].idx;
++                      rix = ath_rc_get_rateindex(rate_table, &rates[i]);
+                       break;
+               }
+       }
+@@ -1080,15 +1099,19 @@ static int ath_rc_get_rateindex(const st
+ {
+       int rix;
++      if (!(rate->flags & IEEE80211_TX_RC_MCS))
++              return rate->idx;
++
++      rix = rate->idx + rate_table->mcs_start;
+       if ((rate->flags & IEEE80211_TX_RC_40_MHZ_WIDTH) &&
+           (rate->flags & IEEE80211_TX_RC_SHORT_GI))
+-              rix = rate_table->info[rate->idx].ht_index;
++              rix = rate_table->info[rix].ht_index;
+       else if (rate->flags & IEEE80211_TX_RC_SHORT_GI)
+-              rix = rate_table->info[rate->idx].sgi_index;
++              rix = rate_table->info[rix].sgi_index;
+       else if (rate->flags & IEEE80211_TX_RC_40_MHZ_WIDTH)
+-              rix = rate_table->info[rate->idx].cw40index;
++              rix = rate_table->info[rix].cw40index;
+       else
+-              rix = rate_table->info[rate->idx].base_index;
++              rix = rate_table->info[rix].base_index;
+       return rix;
+ }
+@@ -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);
+-      return sc->hw_rate_table[mode];
++
++      sc->cur_rate_mode = mode;
++      return hw_rate_table[mode];
+ }
+ static void ath_rc_init(struct ath_softc *sc,
+@@ -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;
+-      if (!rate_table) {
+-              ath_print(common, ATH_DBG_FATAL,
+-                        "Rate table not initialized\n");
+-              return;
+-      }
+-
+       /* Initial rate table size. Will change depending
+        * on the working rate set */
+       ath_rc_priv->rate_table_size = RATE_TABLE_SIZE;
+@@ -1357,7 +1376,8 @@ static void ath_tx_status(void *priv, st
+               }
+       }
+-      ath_debug_stat_rc(sc, skb);
++      ath_debug_stat_rc(sc, ath_rc_get_rateindex(sc->cur_rate_table,
++              &tx_info->status.rates[final_ts_idx]));
+ }
+ static void ath_rate_init(void *priv, struct ieee80211_supported_band *sband,
+@@ -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;
+-      const struct ath_rate_table *rate_table = NULL;
++      const struct ath_rate_table *rate_table;
+       bool is_cw40, is_sgi40;
+       int i, j = 0;
+@@ -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,
+-                                                 sta->ht_cap.ht_supported,
+-                                                 is_cw40);
+-      } else if (sc->sc_ah->opmode == NL80211_IFTYPE_AP) {
+-              /* cur_rate_table would be set on init through config() */
+-              rate_table = sc->cur_rate_table;
++                                    sta->ht_cap.ht_supported, is_cw40);
++      } else {
++              rate_table = hw_rate_table[sc->cur_rate_mode];
+       }
+       ath_rc_priv->ht_cap = ath_rc_build_ht_caps(sc, sta, is_cw40, is_sgi40);
+@@ -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);
++                      sc->cur_rate_table = hw_rate_table[sc->cur_rate_mode];
+               }
+       }
+ }
+@@ -1497,26 +1516,6 @@ static struct rate_control_ops ath_rate_
+       .free_sta = ath_rate_free_sta,
+ };
+-void ath_rate_attach(struct ath_softc *sc)
+-{
+-      sc->hw_rate_table[ATH9K_MODE_11A] =
+-              &ar5416_11a_ratetable;
+-      sc->hw_rate_table[ATH9K_MODE_11G] =
+-              &ar5416_11g_ratetable;
+-      sc->hw_rate_table[ATH9K_MODE_11NA_HT20] =
+-              &ar5416_11na_ratetable;
+-      sc->hw_rate_table[ATH9K_MODE_11NG_HT20] =
+-              &ar5416_11ng_ratetable;
+-      sc->hw_rate_table[ATH9K_MODE_11NA_HT40PLUS] =
+-              &ar5416_11na_ratetable;
+-      sc->hw_rate_table[ATH9K_MODE_11NA_HT40MINUS] =
+-              &ar5416_11na_ratetable;
+-      sc->hw_rate_table[ATH9K_MODE_11NG_HT40PLUS] =
+-              &ar5416_11ng_ratetable;
+-      sc->hw_rate_table[ATH9K_MODE_11NG_HT40MINUS] =
+-              &ar5416_11ng_ratetable;
+-}
+-
+ int ath_rate_control_register(void)
+ {
+       return ieee80211_rate_control_register(&ath_rate_ops);
+--- a/drivers/net/wireless/ath/ath9k/xmit.c
++++ b/drivers/net/wireless/ath/ath9k/xmit.c
+@@ -70,6 +70,29 @@ static int ath_tx_num_badfrms(struct ath
+ static void ath_tx_rc_status(struct ath_buf *bf, struct ath_desc *ds,
+                            int nbad, int txok, bool update_rc);
++enum {
++      MCS_DEFAULT,
++      MCS_HT40,
++      MCS_HT40_SGI,
++};
++
++static int ath_max_4ms_framelen[3][16] = {
++      [MCS_DEFAULT] = {
++              3216,  6434,  9650,  12868, 19304, 25740,  28956,  32180,
++              6430,  12860, 19300, 25736, 38600, 51472,  57890,  64320,
++      },
++      [MCS_HT40] = {
++              6684,  13368, 20052, 26738, 40104, 53476,  60156,  66840,
++              13360, 26720, 40080, 53440, 80160, 106880, 120240, 133600,
++      },
++      [MCS_HT40_SGI] = {
++              /* TODO: Only MCS 7 and 15 updated, recalculate the rest */
++              6684,  13368, 20052, 26738, 40104, 53476,  60156,  74200,
++              13360, 26720, 40080, 53440, 80160, 106880, 120240, 148400,
++      }
++};
++
++
+ /*********************/
+ /* Aggregation logic */
+ /*********************/
+@@ -459,7 +482,6 @@ static void ath_tx_complete_aggr(struct 
+ static u32 ath_lookup_rate(struct ath_softc *sc, struct ath_buf *bf,
+                          struct ath_atx_tid *tid)
+ {
+-      const struct ath_rate_table *rate_table = sc->cur_rate_table;
+       struct sk_buff *skb;
+       struct ieee80211_tx_info *tx_info;
+       struct ieee80211_tx_rate *rates;
+@@ -480,12 +502,20 @@ static u32 ath_lookup_rate(struct ath_so
+       for (i = 0; i < 4; i++) {
+               if (rates[i].count) {
+-                      if (!WLAN_RC_PHY_HT(rate_table->info[rates[i].idx].phy)) {
++                      int modeidx;
++                      if (!(rates[i].flags & IEEE80211_TX_RC_MCS)) {
+                               legacy = 1;
+                               break;
+                       }
+-                      frmlen = rate_table->info[rates[i].idx].max_4ms_framelen;
++                      if (rates[i].flags & IEEE80211_TX_RC_SHORT_GI)
++                              modeidx = MCS_HT40_SGI;
++                      else if (rates[i].flags & IEEE80211_TX_RC_40_MHZ_WIDTH)
++                              modeidx = MCS_HT40;
++                      else
++                              modeidx = MCS_DEFAULT;
++
++                      frmlen = ath_max_4ms_framelen[modeidx][rates[i].idx];
+                       max_4ms_framelen = min(max_4ms_framelen, frmlen);
+               }
+       }
+@@ -523,12 +553,11 @@ static u32 ath_lookup_rate(struct ath_so
+ static int ath_compute_num_delims(struct ath_softc *sc, struct ath_atx_tid *tid,
+                                 struct ath_buf *bf, u16 frmlen)
+ {
+-      const struct ath_rate_table *rt = sc->cur_rate_table;
+       struct sk_buff *skb = bf->bf_mpdu;
+       struct ieee80211_tx_info *tx_info = IEEE80211_SKB_CB(skb);
+       u32 nsymbits, nsymbols;
+       u16 minlen;
+-      u8 rc, flags, rix;
++      u8 flags, rix;
+       int width, half_gi, ndelim, mindelim;
+       /* Select standard number of delimiters based on frame length alone */
+@@ -558,7 +587,6 @@ static int ath_compute_num_delims(struct
+       rix = tx_info->control.rates[0].idx;
+       flags = tx_info->control.rates[0].flags;
+-      rc = rt->info[rix].ratecode;
+       width = (flags & IEEE80211_TX_RC_40_MHZ_WIDTH) ? 1 : 0;
+       half_gi = (flags & IEEE80211_TX_RC_SHORT_GI) ? 1 : 0;
+@@ -570,7 +598,7 @@ static int ath_compute_num_delims(struct
+       if (nsymbols == 0)
+               nsymbols = 1;
+-      nsymbits = bits_per_symbol[HT_RC_2_MCS(rc)][width];
++      nsymbits = bits_per_symbol[rix][width];
+       minlen = (nsymbols * nsymbits) / BITS_PER_BYTE;
+       if (frmlen < minlen) {
+@@ -1425,22 +1453,14 @@ static int setup_tx_flags(struct ath_sof
+ static u32 ath_pkt_duration(struct ath_softc *sc, u8 rix, struct ath_buf *bf,
+                           int width, int half_gi, bool shortPreamble)
+ {
+-      const struct ath_rate_table *rate_table = sc->cur_rate_table;
+       u32 nbits, nsymbits, duration, nsymbols;
+-      u8 rc;
+       int streams, pktlen;
+       pktlen = bf_isaggr(bf) ? bf->bf_al : bf->bf_frmlen;
+-      rc = rate_table->info[rix].ratecode;
+-
+-      /* for legacy rates, use old function to compute packet duration */
+-      if (!IS_HT_RATE(rc))
+-              return ath9k_hw_computetxtime(sc->sc_ah, rate_table, pktlen,
+-                                            rix, shortPreamble);
+       /* find number of symbols: PLCP + data */
+       nbits = (pktlen << 3) + OFDM_PLCP_BITS;
+-      nsymbits = bits_per_symbol[HT_RC_2_MCS(rc)][width];
++      nsymbits = bits_per_symbol[rix][width];
+       nsymbols = (nbits + nsymbits - 1) / nsymbits;
+       if (!half_gi)
+@@ -1449,7 +1469,7 @@ static u32 ath_pkt_duration(struct ath_s
+               duration = SYMBOL_TIME_HALFGI(nsymbols);
+       /* addup duration for legacy/ht training and signal fields */
+-      streams = HT_RC_2_STREAMS(rc);
++      streams = HT_RC_2_STREAMS(rix);
+       duration += L_STF + L_LTF + L_SIG + HT_SIG + HT_STF + HT_LTF(streams);
+       return duration;
+@@ -1458,11 +1478,11 @@ static u32 ath_pkt_duration(struct ath_s
+ static void ath_buf_set_rate(struct ath_softc *sc, struct ath_buf *bf)
+ {
+       struct ath_common *common = ath9k_hw_common(sc->sc_ah);
+-      const struct ath_rate_table *rt = sc->cur_rate_table;
+       struct ath9k_11n_rate_series series[4];
+       struct sk_buff *skb;
+       struct ieee80211_tx_info *tx_info;
+       struct ieee80211_tx_rate *rates;
++      const struct ieee80211_rate *rate;
+       struct ieee80211_hdr *hdr;
+       int i, flags = 0;
+       u8 rix = 0, ctsrate = 0;
+@@ -1481,11 +1501,10 @@ static void ath_buf_set_rate(struct ath_
+        * checking the BSS's global flag.
+        * But for the rate series, IEEE80211_TX_RC_USE_SHORT_PREAMBLE is used.
+        */
++      rate = ieee80211_get_rts_cts_rate(sc->hw, tx_info);
++      ctsrate = rate->hw_value;
+       if (sc->sc_flags & SC_OP_PREAMBLE_SHORT)
+-              ctsrate = rt->info[tx_info->control.rts_cts_rate_idx].ratecode |
+-                      rt->info[tx_info->control.rts_cts_rate_idx].short_preamble;
+-      else
+-              ctsrate = rt->info[tx_info->control.rts_cts_rate_idx].ratecode;
++              ctsrate |= rate->hw_value_short;
+       /*
+        * ATH9K_TXDESC_RTSENA and ATH9K_TXDESC_CTSENA are mutually exclusive.
+@@ -1508,6 +1527,9 @@ static void ath_buf_set_rate(struct ath_
+               flags &= ~(ATH9K_TXDESC_RTSENA);
+       for (i = 0; i < 4; i++) {
++              bool is_40, is_sgi, is_sp;
++              int phy;
++
+               if (!rates[i].count || (rates[i].idx < 0))
+                       continue;
+@@ -1515,12 +1537,6 @@ static void ath_buf_set_rate(struct ath_
+               series[i].Tries = rates[i].count;
+               series[i].ChSel = common->tx_chainmask;
+-              if (rates[i].flags & IEEE80211_TX_RC_USE_SHORT_PREAMBLE)
+-                      series[i].Rate = rt->info[rix].ratecode |
+-                              rt->info[rix].short_preamble;
+-              else
+-                      series[i].Rate = rt->info[rix].ratecode;
+-
+               if (rates[i].flags & IEEE80211_TX_RC_USE_RTS_CTS)
+                       series[i].RateFlags |= ATH9K_RATESERIES_RTS_CTS;
+               if (rates[i].flags & IEEE80211_TX_RC_40_MHZ_WIDTH)
+@@ -1528,10 +1544,36 @@ static void ath_buf_set_rate(struct ath_
+               if (rates[i].flags & IEEE80211_TX_RC_SHORT_GI)
+                       series[i].RateFlags |= ATH9K_RATESERIES_HALFGI;
+-              series[i].PktDuration = ath_pkt_duration(sc, rix, bf,
+-                       (rates[i].flags & IEEE80211_TX_RC_40_MHZ_WIDTH) != 0,
+-                       (rates[i].flags & IEEE80211_TX_RC_SHORT_GI),
+-                       (rates[i].flags & IEEE80211_TX_RC_USE_SHORT_PREAMBLE));
++              is_sgi = !!(rates[i].flags & IEEE80211_TX_RC_SHORT_GI);
++              is_40 = !!(rates[i].flags & IEEE80211_TX_RC_40_MHZ_WIDTH);
++              is_sp = !!(rates[i].flags & IEEE80211_TX_RC_USE_SHORT_PREAMBLE);
++
++              if (rates[i].flags & IEEE80211_TX_RC_MCS) {
++                      /* MCS rates */
++                      series[i].Rate = rix | 0x80;
++                      series[i].PktDuration = ath_pkt_duration(sc, rix, bf,
++                               is_40, is_sgi, is_sp);
++                      continue;
++              }
++
++              /* legcay rates */
++              if ((tx_info->band == IEEE80211_BAND_2GHZ) &&
++                  !(rate->flags & IEEE80211_RATE_ERP_G))
++                      phy = WLAN_RC_PHY_CCK;
++              else
++                      phy = WLAN_RC_PHY_OFDM;
++
++              rate = &sc->sbands[tx_info->band].bitrates[rates[i].idx];
++              series[i].Rate = rate->hw_value;
++              if (rate->hw_value_short) {
++                      if (rates[i].flags & IEEE80211_TX_RC_USE_SHORT_PREAMBLE)
++                              series[i].Rate |= rate->hw_value_short;
++              } else {
++                      is_sp = false;
++              }
++
++              series[i].PktDuration = ath9k_hw_computetxtime(sc->sc_ah,
++                      phy, rate->bitrate * 100, bf->bf_frmlen, rix, is_sp);
+       }
+       /* set dur_update_en for l-sig computation except for PS-Poll frames */
+@@ -1920,8 +1962,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 @@
+ #include <linux/device.h>
+ #include <linux/leds.h>
+-#include "rc.h"
+ #include "debug.h"
+ #include "common.h"
+@@ -423,6 +422,7 @@ struct ath_led {
+ #define SC_OP_BT_PRIORITY_DETECTED BIT(21)
+ struct ath_wiphy;
++struct ath_rate_table;
+ struct ath_softc {
+       struct ieee80211_hw *hw;
+@@ -467,9 +467,8 @@ struct ath_softc {
+       struct ath_rx rx;
+       struct ath_tx tx;
+       struct ath_beacon beacon;
+-      struct ieee80211_rate rates[IEEE80211_NUM_BANDS][ATH_RATE_MAX];
+-      const struct ath_rate_table *hw_rate_table[ATH9K_MODE_MAX];
+       const struct ath_rate_table *cur_rate_table;
++      enum wireless_mode cur_rate_mode;
+       struct ieee80211_supported_band sbands[IEEE80211_NUM_BANDS];
+       struct ath_led radio_led;
+--- a/drivers/net/wireless/ath/ath9k/main.c
++++ b/drivers/net/wireless/ath/ath9k/main.c
+@@ -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[] = {
++      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,
+                               struct ieee80211_conf *conf)
+ {
+       switch (conf->channel->band) {
+       case IEEE80211_BAND_2GHZ:
+               if (conf_is_ht20(conf))
+-                      sc->cur_rate_table =
+-                        sc->hw_rate_table[ATH9K_MODE_11NG_HT20];
++                      sc->cur_rate_mode = ATH9K_MODE_11NG_HT20;
+               else if (conf_is_ht40_minus(conf))
+-                      sc->cur_rate_table =
+-                        sc->hw_rate_table[ATH9K_MODE_11NG_HT40MINUS];
++                      sc->cur_rate_mode = ATH9K_MODE_11NG_HT40MINUS;
+               else if (conf_is_ht40_plus(conf))
+-                      sc->cur_rate_table =
+-                        sc->hw_rate_table[ATH9K_MODE_11NG_HT40PLUS];
++                      sc->cur_rate_mode = ATH9K_MODE_11NG_HT40PLUS;
+               else
+-                      sc->cur_rate_table =
+-                        sc->hw_rate_table[ATH9K_MODE_11G];
++                      sc->cur_rate_mode = ATH9K_MODE_11G;
+               break;
+       case IEEE80211_BAND_5GHZ:
+               if (conf_is_ht20(conf))
+-                      sc->cur_rate_table =
+-                        sc->hw_rate_table[ATH9K_MODE_11NA_HT20];
++                      sc->cur_rate_mode = ATH9K_MODE_11NA_HT20;
+               else if (conf_is_ht40_minus(conf))
+-                      sc->cur_rate_table =
+-                        sc->hw_rate_table[ATH9K_MODE_11NA_HT40MINUS];
++                      sc->cur_rate_mode = ATH9K_MODE_11NA_HT40MINUS;
+               else if (conf_is_ht40_plus(conf))
+-                      sc->cur_rate_table =
+-                        sc->hw_rate_table[ATH9K_MODE_11NA_HT40PLUS];
++                      sc->cur_rate_mode = ATH9K_MODE_11NA_HT40PLUS;
+               else
+-                      sc->cur_rate_table =
+-                        sc->hw_rate_table[ATH9K_MODE_11A];
++                      sc->cur_rate_mode = ATH9K_MODE_11A;
+               break;
+       default:
+               BUG_ON(1);
+@@ -191,51 +209,6 @@ static u8 parse_mpdudensity(u8 mpdudensi
+       }
+ }
+-static void ath_setup_rates(struct ath_softc *sc, enum ieee80211_band band)
+-{
+-      const struct ath_rate_table *rate_table = NULL;
+-      struct ieee80211_supported_band *sband;
+-      struct ieee80211_rate *rate;
+-      int i, maxrates;
+-
+-      switch (band) {
+-      case IEEE80211_BAND_2GHZ:
+-              rate_table = sc->hw_rate_table[ATH9K_MODE_11G];
+-              break;
+-      case IEEE80211_BAND_5GHZ:
+-              rate_table = sc->hw_rate_table[ATH9K_MODE_11A];
+-              break;
+-      default:
+-              break;
+-      }
+-
+-      if (rate_table == NULL)
+-              return;
+-
+-      sband = &sc->sbands[band];
+-      rate = sc->rates[band];
+-
+-      if (rate_table->rate_cnt > ATH_RATE_MAX)
+-              maxrates = ATH_RATE_MAX;
+-      else
+-              maxrates = rate_table->rate_cnt;
+-
+-      for (i = 0; i < maxrates; i++) {
+-              rate[i].bitrate = rate_table->info[i].ratekbps / 100;
+-              rate[i].hw_value = rate_table->info[i].ratecode;
+-              if (rate_table->info[i].short_preamble) {
+-                      rate[i].hw_value_short = rate_table->info[i].ratecode |
+-                              rate_table->info[i].short_preamble;
+-                      rate[i].flags = IEEE80211_RATE_SHORT_PREAMBLE;
+-              }
+-              sband->n_bitrates++;
+-
+-              ath_print(ath9k_hw_common(sc->sc_ah), ATH_DBG_CONFIG,
+-                        "Rate: %2dMbps, ratecode: %2d\n",
+-                        rate[i].bitrate / 10, rate[i].hw_value);
+-      }
+-}
+-
+ static struct ath9k_channel *ath_get_curchannel(struct ath_softc *sc,
+                                               struct ieee80211_hw *hw)
+ {
+@@ -1713,12 +1686,6 @@ static int ath_init_softc(u16 devid, str
+       /* default to MONITOR mode */
+       sc->sc_ah->opmode = NL80211_IFTYPE_MONITOR;
+-      /* Setup rate tables */
+-
+-      ath_rate_attach(sc);
+-      ath_setup_rates(sc, IEEE80211_BAND_2GHZ);
+-      ath_setup_rates(sc, IEEE80211_BAND_5GHZ);
+-
+       /*
+        * Allocate hardware transmit queues: one queue for
+        * beacon frames and one data queue for each QoS
+@@ -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;
+-      sc->sbands[IEEE80211_BAND_2GHZ].bitrates =
+-              sc->rates[IEEE80211_BAND_2GHZ];
+       sc->sbands[IEEE80211_BAND_2GHZ].band = IEEE80211_BAND_2GHZ;
+       sc->sbands[IEEE80211_BAND_2GHZ].n_channels =
+               ARRAY_SIZE(ath9k_2ghz_chantable);
++      sc->sbands[IEEE80211_BAND_2GHZ].bitrates = ath9k_legacy_rates;
++      sc->sbands[IEEE80211_BAND_2GHZ].n_bitrates =
++              ARRAY_SIZE(ath9k_legacy_rates);
+       if (test_bit(ATH9K_MODE_11A, sc->sc_ah->caps.wireless_modes)) {
+               sc->sbands[IEEE80211_BAND_5GHZ].channels = ath9k_5ghz_chantable;
+-              sc->sbands[IEEE80211_BAND_5GHZ].bitrates =
+-                      sc->rates[IEEE80211_BAND_5GHZ];
+               sc->sbands[IEEE80211_BAND_5GHZ].band = IEEE80211_BAND_5GHZ;
+               sc->sbands[IEEE80211_BAND_5GHZ].n_channels =
+                       ARRAY_SIZE(ath9k_5ghz_chantable);
++              sc->sbands[IEEE80211_BAND_5GHZ].bitrates =
++                      ath9k_legacy_rates + 4;
++              sc->sbands[IEEE80211_BAND_5GHZ].n_bitrates =
++                      ARRAY_SIZE(ath9k_legacy_rates) - 4;
+       }
+       switch (ah->btcoex_hw.scheme) {
+--- a/drivers/net/wireless/ath/ath9k/rc.h
++++ b/drivers/net/wireless/ath/ath9k/rc.h
+@@ -104,6 +104,7 @@ enum {
+  */
+ struct ath_rate_table {
+       int rate_cnt;
++      int mcs_start;
+       struct {
+               int valid;
+               int valid_single_stream;
+@@ -179,8 +180,6 @@ enum ath9k_internal_frame_type {
+       ATH9K_INT_UNPAUSE
+ };
+-void ath_rate_attach(struct ath_softc *sc);
+-u8 ath_rate_findrateix(struct ath_softc *sc, u8 dot11_rate);
+ int ath_rate_control_register(void);
+ void ath_rate_control_unregister(void);
+--- a/drivers/net/wireless/ath/ath9k/beacon.c
++++ b/drivers/net/wireless/ath/ath9k/beacon.c
+@@ -65,9 +65,9 @@ static void ath_beacon_setup(struct ath_
+       struct ath_common *common = ath9k_hw_common(ah);
+       struct ath_desc *ds;
+       struct ath9k_11n_rate_series series[4];
+-      const struct ath_rate_table *rt;
+       int flags, antenna, ctsrate = 0, ctsduration = 0;
+-      u8 rate;
++      struct ieee80211_supported_band *sband;
++      u8 rate = 0;
+       ds = bf->bf_desc;
+       flags = ATH9K_TXDESC_NOACK;
+@@ -91,10 +91,10 @@ static void ath_beacon_setup(struct ath_
+       ds->ds_data = bf->bf_buf_addr;
+-      rt = sc->cur_rate_table;
+-      rate = rt->info[0].ratecode;
++      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;
++              rate |= sband->bitrates[0].hw_value_short;
+       ath9k_hw_set11n_txdesc(ah, ds, skb->len + FCS_LEN,
+                              ATH9K_PKT_TYPE_BEACON,
+--- a/drivers/net/wireless/ath/ath9k/debug.h
++++ b/drivers/net/wireless/ath/ath9k/debug.h
+@@ -18,6 +18,7 @@
+ #define DEBUG_H
+ #include "hw.h"
++#include "rc.h"
+ struct ath_txq;
+ struct ath_buf;
+@@ -138,7 +139,7 @@ void ath9k_exit_debug(struct ath_hw *ah)
+ int ath9k_debug_create_root(void);
+ void ath9k_debug_remove_root(void);
+ void ath_debug_stat_interrupt(struct ath_softc *sc, enum ath9k_int status);
+-void ath_debug_stat_rc(struct ath_softc *sc, struct sk_buff *skb);
++void ath_debug_stat_rc(struct ath_softc *sc, int final_rate);
+ void ath_debug_stat_tx(struct ath_softc *sc, struct ath_txq *txq,
+                      struct ath_buf *bf);
+ void ath_debug_stat_retries(struct ath_softc *sc, int rix,
+@@ -170,7 +171,7 @@ static inline void ath_debug_stat_interr
+ }
+ static inline void ath_debug_stat_rc(struct ath_softc *sc,
+-                                   struct sk_buff *skb)
++                                   int final_rate)
+ {
+ }
+--- a/drivers/net/wireless/ath/ath9k/debug.c
++++ b/drivers/net/wireless/ath/ath9k/debug.c
+@@ -255,21 +255,11 @@ static const struct file_operations fops
+       .owner = THIS_MODULE
+ };
+-void ath_debug_stat_rc(struct ath_softc *sc, struct sk_buff *skb)
++void ath_debug_stat_rc(struct ath_softc *sc, int final_rate)
+ {
+-      struct ieee80211_tx_info *tx_info = IEEE80211_SKB_CB(skb);
+-      struct ieee80211_tx_rate *rates = tx_info->status.rates;
+-      int final_ts_idx = 0, idx, i;
+       struct ath_rc_stats *stats;
+-      for (i = 0; i < IEEE80211_TX_MAX_RATES; i++) {
+-              if (!rates[i].count)
+-                      break;
+-
+-              final_ts_idx = i;
+-      }
+-      idx = rates[final_ts_idx].idx;
+-      stats = &sc->debug.stats.rcstats[idx];
++      stats = &sc->debug.stats.rcstats[final_rate];
+       stats->success++;
+ }
+--- a/drivers/net/wireless/ath/ath9k/hw.c
++++ b/drivers/net/wireless/ath/ath9k/hw.c
+@@ -149,22 +149,19 @@ bool ath9k_get_channel_edges(struct ath_
+ }
+ u16 ath9k_hw_computetxtime(struct ath_hw *ah,
+-                         const struct ath_rate_table *rates,
++                         u8 phy, int kbps,
+                          u32 frameLen, u16 rateix,
+                          bool shortPreamble)
+ {
+       u32 bitsPerSymbol, numBits, numSymbols, phyTime, txTime;
+-      u32 kbps;
+-
+-      kbps = rates->info[rateix].ratekbps;
+       if (kbps == 0)
+               return 0;
+-      switch (rates->info[rateix].phy) {
++      switch (phy) {
+       case WLAN_RC_PHY_CCK:
+               phyTime = CCK_PREAMBLE_BITS + CCK_PLCP_BITS;
+-              if (shortPreamble && rates->info[rateix].short_preamble)
++              if (shortPreamble)
+                       phyTime >>= 1;
+               numBits = frameLen << 3;
+               txTime = CCK_SIFS_TIME + phyTime + ((numBits * 1000) / kbps);
+@@ -195,8 +192,7 @@ u16 ath9k_hw_computetxtime(struct ath_hw
+               break;
+       default:
+               ath_print(ath9k_hw_common(ah), ATH_DBG_FATAL,
+-                        "Unknown phy %u (rate ix %u)\n",
+-                        rates->info[rateix].phy, rateix);
++                        "Unknown phy %u (rate ix %u)\n", phy, rateix);
+               txTime = 0;
+               break;
+       }
+--- a/drivers/net/wireless/ath/ath9k/hw.h
++++ b/drivers/net/wireless/ath/ath9k/hw.h
+@@ -647,7 +647,7 @@ bool ath9k_hw_wait(struct ath_hw *ah, u3
+ u32 ath9k_hw_reverse_bits(u32 val, u32 n);
+ bool ath9k_get_channel_edges(struct ath_hw *ah, u16 flags, u16 *low, u16 *high);
+ u16 ath9k_hw_computetxtime(struct ath_hw *ah,
+-                         const struct ath_rate_table *rates,
++                         u8 phy, int kbps,
+                          u32 frameLen, u16 rateix, bool shortPreamble);
+ void ath9k_hw_get_channel_centers(struct ath_hw *ah,
+                                 struct ath9k_channel *chan,
+--- a/drivers/net/wireless/ath/ath9k/mac.h
++++ b/drivers/net/wireless/ath/ath9k/mac.h
+@@ -616,7 +616,6 @@ enum ath9k_cipher {
+ struct ath_hw;
+ struct ath9k_channel;
+-struct ath_rate_table;
+ u32 ath9k_hw_gettxbuf(struct ath_hw *ah, u32 q);
+ void ath9k_hw_puttxbuf(struct ath_hw *ah, u32 q, u32 txdp);
diff --git a/package/mac80211/patches/501-ath9k_rc_table_cleanup.patch b/package/mac80211/patches/501-ath9k_rc_table_cleanup.patch
new file mode 100644 (file)
index 0000000..30e0f9f
--- /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, 0, 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,  1, 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, 2, 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, 3, 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, 4, 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, 5, 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, 6, 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, 7, 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, 0, 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, 1, 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, 2, 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, 3, 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, 4, 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, 5, 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, 6, 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, 7, 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, 8, 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, 9, 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, 10, 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, 11, 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, 12, 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, 13, 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, 14, 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, 15, 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, 0, 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, 1, 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, 2, 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, 3, 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, 4, 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, 5, 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, 6, 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, 7, 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, 7, 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, 8, 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, 9, 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, 10, 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, 11, 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, 12, 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, 13, 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, 14, 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, 15, 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, 15, 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, 0, 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, 1, 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, 2, 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, 3, 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, 4, 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, 5, 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, 6, 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, 7, 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, 8, 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, 9, 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, 10, 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, 11, 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, 0, 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, 1, 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, 2, 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, 3, 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, 4, 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, 5, 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, 6, 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, 7, 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, 8, 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, 9, 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, 10, 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, 11, 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, 12, 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, 13, 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, 14, 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, 15, 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, 0, 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, 1, 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, 2, 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, 3, 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, 4, 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, 5, 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, 6, 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, 7, 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, 7, 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, 8, 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, 9, 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, 10, 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, 11, 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, 12, 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, 13, 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, 14, 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, 15, 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, 15, 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, 0, 0x00, 12,
+-                      0, 0, 0 },
++                      5400, 0, 12, 0, 0, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */
+-                      7800, 1, 0x00, 18,
+-                      0, 1, 0 },
++                      7800,  1, 18, 0, 1, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */
+-                      10000, 2, 0x00, 24,
+-                      2, 2, 0 },
++                      10000, 2, 24, 2, 2, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */
+-                      13900, 3, 0x00, 36,
+-                      2, 3, 0 },
++                      13900, 3, 36, 2, 3, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */
+-                      17300, 4, 0x00, 48,
+-                      4,  4, 0 },
++                      17300, 4, 48, 4, 4, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */
+-                      23000, 5, 0x00, 72,
+-                      4,  5, 0 },
++                      23000, 5, 72, 4, 5, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */
+-                      27400, 6, 0x00, 96,
+-                      4,  6, 0 },
++                      27400, 6, 96, 4, 6, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */
+-                      29300, 7, 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, 0, 0x00, 2,
+-                      0, 0, 0 },
++                      900, 0, 2, 0, 0, 0 },
+               { VALID, VALID, WLAN_RC_PHY_CCK, 2000, /* 2 Mb */
+-                      1900, 1, 0x04, 4,
+-                      1, 1, 0 },
++                      1900, 1, 4, 1, 1, 0 },
+               { VALID, VALID, WLAN_RC_PHY_CCK, 5500, /* 5.5 Mb */
+-                      4900, 2, 0x04, 11,
+-                      2, 2, 0 },
++                      4900, 2, 11, 2, 2, 0 },
+               { VALID, VALID, WLAN_RC_PHY_CCK, 11000, /* 11 Mb */
+-                      8100, 3, 0x04, 22,
+-                      3, 3, 0 },
++                      8100, 3, 22, 3, 3, 0 },
+               { INVALID, INVALID, WLAN_RC_PHY_OFDM, 6000, /* 6 Mb */
+-                      5400, 4, 0x00, 12,
+-                      4, 4, 0 },
++                      5400, 4, 12, 4, 4, 0 },
+               { INVALID, INVALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */
+-                      7800, 5, 0x00, 18,
+-                      4, 5, 0 },
++                      7800, 5, 18, 4, 5, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */
+-                      10000, 6, 0x00, 24,
+-                      6, 6, 0 },
++                      10000, 6, 24, 6, 6, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */
+-                      13900, 7, 0x00, 36,
+-                      6, 7, 0 },
++                      13900, 7, 36, 6, 7, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */
+-                      17300, 8, 0x00, 48,
+-                      8,  8, 0 },
++                      17300, 8, 48, 8, 8, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */
+-                      23000, 9, 0x00, 72,
+-                      8,  9, 0 },
++                      23000, 9, 72, 8, 9, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */
+-                      27400, 10, 0x00, 96,
+-                      8,  10, 0 },
++                      27400, 10, 96, 8, 10, 0 },
+               { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */
+-                      29300, 11, 0x00, 108,
+-                      8,  11, 0 },
++                      29300, 11, 108, 8, 11, 0 },
+       },
+       50,  /* probe interval */
+       0,   /* Phy rates allowed initially */
diff --git a/package/mac80211/patches/510-ath_use_gfp_dma.patch b/package/mac80211/patches/510-ath_use_gfp_dma.patch
new file mode 100644 (file)
index 0000000..af375b1
--- /dev/null
@@ -0,0 +1,11 @@
+--- a/drivers/net/wireless/ath/main.c
++++ b/drivers/net/wireless/ath/main.c
+@@ -43,7 +43,7 @@ struct sk_buff *ath_rxbuf_alloc(struct a
+        * Unfortunately this means we may get 8 KB here from the
+        * kernel... and that is actually what is observed on some
+        * systems :( */
+-      skb = __dev_alloc_skb(len + common->cachelsz - 1, gfp_mask);
++      skb = __dev_alloc_skb(len + common->cachelsz - 1, gfp_mask | GFP_DMA);
+       if (skb != NULL) {
+               off = ((unsigned long) skb->data) % common->cachelsz;
+               if (off != 0)
diff --git a/package/mac80211/patches/510-nl80211_vlan_add_fix.patch b/package/mac80211/patches/510-nl80211_vlan_add_fix.patch
deleted file mode 100644 (file)
index e0cdaea..0000000
+++ /dev/null
@@ -1,20 +0,0 @@
---- a/net/wireless/nl80211.c
-+++ b/net/wireless/nl80211.c
-@@ -1813,7 +1813,7 @@ static int nl80211_get_station(struct sk
- }
- /*
-- * Get vlan interface making sure it is on the right wiphy.
-+ * Get vlan interface making sure it is running and on the right wiphy.
-  */
- static int get_vlan(struct genl_info *info,
-                   struct cfg80211_registered_device *rdev,
-@@ -1831,6 +1831,8 @@ static int get_vlan(struct genl_info *in
-                       return -EINVAL;
-               if ((*vlan)->ieee80211_ptr->wiphy != &rdev->wiphy)
-                       return -EINVAL;
-+              if (!netif_running(*vlan))
-+                      return -ENETDOWN;
-       }
-       return 0;
- }
diff --git a/package/mac80211/patches/520-driver_flags.patch b/package/mac80211/patches/520-driver_flags.patch
deleted file mode 100644 (file)
index 13d85ee..0000000
+++ /dev/null
@@ -1,26 +0,0 @@
---- a/include/net/mac80211.h
-+++ b/include/net/mac80211.h
-@@ -390,10 +390,12 @@ struct ieee80211_tx_rate {
-  * @control: union for control data
-  * @status: union for status data
-  * @driver_data: array of driver_data pointers
-- * @ampdu_ack_len: number of aggregated frames.
-+ * @ampdu_ack_len: number of acked aggregated frames.
-  *    relevant only if IEEE80211_TX_STATUS_AMPDU was set.
-  * @ampdu_ack_map: block ack bit map for the aggregation.
-  *    relevant only if IEEE80211_TX_STATUS_AMPDU was set.
-+ * @ampdu_len: number of aggregated frames.
-+ *    relevant only if IEEE80211_TX_STATUS_AMPDU was set.
-  * @ack_signal: signal strength of the ACK frame
-  */
- struct ieee80211_tx_info {
-@@ -428,7 +430,8 @@ struct ieee80211_tx_info {
-                       u8 ampdu_ack_len;
-                       u64 ampdu_ack_map;
-                       int ack_signal;
--                      /* 8 bytes free */
-+                      u8 ampdu_len;
-+                      /* 7 bytes free */
-               } status;
-               struct {
-                       struct ieee80211_tx_rate driver_rates[
diff --git a/package/mac80211/patches/530-ath9k_cleanup.patch b/package/mac80211/patches/530-ath9k_cleanup.patch
deleted file mode 100644 (file)
index ab205d5..0000000
+++ /dev/null
@@ -1,460 +0,0 @@
---- a/drivers/net/wireless/ath/ath9k/common.h
-+++ b/drivers/net/wireless/ath/ath9k/common.h
-@@ -81,6 +81,7 @@ struct ath_buf {
-       u16 bf_flags;
-       struct ath_buf_state bf_state;
-       dma_addr_t bf_dmacontext;
-+      struct ath_wiphy *aphy;
- };
- struct ath_atx_tid {
---- a/drivers/net/wireless/ath/ath9k/rc.h
-+++ b/drivers/net/wireless/ath/ath9k/rc.h
-@@ -167,24 +167,18 @@ struct ath_rate_priv {
-       struct ath_rate_softc *asc;
- };
-+#define ATH_TX_INFO_FRAME_TYPE_INTERNAL       (1 << 0)
-+#define ATH_TX_INFO_FRAME_TYPE_PAUSE  (1 << 1)
-+#define ATH_TX_INFO_UPDATE_RC         (1 << 2)
-+#define ATH_TX_INFO_XRETRY            (1 << 3)
-+#define ATH_TX_INFO_UNDERRUN          (1 << 4)
-+
- enum ath9k_internal_frame_type {
-       ATH9K_NOT_INTERNAL,
-       ATH9K_INT_PAUSE,
-       ATH9K_INT_UNPAUSE
- };
--struct ath_tx_info_priv {
--      struct ath_wiphy *aphy;
--      struct ath_tx_status tx;
--      int n_frames;
--      int n_bad_frames;
--      bool update_rc;
--      enum ath9k_internal_frame_type frame_type;
--};
--
--#define ATH_TX_INFO_PRIV(tx_info) \
--      ((struct ath_tx_info_priv *)((tx_info)->rate_driver_data[0]))
--
- void ath_rate_attach(struct ath_softc *sc);
- u8 ath_rate_findrateix(struct ath_softc *sc, u8 dot11_rate);
- int ath_rate_control_register(void);
---- a/drivers/net/wireless/ath/ath9k/virtual.c
-+++ b/drivers/net/wireless/ath/ath9k/virtual.c
-@@ -338,13 +338,11 @@ void ath9k_wiphy_chan_work(struct work_s
- void ath9k_tx_status(struct ieee80211_hw *hw, struct sk_buff *skb)
- {
-       struct ath_wiphy *aphy = hw->priv;
--      struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
-       struct ieee80211_tx_info *tx_info = IEEE80211_SKB_CB(skb);
--      struct ath_tx_info_priv *tx_info_priv = ATH_TX_INFO_PRIV(tx_info);
--      if (tx_info_priv && tx_info_priv->frame_type == ATH9K_INT_PAUSE &&
-+      if ((tx_info->pad[0] & ATH_TX_INFO_FRAME_TYPE_PAUSE) &&
-           aphy->state == ATH_WIPHY_PAUSING) {
--              if (!(info->flags & IEEE80211_TX_STAT_ACK)) {
-+              if (!(tx_info->flags & IEEE80211_TX_STAT_ACK)) {
-                       printk(KERN_DEBUG "ath9k: %s: no ACK for pause "
-                              "frame\n", wiphy_name(hw->wiphy));
-                       /*
-@@ -363,9 +361,6 @@ void ath9k_tx_status(struct ieee80211_hw
-               }
-       }
--      kfree(tx_info_priv);
--      tx_info->rate_driver_data[0] = NULL;
--
-       dev_kfree_skb(skb);
- }
---- a/drivers/net/wireless/ath/ath9k/xmit.c
-+++ b/drivers/net/wireless/ath/ath9k/xmit.c
-@@ -251,6 +251,7 @@ static struct ath_buf* ath_clone_txbuf(s
-       ATH_TXBUF_RESET(tbf);
-+      tbf->aphy = bf->aphy;
-       tbf->bf_mpdu = bf->bf_mpdu;
-       tbf->bf_buf_addr = bf->bf_buf_addr;
-       *(tbf->bf_desc) = *(bf->bf_desc);
-@@ -270,7 +271,6 @@ static void ath_tx_complete_aggr(struct 
-       struct ieee80211_hw *hw;
-       struct ieee80211_hdr *hdr;
-       struct ieee80211_tx_info *tx_info;
--      struct ath_tx_info_priv *tx_info_priv;
-       struct ath_atx_tid *tid = NULL;
-       struct ath_buf *bf_next, *bf_last = bf->bf_lastbf;
-       struct ath_desc *ds = bf_last->bf_desc;
-@@ -284,8 +284,7 @@ static void ath_tx_complete_aggr(struct 
-       hdr = (struct ieee80211_hdr *)skb->data;
-       tx_info = IEEE80211_SKB_CB(skb);
--      tx_info_priv = (struct ath_tx_info_priv *) tx_info->rate_driver_data[0];
--      hw = tx_info_priv->aphy->hw;
-+      hw = bf->aphy->hw;
-       rcu_read_lock();
-@@ -464,7 +463,6 @@ static u32 ath_lookup_rate(struct ath_so
-       struct sk_buff *skb;
-       struct ieee80211_tx_info *tx_info;
-       struct ieee80211_tx_rate *rates;
--      struct ath_tx_info_priv *tx_info_priv;
-       u32 max_4ms_framelen, frmlen;
-       u16 aggr_limit, legacy = 0;
-       int i;
-@@ -472,7 +470,6 @@ static u32 ath_lookup_rate(struct ath_so
-       skb = bf->bf_mpdu;
-       tx_info = IEEE80211_SKB_CB(skb);
-       rates = tx_info->control.rates;
--      tx_info_priv = (struct ath_tx_info_priv *)tx_info->rate_driver_data[0];
-       /*
-        * Find the lowest frame length among the rate series that will have a
-@@ -1560,21 +1557,26 @@ static int ath_tx_setup_buffer(struct ie
-       struct ath_softc *sc = aphy->sc;
-       struct ieee80211_tx_info *tx_info = IEEE80211_SKB_CB(skb);
-       struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data;
--      struct ath_tx_info_priv *tx_info_priv;
-       int hdrlen;
-       __le16 fc;
--      tx_info_priv = kzalloc(sizeof(*tx_info_priv), GFP_ATOMIC);
--      if (unlikely(!tx_info_priv))
--              return -ENOMEM;
--      tx_info->rate_driver_data[0] = tx_info_priv;
--      tx_info_priv->aphy = aphy;
--      tx_info_priv->frame_type = txctl->frame_type;
-+      tx_info->pad[0] = 0;
-+      switch (txctl->frame_type) {
-+      case ATH9K_NOT_INTERNAL:
-+              break;
-+      case ATH9K_INT_PAUSE:
-+              tx_info->pad[0] |= ATH_TX_INFO_FRAME_TYPE_PAUSE;
-+              /* fall through */
-+      case ATH9K_INT_UNPAUSE:
-+              tx_info->pad[0] |= ATH_TX_INFO_FRAME_TYPE_INTERNAL;
-+              break;
-+      }
-       hdrlen = ieee80211_get_hdrlen_from_skb(skb);
-       fc = hdr->frame_control;
-       ATH_TXBUF_RESET(bf);
-+      bf->aphy = aphy;
-       bf->bf_frmlen = skb->len + FCS_LEN - (hdrlen & 3);
-       if (conf_is_ht(&hw->conf) && !is_pae(skb))
-@@ -1599,8 +1601,6 @@ static int ath_tx_setup_buffer(struct ie
-                                          skb->len, DMA_TO_DEVICE);
-       if (unlikely(dma_mapping_error(sc->dev, bf->bf_dmacontext))) {
-               bf->bf_mpdu = NULL;
--              kfree(tx_info_priv);
--              tx_info->rate_driver_data[0] = NULL;
-               ath_print(ath9k_hw_common(sc->sc_ah), ATH_DBG_FATAL,
-                         "dma_mapping_error() on TX\n");
-               return -ENOMEM;
-@@ -1781,27 +1781,17 @@ exit:
- /*****************/
- static void ath_tx_complete(struct ath_softc *sc, struct sk_buff *skb,
--                          int tx_flags)
-+                          struct ath_wiphy *aphy, int tx_flags)
- {
-       struct ieee80211_hw *hw = sc->hw;
-       struct ieee80211_tx_info *tx_info = IEEE80211_SKB_CB(skb);
--      struct ath_tx_info_priv *tx_info_priv = ATH_TX_INFO_PRIV(tx_info);
-       struct ath_common *common = ath9k_hw_common(sc->sc_ah);
-       int hdrlen, padsize;
--      int frame_type = ATH9K_NOT_INTERNAL;
-       ath_print(common, ATH_DBG_XMIT, "TX complete: skb: %p\n", skb);
--      if (tx_info_priv) {
--              hw = tx_info_priv->aphy->hw;
--              frame_type = tx_info_priv->frame_type;
--      }
--
--      if (tx_info->flags & IEEE80211_TX_CTL_NO_ACK ||
--          tx_info->flags & IEEE80211_TX_STAT_TX_FILTERED) {
--              kfree(tx_info_priv);
--              tx_info->rate_driver_data[0] = NULL;
--      }
-+      if (aphy)
-+              hw = aphy->hw;
-       if (tx_flags & ATH_TX_BAR)
-               tx_info->flags |= IEEE80211_TX_STAT_AMPDU_NO_BACK;
-@@ -1833,10 +1823,10 @@ static void ath_tx_complete(struct ath_s
-                                       SC_OP_WAIT_FOR_TX_ACK));
-       }
--      if (frame_type == ATH9K_NOT_INTERNAL)
--              ieee80211_tx_status(hw, skb);
--      else
-+      if (unlikely(tx_info->pad[0] & ATH_TX_INFO_FRAME_TYPE_INTERNAL))
-               ath9k_tx_status(hw, skb);
-+      else
-+              ieee80211_tx_status(hw, skb);
- }
- static void ath_tx_complete_buf(struct ath_softc *sc, struct ath_buf *bf,
-@@ -1859,7 +1849,7 @@ static void ath_tx_complete_buf(struct a
-       }
-       dma_unmap_single(sc->dev, bf->bf_dmacontext, skb->len, DMA_TO_DEVICE);
--      ath_tx_complete(sc, skb, tx_flags);
-+      ath_tx_complete(sc, skb, bf->aphy, tx_flags);
-       ath_debug_stat_tx(sc, txq, bf);
-       /*
-@@ -1907,8 +1897,7 @@ static void ath_tx_rc_status(struct ath_
-       struct sk_buff *skb = bf->bf_mpdu;
-       struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data;
-       struct ieee80211_tx_info *tx_info = IEEE80211_SKB_CB(skb);
--      struct ath_tx_info_priv *tx_info_priv = ATH_TX_INFO_PRIV(tx_info);
--      struct ieee80211_hw *hw = tx_info_priv->aphy->hw;
-+      struct ieee80211_hw *hw = bf->aphy->hw;
-       u8 i, tx_rateindex;
-       if (txok)
-@@ -1917,17 +1906,22 @@ static void ath_tx_rc_status(struct ath_
-       tx_rateindex = ds->ds_txstat.ts_rateindex;
-       WARN_ON(tx_rateindex >= hw->max_rates);
--      tx_info_priv->update_rc = update_rc;
-+      if (update_rc)
-+              tx_info->pad[0] |= ATH_TX_INFO_UPDATE_RC;
-       if (ds->ds_txstat.ts_status & ATH9K_TXERR_FILT)
-               tx_info->flags |= IEEE80211_TX_STAT_TX_FILTERED;
-       if ((ds->ds_txstat.ts_status & ATH9K_TXERR_FILT) == 0 &&
-           (bf->bf_flags & ATH9K_TXDESC_NOACK) == 0 && update_rc) {
-               if (ieee80211_is_data(hdr->frame_control)) {
--                      memcpy(&tx_info_priv->tx, &ds->ds_txstat,
--                             sizeof(tx_info_priv->tx));
--                      tx_info_priv->n_frames = bf->bf_nframes;
--                      tx_info_priv->n_bad_frames = nbad;
-+                      if (ds->ds_txstat.ts_flags &
-+                          (ATH9K_TX_DATA_UNDERRUN | ATH9K_TX_DELIM_UNDERRUN))
-+                              tx_info->pad[0] |= ATH_TX_INFO_UNDERRUN;
-+                      if ((ds->ds_txstat.ts_status & ATH9K_TXERR_XRETRY) ||
-+                          (ds->ds_txstat.ts_status & ATH9K_TXERR_FIFO))
-+                              tx_info->pad[0] |= ATH_TX_INFO_XRETRY;
-+                      tx_info->status.ampdu_len = bf->bf_nframes;
-+                      tx_info->status.ampdu_ack_len = bf->bf_nframes - nbad;
-               }
-       }
---- a/drivers/net/wireless/ath/ath9k/debug.c
-+++ b/drivers/net/wireless/ath/ath9k/debug.c
-@@ -257,14 +257,17 @@ static const struct file_operations fops
- void ath_debug_stat_rc(struct ath_softc *sc, struct sk_buff *skb)
- {
--      struct ath_tx_info_priv *tx_info_priv = NULL;
-       struct ieee80211_tx_info *tx_info = IEEE80211_SKB_CB(skb);
-       struct ieee80211_tx_rate *rates = tx_info->status.rates;
--      int final_ts_idx, idx;
-+      int final_ts_idx = 0, idx, i;
-       struct ath_rc_stats *stats;
--      tx_info_priv = ATH_TX_INFO_PRIV(tx_info);
--      final_ts_idx = tx_info_priv->tx.ts_rateindex;
-+      for (i = 0; i < IEEE80211_TX_MAX_RATES; i++) {
-+              if (!rates[i].count)
-+                      break;
-+
-+              final_ts_idx = i;
-+      }
-       idx = rates[final_ts_idx].idx;
-       stats = &sc->debug.stats.rcstats[idx];
-       stats->success++;
---- a/drivers/net/wireless/ath/ath9k/rc.c
-+++ b/drivers/net/wireless/ath/ath9k/rc.c
-@@ -859,12 +859,12 @@ static void ath_get_rate(void *priv, str
- static bool ath_rc_update_per(struct ath_softc *sc,
-                             const struct ath_rate_table *rate_table,
-                             struct ath_rate_priv *ath_rc_priv,
--                            struct ath_tx_info_priv *tx_info_priv,
-+                                struct ieee80211_tx_info *tx_info,
-                             int tx_rate, int xretries, int retries,
-                             u32 now_msec)
- {
-       bool state_change = false;
--      int count;
-+      int count, n_bad_frames;
-       u8 last_per;
-       static u32 nretry_to_per_lookup[10] = {
-               100 * 0 / 1,
-@@ -880,6 +880,7 @@ static bool ath_rc_update_per(struct ath
-       };
-       last_per = ath_rc_priv->per[tx_rate];
-+      n_bad_frames = tx_info->status.ampdu_len - tx_info->status.ampdu_ack_len;
-       if (xretries) {
-               if (xretries == 1) {
-@@ -907,7 +908,7 @@ static bool ath_rc_update_per(struct ath
-               if (retries >= count)
-                       retries = count - 1;
--              if (tx_info_priv->n_bad_frames) {
-+              if (n_bad_frames) {
-                       /* new_PER = 7/8*old_PER + 1/8*(currentPER)
-                        * Assuming that n_frames is not 0.  The current PER
-                        * from the retries is 100 * retries / (retries+1),
-@@ -920,14 +921,14 @@ static bool ath_rc_update_per(struct ath
-                        * the above PER.  The expression below is a
-                        * simplified version of the sum of these two terms.
-                        */
--                      if (tx_info_priv->n_frames > 0) {
--                              int n_frames, n_bad_frames;
-+                      if (tx_info->status.ampdu_len > 0) {
-+                              int n_frames, n_bad_tries;
-                               u8 cur_per, new_per;
--                              n_bad_frames = retries * tx_info_priv->n_frames +
--                                      tx_info_priv->n_bad_frames;
--                              n_frames = tx_info_priv->n_frames * (retries + 1);
--                              cur_per = (100 * n_bad_frames / n_frames) >> 3;
-+                              n_bad_tries = retries * tx_info->status.ampdu_len +
-+                                      n_bad_frames;
-+                              n_frames = tx_info->status.ampdu_len * (retries + 1);
-+                              cur_per = (100 * n_bad_tries / n_frames) >> 3;
-                               new_per = (u8)(last_per - (last_per >> 3) + cur_per);
-                               ath_rc_priv->per[tx_rate] = new_per;
-                       }
-@@ -943,8 +944,7 @@ static bool ath_rc_update_per(struct ath
-                * this was a probe.  Otherwise, ignore the probe.
-                */
-               if (ath_rc_priv->probe_rate && ath_rc_priv->probe_rate == tx_rate) {
--                      if (retries > 0 || 2 * tx_info_priv->n_bad_frames >
--                              tx_info_priv->n_frames) {
-+                      if (retries > 0 || 2 * n_bad_frames > tx_info->status.ampdu_len) {
-                               /*
-                                * Since we probed with just a single attempt,
-                                * any retries means the probe failed.  Also,
-@@ -1003,7 +1003,7 @@ static bool ath_rc_update_per(struct ath
- static void ath_rc_update_ht(struct ath_softc *sc,
-                            struct ath_rate_priv *ath_rc_priv,
--                           struct ath_tx_info_priv *tx_info_priv,
-+                           struct ieee80211_tx_info *tx_info,
-                            int tx_rate, int xretries, int retries)
- {
-       u32 now_msec = jiffies_to_msecs(jiffies);
-@@ -1020,7 +1020,7 @@ static void ath_rc_update_ht(struct ath_
-       /* Update PER first */
-       state_change = ath_rc_update_per(sc, rate_table, ath_rc_priv,
--                                       tx_info_priv, tx_rate, xretries,
-+                                       tx_info, tx_rate, xretries,
-                                        retries, now_msec);
-       /*
-@@ -1098,7 +1098,6 @@ static void ath_rc_tx_status(struct ath_
-                            struct ieee80211_tx_info *tx_info,
-                            int final_ts_idx, int xretries, int long_retry)
- {
--      struct ath_tx_info_priv *tx_info_priv = ATH_TX_INFO_PRIV(tx_info);
-       const struct ath_rate_table *rate_table;
-       struct ieee80211_tx_rate *rates = tx_info->status.rates;
-       u8 flags;
-@@ -1124,9 +1123,8 @@ static void ath_rc_tx_status(struct ath_
-                                       return;
-                               rix = ath_rc_get_rateindex(rate_table, &rates[i]);
--                              ath_rc_update_ht(sc, ath_rc_priv,
--                                              tx_info_priv, rix,
--                                              xretries ? 1 : 2,
-+                              ath_rc_update_ht(sc, ath_rc_priv, tx_info,
-+                                              rix, xretries ? 1 : 2,
-                                               rates[i].count);
-                       }
-               }
-@@ -1149,8 +1147,7 @@ static void ath_rc_tx_status(struct ath_
-               return;
-       rix = ath_rc_get_rateindex(rate_table, &rates[i]);
--      ath_rc_update_ht(sc, ath_rc_priv, tx_info_priv, rix,
--                       xretries, long_retry);
-+      ath_rc_update_ht(sc, ath_rc_priv, tx_info, rix, xretries, long_retry);
- }
- static const
-@@ -1301,23 +1298,30 @@ static void ath_tx_status(void *priv, st
- {
-       struct ath_softc *sc = priv;
-       struct ath_rate_priv *ath_rc_priv = priv_sta;
--      struct ath_tx_info_priv *tx_info_priv = NULL;
-       struct ieee80211_tx_info *tx_info = IEEE80211_SKB_CB(skb);
-       struct ieee80211_hdr *hdr;
--      int final_ts_idx, tx_status = 0, is_underrun = 0;
-+      int final_ts_idx = 0, tx_status = 0, is_underrun = 0;
-+      int long_retry = 0;
-       __le16 fc;
-+      int i;
-       hdr = (struct ieee80211_hdr *)skb->data;
-       fc = hdr->frame_control;
--      tx_info_priv = ATH_TX_INFO_PRIV(tx_info);
--      final_ts_idx = tx_info_priv->tx.ts_rateindex;
-+      for (i = 0; i < IEEE80211_TX_MAX_RATES; i++) {
-+              struct ieee80211_tx_rate *rate = &tx_info->status.rates[i];
-+              if (!rate->count)
-+                      break;
-+
-+              final_ts_idx = i;
-+              long_retry = rate->count - 1;
-+      }
-       if (!priv_sta || !ieee80211_is_data(fc) ||
--          !tx_info_priv->update_rc)
--              goto exit;
-+          !(tx_info->pad[0] & ATH_TX_INFO_UPDATE_RC))
-+              return;
--      if (tx_info_priv->tx.ts_status & ATH9K_TXERR_FILT)
--              goto exit;
-+      if (tx_info->flags & IEEE80211_TX_STAT_TX_FILTERED)
-+              return;
-       /*
-        * If underrun error is seen assume it as an excessive retry only
-@@ -1325,20 +1329,17 @@ static void ath_tx_status(void *priv, st
-        * Adjust the long retry as if the frame was tried hw->max_rate_tries
-        * times. This affects how ratectrl updates PER for the failed rate.
-        */
--      if (tx_info_priv->tx.ts_flags &
--          (ATH9K_TX_DATA_UNDERRUN | ATH9K_TX_DELIM_UNDERRUN) &&
--          ((sc->sc_ah->tx_trig_level) >= ath_rc_priv->tx_triglevel_max)) {
-+      if ((tx_info->pad[0] & ATH_TX_INFO_UNDERRUN) &&
-+          (sc->sc_ah->tx_trig_level >= ath_rc_priv->tx_triglevel_max)) {
-               tx_status = 1;
-               is_underrun = 1;
-       }
--      if ((tx_info_priv->tx.ts_status & ATH9K_TXERR_XRETRY) ||
--          (tx_info_priv->tx.ts_status & ATH9K_TXERR_FIFO))
-+      if (tx_info->pad[0] & ATH_TX_INFO_XRETRY)
-               tx_status = 1;
-       ath_rc_tx_status(sc, ath_rc_priv, tx_info, final_ts_idx, tx_status,
--                       (is_underrun) ? sc->hw->max_rate_tries :
--                       tx_info_priv->tx.ts_longretry);
-+                       (is_underrun) ? sc->hw->max_rate_tries : long_retry);
-       /* Check if aggregation has to be enabled for this tid */
-       if (conf_is_ht(&sc->hw->conf) &&
-@@ -1357,8 +1358,6 @@ static void ath_tx_status(void *priv, st
-       }
-       ath_debug_stat_rc(sc, skb);
--exit:
--      kfree(tx_info_priv);
- }
- static void ath_rate_init(void *priv, struct ieee80211_supported_band *sband,
diff --git a/package/mac80211/patches/540-monitor_tx_status.patch b/package/mac80211/patches/540-monitor_tx_status.patch
deleted file mode 100644 (file)
index b2a35de..0000000
+++ /dev/null
@@ -1,14 +0,0 @@
---- a/net/mac80211/main.c
-+++ b/net/mac80211/main.c
-@@ -587,6 +587,11 @@ void ieee80211_tx_status(struct ieee8021
-                       if (!netif_running(sdata->dev))
-                               continue;
-+                      if ((sdata->u.mntr_flags & MONITOR_FLAG_COOK_FRAMES) &&
-+                          !(info->flags & IEEE80211_TX_CTL_INJECTED) &&
-+                          (type == IEEE80211_FTYPE_DATA))
-+                              continue;
-+
-                       if (prev_dev) {
-                               skb2 = skb_clone(skb, GFP_ATOMIC);
-                               if (skb2) {
diff --git a/package/mac80211/patches/550-ath9k_rx_fix.patch b/package/mac80211/patches/550-ath9k_rx_fix.patch
deleted file mode 100644 (file)
index cdef13c..0000000
+++ /dev/null
@@ -1,10 +0,0 @@
---- a/drivers/net/wireless/ath/ath9k/common.c
-+++ b/drivers/net/wireless/ath/ath9k/common.c
-@@ -203,6 +203,7 @@ int ath9k_cmn_rx_skb_preprocess(struct a
- {
-       struct ath_hw *ah = common->ah;
-+      memset(rx_status, 0, sizeof(struct ieee80211_rx_status));
-       if (!ath9k_rx_accept(common, skb, rx_status, rx_stats, decrypt_error))
-               return -EINVAL;
diff --git a/package/mac80211/patches/560-ath9k_rate_control_api.patch b/package/mac80211/patches/560-ath9k_rate_control_api.patch
deleted file mode 100644 (file)
index b4f2a12..0000000
+++ /dev/null
@@ -1,1244 +0,0 @@
---- a/drivers/net/wireless/ath/ath9k/rc.c
-+++ b/drivers/net/wireless/ath/ath9k/rc.c
-@@ -19,132 +19,133 @@
- 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,
-+                      5400, 0, 0x00, 12,
-                       0, 0, 0, 0, 0, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */
--                      7800,  0x0f, 0x00, 18,
-+                      7800,  1, 0x00, 18,
-                       0, 1, 1, 1, 1, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */
--                      10000, 0x0a, 0x00, 24,
-+                      10000, 2, 0x00, 24,
-                       2, 2, 2, 2, 2, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */
--                      13900, 0x0e, 0x00, 36,
-+                      13900, 3, 0x00, 36,
-                       2,  3, 3, 3, 3, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */
--                      17300, 0x09, 0x00, 48,
-+                      17300, 4, 0x00, 48,
-                       4,  4, 4, 4, 4, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */
--                      23000, 0x0d, 0x00, 72,
-+                      23000, 5, 0x00, 72,
-                       4,  5, 5, 5, 5, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */
--                      27400, 0x08, 0x00, 96,
-+                      27400, 6, 0x00, 96,
-                       4,  6, 6, 6, 6, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */
--                      29300, 0x0c, 0x00, 108,
-+                      29300, 7, 0x00, 108,
-                       4,  7, 7, 7, 7, 0 },
-               { VALID_2040, VALID_2040, WLAN_RC_PHY_HT_20_SS, 6500, /* 6.5 Mb */
--                      6400, 0x80, 0x00, 0,
-+                      6400, 0, 0x00, 0,
-                       0, 8, 24, 8, 24, 3216 },
-               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 13000, /* 13 Mb */
--                      12700, 0x81, 0x00, 1,
-+                      12700, 1, 0x00, 1,
-                       2, 9, 25, 9, 25, 6434 },
-               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 19500, /* 19.5 Mb */
--                      18800, 0x82, 0x00, 2,
-+                      18800, 2, 0x00, 2,
-                       2, 10, 26, 10, 26, 9650 },
-               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 26000, /* 26 Mb */
--                      25000, 0x83, 0x00, 3,
-+                      25000, 3, 0x00, 3,
-                       4,  11, 27, 11, 27, 12868 },
-               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 39000, /* 39 Mb */
--                      36700, 0x84, 0x00, 4,
-+                      36700, 4, 0x00, 4,
-                       4,  12, 28, 12, 28, 19304 },
-               { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 52000, /* 52 Mb */
--                      48100, 0x85, 0x00, 5,
-+                      48100, 5, 0x00, 5,
-                       4,  13, 29, 13, 29, 25740 },
-               { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 58500, /* 58.5 Mb */
--                      53500, 0x86, 0x00, 6,
-+                      53500, 6, 0x00, 6,
-                       4,  14, 30, 14, 30,  28956 },
-               { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 65000, /* 65 Mb */
--                      59000, 0x87, 0x00, 7,
-+                      59000, 7, 0x00, 7,
-                       4,  15, 31, 15, 32, 32180 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 13000, /* 13 Mb */
--                      12700, 0x88, 0x00,
-+                      12700, 8, 0x00,
-                       8, 3, 16, 33, 16, 33, 6430 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 26000, /* 26 Mb */
--                      24800, 0x89, 0x00, 9,
-+                      24800, 9, 0x00, 9,
-                       2, 17, 34, 17, 34, 12860 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 39000, /* 39 Mb */
--                      36600, 0x8a, 0x00, 10,
-+                      36600, 10, 0x00, 10,
-                       2, 18, 35, 18, 35, 19300 },
-               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 52000, /* 52 Mb */
--                      48100, 0x8b, 0x00, 11,
-+                      48100, 11, 0x00, 11,
-                       4,  19, 36, 19, 36, 25736 },
-               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 78000, /* 78 Mb */
--                      69500, 0x8c, 0x00, 12,
-+                      69500, 12, 0x00, 12,
-                       4,  20, 37, 20, 37, 38600 },
-               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 104000, /* 104 Mb */
--                      89500, 0x8d, 0x00, 13,
-+                      89500, 13, 0x00, 13,
-                       4,  21, 38, 21, 38, 51472 },
-               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 117000, /* 117 Mb */
--                      98900, 0x8e, 0x00, 14,
-+                      98900, 14, 0x00, 14,
-                       4,  22, 39, 22, 39, 57890 },
-               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 130000, /* 130 Mb */
--                      108300, 0x8f, 0x00, 15,
-+                      108300, 15, 0x00, 15,
-                       4,  23, 40, 23, 41, 64320 },
-               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 13500, /* 13.5 Mb */
--                      13200, 0x80, 0x00, 0,
-+                      13200, 0, 0x00, 0,
-                       0, 8, 24, 24, 24, 6684 },
-               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 27500, /* 27.0 Mb */
--                      25900, 0x81, 0x00, 1,
-+                      25900, 1, 0x00, 1,
-                       2, 9, 25, 25, 25, 13368 },
-               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 40500, /* 40.5 Mb */
--                      38600, 0x82, 0x00, 2,
-+                      38600, 2, 0x00, 2,
-                       2, 10, 26, 26, 26, 20052 },
-               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 54000, /* 54 Mb */
--                      49800, 0x83, 0x00, 3,
-+                      49800, 3, 0x00, 3,
-                       4,  11, 27, 27, 27, 26738 },
-               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 81500, /* 81 Mb */
--                      72200, 0x84, 0x00, 4,
-+                      72200, 4, 0x00, 4,
-                       4,  12, 28, 28, 28, 40104 },
-               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 108000, /* 108 Mb */
--                      92900, 0x85, 0x00, 5,
-+                      92900, 5, 0x00, 5,
-                       4,  13, 29, 29, 29, 53476 },
-               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 121500, /* 121.5 Mb */
--                      102700, 0x86, 0x00, 6,
-+                      102700, 6, 0x00, 6,
-                       4,  14, 30, 30, 30, 60156 },
-               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 135000, /* 135 Mb */
--                      112000, 0x87, 0x00, 7,
-+                      112000, 7, 0x00, 7,
-                       4,  15, 31, 32, 32, 66840 },
-               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS_HGI, 150000, /* 150 Mb */
--                      122000, 0x87, 0x00, 7,
-+                      122000, 7, 0x00, 7,
-                       4,  15, 31, 32, 32, 74200 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 27000, /* 27 Mb */
--                      25800, 0x88, 0x00, 8,
-+                      25800, 8, 0x00, 8,
-                       0, 16, 33, 33, 33, 13360 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 54000, /* 54 Mb */
--                      49800, 0x89, 0x00, 9,
-+                      49800, 9, 0x00, 9,
-                       2, 17, 34, 34, 34, 26720 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 81000, /* 81 Mb */
--                      71900, 0x8a, 0x00, 10,
-+                      71900, 10, 0x00, 10,
-                       2, 18, 35, 35, 35, 40080 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 108000, /* 108 Mb */
--                      92500, 0x8b, 0x00, 11,
-+                      92500, 11, 0x00, 11,
-                       4,  19, 36, 36, 36, 53440 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 162000, /* 162 Mb */
--                      130300, 0x8c, 0x00, 12,
-+                      130300, 12, 0x00, 12,
-                       4,  20, 37, 37, 37, 80160 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 216000, /* 216 Mb */
--                      162800, 0x8d, 0x00, 13,
-+                      162800, 13, 0x00, 13,
-                       4,  21, 38, 38, 38, 106880 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 243000, /* 243 Mb */
--                      178200, 0x8e, 0x00, 14,
-+                      178200, 14, 0x00, 14,
-                       4,  22, 39, 39, 39, 120240 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 270000, /* 270 Mb */
--                      192100, 0x8f, 0x00, 15,
-+                      192100, 15, 0x00, 15,
-                       4,  23, 40, 41, 41, 133600 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS_HGI, 300000, /* 300 Mb */
--                      207000, 0x8f, 0x00, 15,
-+                      207000, 15, 0x00, 15,
-                       4,  23, 40, 41, 41, 148400 },
-       },
-       50,  /* probe interval */
-@@ -156,144 +157,145 @@ 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,
-+                      900, 0, 0x00, 2,
-                       0, 0, 0, 0, 0, 0 },
-               { VALID_ALL, VALID_ALL, WLAN_RC_PHY_CCK, 2000, /* 2 Mb */
--                      1900, 0x1a, 0x04, 4,
-+                      1900, 1, 0x04, 4,
-                       1, 1, 1, 1, 1, 0 },
-               { VALID_ALL, VALID_ALL, WLAN_RC_PHY_CCK, 5500, /* 5.5 Mb */
--                      4900, 0x19, 0x04, 11,
-+                      4900, 2, 0x04, 11,
-                       2, 2, 2, 2, 2, 0 },
-               { VALID_ALL, VALID_ALL, WLAN_RC_PHY_CCK, 11000, /* 11 Mb */
--                      8100, 0x18, 0x04, 22,
-+                      8100, 3, 0x04, 22,
-                       3, 3, 3, 3, 3, 0 },
-               { INVALID, INVALID, WLAN_RC_PHY_OFDM, 6000, /* 6 Mb */
--                      5400, 0x0b, 0x00, 12,
-+                      5400, 4, 0x00, 12,
-                       4, 4, 4, 4, 4, 0 },
-               { INVALID, INVALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */
--                      7800, 0x0f, 0x00, 18,
-+                      7800, 5, 0x00, 18,
-                       4, 5, 5, 5, 5, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */
--                      10100, 0x0a, 0x00, 24,
-+                      10100, 6, 0x00, 24,
-                       6, 6, 6, 6, 6, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */
--                      14100,  0x0e, 0x00, 36,
-+                      14100, 7, 0x00, 36,
-                       6, 7, 7, 7, 7, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */
--                      17700, 0x09, 0x00, 48,
-+                      17700, 8, 0x00, 48,
-                       8,  8, 8, 8, 8, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */
--                      23700, 0x0d, 0x00, 72,
-+                      23700, 9, 0x00, 72,
-                       8,  9, 9, 9, 9, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */
--                      27400, 0x08, 0x00, 96,
-+                      27400, 10, 0x00, 96,
-                       8,  10, 10, 10, 10, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */
--                      30900, 0x0c, 0x00, 108,
-+                      30900, 11, 0x00, 108,
-                       8,  11, 11, 11, 11, 0 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_20_SS, 6500, /* 6.5 Mb */
--                      6400, 0x80, 0x00, 0,
-+                      6400, 0, 0x00, 0,
-                       4, 12, 28, 12, 28, 3216 },
-               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 13000, /* 13 Mb */
--                      12700, 0x81, 0x00, 1,
-+                      12700, 1, 0x00, 1,
-                       6, 13, 29, 13, 29, 6434 },
-               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 19500, /* 19.5 Mb */
--                      18800, 0x82, 0x00, 2,
-+                      18800, 2, 0x00, 2,
-                       6, 14, 30, 14, 30, 9650 },
-               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 26000, /* 26 Mb */
--                      25000, 0x83, 0x00, 3,
-+                      25000, 3, 0x00, 3,
-                       8,  15, 31, 15, 31, 12868 },
-               { VALID_20, VALID_20, WLAN_RC_PHY_HT_20_SS, 39000, /* 39 Mb */
--                      36700, 0x84, 0x00, 4,
-+                      36700, 4, 0x00, 4,
-                       8,  16, 32, 16, 32, 19304 },
-               { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 52000, /* 52 Mb */
--                      48100, 0x85, 0x00, 5,
-+                      48100, 5, 0x00, 5,
-                       8,  17, 33, 17, 33, 25740 },
-               { INVALID,  VALID_20, WLAN_RC_PHY_HT_20_SS, 58500, /* 58.5 Mb */
--                      53500, 0x86, 0x00, 6,
-+                      53500, 6, 0x00, 6,
-                       8,  18, 34, 18, 34, 28956 },
-               { INVALID, VALID_20, WLAN_RC_PHY_HT_20_SS, 65000, /* 65 Mb */
--                      59000, 0x87, 0x00, 7,
-+                      59000, 7, 0x00, 7,
-                       8,  19, 35, 19, 36, 32180 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 13000, /* 13 Mb */
--                      12700, 0x88, 0x00, 8,
-+                      12700, 8, 0x00, 8,
-                       4, 20, 37, 20, 37, 6430 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 26000, /* 26 Mb */
--                      24800, 0x89, 0x00, 9,
-+                      24800, 9, 0x00, 9,
-                       6, 21, 38, 21, 38, 12860 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_20_DS, 39000, /* 39 Mb */
--                      36600, 0x8a, 0x00, 10,
-+                      36600, 10, 0x00, 10,
-                       6, 22, 39, 22, 39, 19300 },
-               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 52000, /* 52 Mb */
--                      48100, 0x8b, 0x00, 11,
-+                      48100, 11, 0x00, 11,
-                       8,  23, 40, 23, 40, 25736 },
-               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 78000, /* 78 Mb */
--                      69500, 0x8c, 0x00, 12,
-+                      69500, 12, 0x00, 12,
-                       8,  24, 41, 24, 41, 38600 },
-               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 104000, /* 104 Mb */
--                      89500, 0x8d, 0x00, 13,
-+                      89500, 13, 0x00, 13,
-                       8,  25, 42, 25, 42, 51472 },
-               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 117000, /* 117 Mb */
--                      98900, 0x8e, 0x00, 14,
-+                      98900, 14, 0x00, 14,
-                       8,  26, 43, 26, 44, 57890 },
-               { VALID_20, INVALID, WLAN_RC_PHY_HT_20_DS, 130000, /* 130 Mb */
--                      108300, 0x8f, 0x00, 15,
-+                      108300, 15, 0x00, 15,
-                       8,  27, 44, 27, 45, 64320 },
-               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 13500, /* 13.5 Mb */
--                      13200, 0x80, 0x00, 0,
-+                      13200, 0, 0x00, 0,
-                       8, 12, 28, 28, 28, 6684 },
-               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 27500, /* 27.0 Mb */
--                      25900, 0x81, 0x00, 1,
-+                      25900, 1, 0x00, 1,
-                       8, 13, 29, 29, 29, 13368 },
-               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 40500, /* 40.5 Mb */
--                      38600, 0x82, 0x00, 2,
-+                      38600, 2, 0x00, 2,
-                       8, 14, 30, 30, 30, 20052 },
-               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 54000, /* 54 Mb */
--                      49800, 0x83, 0x00, 3,
-+                      49800, 3, 0x00, 3,
-                       8,  15, 31, 31, 31, 26738 },
-               { VALID_40, VALID_40, WLAN_RC_PHY_HT_40_SS, 81500, /* 81 Mb */
--                      72200, 0x84, 0x00, 4,
-+                      72200, 4, 0x00, 4,
-                       8,  16, 32, 32, 32, 40104 },
-               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 108000, /* 108 Mb */
--                      92900, 0x85, 0x00, 5,
-+                      92900, 5, 0x00, 5,
-                       8,  17, 33, 33, 33, 53476 },
-               { INVALID,  VALID_40, WLAN_RC_PHY_HT_40_SS, 121500, /* 121.5 Mb */
--                      102700, 0x86, 0x00, 6,
-+                      102700, 6, 0x00, 6,
-                       8,  18, 34, 34, 34, 60156 },
-               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS, 135000, /* 135 Mb */
--                      112000, 0x87, 0x00, 7,
-+                      112000, 7, 0x00, 7,
-                       8,  19, 35, 36, 36, 66840 },
-               { INVALID, VALID_40, WLAN_RC_PHY_HT_40_SS_HGI, 150000, /* 150 Mb */
--                      122000, 0x87, 0x00, 7,
-+                      122000, 7, 0x00, 7,
-                       8,  19, 35, 36, 36, 74200 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 27000, /* 27 Mb */
--                      25800, 0x88, 0x00, 8,
-+                      25800, 8, 0x00, 8,
-                       8, 20, 37, 37, 37, 13360 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 54000, /* 54 Mb */
--                      49800, 0x89, 0x00, 9,
-+                      49800, 9, 0x00, 9,
-                       8, 21, 38, 38, 38, 26720 },
-               { INVALID, INVALID, WLAN_RC_PHY_HT_40_DS, 81000, /* 81 Mb */
--                      71900, 0x8a, 0x00, 10,
-+                      71900, 10, 0x00, 10,
-                       8, 22, 39, 39, 39, 40080 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 108000, /* 108 Mb */
--                      92500, 0x8b, 0x00, 11,
-+                      92500, 11, 0x00, 11,
-                       8,  23, 40, 40, 40, 53440 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 162000, /* 162 Mb */
--                      130300, 0x8c, 0x00, 12,
-+                      130300, 12, 0x00, 12,
-                       8,  24, 41, 41, 41, 80160 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 216000, /* 216 Mb */
--                      162800, 0x8d, 0x00, 13,
-+                      162800, 13, 0x00, 13,
-                       8,  25, 42, 42, 42, 106880 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 243000, /* 243 Mb */
--                      178200, 0x8e, 0x00, 14,
-+                      178200, 14, 0x00, 14,
-                       8,  26, 43, 43, 43, 120240 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS, 270000, /* 270 Mb */
--                      192100, 0x8f, 0x00, 15,
-+                      192100, 15, 0x00, 15,
-                       8,  27, 44, 45, 45, 133600 },
-               { VALID_40, INVALID, WLAN_RC_PHY_HT_40_DS_HGI, 300000, /* 300 Mb */
--                      207000, 0x8f, 0x00, 15,
-+                      207000, 15, 0x00, 15,
-                       8,  27, 44, 45, 45, 148400 },
-               },
-       50,  /* probe interval */
-@@ -302,30 +304,31 @@ 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),
-+                      5400, 0, 0x00, 12,
-                       0, 0, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */
--                      7800, 0x0f, 0x00, 18,
-+                      7800, 1, 0x00, 18,
-                       0, 1, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */
--                      10000, 0x0a, 0x00, (0x80|24),
-+                      10000, 2, 0x00, 24,
-                       2, 2, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */
--                      13900, 0x0e, 0x00, 36,
-+                      13900, 3, 0x00, 36,
-                       2, 3, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */
--                      17300, 0x09, 0x00, (0x80|48),
-+                      17300, 4, 0x00, 48,
-                       4,  4, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */
--                      23000, 0x0d, 0x00, 72,
-+                      23000, 5, 0x00, 72,
-                       4,  5, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */
--                      27400, 0x08, 0x00, 96,
-+                      27400, 6, 0x00, 96,
-                       4,  6, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */
--                      29300, 0x0c, 0x00, 108,
-+                      29300, 7, 0x00, 108,
-                       4,  7, 0 },
-       },
-       50,  /* probe interval */
-@@ -334,48 +337,63 @@ 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,
-+                      900, 0, 0x00, 2,
-                       0, 0, 0 },
-               { VALID, VALID, WLAN_RC_PHY_CCK, 2000, /* 2 Mb */
--                      1900, 0x1a, 0x04, 4,
-+                      1900, 1, 0x04, 4,
-                       1, 1, 0 },
-               { VALID, VALID, WLAN_RC_PHY_CCK, 5500, /* 5.5 Mb */
--                      4900, 0x19, 0x04, 11,
-+                      4900, 2, 0x04, 11,
-                       2, 2, 0 },
-               { VALID, VALID, WLAN_RC_PHY_CCK, 11000, /* 11 Mb */
--                      8100, 0x18, 0x04, 22,
-+                      8100, 3, 0x04, 22,
-                       3, 3, 0 },
-               { INVALID, INVALID, WLAN_RC_PHY_OFDM, 6000, /* 6 Mb */
--                      5400, 0x0b, 0x00, 12,
-+                      5400, 4, 0x00, 12,
-                       4, 4, 0 },
-               { INVALID, INVALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */
--                      7800, 0x0f, 0x00, 18,
-+                      7800, 5, 0x00, 18,
-                       4, 5, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */
--                      10000, 0x0a, 0x00, 24,
-+                      10000, 6, 0x00, 24,
-                       6, 6, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */
--                      13900, 0x0e, 0x00, 36,
-+                      13900, 7, 0x00, 36,
-                       6, 7, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */
--                      17300, 0x09, 0x00, 48,
-+                      17300, 8, 0x00, 48,
-                       8,  8, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */
--                      23000, 0x0d, 0x00, 72,
-+                      23000, 9, 0x00, 72,
-                       8,  9, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */
--                      27400, 0x08, 0x00, 96,
-+                      27400, 10, 0x00, 96,
-                       8,  10, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */
--                      29300, 0x0c, 0x00, 108,
-+                      29300, 11, 0x00, 108,
-                       8,  11, 0 },
-       },
-       50,  /* probe interval */
-       0,   /* Phy rates allowed initially */
- };
-+static const struct ath_rate_table *hw_rate_table[ATH9K_MODE_MAX] = {
-+      [ATH9K_MODE_11A] = &ar5416_11a_ratetable,
-+      [ATH9K_MODE_11G] = &ar5416_11g_ratetable,
-+      [ATH9K_MODE_11NA_HT20] = &ar5416_11na_ratetable,
-+      [ATH9K_MODE_11NG_HT20] = &ar5416_11ng_ratetable,
-+      [ATH9K_MODE_11NA_HT40PLUS] = &ar5416_11na_ratetable,
-+      [ATH9K_MODE_11NA_HT40MINUS] = &ar5416_11na_ratetable,
-+      [ATH9K_MODE_11NG_HT40PLUS] = &ar5416_11ng_ratetable,
-+      [ATH9K_MODE_11NG_HT40MINUS] = &ar5416_11ng_ratetable,
-+};
-+
-+static int ath_rc_get_rateindex(const struct ath_rate_table *rate_table,
-+                              struct ieee80211_tx_rate *rate);
-+
- static inline int8_t median(int8_t a, int8_t b, int8_t c)
- {
-       if (a >= b) {
-@@ -534,7 +552,7 @@ static u8 ath_rc_setvalid_rates(struct a
-                        * capflag matches one of the validity
-                        * (VALID/VALID_20/VALID_40) flags */
--                      if (((rate & 0x7F) == (dot11rate & 0x7F)) &&
-+                      if ((rate == dot11rate) &&
-                           ((valid & WLAN_RC_CAP_MODE(capflag)) ==
-                            WLAN_RC_CAP_MODE(capflag)) &&
-                           !WLAN_RC_PHY_HT(phy)) {
-@@ -576,8 +594,7 @@ static u8 ath_rc_setvalid_htrates(struct
-                       u8 rate = rateset->rs_rates[i];
-                       u8 dot11rate = rate_table->info[j].dot11rate;
--                      if (((rate & 0x7F) != (dot11rate & 0x7F)) ||
--                          !WLAN_RC_PHY_HT(phy) ||
-+                      if ((rate != dot11rate) || !WLAN_RC_PHY_HT(phy) ||
-                           !WLAN_RC_PHY_HT_VALID(valid, capflag))
-                               continue;
-@@ -696,18 +713,20 @@ static void ath_rc_rate_set_series(const
-                                  u8 tries, u8 rix, int rtsctsenable)
- {
-       rate->count = tries;
--      rate->idx = rix;
-+      rate->idx = rate_table->info[rix].ratecode;
-       if (txrc->short_preamble)
-               rate->flags |= IEEE80211_TX_RC_USE_SHORT_PREAMBLE;
-       if (txrc->rts || rtsctsenable)
-               rate->flags |= IEEE80211_TX_RC_USE_RTS_CTS;
--      if (WLAN_RC_PHY_40(rate_table->info[rix].phy))
--              rate->flags |= IEEE80211_TX_RC_40_MHZ_WIDTH;
--      if (WLAN_RC_PHY_SGI(rate_table->info[rix].phy))
--              rate->flags |= IEEE80211_TX_RC_SHORT_GI;
--      if (WLAN_RC_PHY_HT(rate_table->info[rix].phy))
-+
-+      if (WLAN_RC_PHY_HT(rate_table->info[rix].phy)) {
-               rate->flags |= IEEE80211_TX_RC_MCS;
-+              if (WLAN_RC_PHY_40(rate_table->info[rix].phy))
-+                      rate->flags |= IEEE80211_TX_RC_40_MHZ_WIDTH;
-+              if (WLAN_RC_PHY_SGI(rate_table->info[rix].phy))
-+                      rate->flags |= IEEE80211_TX_RC_SHORT_GI;
-+      }
- }
- static void ath_rc_rate_set_rtscts(struct ath_softc *sc,
-@@ -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)) {
--                      rix = rates[i].idx;
-+                      rix = ath_rc_get_rateindex(rate_table, &rates[i]);
-                       break;
-               }
-       }
-@@ -1080,15 +1099,19 @@ static int ath_rc_get_rateindex(const st
- {
-       int rix;
-+      if (!(rate->flags & IEEE80211_TX_RC_MCS))
-+              return rate->idx;
-+
-+      rix = rate->idx + rate_table->mcs_start;
-       if ((rate->flags & IEEE80211_TX_RC_40_MHZ_WIDTH) &&
-           (rate->flags & IEEE80211_TX_RC_SHORT_GI))
--              rix = rate_table->info[rate->idx].ht_index;
-+              rix = rate_table->info[rix].ht_index;
-       else if (rate->flags & IEEE80211_TX_RC_SHORT_GI)
--              rix = rate_table->info[rate->idx].sgi_index;
-+              rix = rate_table->info[rix].sgi_index;
-       else if (rate->flags & IEEE80211_TX_RC_40_MHZ_WIDTH)
--              rix = rate_table->info[rate->idx].cw40index;
-+              rix = rate_table->info[rix].cw40index;
-       else
--              rix = rate_table->info[rate->idx].base_index;
-+              rix = rate_table->info[rix].base_index;
-       return rix;
- }
-@@ -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);
--      return sc->hw_rate_table[mode];
-+
-+      sc->cur_rate_mode = mode;
-+      return hw_rate_table[mode];
- }
- static void ath_rc_init(struct ath_softc *sc,
-@@ -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;
--      if (!rate_table) {
--              ath_print(common, ATH_DBG_FATAL,
--                        "Rate table not initialized\n");
--              return;
--      }
--
-       /* Initial rate table size. Will change depending
-        * on the working rate set */
-       ath_rc_priv->rate_table_size = RATE_TABLE_SIZE;
-@@ -1357,7 +1376,8 @@ static void ath_tx_status(void *priv, st
-               }
-       }
--      ath_debug_stat_rc(sc, skb);
-+      ath_debug_stat_rc(sc, ath_rc_get_rateindex(sc->cur_rate_table,
-+              &tx_info->status.rates[final_ts_idx]));
- }
- static void ath_rate_init(void *priv, struct ieee80211_supported_band *sband,
-@@ -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;
--      const struct ath_rate_table *rate_table = NULL;
-+      const struct ath_rate_table *rate_table;
-       bool is_cw40, is_sgi40;
-       int i, j = 0;
-@@ -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,
--                                                 sta->ht_cap.ht_supported,
--                                                 is_cw40);
--      } else if (sc->sc_ah->opmode == NL80211_IFTYPE_AP) {
--              /* cur_rate_table would be set on init through config() */
--              rate_table = sc->cur_rate_table;
-+                                    sta->ht_cap.ht_supported, is_cw40);
-+      } else {
-+              rate_table = hw_rate_table[sc->cur_rate_mode];
-       }
-       ath_rc_priv->ht_cap = ath_rc_build_ht_caps(sc, sta, is_cw40, is_sgi40);
-@@ -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);
-+                      sc->cur_rate_table = hw_rate_table[sc->cur_rate_mode];
-               }
-       }
- }
-@@ -1497,26 +1516,6 @@ static struct rate_control_ops ath_rate_
-       .free_sta = ath_rate_free_sta,
- };
--void ath_rate_attach(struct ath_softc *sc)
--{
--      sc->hw_rate_table[ATH9K_MODE_11A] =
--              &ar5416_11a_ratetable;
--      sc->hw_rate_table[ATH9K_MODE_11G] =
--              &ar5416_11g_ratetable;
--      sc->hw_rate_table[ATH9K_MODE_11NA_HT20] =
--              &ar5416_11na_ratetable;
--      sc->hw_rate_table[ATH9K_MODE_11NG_HT20] =
--              &ar5416_11ng_ratetable;
--      sc->hw_rate_table[ATH9K_MODE_11NA_HT40PLUS] =
--              &ar5416_11na_ratetable;
--      sc->hw_rate_table[ATH9K_MODE_11NA_HT40MINUS] =
--              &ar5416_11na_ratetable;
--      sc->hw_rate_table[ATH9K_MODE_11NG_HT40PLUS] =
--              &ar5416_11ng_ratetable;
--      sc->hw_rate_table[ATH9K_MODE_11NG_HT40MINUS] =
--              &ar5416_11ng_ratetable;
--}
--
- int ath_rate_control_register(void)
- {
-       return ieee80211_rate_control_register(&ath_rate_ops);
---- a/drivers/net/wireless/ath/ath9k/xmit.c
-+++ b/drivers/net/wireless/ath/ath9k/xmit.c
-@@ -70,6 +70,29 @@ static int ath_tx_num_badfrms(struct ath
- static void ath_tx_rc_status(struct ath_buf *bf, struct ath_desc *ds,
-                            int nbad, int txok, bool update_rc);
-+enum {
-+      MCS_DEFAULT,
-+      MCS_HT40,
-+      MCS_HT40_SGI,
-+};
-+
-+static int ath_max_4ms_framelen[3][16] = {
-+      [MCS_DEFAULT] = {
-+              3216,  6434,  9650,  12868, 19304, 25740,  28956,  32180,
-+              6430,  12860, 19300, 25736, 38600, 51472,  57890,  64320,
-+      },
-+      [MCS_HT40] = {
-+              6684,  13368, 20052, 26738, 40104, 53476,  60156,  66840,
-+              13360, 26720, 40080, 53440, 80160, 106880, 120240, 133600,
-+      },
-+      [MCS_HT40_SGI] = {
-+              /* TODO: Only MCS 7 and 15 updated, recalculate the rest */
-+              6684,  13368, 20052, 26738, 40104, 53476,  60156,  74200,
-+              13360, 26720, 40080, 53440, 80160, 106880, 120240, 148400,
-+      }
-+};
-+
-+
- /*********************/
- /* Aggregation logic */
- /*********************/
-@@ -459,7 +482,6 @@ static void ath_tx_complete_aggr(struct 
- static u32 ath_lookup_rate(struct ath_softc *sc, struct ath_buf *bf,
-                          struct ath_atx_tid *tid)
- {
--      const struct ath_rate_table *rate_table = sc->cur_rate_table;
-       struct sk_buff *skb;
-       struct ieee80211_tx_info *tx_info;
-       struct ieee80211_tx_rate *rates;
-@@ -480,12 +502,20 @@ static u32 ath_lookup_rate(struct ath_so
-       for (i = 0; i < 4; i++) {
-               if (rates[i].count) {
--                      if (!WLAN_RC_PHY_HT(rate_table->info[rates[i].idx].phy)) {
-+                      int modeidx;
-+                      if (!(rates[i].flags & IEEE80211_TX_RC_MCS)) {
-                               legacy = 1;
-                               break;
-                       }
--                      frmlen = rate_table->info[rates[i].idx].max_4ms_framelen;
-+                      if (rates[i].flags & IEEE80211_TX_RC_SHORT_GI)
-+                              modeidx = MCS_HT40_SGI;
-+                      else if (rates[i].flags & IEEE80211_TX_RC_40_MHZ_WIDTH)
-+                              modeidx = MCS_HT40;
-+                      else
-+                              modeidx = MCS_DEFAULT;
-+
-+                      frmlen = ath_max_4ms_framelen[modeidx][rates[i].idx];
-                       max_4ms_framelen = min(max_4ms_framelen, frmlen);
-               }
-       }
-@@ -523,12 +553,11 @@ static u32 ath_lookup_rate(struct ath_so
- static int ath_compute_num_delims(struct ath_softc *sc, struct ath_atx_tid *tid,
-                                 struct ath_buf *bf, u16 frmlen)
- {
--      const struct ath_rate_table *rt = sc->cur_rate_table;
-       struct sk_buff *skb = bf->bf_mpdu;
-       struct ieee80211_tx_info *tx_info = IEEE80211_SKB_CB(skb);
-       u32 nsymbits, nsymbols;
-       u16 minlen;
--      u8 rc, flags, rix;
-+      u8 flags, rix;
-       int width, half_gi, ndelim, mindelim;
-       /* Select standard number of delimiters based on frame length alone */
-@@ -558,7 +587,6 @@ static int ath_compute_num_delims(struct
-       rix = tx_info->control.rates[0].idx;
-       flags = tx_info->control.rates[0].flags;
--      rc = rt->info[rix].ratecode;
-       width = (flags & IEEE80211_TX_RC_40_MHZ_WIDTH) ? 1 : 0;
-       half_gi = (flags & IEEE80211_TX_RC_SHORT_GI) ? 1 : 0;
-@@ -570,7 +598,7 @@ static int ath_compute_num_delims(struct
-       if (nsymbols == 0)
-               nsymbols = 1;
--      nsymbits = bits_per_symbol[HT_RC_2_MCS(rc)][width];
-+      nsymbits = bits_per_symbol[rix][width];
-       minlen = (nsymbols * nsymbits) / BITS_PER_BYTE;
-       if (frmlen < minlen) {
-@@ -1430,22 +1458,14 @@ static int setup_tx_flags(struct ath_sof
- static u32 ath_pkt_duration(struct ath_softc *sc, u8 rix, struct ath_buf *bf,
-                           int width, int half_gi, bool shortPreamble)
- {
--      const struct ath_rate_table *rate_table = sc->cur_rate_table;
-       u32 nbits, nsymbits, duration, nsymbols;
--      u8 rc;
-       int streams, pktlen;
-       pktlen = bf_isaggr(bf) ? bf->bf_al : bf->bf_frmlen;
--      rc = rate_table->info[rix].ratecode;
--
--      /* for legacy rates, use old function to compute packet duration */
--      if (!IS_HT_RATE(rc))
--              return ath9k_hw_computetxtime(sc->sc_ah, rate_table, pktlen,
--                                            rix, shortPreamble);
-       /* find number of symbols: PLCP + data */
-       nbits = (pktlen << 3) + OFDM_PLCP_BITS;
--      nsymbits = bits_per_symbol[HT_RC_2_MCS(rc)][width];
-+      nsymbits = bits_per_symbol[rix][width];
-       nsymbols = (nbits + nsymbits - 1) / nsymbits;
-       if (!half_gi)
-@@ -1454,7 +1474,7 @@ static u32 ath_pkt_duration(struct ath_s
-               duration = SYMBOL_TIME_HALFGI(nsymbols);
-       /* addup duration for legacy/ht training and signal fields */
--      streams = HT_RC_2_STREAMS(rc);
-+      streams = HT_RC_2_STREAMS(rix);
-       duration += L_STF + L_LTF + L_SIG + HT_SIG + HT_STF + HT_LTF(streams);
-       return duration;
-@@ -1463,11 +1483,11 @@ static u32 ath_pkt_duration(struct ath_s
- static void ath_buf_set_rate(struct ath_softc *sc, struct ath_buf *bf)
- {
-       struct ath_common *common = ath9k_hw_common(sc->sc_ah);
--      const struct ath_rate_table *rt = sc->cur_rate_table;
-       struct ath9k_11n_rate_series series[4];
-       struct sk_buff *skb;
-       struct ieee80211_tx_info *tx_info;
-       struct ieee80211_tx_rate *rates;
-+      const struct ieee80211_rate *rate;
-       struct ieee80211_hdr *hdr;
-       int i, flags = 0;
-       u8 rix = 0, ctsrate = 0;
-@@ -1486,11 +1506,10 @@ static void ath_buf_set_rate(struct ath_
-        * checking the BSS's global flag.
-        * But for the rate series, IEEE80211_TX_RC_USE_SHORT_PREAMBLE is used.
-        */
-+      rate = ieee80211_get_rts_cts_rate(sc->hw, tx_info);
-+      ctsrate = rate->hw_value;
-       if (sc->sc_flags & SC_OP_PREAMBLE_SHORT)
--              ctsrate = rt->info[tx_info->control.rts_cts_rate_idx].ratecode |
--                      rt->info[tx_info->control.rts_cts_rate_idx].short_preamble;
--      else
--              ctsrate = rt->info[tx_info->control.rts_cts_rate_idx].ratecode;
-+              ctsrate |= rate->hw_value_short;
-       /*
-        * ATH9K_TXDESC_RTSENA and ATH9K_TXDESC_CTSENA are mutually exclusive.
-@@ -1513,6 +1532,9 @@ static void ath_buf_set_rate(struct ath_
-               flags &= ~(ATH9K_TXDESC_RTSENA);
-       for (i = 0; i < 4; i++) {
-+              bool is_40, is_sgi, is_sp;
-+              int phy;
-+
-               if (!rates[i].count || (rates[i].idx < 0))
-                       continue;
-@@ -1520,12 +1542,6 @@ static void ath_buf_set_rate(struct ath_
-               series[i].Tries = rates[i].count;
-               series[i].ChSel = common->tx_chainmask;
--              if (rates[i].flags & IEEE80211_TX_RC_USE_SHORT_PREAMBLE)
--                      series[i].Rate = rt->info[rix].ratecode |
--                              rt->info[rix].short_preamble;
--              else
--                      series[i].Rate = rt->info[rix].ratecode;
--
-               if (rates[i].flags & IEEE80211_TX_RC_USE_RTS_CTS)
-                       series[i].RateFlags |= ATH9K_RATESERIES_RTS_CTS;
-               if (rates[i].flags & IEEE80211_TX_RC_40_MHZ_WIDTH)
-@@ -1533,10 +1549,36 @@ static void ath_buf_set_rate(struct ath_
-               if (rates[i].flags & IEEE80211_TX_RC_SHORT_GI)
-                       series[i].RateFlags |= ATH9K_RATESERIES_HALFGI;
--              series[i].PktDuration = ath_pkt_duration(sc, rix, bf,
--                       (rates[i].flags & IEEE80211_TX_RC_40_MHZ_WIDTH) != 0,
--                       (rates[i].flags & IEEE80211_TX_RC_SHORT_GI),
--                       (rates[i].flags & IEEE80211_TX_RC_USE_SHORT_PREAMBLE));
-+              is_sgi = !!(rates[i].flags & IEEE80211_TX_RC_SHORT_GI);
-+              is_40 = !!(rates[i].flags & IEEE80211_TX_RC_40_MHZ_WIDTH);
-+              is_sp = !!(rates[i].flags & IEEE80211_TX_RC_USE_SHORT_PREAMBLE);
-+
-+              if (rates[i].flags & IEEE80211_TX_RC_MCS) {
-+                      /* MCS rates */
-+                      series[i].Rate = rix | 0x80;
-+                      series[i].PktDuration = ath_pkt_duration(sc, rix, bf,
-+                               is_40, is_sgi, is_sp);
-+                      continue;
-+              }
-+
-+              /* legcay rates */
-+              if ((tx_info->band == IEEE80211_BAND_2GHZ) &&
-+                  !(rate->flags & IEEE80211_RATE_ERP_G))
-+                      phy = WLAN_RC_PHY_CCK;
-+              else
-+                      phy = WLAN_RC_PHY_OFDM;
-+
-+              rate = &sc->sbands[tx_info->band].bitrates[rates[i].idx];
-+              series[i].Rate = rate->hw_value;
-+              if (rate->hw_value_short) {
-+                      if (rates[i].flags & IEEE80211_TX_RC_USE_SHORT_PREAMBLE)
-+                              series[i].Rate |= rate->hw_value_short;
-+              } else {
-+                      is_sp = false;
-+              }
-+
-+              series[i].PktDuration = ath9k_hw_computetxtime(sc->sc_ah,
-+                      phy, rate->bitrate * 100, bf->bf_frmlen, rix, is_sp);
-       }
-       /* 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 @@
- #include <linux/device.h>
- #include <linux/leds.h>
--#include "rc.h"
- #include "debug.h"
- #include "common.h"
-@@ -433,6 +432,7 @@ struct ath_led {
- #define SC_OP_BT_PRIORITY_DETECTED BIT(21)
- struct ath_wiphy;
-+struct ath_rate_table;
- struct ath_softc {
-       struct ieee80211_hw *hw;
-@@ -477,9 +477,8 @@ struct ath_softc {
-       struct ath_rx rx;
-       struct ath_tx tx;
-       struct ath_beacon beacon;
--      struct ieee80211_rate rates[IEEE80211_NUM_BANDS][ATH_RATE_MAX];
--      const struct ath_rate_table *hw_rate_table[ATH9K_MODE_MAX];
-       const struct ath_rate_table *cur_rate_table;
-+      enum wireless_mode cur_rate_mode;
-       struct ieee80211_supported_band sbands[IEEE80211_NUM_BANDS];
-       struct ath_led radio_led;
---- a/drivers/net/wireless/ath/ath9k/main.c
-+++ b/drivers/net/wireless/ath/ath9k/main.c
-@@ -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[] = {
-+      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,
-                               struct ieee80211_conf *conf)
- {
-       switch (conf->channel->band) {
-       case IEEE80211_BAND_2GHZ:
-               if (conf_is_ht20(conf))
--                      sc->cur_rate_table =
--                        sc->hw_rate_table[ATH9K_MODE_11NG_HT20];
-+                      sc->cur_rate_mode = ATH9K_MODE_11NG_HT20;
-               else if (conf_is_ht40_minus(conf))
--                      sc->cur_rate_table =
--                        sc->hw_rate_table[ATH9K_MODE_11NG_HT40MINUS];
-+                      sc->cur_rate_mode = ATH9K_MODE_11NG_HT40MINUS;
-               else if (conf_is_ht40_plus(conf))
--                      sc->cur_rate_table =
--                        sc->hw_rate_table[ATH9K_MODE_11NG_HT40PLUS];
-+                      sc->cur_rate_mode = ATH9K_MODE_11NG_HT40PLUS;
-               else
--                      sc->cur_rate_table =
--                        sc->hw_rate_table[ATH9K_MODE_11G];
-+                      sc->cur_rate_mode = ATH9K_MODE_11G;
-               break;
-       case IEEE80211_BAND_5GHZ:
-               if (conf_is_ht20(conf))
--                      sc->cur_rate_table =
--                        sc->hw_rate_table[ATH9K_MODE_11NA_HT20];
-+                      sc->cur_rate_mode = ATH9K_MODE_11NA_HT20;
-               else if (conf_is_ht40_minus(conf))
--                      sc->cur_rate_table =
--                        sc->hw_rate_table[ATH9K_MODE_11NA_HT40MINUS];
-+                      sc->cur_rate_mode = ATH9K_MODE_11NA_HT40MINUS;
-               else if (conf_is_ht40_plus(conf))
--                      sc->cur_rate_table =
--                        sc->hw_rate_table[ATH9K_MODE_11NA_HT40PLUS];
-+                      sc->cur_rate_mode = ATH9K_MODE_11NA_HT40PLUS;
-               else
--                      sc->cur_rate_table =
--                        sc->hw_rate_table[ATH9K_MODE_11A];
-+                      sc->cur_rate_mode = ATH9K_MODE_11A;
-               break;
-       default:
-               BUG_ON(1);
-@@ -191,51 +209,6 @@ static u8 parse_mpdudensity(u8 mpdudensi
-       }
- }
--static void ath_setup_rates(struct ath_softc *sc, enum ieee80211_band band)
--{
--      const struct ath_rate_table *rate_table = NULL;
--      struct ieee80211_supported_band *sband;
--      struct ieee80211_rate *rate;
--      int i, maxrates;
--
--      switch (band) {
--      case IEEE80211_BAND_2GHZ:
--              rate_table = sc->hw_rate_table[ATH9K_MODE_11G];
--              break;
--      case IEEE80211_BAND_5GHZ:
--              rate_table = sc->hw_rate_table[ATH9K_MODE_11A];
--              break;
--      default:
--              break;
--      }
--
--      if (rate_table == NULL)
--              return;
--
--      sband = &sc->sbands[band];
--      rate = sc->rates[band];
--
--      if (rate_table->rate_cnt > ATH_RATE_MAX)
--              maxrates = ATH_RATE_MAX;
--      else
--              maxrates = rate_table->rate_cnt;
--
--      for (i = 0; i < maxrates; i++) {
--              rate[i].bitrate = rate_table->info[i].ratekbps / 100;
--              rate[i].hw_value = rate_table->info[i].ratecode;
--              if (rate_table->info[i].short_preamble) {
--                      rate[i].hw_value_short = rate_table->info[i].ratecode |
--                              rate_table->info[i].short_preamble;
--                      rate[i].flags = IEEE80211_RATE_SHORT_PREAMBLE;
--              }
--              sband->n_bitrates++;
--
--              ath_print(ath9k_hw_common(sc->sc_ah), ATH_DBG_CONFIG,
--                        "Rate: %2dMbps, ratecode: %2d\n",
--                        rate[i].bitrate / 10, rate[i].hw_value);
--      }
--}
--
- static struct ath9k_channel *ath_get_curchannel(struct ath_softc *sc,
-                                               struct ieee80211_hw *hw)
- {
-@@ -1713,12 +1686,6 @@ static int ath_init_softc(u16 devid, str
-       /* default to MONITOR mode */
-       sc->sc_ah->opmode = NL80211_IFTYPE_MONITOR;
--      /* Setup rate tables */
--
--      ath_rate_attach(sc);
--      ath_setup_rates(sc, IEEE80211_BAND_2GHZ);
--      ath_setup_rates(sc, IEEE80211_BAND_5GHZ);
--
-       /*
-        * Allocate hardware transmit queues: one queue for
-        * beacon frames and one data queue for each QoS
-@@ -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;
--      sc->sbands[IEEE80211_BAND_2GHZ].bitrates =
--              sc->rates[IEEE80211_BAND_2GHZ];
-       sc->sbands[IEEE80211_BAND_2GHZ].band = IEEE80211_BAND_2GHZ;
-       sc->sbands[IEEE80211_BAND_2GHZ].n_channels =
-               ARRAY_SIZE(ath9k_2ghz_chantable);
-+      sc->sbands[IEEE80211_BAND_2GHZ].bitrates = ath9k_legacy_rates;
-+      sc->sbands[IEEE80211_BAND_2GHZ].n_bitrates =
-+              ARRAY_SIZE(ath9k_legacy_rates);
-       if (test_bit(ATH9K_MODE_11A, sc->sc_ah->caps.wireless_modes)) {
-               sc->sbands[IEEE80211_BAND_5GHZ].channels = ath9k_5ghz_chantable;
--              sc->sbands[IEEE80211_BAND_5GHZ].bitrates =
--                      sc->rates[IEEE80211_BAND_5GHZ];
-               sc->sbands[IEEE80211_BAND_5GHZ].band = IEEE80211_BAND_5GHZ;
-               sc->sbands[IEEE80211_BAND_5GHZ].n_channels =
-                       ARRAY_SIZE(ath9k_5ghz_chantable);
-+              sc->sbands[IEEE80211_BAND_5GHZ].bitrates =
-+                      ath9k_legacy_rates + 4;
-+              sc->sbands[IEEE80211_BAND_5GHZ].n_bitrates =
-+                      ARRAY_SIZE(ath9k_legacy_rates) - 4;
-       }
-       switch (ah->btcoex_hw.scheme) {
---- a/drivers/net/wireless/ath/ath9k/rc.h
-+++ b/drivers/net/wireless/ath/ath9k/rc.h
-@@ -104,6 +104,7 @@ enum {
-  */
- struct ath_rate_table {
-       int rate_cnt;
-+      int mcs_start;
-       struct {
-               int valid;
-               int valid_single_stream;
-@@ -179,8 +180,6 @@ enum ath9k_internal_frame_type {
-       ATH9K_INT_UNPAUSE
- };
--void ath_rate_attach(struct ath_softc *sc);
--u8 ath_rate_findrateix(struct ath_softc *sc, u8 dot11_rate);
- int ath_rate_control_register(void);
- void ath_rate_control_unregister(void);
---- a/drivers/net/wireless/ath/ath9k/beacon.c
-+++ b/drivers/net/wireless/ath/ath9k/beacon.c
-@@ -65,9 +65,9 @@ static void ath_beacon_setup(struct ath_
-       struct ath_common *common = ath9k_hw_common(ah);
-       struct ath_desc *ds;
-       struct ath9k_11n_rate_series series[4];
--      const struct ath_rate_table *rt;
-       int flags, antenna, ctsrate = 0, ctsduration = 0;
--      u8 rate;
-+      struct ieee80211_supported_band *sband;
-+      u8 rate = 0;
-       ds = bf->bf_desc;
-       flags = ATH9K_TXDESC_NOACK;
-@@ -91,10 +91,10 @@ static void ath_beacon_setup(struct ath_
-       ds->ds_data = bf->bf_buf_addr;
--      rt = sc->cur_rate_table;
--      rate = rt->info[0].ratecode;
-+      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;
-+              rate |= sband->bitrates[0].hw_value_short;
-       ath9k_hw_set11n_txdesc(ah, ds, skb->len + FCS_LEN,
-                              ATH9K_PKT_TYPE_BEACON,
---- a/drivers/net/wireless/ath/ath9k/debug.h
-+++ b/drivers/net/wireless/ath/ath9k/debug.h
-@@ -18,6 +18,7 @@
- #define DEBUG_H
- #include "hw.h"
-+#include "rc.h"
- struct ath_txq;
- struct ath_buf;
-@@ -138,7 +139,7 @@ void ath9k_exit_debug(struct ath_hw *ah)
- int ath9k_debug_create_root(void);
- void ath9k_debug_remove_root(void);
- void ath_debug_stat_interrupt(struct ath_softc *sc, enum ath9k_int status);
--void ath_debug_stat_rc(struct ath_softc *sc, struct sk_buff *skb);
-+void ath_debug_stat_rc(struct ath_softc *sc, int final_rate);
- void ath_debug_stat_tx(struct ath_softc *sc, struct ath_txq *txq,
-                      struct ath_buf *bf);
- void ath_debug_stat_retries(struct ath_softc *sc, int rix,
-@@ -170,7 +171,7 @@ static inline void ath_debug_stat_interr
- }
- static inline void ath_debug_stat_rc(struct ath_softc *sc,
--                                   struct sk_buff *skb)
-+                                   int final_rate)
- {
- }
---- a/drivers/net/wireless/ath/ath9k/debug.c
-+++ b/drivers/net/wireless/ath/ath9k/debug.c
-@@ -255,21 +255,11 @@ static const struct file_operations fops
-       .owner = THIS_MODULE
- };
--void ath_debug_stat_rc(struct ath_softc *sc, struct sk_buff *skb)
-+void ath_debug_stat_rc(struct ath_softc *sc, int final_rate)
- {
--      struct ieee80211_tx_info *tx_info = IEEE80211_SKB_CB(skb);
--      struct ieee80211_tx_rate *rates = tx_info->status.rates;
--      int final_ts_idx = 0, idx, i;
-       struct ath_rc_stats *stats;
--      for (i = 0; i < IEEE80211_TX_MAX_RATES; i++) {
--              if (!rates[i].count)
--                      break;
--
--              final_ts_idx = i;
--      }
--      idx = rates[final_ts_idx].idx;
--      stats = &sc->debug.stats.rcstats[idx];
-+      stats = &sc->debug.stats.rcstats[final_rate];
-       stats->success++;
- }
---- a/drivers/net/wireless/ath/ath9k/hw.c
-+++ b/drivers/net/wireless/ath/ath9k/hw.c
-@@ -149,22 +149,19 @@ bool ath9k_get_channel_edges(struct ath_
- }
- u16 ath9k_hw_computetxtime(struct ath_hw *ah,
--                         const struct ath_rate_table *rates,
-+                         u8 phy, int kbps,
-                          u32 frameLen, u16 rateix,
-                          bool shortPreamble)
- {
-       u32 bitsPerSymbol, numBits, numSymbols, phyTime, txTime;
--      u32 kbps;
--
--      kbps = rates->info[rateix].ratekbps;
-       if (kbps == 0)
-               return 0;
--      switch (rates->info[rateix].phy) {
-+      switch (phy) {
-       case WLAN_RC_PHY_CCK:
-               phyTime = CCK_PREAMBLE_BITS + CCK_PLCP_BITS;
--              if (shortPreamble && rates->info[rateix].short_preamble)
-+              if (shortPreamble)
-                       phyTime >>= 1;
-               numBits = frameLen << 3;
-               txTime = CCK_SIFS_TIME + phyTime + ((numBits * 1000) / kbps);
-@@ -195,8 +192,7 @@ u16 ath9k_hw_computetxtime(struct ath_hw
-               break;
-       default:
-               ath_print(ath9k_hw_common(ah), ATH_DBG_FATAL,
--                        "Unknown phy %u (rate ix %u)\n",
--                        rates->info[rateix].phy, rateix);
-+                        "Unknown phy %u (rate ix %u)\n", phy, rateix);
-               txTime = 0;
-               break;
-       }
---- a/drivers/net/wireless/ath/ath9k/hw.h
-+++ b/drivers/net/wireless/ath/ath9k/hw.h
-@@ -670,7 +670,7 @@ bool ath9k_hw_wait(struct ath_hw *ah, u3
- u32 ath9k_hw_reverse_bits(u32 val, u32 n);
- bool ath9k_get_channel_edges(struct ath_hw *ah, u16 flags, u16 *low, u16 *high);
- u16 ath9k_hw_computetxtime(struct ath_hw *ah,
--                         const struct ath_rate_table *rates,
-+                         u8 phy, int kbps,
-                          u32 frameLen, u16 rateix, bool shortPreamble);
- void ath9k_hw_get_channel_centers(struct ath_hw *ah,
-                                 struct ath9k_channel *chan,
---- a/drivers/net/wireless/ath/ath9k/mac.h
-+++ b/drivers/net/wireless/ath/ath9k/mac.h
-@@ -616,7 +616,6 @@ enum ath9k_cipher {
- struct ath_hw;
- struct ath9k_channel;
--struct ath_rate_table;
- u32 ath9k_hw_gettxbuf(struct ath_hw *ah, u32 q);
- void ath9k_hw_puttxbuf(struct ath_hw *ah, u32 q, u32 txdp);
diff --git a/package/mac80211/patches/561-ath9k_rc_table_cleanup.patch b/package/mac80211/patches/561-ath9k_rc_table_cleanup.patch
deleted file mode 100644 (file)
index 30e0f9f..0000000
+++ /dev/null
@@ -1,477 +0,0 @@
---- 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, 0, 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,  1, 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, 2, 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, 3, 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, 4, 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, 5, 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, 6, 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, 7, 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, 0, 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, 1, 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, 2, 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, 3, 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, 4, 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, 5, 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, 6, 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, 7, 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, 8, 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, 9, 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, 10, 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, 11, 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, 12, 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, 13, 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, 14, 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, 15, 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, 0, 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, 1, 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, 2, 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, 3, 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, 4, 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, 5, 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, 6, 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, 7, 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, 7, 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, 8, 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, 9, 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, 10, 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, 11, 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, 12, 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, 13, 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, 14, 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, 15, 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, 15, 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, 0, 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, 1, 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, 2, 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, 3, 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, 4, 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, 5, 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, 6, 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, 7, 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, 8, 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, 9, 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, 10, 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, 11, 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, 0, 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, 1, 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, 2, 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, 3, 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, 4, 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, 5, 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, 6, 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, 7, 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, 8, 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, 9, 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, 10, 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, 11, 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, 12, 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, 13, 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, 14, 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, 15, 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, 0, 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, 1, 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, 2, 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, 3, 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, 4, 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, 5, 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, 6, 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, 7, 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, 7, 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, 8, 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, 9, 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, 10, 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, 11, 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, 12, 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, 13, 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, 14, 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, 15, 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, 15, 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, 0, 0x00, 12,
--                      0, 0, 0 },
-+                      5400, 0, 12, 0, 0, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */
--                      7800, 1, 0x00, 18,
--                      0, 1, 0 },
-+                      7800,  1, 18, 0, 1, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */
--                      10000, 2, 0x00, 24,
--                      2, 2, 0 },
-+                      10000, 2, 24, 2, 2, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */
--                      13900, 3, 0x00, 36,
--                      2, 3, 0 },
-+                      13900, 3, 36, 2, 3, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */
--                      17300, 4, 0x00, 48,
--                      4,  4, 0 },
-+                      17300, 4, 48, 4, 4, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */
--                      23000, 5, 0x00, 72,
--                      4,  5, 0 },
-+                      23000, 5, 72, 4, 5, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */
--                      27400, 6, 0x00, 96,
--                      4,  6, 0 },
-+                      27400, 6, 96, 4, 6, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */
--                      29300, 7, 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, 0, 0x00, 2,
--                      0, 0, 0 },
-+                      900, 0, 2, 0, 0, 0 },
-               { VALID, VALID, WLAN_RC_PHY_CCK, 2000, /* 2 Mb */
--                      1900, 1, 0x04, 4,
--                      1, 1, 0 },
-+                      1900, 1, 4, 1, 1, 0 },
-               { VALID, VALID, WLAN_RC_PHY_CCK, 5500, /* 5.5 Mb */
--                      4900, 2, 0x04, 11,
--                      2, 2, 0 },
-+                      4900, 2, 11, 2, 2, 0 },
-               { VALID, VALID, WLAN_RC_PHY_CCK, 11000, /* 11 Mb */
--                      8100, 3, 0x04, 22,
--                      3, 3, 0 },
-+                      8100, 3, 22, 3, 3, 0 },
-               { INVALID, INVALID, WLAN_RC_PHY_OFDM, 6000, /* 6 Mb */
--                      5400, 4, 0x00, 12,
--                      4, 4, 0 },
-+                      5400, 4, 12, 4, 4, 0 },
-               { INVALID, INVALID, WLAN_RC_PHY_OFDM, 9000, /* 9 Mb */
--                      7800, 5, 0x00, 18,
--                      4, 5, 0 },
-+                      7800, 5, 18, 4, 5, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 12000, /* 12 Mb */
--                      10000, 6, 0x00, 24,
--                      6, 6, 0 },
-+                      10000, 6, 24, 6, 6, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 18000, /* 18 Mb */
--                      13900, 7, 0x00, 36,
--                      6, 7, 0 },
-+                      13900, 7, 36, 6, 7, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 24000, /* 24 Mb */
--                      17300, 8, 0x00, 48,
--                      8,  8, 0 },
-+                      17300, 8, 48, 8, 8, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 36000, /* 36 Mb */
--                      23000, 9, 0x00, 72,
--                      8,  9, 0 },
-+                      23000, 9, 72, 8, 9, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 48000, /* 48 Mb */
--                      27400, 10, 0x00, 96,
--                      8,  10, 0 },
-+                      27400, 10, 96, 8, 10, 0 },
-               { VALID, VALID, WLAN_RC_PHY_OFDM, 54000, /* 54 Mb */
--                      29300, 11, 0x00, 108,
--                      8,  11, 0 },
-+                      29300, 11, 108, 8, 11, 0 },
-       },
-       50,  /* probe interval */
-       0,   /* Phy rates allowed initially */
diff --git a/package/mac80211/patches/570-ath_use_gfp_dma.patch b/package/mac80211/patches/570-ath_use_gfp_dma.patch
deleted file mode 100644 (file)
index af375b1..0000000
+++ /dev/null
@@ -1,11 +0,0 @@
---- a/drivers/net/wireless/ath/main.c
-+++ b/drivers/net/wireless/ath/main.c
-@@ -43,7 +43,7 @@ struct sk_buff *ath_rxbuf_alloc(struct a
-        * Unfortunately this means we may get 8 KB here from the
-        * kernel... and that is actually what is observed on some
-        * systems :( */
--      skb = __dev_alloc_skb(len + common->cachelsz - 1, gfp_mask);
-+      skb = __dev_alloc_skb(len + common->cachelsz - 1, gfp_mask | GFP_DMA);
-       if (skb != NULL) {
-               off = ((unsigned long) skb->data) % common->cachelsz;
-               if (off != 0)