[PATCH 1/2] compat-drivers: Move next-pending patches to cherry-picks

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



All of the pending patches have been merged in linux-next,
move them to the linux-next-cherry-picks.

Also add new patches to cherry-picks.

Signed-off-by: Bala Shanmugam <bkamatch@xxxxxxxxxxxxxxxx>
---
 ...5-ath9k-fix-ASPM-initialization-on-resume.patch |   40 +++
 ...-ath9k-improve-suspend-resume-reliability.patch |  117 ++++++++
 .../0088-cfg80211-fix-antenna-gain-handling.patch  |   39 +++
 ...k-Use-a-helper-routine-for-MCI-FTP-tuning.patch |   72 +++++
 .../0090-ath9k-Fix-BT_OP_SCAN-usage.patch          |   95 ++++++
 ...091-ath9k-perform-ANI-cycle-in-idle-state.patch |  107 +++++++
 ...tale-pointers-potentially-causing-access-.patch |   43 +++
 .../0094-ath9k-Send-WLAN-channel-info-to-BT.patch  |  147 +++++++++
 ...oncurrent-WLAN-and-BT-tx-support-for-MCI-.patch |  264 +++++++++++++++++
 .../0096-ath9k-fill-channel-mode-in-caldata.patch  |   44 +++
 ...djust-WLAN-and-BT-concurrent-transmission.patch |  313 ++++++++++++++++++++
 ...00-ath9k_hw-Enable-OSLA-hw-fix-for-AR9565.patch |   42 +++
 ...1-ath9k_hw-Fix-selfgen-chainmask-for-9565.patch |   34 +++
 ...ppropriate-bit-for-AR9565-in-btc-control-.patch |   39 +++
 ...off-RXIQ-calibration-while-re-calibrating.patch |   54 ++++
 ...sable-MCI-stat-counter-by-default-for-AR9.patch |   42 +++
 ...0105-ath9k_hw-Fix-frequent-BT-rx-recovery.patch |   76 +++++
 ...-ath9k_hw-Fix-max-rx-rate-drop-for-AR9565.patch |   34 +++
 ...nfigure-new-switch-table-for-AR9565-BTCOE.patch |   57 ++++
 ...th9k_hw-Set-default-MCI-config-for-AR9565.patch |   27 ++
 ...ust-duty-cycle-for-FTP-profile-for-AR9565.patch |   27 ++
 ...-ath9k-Add-new-BT-profile-info-A2DP_Voice.patch |   52 ++++
 ...111-cfg80211-Disallow-HT-WEP-in-IBSS-mode.patch |   63 ++++
 ...9k_hw-Enable-hw-PLL-power-save-for-AR9565.patch |   49 +++
 ...9k_hw-Fix-concurrent-tx-on-lower-tx-power.patch |   51 ++++
 ...9k_hw-validate-MCI-stuck-after-RTC-wakeup.patch |   38 +++
 .../0118-ath9k-Dump-BTCOEX-tuning-parameters.patch |  148 +++++++++
 ...for-TID-only-in-BlockAcks-while-checking-.patch |   65 ++++
 ...01-ath9k_hw-Enable-OSLA-hw-fix-for-AR9565.patch |   34 ---
 ...2-ath9k_hw-Fix-selfgen-chainmask-for-9565.patch |   28 --
 ...ppropriate-bit-for-AR9565-in-btc-control-.patch |   33 --
 ...off-RXIQ-calibration-while-re-calibrating.patch |   46 ---
 ...sable-MCI-stat-counter-by-default-for-AR9.patch |   34 ---
 ...0006-ath9k_hw-Fix-frequent-BT-rx-recovery.patch |   66 ----
 ...-ath9k_hw-Fix-max-rx-rate-drop-for-AR9565.patch |   28 --
 ...nfigure-new-switch-table-for-AR9565-BTCOE.patch |   47 ---
 ...th9k_hw-Set-default-MCI-config-for-AR9565.patch |   21 --
 ...ust-duty-cycle-for-FTP-profile-for-AR9565.patch |   21 --
 ...-ath9k-Add-new-BT-profile-info-A2DP_Voice.patch |   44 ---
 ...012-cfg80211-Disallow-HT-WEP-in-IBSS-mode.patch |   63 ----
 40 files changed, 2179 insertions(+), 465 deletions(-)
 create mode 100644 linux-next-cherry-picks/0085-ath9k-fix-ASPM-initialization-on-resume.patch
 create mode 100644 linux-next-cherry-picks/0086-ath9k-improve-suspend-resume-reliability.patch
 create mode 100644 linux-next-cherry-picks/0088-cfg80211-fix-antenna-gain-handling.patch
 create mode 100644 linux-next-cherry-picks/0089-ath9k-Use-a-helper-routine-for-MCI-FTP-tuning.patch
 create mode 100644 linux-next-cherry-picks/0090-ath9k-Fix-BT_OP_SCAN-usage.patch
 create mode 100644 linux-next-cherry-picks/0091-ath9k-perform-ANI-cycle-in-idle-state.patch
 create mode 100644 linux-next-cherry-picks/0093-ath9k-fix-stale-pointers-potentially-causing-access-.patch
 create mode 100644 linux-next-cherry-picks/0094-ath9k-Send-WLAN-channel-info-to-BT.patch
 create mode 100644 linux-next-cherry-picks/0095-ath9k-Add-concurrent-WLAN-and-BT-tx-support-for-MCI-.patch
 create mode 100644 linux-next-cherry-picks/0096-ath9k-fill-channel-mode-in-caldata.patch
 create mode 100644 linux-next-cherry-picks/0097-ath9k-adjust-WLAN-and-BT-concurrent-transmission.patch
 create mode 100644 linux-next-cherry-picks/0100-ath9k_hw-Enable-OSLA-hw-fix-for-AR9565.patch
 create mode 100644 linux-next-cherry-picks/0101-ath9k_hw-Fix-selfgen-chainmask-for-9565.patch
 create mode 100644 linux-next-cherry-picks/0102-ath9k-Set-appropriate-bit-for-AR9565-in-btc-control-.patch
 create mode 100644 linux-next-cherry-picks/0103-ath9k-turn-off-RXIQ-calibration-while-re-calibrating.patch
 create mode 100644 linux-next-cherry-picks/0104-ath9k_hw-Disable-MCI-stat-counter-by-default-for-AR9.patch
 create mode 100644 linux-next-cherry-picks/0105-ath9k_hw-Fix-frequent-BT-rx-recovery.patch
 create mode 100644 linux-next-cherry-picks/0106-ath9k_hw-Fix-max-rx-rate-drop-for-AR9565.patch
 create mode 100644 linux-next-cherry-picks/0107-ath9k_hw-Configure-new-switch-table-for-AR9565-BTCOE.patch
 create mode 100644 linux-next-cherry-picks/0108-ath9k_hw-Set-default-MCI-config-for-AR9565.patch
 create mode 100644 linux-next-cherry-picks/0109-ath9k-adjust-duty-cycle-for-FTP-profile-for-AR9565.patch
 create mode 100644 linux-next-cherry-picks/0110-ath9k-Add-new-BT-profile-info-A2DP_Voice.patch
 create mode 100644 linux-next-cherry-picks/0111-cfg80211-Disallow-HT-WEP-in-IBSS-mode.patch
 create mode 100644 linux-next-cherry-picks/0115-ath9k_hw-Enable-hw-PLL-power-save-for-AR9565.patch
 create mode 100644 linux-next-cherry-picks/0116-ath9k_hw-Fix-concurrent-tx-on-lower-tx-power.patch
 create mode 100644 linux-next-cherry-picks/0117-ath9k_hw-validate-MCI-stuck-after-RTC-wakeup.patch
 create mode 100644 linux-next-cherry-picks/0118-ath9k-Dump-BTCOEX-tuning-parameters.patch
 create mode 100644 linux-next-cherry-picks/0119-ath9k-Test-for-TID-only-in-BlockAcks-while-checking-.patch
 delete mode 100644 linux-next-pending/0001-ath9k_hw-Enable-OSLA-hw-fix-for-AR9565.patch
 delete mode 100644 linux-next-pending/0002-ath9k_hw-Fix-selfgen-chainmask-for-9565.patch
 delete mode 100644 linux-next-pending/0003-ath9k-Set-appropriate-bit-for-AR9565-in-btc-control-.patch
 delete mode 100644 linux-next-pending/0004-ath9k-turn-off-RXIQ-calibration-while-re-calibrating.patch
 delete mode 100644 linux-next-pending/0005-ath9k_hw-Disable-MCI-stat-counter-by-default-for-AR9.patch
 delete mode 100644 linux-next-pending/0006-ath9k_hw-Fix-frequent-BT-rx-recovery.patch
 delete mode 100644 linux-next-pending/0007-ath9k_hw-Fix-max-rx-rate-drop-for-AR9565.patch
 delete mode 100644 linux-next-pending/0008-ath9k_hw-Configure-new-switch-table-for-AR9565-BTCOE.patch
 delete mode 100644 linux-next-pending/0009-ath9k_hw-Set-default-MCI-config-for-AR9565.patch
 delete mode 100644 linux-next-pending/0010-ath9k-adjust-duty-cycle-for-FTP-profile-for-AR9565.patch
 delete mode 100644 linux-next-pending/0011-ath9k-Add-new-BT-profile-info-A2DP_Voice.patch
 delete mode 100644 linux-next-pending/0012-cfg80211-Disallow-HT-WEP-in-IBSS-mode.patch

diff --git a/linux-next-cherry-picks/0085-ath9k-fix-ASPM-initialization-on-resume.patch b/linux-next-cherry-picks/0085-ath9k-fix-ASPM-initialization-on-resume.patch
new file mode 100644
index 0000000..4bcad79
--- /dev/null
+++ b/linux-next-cherry-picks/0085-ath9k-fix-ASPM-initialization-on-resume.patch
@@ -0,0 +1,40 @@
+From 93170516a4d64319ffcc43bc9dd61f12775bd297 Mon Sep 17 00:00:00 2001
+From: Felix Fietkau <nbd@xxxxxxxxxxx>
+Date: Wed, 3 Oct 2012 21:07:50 +0200
+Subject: [PATCH] ath9k: fix ASPM initialization on resume
+
+ath_pci_aspm_init is only called on card init, so PCI registers get reset
+after a suspend/resume cycle.
+
+Signed-off-by: Felix Fietkau <nbd@xxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/pci.c |    5 +++++
+ 1 files changed, 5 insertions(+), 0 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/pci.c b/drivers/net/wireless/ath/ath9k/pci.c
+index 0e630a9..270abf7 100644
+--- a/drivers/net/wireless/ath/ath9k/pci.c
++++ b/drivers/net/wireless/ath/ath9k/pci.c
+@@ -324,6 +324,9 @@ static int ath_pci_suspend(struct device *device)
+ static int ath_pci_resume(struct device *device)
+ {
+ 	struct pci_dev *pdev = to_pci_dev(device);
++	struct ieee80211_hw *hw = pci_get_drvdata(pdev);
++	struct ath_softc *sc = hw->priv;
++	struct ath_common *common = ath9k_hw_common(sc->sc_ah);
+ 	u32 val;
+ 
+ 	/*
+@@ -335,6 +338,8 @@ static int ath_pci_resume(struct device *device)
+ 	if ((val & 0x0000ff00) != 0)
+ 		pci_write_config_dword(pdev, 0x40, val & 0xffff00ff);
+ 
++	ath_pci_aspm_init(common);
++
+ 	return 0;
+ }
+ 
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0086-ath9k-improve-suspend-resume-reliability.patch b/linux-next-cherry-picks/0086-ath9k-improve-suspend-resume-reliability.patch
new file mode 100644
index 0000000..c755abd
--- /dev/null
+++ b/linux-next-cherry-picks/0086-ath9k-improve-suspend-resume-reliability.patch
@@ -0,0 +1,117 @@
+From ceb26a6013b962b82f644189ea29d802490fc8fc Mon Sep 17 00:00:00 2001
+From: Felix Fietkau <nbd@xxxxxxxxxxx>
+Date: Wed, 3 Oct 2012 21:07:51 +0200
+Subject: [PATCH] ath9k: improve suspend/resume reliability
+
+Ensure that drv_start() always returns true, as a failing hw start usually
+eventually leads to crashes when there's still a station entry present.
+Call a power-on reset after a resume and after a hw reset failure to bring
+the hardware back to life again.
+
+Signed-off-by: Felix Fietkau <nbd@xxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/hw.c   |    5 +++++
+ drivers/net/wireless/ath/ath9k/hw.h   |    1 +
+ drivers/net/wireless/ath/ath9k/main.c |   13 ++++---------
+ drivers/net/wireless/ath/ath9k/pci.c  |    4 +++-
+ 4 files changed, 13 insertions(+), 10 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/hw.c b/drivers/net/wireless/ath/ath9k/hw.c
+index f9a6ec5..8e1559a 100644
+--- a/drivers/net/wireless/ath/ath9k/hw.c
++++ b/drivers/net/wireless/ath/ath9k/hw.c
+@@ -1450,9 +1450,14 @@ static bool ath9k_hw_set_reset_reg(struct ath_hw *ah, u32 type)
+ 	REG_WRITE(ah, AR_RTC_FORCE_WAKE,
+ 		  AR_RTC_FORCE_WAKE_EN | AR_RTC_FORCE_WAKE_ON_INT);
+ 
++	if (!ah->reset_power_on)
++		type = ATH9K_RESET_POWER_ON;
++
+ 	switch (type) {
+ 	case ATH9K_RESET_POWER_ON:
+ 		ret = ath9k_hw_set_reset_power_on(ah);
++		if (!ret)
++			ah->reset_power_on = true;
+ 		break;
+ 	case ATH9K_RESET_WARM:
+ 	case ATH9K_RESET_COLD:
+diff --git a/drivers/net/wireless/ath/ath9k/hw.h b/drivers/net/wireless/ath/ath9k/hw.h
+index 566a4ce..dbc1b7a 100644
+--- a/drivers/net/wireless/ath/ath9k/hw.h
++++ b/drivers/net/wireless/ath/ath9k/hw.h
+@@ -741,6 +741,7 @@ struct ath_hw {
+ 	u32 rfkill_polarity;
+ 	u32 ah_flags;
+ 
++	bool reset_power_on;
+ 	bool htc_reset_init;
+ 
+ 	enum nl80211_iftype opmode;
+diff --git a/drivers/net/wireless/ath/ath9k/main.c b/drivers/net/wireless/ath/ath9k/main.c
+index 31ab82e..e2fe713 100644
+--- a/drivers/net/wireless/ath/ath9k/main.c
++++ b/drivers/net/wireless/ath/ath9k/main.c
+@@ -639,8 +639,7 @@ static int ath9k_start(struct ieee80211_hw *hw)
+ 		ath_err(common,
+ 			"Unable to reset hardware; reset status %d (freq %u MHz)\n",
+ 			r, curchan->center_freq);
+-		spin_unlock_bh(&sc->sc_pcu_lock);
+-		goto mutex_unlock;
++		ah->reset_power_on = false;
+ 	}
+ 
+ 	/* Setup our intr mask. */
+@@ -665,11 +664,8 @@ static int ath9k_start(struct ieee80211_hw *hw)
+ 	clear_bit(SC_OP_INVALID, &sc->sc_flags);
+ 	sc->sc_ah->is_monitoring = false;
+ 
+-	if (!ath_complete_reset(sc, false)) {
+-		r = -EIO;
+-		spin_unlock_bh(&sc->sc_pcu_lock);
+-		goto mutex_unlock;
+-	}
++	if (!ath_complete_reset(sc, false))
++		ah->reset_power_on = false;
+ 
+ 	if (ah->led_pin >= 0) {
+ 		ath9k_hw_cfg_output(ah, ah->led_pin,
+@@ -688,12 +684,11 @@ static int ath9k_start(struct ieee80211_hw *hw)
+ 	if (ah->caps.pcie_lcr_extsync_en && common->bus_ops->extn_synch_en)
+ 		common->bus_ops->extn_synch_en(common);
+ 
+-mutex_unlock:
+ 	mutex_unlock(&sc->mutex);
+ 
+ 	ath9k_ps_restore(sc);
+ 
+-	return r;
++	return 0;
+ }
+ 
+ static void ath9k_tx(struct ieee80211_hw *hw,
+diff --git a/drivers/net/wireless/ath/ath9k/pci.c b/drivers/net/wireless/ath/ath9k/pci.c
+index 270abf7..f088f4b 100644
+--- a/drivers/net/wireless/ath/ath9k/pci.c
++++ b/drivers/net/wireless/ath/ath9k/pci.c
+@@ -326,7 +326,8 @@ static int ath_pci_resume(struct device *device)
+ 	struct pci_dev *pdev = to_pci_dev(device);
+ 	struct ieee80211_hw *hw = pci_get_drvdata(pdev);
+ 	struct ath_softc *sc = hw->priv;
+-	struct ath_common *common = ath9k_hw_common(sc->sc_ah);
++	struct ath_hw *ah = sc->sc_ah;
++	struct ath_common *common = ath9k_hw_common(ah);
+ 	u32 val;
+ 
+ 	/*
+@@ -339,6 +340,7 @@ static int ath_pci_resume(struct device *device)
+ 		pci_write_config_dword(pdev, 0x40, val & 0xffff00ff);
+ 
+ 	ath_pci_aspm_init(common);
++	ah->reset_power_on = false;
+ 
+ 	return 0;
+ }
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0088-cfg80211-fix-antenna-gain-handling.patch b/linux-next-cherry-picks/0088-cfg80211-fix-antenna-gain-handling.patch
new file mode 100644
index 0000000..b5ee43d
--- /dev/null
+++ b/linux-next-cherry-picks/0088-cfg80211-fix-antenna-gain-handling.patch
@@ -0,0 +1,39 @@
+From c4a9fafc77a5318f5ed26c509bbcddf03e18c201 Mon Sep 17 00:00:00 2001
+From: Felix Fietkau <nbd@xxxxxxxxxxx>
+Date: Wed, 17 Oct 2012 13:56:19 +0200
+Subject: [PATCH] cfg80211: fix antenna gain handling
+
+No driver initializes chan->max_antenna_gain to something sensible, and
+the only place where it is being used right now is inside ath9k. This
+leads to ath9k potentially using less tx power than it can use, which can
+decrease performance/range in some rare cases.
+
+Rather than going through every single driver, this patch initializes
+chan->orig_mag in wiphy_register(), ignoring whatever value the driver
+left in there. If a driver for some reason wishes to limit it independent
+from regulatory rulesets, it can do so internally.
+
+Signed-off-by: Felix Fietkau <nbd@xxxxxxxxxxx>
+Cc: stable@xxxxxxxxxxxxxxx
+Signed-off-by: Johannes Berg <johannes.berg@xxxxxxxxx>
+---
+ net/wireless/core.c |    3 +--
+ 1 files changed, 1 insertions(+), 2 deletions(-)
+
+diff --git a/net/wireless/core.c b/net/wireless/core.c
+index 443d4d7..3f72530 100644
+--- a/net/wireless/core.c
++++ b/net/wireless/core.c
+@@ -526,8 +526,7 @@ int wiphy_register(struct wiphy *wiphy)
+ 		for (i = 0; i < sband->n_channels; i++) {
+ 			sband->channels[i].orig_flags =
+ 				sband->channels[i].flags;
+-			sband->channels[i].orig_mag =
+-				sband->channels[i].max_antenna_gain;
++			sband->channels[i].orig_mag = INT_MAX;
+ 			sband->channels[i].orig_mpwr =
+ 				sband->channels[i].max_power;
+ 			sband->channels[i].band = band;
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0089-ath9k-Use-a-helper-routine-for-MCI-FTP-tuning.patch b/linux-next-cherry-picks/0089-ath9k-Use-a-helper-routine-for-MCI-FTP-tuning.patch
new file mode 100644
index 0000000..7262bc7
--- /dev/null
+++ b/linux-next-cherry-picks/0089-ath9k-Use-a-helper-routine-for-MCI-FTP-tuning.patch
@@ -0,0 +1,72 @@
+From 78b1775ba03c2edcc8d765dd53a7e171b18e79ac Mon Sep 17 00:00:00 2001
+From: Sujith Manoharan <c_manoha@xxxxxxxxxxxxxxxx>
+Date: Sun, 30 Sep 2012 09:03:20 +0530
+Subject: [PATCH] ath9k: Use a helper routine for MCI/FTP tuning
+
+Signed-off-by: Sujith Manoharan <c_manoha@xxxxxxxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/gpio.c |   33 +++++++++++++++++++++------------
+ 1 files changed, 21 insertions(+), 12 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/gpio.c b/drivers/net/wireless/ath/ath9k/gpio.c
+index d9ed141..334c98d 100644
+--- a/drivers/net/wireless/ath/ath9k/gpio.c
++++ b/drivers/net/wireless/ath/ath9k/gpio.c
+@@ -187,6 +187,25 @@ static void ath9k_gen_timer_stop(struct ath_hw *ah, struct ath_gen_timer *timer)
+ 	}
+ }
+ 
++static void ath_mci_ftp_adjust(struct ath_softc *sc)
++{
++	struct ath_btcoex *btcoex = &sc->btcoex;
++	struct ath_mci_profile *mci = &btcoex->mci;
++	struct ath_hw *ah = sc->sc_ah;
++
++	btcoex->bt_wait_time += btcoex->btcoex_period;
++	if (btcoex->bt_wait_time > ATH_BTCOEX_RX_WAIT_TIME) {
++		if (ar9003_mci_state(ah, MCI_STATE_NEED_FTP_STOMP) &&
++		    (mci->num_pan || mci->num_other_acl))
++			ah->btcoex_hw.mci.stomp_ftp =
++				(sc->rx.num_pkts < ATH_BTCOEX_STOMP_FTP_THRESH);
++		else
++			ah->btcoex_hw.mci.stomp_ftp = false;
++		btcoex->bt_wait_time = 0;
++		sc->rx.num_pkts = 0;
++	}
++}
++
+ /*
+  * This is the master bt coex timer which runs for every
+  * 45ms, bt traffic will be given priority during 55% of this
+@@ -197,7 +216,6 @@ static void ath_btcoex_period_timer(unsigned long data)
+ 	struct ath_softc *sc = (struct ath_softc *) data;
+ 	struct ath_hw *ah = sc->sc_ah;
+ 	struct ath_btcoex *btcoex = &sc->btcoex;
+-	struct ath_mci_profile *mci = &btcoex->mci;
+ 	u32 timer_period;
+ 	bool is_btscan;
+ 	unsigned long flags;
+@@ -214,17 +232,8 @@ static void ath_btcoex_period_timer(unsigned long data)
+ 		ath_detect_bt_priority(sc);
+ 	is_btscan = test_bit(BT_OP_SCAN, &btcoex->op_flags);
+ 
+-	btcoex->bt_wait_time += btcoex->btcoex_period;
+-	if (btcoex->bt_wait_time > ATH_BTCOEX_RX_WAIT_TIME) {
+-		if (ar9003_mci_state(ah, MCI_STATE_NEED_FTP_STOMP) &&
+-		    (mci->num_pan || mci->num_other_acl))
+-			ah->btcoex_hw.mci.stomp_ftp =
+-				(sc->rx.num_pkts < ATH_BTCOEX_STOMP_FTP_THRESH);
+-		else
+-			ah->btcoex_hw.mci.stomp_ftp = false;
+-		btcoex->bt_wait_time = 0;
+-		sc->rx.num_pkts = 0;
+-	}
++	if (ah->caps.hw_caps & ATH9K_HW_CAP_MCI)
++		ath_mci_ftp_adjust(sc);
+ 
+ 	spin_lock_bh(&btcoex->btcoex_lock);
+ 
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0090-ath9k-Fix-BT_OP_SCAN-usage.patch b/linux-next-cherry-picks/0090-ath9k-Fix-BT_OP_SCAN-usage.patch
new file mode 100644
index 0000000..42a0afa
--- /dev/null
+++ b/linux-next-cherry-picks/0090-ath9k-Fix-BT_OP_SCAN-usage.patch
@@ -0,0 +1,95 @@
+From 750f32cf0a6e2a4d798e09da4079ede7d1721e54 Mon Sep 17 00:00:00 2001
+From: Sujith Manoharan <c_manoha@xxxxxxxxxxxxxxxx>
+Date: Sun, 30 Sep 2012 09:03:37 +0530
+Subject: [PATCH] ath9k: Fix BT_OP_SCAN usage
+
+BT_OP_SCAN is applicable only for pre-MCI WLAN/BT combo chips
+and using it for MCI-based cards is incorrect. Fix this by
+cleaning up its usage.
+
+Signed-off-by: Sujith Manoharan <c_manoha@xxxxxxxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/gpio.c |   27 ++++++++++++++++++---------
+ 1 files changed, 18 insertions(+), 9 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/gpio.c b/drivers/net/wireless/ath/ath9k/gpio.c
+index 334c98d..bf4fb7d 100644
+--- a/drivers/net/wireless/ath/ath9k/gpio.c
++++ b/drivers/net/wireless/ath/ath9k/gpio.c
+@@ -216,8 +216,8 @@ static void ath_btcoex_period_timer(unsigned long data)
+ 	struct ath_softc *sc = (struct ath_softc *) data;
+ 	struct ath_hw *ah = sc->sc_ah;
+ 	struct ath_btcoex *btcoex = &sc->btcoex;
++	enum ath_stomp_type stomp_type;
+ 	u32 timer_period;
+-	bool is_btscan;
+ 	unsigned long flags;
+ 
+ 	spin_lock_irqsave(&sc->sc_pm_lock, flags);
+@@ -228,19 +228,28 @@ static void ath_btcoex_period_timer(unsigned long data)
+ 	spin_unlock_irqrestore(&sc->sc_pm_lock, flags);
+ 
+ 	ath9k_ps_wakeup(sc);
++
+ 	if (!(ah->caps.hw_caps & ATH9K_HW_CAP_MCI))
+ 		ath_detect_bt_priority(sc);
+-	is_btscan = test_bit(BT_OP_SCAN, &btcoex->op_flags);
+ 
+ 	if (ah->caps.hw_caps & ATH9K_HW_CAP_MCI)
+ 		ath_mci_ftp_adjust(sc);
+ 
+ 	spin_lock_bh(&btcoex->btcoex_lock);
+ 
+-	ath9k_hw_btcoex_bt_stomp(ah, is_btscan ? ATH_BTCOEX_STOMP_ALL :
+-			      btcoex->bt_stomp_type);
++	stomp_type = btcoex->bt_stomp_type;
++	timer_period = btcoex->btcoex_no_stomp;
++
++	if (!(ah->caps.hw_caps & ATH9K_HW_CAP_MCI)) {
++		if (test_bit(BT_OP_SCAN, &btcoex->op_flags)) {
++			stomp_type = ATH_BTCOEX_STOMP_ALL;
++			timer_period = btcoex->btscan_no_stomp;
++		}
++	}
+ 
++	ath9k_hw_btcoex_bt_stomp(ah, stomp_type);
+ 	ath9k_hw_btcoex_enable(ah);
++
+ 	spin_unlock_bh(&btcoex->btcoex_lock);
+ 
+ 	/*
+@@ -252,17 +261,16 @@ static void ath_btcoex_period_timer(unsigned long data)
+ 		if (btcoex->hw_timer_enabled)
+ 			ath9k_gen_timer_stop(ah, btcoex->no_stomp_timer);
+ 
+-		timer_period = is_btscan ? btcoex->btscan_no_stomp :
+-					   btcoex->btcoex_no_stomp;
+ 		ath9k_gen_timer_start(ah, btcoex->no_stomp_timer, timer_period,
+ 				      timer_period * 10);
+ 		btcoex->hw_timer_enabled = true;
+ 	}
+ 
+ 	ath9k_ps_restore(sc);
++
+ skip_hw_wakeup:
+-	timer_period = btcoex->btcoex_period;
+-	mod_timer(&btcoex->period_timer, jiffies + msecs_to_jiffies(timer_period));
++	mod_timer(&btcoex->period_timer,
++		  jiffies + msecs_to_jiffies(btcoex->btcoex_period));
+ }
+ 
+ /*
+@@ -282,7 +290,8 @@ static void ath_btcoex_no_stomp_timer(void *arg)
+ 	spin_lock_bh(&btcoex->btcoex_lock);
+ 
+ 	if (btcoex->bt_stomp_type == ATH_BTCOEX_STOMP_LOW ||
+-	    test_bit(BT_OP_SCAN, &btcoex->op_flags))
++	    (!(ah->caps.hw_caps & ATH9K_HW_CAP_MCI) &&
++	     test_bit(BT_OP_SCAN, &btcoex->op_flags)))
+ 		ath9k_hw_btcoex_bt_stomp(ah, ATH_BTCOEX_STOMP_NONE);
+ 	 else if (btcoex->bt_stomp_type == ATH_BTCOEX_STOMP_ALL)
+ 		ath9k_hw_btcoex_bt_stomp(ah, ATH_BTCOEX_STOMP_LOW);
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0091-ath9k-perform-ANI-cycle-in-idle-state.patch b/linux-next-cherry-picks/0091-ath9k-perform-ANI-cycle-in-idle-state.patch
new file mode 100644
index 0000000..1240b27
--- /dev/null
+++ b/linux-next-cherry-picks/0091-ath9k-perform-ANI-cycle-in-idle-state.patch
@@ -0,0 +1,107 @@
+From 424749c75daf3611a68a49eca5940ac2b74e4406 Mon Sep 17 00:00:00 2001
+From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Date: Wed, 10 Oct 2012 23:03:02 +0530
+Subject: [PATCH] ath9k: perform ANI cycle in idle state
+
+As of now the ANI cycle is executed only when the chip is awake.
+On idle state case, the station wakes up from network sleep for
+beacon reception. Since most of the time, ANI cycle is not syncing
+with beacon wakeup, ANI cycle is ignored. Approx 5 mins once, the
+calibration is performed. This could affect the connection stability
+when the station is idle for long. Even though the OFDM and CCK phy
+error rates are too high, ANI is unable to tune its immunity level
+as quick enough due to rare execution.
+
+Here the experiment shows that OFDM and CCK levels are at default
+even on higher phy error rate.
+
+listenTime=44 OFDM:3 errs=121977/s CCK:2 errs=440818/s ofdm_turn=1
+
+This change ensures that ANI calibration will be exectued atleast
+once for every 10 seconds. The below result shows improvements and
+immunity levels are adopted quick enough.
+
+listenTime=557 OFDM:4 errs=752/s CCK:4 errs=125/s ofdm_turn=0
+
+Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/ath9k.h |    2 ++
+ drivers/net/wireless/ath/ath9k/hw.h    |    1 +
+ drivers/net/wireless/ath/ath9k/link.c  |   12 +++++++++++-
+ drivers/net/wireless/ath/ath9k/main.c  |    3 ++-
+ 4 files changed, 16 insertions(+), 2 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/ath9k.h b/drivers/net/wireless/ath/ath9k/ath9k.h
+index dfe6a47..77c2c16 100644
+--- a/drivers/net/wireless/ath/ath9k/ath9k.h
++++ b/drivers/net/wireless/ath/ath9k/ath9k.h
+@@ -437,6 +437,7 @@ void ath9k_set_beacon(struct ath_softc *sc);
+ #define ATH_LONG_CALINTERVAL_INT  1000    /* 1000 ms */
+ #define ATH_LONG_CALINTERVAL      30000   /* 30 seconds */
+ #define ATH_RESTART_CALINTERVAL   1200000 /* 20 minutes */
++#define ATH_ANI_MAX_SKIP_COUNT  10
+ 
+ #define ATH_PAPRD_TIMEOUT	100 /* msecs */
+ #define ATH_PLL_WORK_INTERVAL   100
+@@ -642,6 +643,7 @@ enum sc_op_flags {
+ #define PS_WAIT_FOR_PSPOLL_DATA   BIT(2)
+ #define PS_WAIT_FOR_TX_ACK        BIT(3)
+ #define PS_BEACON_SYNC            BIT(4)
++#define PS_WAIT_FOR_ANI           BIT(5)
+ 
+ struct ath_rate_table;
+ 
+diff --git a/drivers/net/wireless/ath/ath9k/hw.h b/drivers/net/wireless/ath/ath9k/hw.h
+index dbc1b7a..1d4f5f1 100644
+--- a/drivers/net/wireless/ath/ath9k/hw.h
++++ b/drivers/net/wireless/ath/ath9k/hw.h
+@@ -834,6 +834,7 @@ struct ath_hw {
+ 	int coarse_low[5];
+ 	int firpwr[5];
+ 	enum ath9k_ani_cmd ani_function;
++	u32 ani_skip_count;
+ 
+ #ifdef CONFIG_ATH9K_BTCOEX_SUPPORT
+ 	struct ath_btcoex_hw btcoex_hw;
+diff --git a/drivers/net/wireless/ath/ath9k/link.c b/drivers/net/wireless/ath/ath9k/link.c
+index 7b88b9c..223b969 100644
+--- a/drivers/net/wireless/ath/ath9k/link.c
++++ b/drivers/net/wireless/ath/ath9k/link.c
+@@ -350,8 +350,18 @@ void ath_ani_calibrate(unsigned long data)
+ 		ATH_AP_SHORT_CALINTERVAL : ATH_STA_SHORT_CALINTERVAL;
+ 
+ 	/* Only calibrate if awake */
+-	if (sc->sc_ah->power_mode != ATH9K_PM_AWAKE)
++	if (sc->sc_ah->power_mode != ATH9K_PM_AWAKE) {
++		if (++ah->ani_skip_count >= ATH_ANI_MAX_SKIP_COUNT) {
++			spin_lock_irqsave(&sc->sc_pm_lock, flags);
++			sc->ps_flags |= PS_WAIT_FOR_ANI;
++			spin_unlock_irqrestore(&sc->sc_pm_lock, flags);
++		}
+ 		goto set_timer;
++	}
++	ah->ani_skip_count = 0;
++	spin_lock_irqsave(&sc->sc_pm_lock, flags);
++	sc->ps_flags &= ~PS_WAIT_FOR_ANI;
++	spin_unlock_irqrestore(&sc->sc_pm_lock, flags);
+ 
+ 	ath9k_ps_wakeup(sc);
+ 
+diff --git a/drivers/net/wireless/ath/ath9k/main.c b/drivers/net/wireless/ath/ath9k/main.c
+index dd45edf..2da62be 100644
+--- a/drivers/net/wireless/ath/ath9k/main.c
++++ b/drivers/net/wireless/ath/ath9k/main.c
+@@ -131,7 +131,8 @@ void ath9k_ps_restore(struct ath_softc *sc)
+ 		   !(sc->ps_flags & (PS_WAIT_FOR_BEACON |
+ 				     PS_WAIT_FOR_CAB |
+ 				     PS_WAIT_FOR_PSPOLL_DATA |
+-				     PS_WAIT_FOR_TX_ACK))) {
++				     PS_WAIT_FOR_TX_ACK |
++				     PS_WAIT_FOR_ANI))) {
+ 		mode = ATH9K_PM_NETWORK_SLEEP;
+ 		if (ath9k_hw_btcoex_is_enabled(sc->sc_ah))
+ 			ath9k_btcoex_stop_gen_timer(sc);
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0093-ath9k-fix-stale-pointers-potentially-causing-access-.patch b/linux-next-cherry-picks/0093-ath9k-fix-stale-pointers-potentially-causing-access-.patch
new file mode 100644
index 0000000..e3a77ab
--- /dev/null
+++ b/linux-next-cherry-picks/0093-ath9k-fix-stale-pointers-potentially-causing-access-.patch
@@ -0,0 +1,43 @@
+From 8c6e30936a7893a85f6222084f0f26aceb81137a Mon Sep 17 00:00:00 2001
+From: Felix Fietkau <nbd@xxxxxxxxxxx>
+Date: Fri, 26 Oct 2012 00:31:11 +0200
+Subject: [PATCH] ath9k: fix stale pointers potentially causing access to free'd skbs
+
+bf->bf_next is only while buffers are chained as part of an A-MPDU
+in the tx queue. When a tid queue is flushed (e.g. on tearing down
+an aggregation session), frames can be enqueued again as normal
+transmission, without bf_next being cleared. This can lead to the
+old pointer being dereferenced again later.
+
+This patch might fix crashes and "Failed to stop TX DMA!" messages.
+
+Signed-off-by: Felix Fietkau <nbd@xxxxxxxxxxx>
+Cc: stable@xxxxxxxxxxxxxxx
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/xmit.c |    2 ++
+ 1 files changed, 2 insertions(+), 0 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/xmit.c b/drivers/net/wireless/ath/ath9k/xmit.c
+index 378bd70..1ffca75 100644
+--- a/drivers/net/wireless/ath/ath9k/xmit.c
++++ b/drivers/net/wireless/ath/ath9k/xmit.c
+@@ -312,6 +312,7 @@ static struct ath_buf *ath_tx_get_buffer(struct ath_softc *sc)
+ 	}
+ 
+ 	bf = list_first_entry(&sc->tx.txbuf, struct ath_buf, list);
++	bf->bf_next = NULL;
+ 	list_del(&bf->list);
+ 
+ 	spin_unlock_bh(&sc->tx.txbuflock);
+@@ -1774,6 +1775,7 @@ static void ath_tx_send_normal(struct ath_softc *sc, struct ath_txq *txq,
+ 	list_add_tail(&bf->list, &bf_head);
+ 	bf->bf_state.bf_type = 0;
+ 
++	bf->bf_next = NULL;
+ 	bf->bf_lastbf = bf;
+ 	ath_tx_fill_desc(sc, bf, txq, fi->framelen);
+ 	ath_tx_txqaddbuf(sc, txq, &bf_head, false);
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0094-ath9k-Send-WLAN-channel-info-to-BT.patch b/linux-next-cherry-picks/0094-ath9k-Send-WLAN-channel-info-to-BT.patch
new file mode 100644
index 0000000..c80a290
--- /dev/null
+++ b/linux-next-cherry-picks/0094-ath9k-Send-WLAN-channel-info-to-BT.patch
@@ -0,0 +1,147 @@
+From 50072ebca3d0aec8c5b8543e767d45c6626523af Mon Sep 17 00:00:00 2001
+From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Date: Fri, 12 Oct 2012 14:07:22 +0530
+Subject: [PATCH] ath9k: Send WLAN channel info to BT
+
+WLAN updates channel bitmap when associated and disassociated. Channel
+bitmap will reflect whare are the channels used or affected by WLAN and
+BT should avoid using those. Not doing so, could affect BT traffic
+as both WLAN and BT is operating on same channel.
+
+Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/main.c |    5 +++
+ drivers/net/wireless/ath/ath9k/mci.c  |   50 +++++++++++++++++++++++++++++++++
+ drivers/net/wireless/ath/ath9k/mci.h  |   23 +++++++++++++++
+ 3 files changed, 78 insertions(+), 0 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/main.c b/drivers/net/wireless/ath/ath9k/main.c
+index 2da62be..515e184 100644
+--- a/drivers/net/wireless/ath/ath9k/main.c
++++ b/drivers/net/wireless/ath/ath9k/main.c
+@@ -1450,6 +1450,9 @@ static void ath9k_set_assoc_state(struct ath_softc *sc,
+ 	sc->ps_flags |= PS_BEACON_SYNC | PS_WAIT_FOR_BEACON;
+ 	spin_unlock_irqrestore(&sc->sc_pm_lock, flags);
+ 
++	if (ath9k_hw_mci_is_enabled(sc->sc_ah))
++		ath9k_mci_update_wlan_channels(sc, false);
++
+ 	ath_dbg(common, CONFIG,
+ 		"Primary Station interface: %pM, BSSID: %pM\n",
+ 		vif->addr, common->curbssid);
+@@ -1506,6 +1509,8 @@ static void ath9k_bss_info_changed(struct ieee80211_hw *hw,
+ 			memset(common->curbssid, 0, ETH_ALEN);
+ 			common->curaid = 0;
+ 			ath9k_hw_write_associd(sc->sc_ah);
++			if (ath9k_hw_mci_is_enabled(sc->sc_ah))
++				ath9k_mci_update_wlan_channels(sc, true);
+ 		}
+ 	}
+ 
+diff --git a/drivers/net/wireless/ath/ath9k/mci.c b/drivers/net/wireless/ath/ath9k/mci.c
+index ec2d7c8..1733a5a 100644
+--- a/drivers/net/wireless/ath/ath9k/mci.c
++++ b/drivers/net/wireless/ath/ath9k/mci.c
+@@ -600,3 +600,53 @@ void ath_mci_enable(struct ath_softc *sc)
+ 	if (sc->sc_ah->caps.hw_caps & ATH9K_HW_CAP_MCI)
+ 		sc->sc_ah->imask |= ATH9K_INT_MCI;
+ }
++
++void ath9k_mci_update_wlan_channels(struct ath_softc *sc, bool allow_all)
++{
++	struct ath_hw *ah = sc->sc_ah;
++	struct ath9k_hw_mci *mci = &ah->btcoex_hw.mci;
++	struct ath9k_channel *chan = ah->curchan;
++	u32 channelmap[] = {0x00000000, 0xffff0000, 0xffffffff, 0x7fffffff};
++	int i;
++	s16 chan_start, chan_end;
++	u16 wlan_chan;
++
++	if (!chan || !IS_CHAN_2GHZ(chan))
++		return;
++
++	if (allow_all)
++		goto send_wlan_chan;
++
++	wlan_chan = chan->channel - 2402;
++
++	chan_start = wlan_chan - 10;
++	chan_end = wlan_chan + 10;
++
++	if (chan->chanmode == CHANNEL_G_HT40PLUS)
++		chan_end += 20;
++	else if (chan->chanmode == CHANNEL_G_HT40MINUS)
++		chan_start -= 20;
++
++	/* adjust side band */
++	chan_start -= 7;
++	chan_end += 7;
++
++	if (chan_start <= 0)
++		chan_start = 0;
++	if (chan_end >= ATH_MCI_NUM_BT_CHANNELS)
++		chan_end = ATH_MCI_NUM_BT_CHANNELS - 1;
++
++	ath_dbg(ath9k_hw_common(ah), MCI,
++		"WLAN current channel %d mask BT channel %d - %d\n",
++		wlan_chan, chan_start, chan_end);
++
++	for (i = chan_start; i < chan_end; i++)
++		MCI_GPM_CLR_CHANNEL_BIT(&channelmap, i);
++
++send_wlan_chan:
++	/* update and send wlan channels info to BT */
++	for (i = 0; i < 4; i++)
++		mci->wlan_channels[i] = channelmap[i];
++	ar9003_mci_send_wlan_channels(ah);
++	ar9003_mci_state(ah, MCI_STATE_SEND_VERSION_QUERY);
++}
+diff --git a/drivers/net/wireless/ath/ath9k/mci.h b/drivers/net/wireless/ath/ath9k/mci.h
+index fc14eea..a3df314 100644
+--- a/drivers/net/wireless/ath/ath9k/mci.h
++++ b/drivers/net/wireless/ath/ath9k/mci.h
+@@ -32,6 +32,24 @@
+ #define ATH_MCI_MAX_PROFILE		(ATH_MCI_MAX_ACL_PROFILE +\
+ 					 ATH_MCI_MAX_SCO_PROFILE)
+ 
++#define ATH_MCI_NUM_BT_CHANNELS      79
++
++#define MCI_GPM_SET_CHANNEL_BIT(_p_gpm, _bt_chan)			  \
++	do {								  \
++		if (_bt_chan < ATH_MCI_NUM_BT_CHANNELS) {		  \
++			*(((u8 *)(_p_gpm)) + MCI_GPM_COEX_B_CHANNEL_MAP + \
++				(_bt_chan / 8)) |= (1 << (_bt_chan & 7)); \
++		}							  \
++	} while (0)
++
++#define MCI_GPM_CLR_CHANNEL_BIT(_p_gpm, _bt_chan)			  \
++	do {								  \
++		if (_bt_chan < ATH_MCI_NUM_BT_CHANNELS) {		  \
++			*(((u8 *)(_p_gpm)) + MCI_GPM_COEX_B_CHANNEL_MAP + \
++				(_bt_chan / 8)) &= ~(1 << (_bt_chan & 7));\
++		}							  \
++	} while (0)
++
+ #define INC_PROF(_mci, _info) do {		 \
+ 		switch (_info->type) {		 \
+ 		case MCI_GPM_COEX_PROFILE_RFCOMM:\
+@@ -133,10 +151,15 @@ void ath_mci_intr(struct ath_softc *sc);
+ 
+ #ifdef CONFIG_ATH9K_BTCOEX_SUPPORT
+ void ath_mci_enable(struct ath_softc *sc);
++void ath9k_mci_update_wlan_channels(struct ath_softc *sc, bool allow_all);
+ #else
+ static inline void ath_mci_enable(struct ath_softc *sc)
+ {
+ }
++static inline void ath9k_mci_update_wlan_channels(struct ath_softc *sc,
++						  bool allow_all)
++{
++}
+ #endif /* CONFIG_ATH9K_BTCOEX_SUPPORT */
+ 
+ #endif /* MCI_H*/
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0095-ath9k-Add-concurrent-WLAN-and-BT-tx-support-for-MCI-.patch b/linux-next-cherry-picks/0095-ath9k-Add-concurrent-WLAN-and-BT-tx-support-for-MCI-.patch
new file mode 100644
index 0000000..3ea4027
--- /dev/null
+++ b/linux-next-cherry-picks/0095-ath9k-Add-concurrent-WLAN-and-BT-tx-support-for-MCI-.patch
@@ -0,0 +1,264 @@
+From db60428b1af11cf216bb0736b24b2cf0c7b54071 Mon Sep 17 00:00:00 2001
+From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Date: Fri, 12 Oct 2012 14:07:23 +0530
+Subject: [PATCH] ath9k: Add concurrent WLAN and BT tx support for MCI based chips
+
+This feature enables both WLAN and BT can transmit simultaneously
+by setting WLAN and BT to equal priorities. Whenever both are
+transmitting, it might violate regulatory power limits. To avoid
+regulatory violation, WLAN tx power will be adjusted according to BT
+power index based on avaliability of BT scheduling message. If the
+combined power exceeds threshold, BT transmission will be held off.
+
+Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/ar9003_mci.h |    1 -
+ drivers/net/wireless/ath/ath9k/btcoex.c     |   60 +++++++++++++++++++-------
+ drivers/net/wireless/ath/ath9k/btcoex.h     |    3 +
+ drivers/net/wireless/ath/ath9k/mci.c        |   60 +++++++++++++++++++++++++++
+ drivers/net/wireless/ath/ath9k/mci.h        |    3 +
+ 5 files changed, 110 insertions(+), 17 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/ar9003_mci.h b/drivers/net/wireless/ath/ath9k/ar9003_mci.h
+index 2a2d018..2928234 100644
+--- a/drivers/net/wireless/ath/ath9k/ar9003_mci.h
++++ b/drivers/net/wireless/ath/ath9k/ar9003_mci.h
+@@ -196,7 +196,6 @@ enum mci_state_type {
+ 	MCI_STATE_SEND_WLAN_COEX_VERSION,
+ 	MCI_STATE_SEND_VERSION_QUERY,
+ 	MCI_STATE_SEND_STATUS_QUERY,
+-	MCI_STATE_SET_CONCUR_TX_PRI,
+ 	MCI_STATE_RECOVER_RX,
+ 	MCI_STATE_NEED_FTP_STOMP,
+ 	MCI_STATE_DEBUG,
+diff --git a/drivers/net/wireless/ath/ath9k/btcoex.c b/drivers/net/wireless/ath/ath9k/btcoex.c
+index 419e9a3..05d9be5 100644
+--- a/drivers/net/wireless/ath/ath9k/btcoex.c
++++ b/drivers/net/wireless/ath/ath9k/btcoex.c
+@@ -218,27 +218,45 @@ void ath9k_hw_btcoex_set_weight(struct ath_hw *ah,
+ 				enum ath_stomp_type stomp_type)
+ {
+ 	struct ath_btcoex_hw *btcoex_hw = &ah->btcoex_hw;
++	struct ath9k_hw_mci *mci_hw = &ah->btcoex_hw.mci;
++	u8 txprio_shift[] = { 24, 16, 16, 0 }; /* tx priority weight */
++	bool concur_tx = (mci_hw->concur_tx && btcoex_hw->tx_prio[stomp_type]);
++	const u32 *weight = ar9003_wlan_weights[stomp_type];
++	int i;
+ 
+-	if (AR_SREV_9300_20_OR_LATER(ah)) {
+-		const u32 *weight = ar9003_wlan_weights[stomp_type];
+-		int i;
+-
+-		if (AR_SREV_9462(ah) || AR_SREV_9565(ah)) {
+-			if ((stomp_type == ATH_BTCOEX_STOMP_LOW) &&
+-			    btcoex_hw->mci.stomp_ftp)
+-				stomp_type = ATH_BTCOEX_STOMP_LOW_FTP;
+-			weight = mci_wlan_weights[stomp_type];
+-		}
+-
+-		for (i = 0; i < AR9300_NUM_WLAN_WEIGHTS; i++) {
+-			btcoex_hw->bt_weight[i] = AR9300_BT_WGHT;
+-			btcoex_hw->wlan_weight[i] = weight[i];
+-		}
+-	} else {
++	if (!AR_SREV_9300_20_OR_LATER(ah)) {
+ 		btcoex_hw->bt_coex_weights =
+ 			SM(bt_weight, AR_BTCOEX_BT_WGHT) |
+ 			SM(wlan_weight, AR_BTCOEX_WL_WGHT);
++		return;
++	}
++
++	if (AR_SREV_9462(ah) || AR_SREV_9565(ah)) {
++		enum ath_stomp_type stype =
++			((stomp_type == ATH_BTCOEX_STOMP_LOW) &&
++			 btcoex_hw->mci.stomp_ftp) ?
++			ATH_BTCOEX_STOMP_LOW_FTP : stomp_type;
++		weight = mci_wlan_weights[stype];
+ 	}
++
++	for (i = 0; i < AR9300_NUM_WLAN_WEIGHTS; i++) {
++		btcoex_hw->bt_weight[i] = AR9300_BT_WGHT;
++		btcoex_hw->wlan_weight[i] = weight[i];
++		if (concur_tx && i) {
++			btcoex_hw->wlan_weight[i] &=
++				~(0xff << txprio_shift[i-1]);
++			btcoex_hw->wlan_weight[i] |=
++				(btcoex_hw->tx_prio[stomp_type] <<
++				 txprio_shift[i-1]);
++		}
++	}
++	/* Last WLAN weight has to be adjusted wrt tx priority */
++	if (concur_tx) {
++		btcoex_hw->wlan_weight[i-1] &= ~(0xff << txprio_shift[i-1]);
++		btcoex_hw->wlan_weight[i-1] |= (btcoex_hw->tx_prio[stomp_type]
++						      << txprio_shift[i-1]);
++	}
++
+ }
+ EXPORT_SYMBOL(ath9k_hw_btcoex_set_weight);
+ 
+@@ -385,3 +403,13 @@ void ath9k_hw_btcoex_bt_stomp(struct ath_hw *ah,
+ 	}
+ }
+ EXPORT_SYMBOL(ath9k_hw_btcoex_bt_stomp);
++
++void ath9k_hw_btcoex_set_concur_txprio(struct ath_hw *ah, u8 *stomp_txprio)
++{
++	struct ath_btcoex_hw *btcoex = &ah->btcoex_hw;
++	int i;
++
++	for (i = 0; i < ATH_BTCOEX_STOMP_MAX; i++)
++		btcoex->tx_prio[i] = stomp_txprio[i];
++}
++EXPORT_SYMBOL(ath9k_hw_btcoex_set_concur_txprio);
+diff --git a/drivers/net/wireless/ath/ath9k/btcoex.h b/drivers/net/wireless/ath/ath9k/btcoex.h
+index 385197a..a260fcb 100644
+--- a/drivers/net/wireless/ath/ath9k/btcoex.h
++++ b/drivers/net/wireless/ath/ath9k/btcoex.h
+@@ -84,6 +84,7 @@ struct ath9k_hw_mci {
+ 	u8 bt_ver_minor;
+ 	u8 bt_state;
+ 	u8 stomp_ftp;
++	bool concur_tx;
+ };
+ 
+ struct ath_btcoex_hw {
+@@ -98,6 +99,7 @@ struct ath_btcoex_hw {
+ 	u32 bt_coex_mode2; 	/* Register setting for AR_BT_COEX_MODE2 */
+ 	u32 bt_weight[AR9300_NUM_BT_WEIGHTS];
+ 	u32 wlan_weight[AR9300_NUM_WLAN_WEIGHTS];
++	u8 tx_prio[ATH_BTCOEX_STOMP_MAX];
+ };
+ 
+ void ath9k_hw_btcoex_init_scheme(struct ath_hw *ah);
+@@ -112,5 +114,6 @@ void ath9k_hw_btcoex_set_weight(struct ath_hw *ah,
+ void ath9k_hw_btcoex_disable(struct ath_hw *ah);
+ void ath9k_hw_btcoex_bt_stomp(struct ath_hw *ah,
+ 			      enum ath_stomp_type stomp_type);
++void ath9k_hw_btcoex_set_concur_txprio(struct ath_hw *ah, u8 *stomp_txprio);
+ 
+ #endif
+diff --git a/drivers/net/wireless/ath/ath9k/mci.c b/drivers/net/wireless/ath/ath9k/mci.c
+index 1733a5a..b37c8af 100644
+--- a/drivers/net/wireless/ath/ath9k/mci.c
++++ b/drivers/net/wireless/ath/ath9k/mci.c
+@@ -43,6 +43,7 @@ static bool ath_mci_add_profile(struct ath_common *common,
+ 				struct ath_mci_profile_info *info)
+ {
+ 	struct ath_mci_profile_info *entry;
++	u8 voice_priority[] = { 110, 110, 110, 112, 110, 110, 114, 116, 118 };
+ 
+ 	if ((mci->num_sco == ATH_MCI_MAX_SCO_PROFILE) &&
+ 	    (info->type == MCI_GPM_COEX_PROFILE_VOICE))
+@@ -59,6 +60,12 @@ static bool ath_mci_add_profile(struct ath_common *common,
+ 	memcpy(entry, info, 10);
+ 	INC_PROF(mci, info);
+ 	list_add_tail(&entry->list, &mci->info);
++	if (info->type == MCI_GPM_COEX_PROFILE_VOICE) {
++		if (info->voice_type < sizeof(voice_priority))
++			mci->voice_priority = voice_priority[info->voice_type];
++		else
++			mci->voice_priority = 110;
++	}
+ 
+ 	return true;
+ }
+@@ -250,6 +257,57 @@ static void ath9k_mci_work(struct work_struct *work)
+ 	ath_mci_update_scheme(sc);
+ }
+ 
++static void ath_mci_update_stomp_txprio(u8 cur_txprio, u8 *stomp_prio)
++{
++	if (cur_txprio < stomp_prio[ATH_BTCOEX_STOMP_NONE])
++		stomp_prio[ATH_BTCOEX_STOMP_NONE] = cur_txprio;
++
++	if (cur_txprio > stomp_prio[ATH_BTCOEX_STOMP_ALL])
++		stomp_prio[ATH_BTCOEX_STOMP_ALL] = cur_txprio;
++
++	if ((cur_txprio > ATH_MCI_HI_PRIO) &&
++	    (cur_txprio < stomp_prio[ATH_BTCOEX_STOMP_LOW]))
++		stomp_prio[ATH_BTCOEX_STOMP_LOW] = cur_txprio;
++}
++
++static void ath_mci_set_concur_txprio(struct ath_softc *sc)
++{
++	struct ath_btcoex *btcoex = &sc->btcoex;
++	struct ath_mci_profile *mci = &btcoex->mci;
++	u8 stomp_txprio[] = { 0, 0, 0, 0 }; /* all, low, none, low_ftp */
++
++	if (mci->num_mgmt) {
++		stomp_txprio[ATH_BTCOEX_STOMP_ALL] = ATH_MCI_INQUIRY_PRIO;
++		if (!mci->num_pan && !mci->num_other_acl)
++			stomp_txprio[ATH_BTCOEX_STOMP_NONE] =
++				ATH_MCI_INQUIRY_PRIO;
++	} else {
++		u8 prof_prio[] = { 50, 90, 94, 52 };/* RFCOMM, A2DP, HID, PAN */
++
++		stomp_txprio[ATH_BTCOEX_STOMP_LOW] =
++		stomp_txprio[ATH_BTCOEX_STOMP_NONE] = 0xff;
++
++		if (mci->num_sco)
++			ath_mci_update_stomp_txprio(mci->voice_priority,
++						    stomp_txprio);
++		if (mci->num_other_acl)
++			ath_mci_update_stomp_txprio(prof_prio[0], stomp_txprio);
++		if (mci->num_a2dp)
++			ath_mci_update_stomp_txprio(prof_prio[1], stomp_txprio);
++		if (mci->num_hid)
++			ath_mci_update_stomp_txprio(prof_prio[2], stomp_txprio);
++		if (mci->num_pan)
++			ath_mci_update_stomp_txprio(prof_prio[3], stomp_txprio);
++
++		if (stomp_txprio[ATH_BTCOEX_STOMP_NONE] == 0xff)
++			stomp_txprio[ATH_BTCOEX_STOMP_NONE] = 0;
++
++		if (stomp_txprio[ATH_BTCOEX_STOMP_LOW] == 0xff)
++			stomp_txprio[ATH_BTCOEX_STOMP_LOW] = 0;
++	}
++	ath9k_hw_btcoex_set_concur_txprio(sc->sc_ah, stomp_txprio);
++}
++
+ static u8 ath_mci_process_profile(struct ath_softc *sc,
+ 				  struct ath_mci_profile_info *info)
+ {
+@@ -281,6 +339,7 @@ static u8 ath_mci_process_profile(struct ath_softc *sc,
+ 	} else
+ 		ath_mci_del_profile(common, mci, entry);
+ 
++	ath_mci_set_concur_txprio(sc);
+ 	return 1;
+ }
+ 
+@@ -314,6 +373,7 @@ static u8 ath_mci_process_status(struct ath_softc *sc,
+ 			mci->num_mgmt++;
+ 	} while (++i < ATH_MCI_MAX_PROFILE);
+ 
++	ath_mci_set_concur_txprio(sc);
+ 	if (old_num_mgmt != mci->num_mgmt)
+ 		return 1;
+ 
+diff --git a/drivers/net/wireless/ath/ath9k/mci.h b/drivers/net/wireless/ath/ath9k/mci.h
+index a3df314..e85a0e9 100644
+--- a/drivers/net/wireless/ath/ath9k/mci.h
++++ b/drivers/net/wireless/ath/ath9k/mci.h
+@@ -32,6 +32,8 @@
+ #define ATH_MCI_MAX_PROFILE		(ATH_MCI_MAX_ACL_PROFILE +\
+ 					 ATH_MCI_MAX_SCO_PROFILE)
+ 
++#define ATH_MCI_INQUIRY_PRIO         62
++#define ATH_MCI_HI_PRIO              60
+ #define ATH_MCI_NUM_BT_CHANNELS      79
+ 
+ #define MCI_GPM_SET_CHANNEL_BIT(_p_gpm, _bt_chan)			  \
+@@ -131,6 +133,7 @@ struct ath_mci_profile {
+ 	u8 num_pan;
+ 	u8 num_other_acl;
+ 	u8 num_bdr;
++	u8 voice_priority;
+ };
+ 
+ struct ath_mci_buf {
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0096-ath9k-fill-channel-mode-in-caldata.patch b/linux-next-cherry-picks/0096-ath9k-fill-channel-mode-in-caldata.patch
new file mode 100644
index 0000000..2819e4e
--- /dev/null
+++ b/linux-next-cherry-picks/0096-ath9k-fill-channel-mode-in-caldata.patch
@@ -0,0 +1,44 @@
+From 77d848372875d2e4cbdbf07030f0e08cab5e7f4d Mon Sep 17 00:00:00 2001
+From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Date: Fri, 12 Oct 2012 14:07:24 +0530
+Subject: [PATCH] ath9k: fill channel mode in caldata
+
+It is useful to have channel mode in caldata to find out
+whether operaing channel is in HT40/20 when we are currently
+on offchannel. It will be used by BTCOEX to enable/disable
+concurrent tx mechanism later.
+
+Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/calib.c |    1 +
+ drivers/net/wireless/ath/ath9k/hw.h    |    1 +
+ 2 files changed, 2 insertions(+), 0 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/calib.c b/drivers/net/wireless/ath/ath9k/calib.c
+index e5cceb0..f3448a0 100644
+--- a/drivers/net/wireless/ath/ath9k/calib.c
++++ b/drivers/net/wireless/ath/ath9k/calib.c
+@@ -410,6 +410,7 @@ void ath9k_init_nfcal_hist_buffer(struct ath_hw *ah,
+ 
+ 	ah->caldata->channel = chan->channel;
+ 	ah->caldata->channelFlags = chan->channelFlags & ~CHANNEL_CW_INT;
++	ah->caldata->chanmode = chan->chanmode;
+ 	h = ah->caldata->nfCalHist;
+ 	default_nf = ath9k_hw_get_default_nf(ah, chan);
+ 	for (i = 0; i < NUM_NF_READINGS; i++) {
+diff --git a/drivers/net/wireless/ath/ath9k/hw.h b/drivers/net/wireless/ath/ath9k/hw.h
+index 1d4f5f1..3e73bfe 100644
+--- a/drivers/net/wireless/ath/ath9k/hw.h
++++ b/drivers/net/wireless/ath/ath9k/hw.h
+@@ -401,6 +401,7 @@ enum ath9k_int {
+ struct ath9k_hw_cal_data {
+ 	u16 channel;
+ 	u32 channelFlags;
++	u32 chanmode;
+ 	int32_t CalValid;
+ 	int8_t iCoff;
+ 	int8_t qCoff;
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0097-ath9k-adjust-WLAN-and-BT-concurrent-transmission.patch b/linux-next-cherry-picks/0097-ath9k-adjust-WLAN-and-BT-concurrent-transmission.patch
new file mode 100644
index 0000000..a559028
--- /dev/null
+++ b/linux-next-cherry-picks/0097-ath9k-adjust-WLAN-and-BT-concurrent-transmission.patch
@@ -0,0 +1,313 @@
+From e82cb03f5a645533def34923d55404526bc22fae Mon Sep 17 00:00:00 2001
+From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Date: Fri, 12 Oct 2012 14:07:25 +0530
+Subject: [PATCH] ath9k: adjust WLAN and BT concurrent transmission
+
+The simulataneous transmission of both WLAN and BT might cause
+increase in power levels. To avoid regulatory violation, WLAN tx
+power will be adjusted according to BT power index based on avaliability
+of BT scheduling messages. WLAN tx power reduction might affect its
+performance. So WLAN tx power is only be lowered when the signal strength
+is good enough. Otherwise concurrent tx will be disabled and WLAN uses
+it default power levels. Also concurrent tx is disabled whenever WLAN is
+moving to off-channel which might be used by BT.
+
+Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/ar9003_eeprom.c |   18 ++++++-
+ drivers/net/wireless/ath/ath9k/ar9003_mci.c    |   28 +++++++++++-
+ drivers/net/wireless/ath/ath9k/ar9003_mci.h    |    5 ++
+ drivers/net/wireless/ath/ath9k/ath9k.h         |    1 +
+ drivers/net/wireless/ath/ath9k/btcoex.h        |    3 +
+ drivers/net/wireless/ath/ath9k/gpio.c          |    2 +
+ drivers/net/wireless/ath/ath9k/main.c          |    4 ++
+ drivers/net/wireless/ath/ath9k/mci.c           |   59 ++++++++++++++++++++++++
+ drivers/net/wireless/ath/ath9k/mci.h           |    8 +++
+ 9 files changed, 124 insertions(+), 4 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/ar9003_eeprom.c b/drivers/net/wireless/ath/ath9k/ar9003_eeprom.c
+index 189aeb2..d313998 100644
+--- a/drivers/net/wireless/ath/ath9k/ar9003_eeprom.c
++++ b/drivers/net/wireless/ath/ath9k/ar9003_eeprom.c
+@@ -18,6 +18,7 @@
+ #include "hw.h"
+ #include "ar9003_phy.h"
+ #include "ar9003_eeprom.h"
++#include "ar9003_mci.h"
+ 
+ #define COMP_HDR_LEN 4
+ #define COMP_CKSUM_LEN 2
+@@ -41,7 +42,6 @@
+ static int ar9003_hw_power_interpolate(int32_t x,
+ 				       int32_t *px, int32_t *py, u_int16_t np);
+ 
+-
+ static const struct ar9300_eeprom ar9300_default = {
+ 	.eepromVersion = 2,
+ 	.templateVersion = 2,
+@@ -5037,16 +5037,28 @@ static void ar9003_hw_set_power_per_rate_table(struct ath_hw *ah,
+ 		case CTL_5GHT20:
+ 		case CTL_2GHT20:
+ 			for (i = ALL_TARGET_HT20_0_8_16;
+-			     i <= ALL_TARGET_HT20_23; i++)
++			     i <= ALL_TARGET_HT20_23; i++) {
+ 				pPwrArray[i] = (u8)min((u16)pPwrArray[i],
+ 						       minCtlPower);
++				if (ath9k_hw_mci_is_enabled(ah))
++					pPwrArray[i] =
++						(u8)min((u16)pPwrArray[i],
++						ar9003_mci_get_max_txpower(ah,
++							pCtlMode[ctlMode]));
++			}
+ 			break;
+ 		case CTL_5GHT40:
+ 		case CTL_2GHT40:
+ 			for (i = ALL_TARGET_HT40_0_8_16;
+-			     i <= ALL_TARGET_HT40_23; i++)
++			     i <= ALL_TARGET_HT40_23; i++) {
+ 				pPwrArray[i] = (u8)min((u16)pPwrArray[i],
+ 						       minCtlPower);
++				if (ath9k_hw_mci_is_enabled(ah))
++					pPwrArray[i] =
++						(u8)min((u16)pPwrArray[i],
++						ar9003_mci_get_max_txpower(ah,
++							pCtlMode[ctlMode]));
++			}
+ 			break;
+ 		default:
+ 			break;
+diff --git a/drivers/net/wireless/ath/ath9k/ar9003_mci.c b/drivers/net/wireless/ath/ath9k/ar9003_mci.c
+index 44c202c..9aa8704 100644
+--- a/drivers/net/wireless/ath/ath9k/ar9003_mci.c
++++ b/drivers/net/wireless/ath/ath9k/ar9003_mci.c
+@@ -818,7 +818,7 @@ int ar9003_mci_reset(struct ath_hw *ah, bool en_int, bool is_2g,
+ {
+ 	struct ath_common *common = ath9k_hw_common(ah);
+ 	struct ath9k_hw_mci *mci = &ah->btcoex_hw.mci;
+-	u32 regval;
++	u32 regval, i;
+ 
+ 	ath_dbg(common, MCI, "MCI Reset (full_sleep = %d, is_2g = %d)\n",
+ 		is_full_sleep, is_2g);
+@@ -868,6 +868,18 @@ int ar9003_mci_reset(struct ath_hw *ah, bool en_int, bool is_2g,
+ 	REG_RMW_FIELD(ah, AR_BTCOEX_CTRL2, AR_BTCOEX_CTRL2_RX_DEWEIGHT, 1);
+ 	REG_RMW_FIELD(ah, AR_PCU_MISC, AR_PCU_BT_ANT_PREVENT_RX, 0);
+ 
++	/* concurrent tx priority */
++	if (mci->config & ATH_MCI_CONFIG_CONCUR_TX) {
++		REG_RMW_FIELD(ah, AR_BTCOEX_CTRL2,
++			      AR_BTCOEX_CTRL2_DESC_BASED_TXPWR_ENABLE, 0);
++		REG_RMW_FIELD(ah, AR_BTCOEX_CTRL2,
++			      AR_BTCOEX_CTRL2_TXPWR_THRESH, 0x7f);
++		REG_RMW_FIELD(ah, AR_BTCOEX_CTRL,
++			      AR_BTCOEX_CTRL_REDUCE_TXPWR, 0);
++		for (i = 0; i < 8; i++)
++			REG_WRITE(ah, AR_BTCOEX_MAX_TXPWR(i), 0x7f7f7f7f);
++	}
++
+ 	regval = MS(mci->config, ATH_MCI_CONFIG_CLK_DIV);
+ 	REG_RMW_FIELD(ah, AR_MCI_TX_CTRL, AR_MCI_TX_CTRL_CLK_DIV, regval);
+ 	REG_SET_BIT(ah, AR_BTCOEX_CTRL, AR_BTCOEX_CTRL_MCI_MODE_EN);
+@@ -1426,3 +1438,17 @@ void ar9003_mci_send_wlan_channels(struct ath_hw *ah)
+ 	ar9003_mci_send_coex_wlan_channels(ah, true);
+ }
+ EXPORT_SYMBOL(ar9003_mci_send_wlan_channels);
++
++u16 ar9003_mci_get_max_txpower(struct ath_hw *ah, u8 ctlmode)
++{
++	if (!ah->btcoex_hw.mci.concur_tx)
++		goto out;
++
++	if (ctlmode == CTL_2GHT20)
++		return ATH_BTCOEX_HT20_MAX_TXPOWER;
++	else if (ctlmode == CTL_2GHT40)
++		return ATH_BTCOEX_HT40_MAX_TXPOWER;
++
++out:
++	return -1;
++}
+diff --git a/drivers/net/wireless/ath/ath9k/ar9003_mci.h b/drivers/net/wireless/ath/ath9k/ar9003_mci.h
+index 2928234..0910310 100644
+--- a/drivers/net/wireless/ath/ath9k/ar9003_mci.h
++++ b/drivers/net/wireless/ath/ath9k/ar9003_mci.h
+@@ -277,6 +277,7 @@ void ar9003_mci_get_isr(struct ath_hw *ah, enum ath9k_int *masked);
+ void ar9003_mci_bt_gain_ctrl(struct ath_hw *ah);
+ void ar9003_mci_set_power_awake(struct ath_hw *ah);
+ void ar9003_mci_check_gpm_offset(struct ath_hw *ah);
++u16 ar9003_mci_get_max_txpower(struct ath_hw *ah, u8 ctlmode);
+ 
+ #else
+ 
+@@ -323,6 +324,10 @@ static inline void ar9003_mci_set_power_awake(struct ath_hw *ah)
+ static inline void ar9003_mci_check_gpm_offset(struct ath_hw *ah)
+ {
+ }
++static inline u16 ar9003_mci_get_max_txpower(struct ath_hw *ah, u8 ctlmode)
++{
++	return -1;
++}
+ #endif /* CONFIG_ATH9K_BTCOEX_SUPPORT */
+ 
+ #endif
+diff --git a/drivers/net/wireless/ath/ath9k/ath9k.h b/drivers/net/wireless/ath/ath9k/ath9k.h
+index 77c2c16..18dfb76 100644
+--- a/drivers/net/wireless/ath/ath9k/ath9k.h
++++ b/drivers/net/wireless/ath/ath9k/ath9k.h
+@@ -479,6 +479,7 @@ struct ath_btcoex {
+ 	u32 btscan_no_stomp; /* in usec */
+ 	u32 duty_cycle;
+ 	u32 bt_wait_time;
++	int rssi_count;
+ 	struct ath_gen_timer *no_stomp_timer; /* Timer for no BT stomping */
+ 	struct ath_mci_profile mci;
+ };
+diff --git a/drivers/net/wireless/ath/ath9k/btcoex.h b/drivers/net/wireless/ath/ath9k/btcoex.h
+index a260fcb..94e9211 100644
+--- a/drivers/net/wireless/ath/ath9k/btcoex.h
++++ b/drivers/net/wireless/ath/ath9k/btcoex.h
+@@ -39,6 +39,9 @@
+ #define ATH_BTCOEX_RX_WAIT_TIME       100
+ #define ATH_BTCOEX_STOMP_FTP_THRESH   5
+ 
++#define ATH_BTCOEX_HT20_MAX_TXPOWER   0x14
++#define ATH_BTCOEX_HT40_MAX_TXPOWER   0x10
++
+ #define AR9300_NUM_BT_WEIGHTS   4
+ #define AR9300_NUM_WLAN_WEIGHTS 4
+ /* Defines the BT AR_BT_COEX_WGHT used */
+diff --git a/drivers/net/wireless/ath/ath9k/gpio.c b/drivers/net/wireless/ath/ath9k/gpio.c
+index 9e63a03..64dde1c 100644
+--- a/drivers/net/wireless/ath/ath9k/gpio.c
++++ b/drivers/net/wireless/ath/ath9k/gpio.c
+@@ -227,6 +227,8 @@ static void ath_btcoex_period_timer(unsigned long data)
+ 	}
+ 	spin_unlock_irqrestore(&sc->sc_pm_lock, flags);
+ 
++	ath9k_mci_update_rssi(sc);
++
+ 	ath9k_ps_wakeup(sc);
+ 
+ 	if (!(ah->caps.hw_caps & ATH9K_HW_CAP_MCI))
+diff --git a/drivers/net/wireless/ath/ath9k/main.c b/drivers/net/wireless/ath/ath9k/main.c
+index 515e184..578a723 100644
+--- a/drivers/net/wireless/ath/ath9k/main.c
++++ b/drivers/net/wireless/ath/ath9k/main.c
+@@ -293,6 +293,10 @@ static int ath_reset_internal(struct ath_softc *sc, struct ath9k_channel *hchan,
+ 		goto out;
+ 	}
+ 
++	if (ath9k_hw_mci_is_enabled(sc->sc_ah) &&
++	    (sc->hw->conf.flags & IEEE80211_CONF_OFFCHANNEL))
++		ath9k_mci_set_txpower(sc, true, false);
++
+ 	if (!ath_complete_reset(sc, true))
+ 		r = -EIO;
+ 
+diff --git a/drivers/net/wireless/ath/ath9k/mci.c b/drivers/net/wireless/ath/ath9k/mci.c
+index b37c8af..19dbac4 100644
+--- a/drivers/net/wireless/ath/ath9k/mci.c
++++ b/drivers/net/wireless/ath/ath9k/mci.c
+@@ -710,3 +710,62 @@ send_wlan_chan:
+ 	ar9003_mci_send_wlan_channels(ah);
+ 	ar9003_mci_state(ah, MCI_STATE_SEND_VERSION_QUERY);
+ }
++
++void ath9k_mci_set_txpower(struct ath_softc *sc, bool setchannel,
++			   bool concur_tx)
++{
++	struct ath_hw *ah = sc->sc_ah;
++	struct ath9k_hw_mci *mci_hw = &sc->sc_ah->btcoex_hw.mci;
++	bool old_concur_tx = mci_hw->concur_tx;
++
++	if (!(mci_hw->config & ATH_MCI_CONFIG_CONCUR_TX)) {
++		mci_hw->concur_tx = false;
++		return;
++	}
++
++	if (!IS_CHAN_2GHZ(ah->curchan))
++		return;
++
++	if (setchannel) {
++		struct ath9k_hw_cal_data *caldata = &sc->caldata;
++		if ((caldata->chanmode == CHANNEL_G_HT40PLUS) &&
++		    (ah->curchan->channel > caldata->channel) &&
++		    (ah->curchan->channel <= caldata->channel + 20))
++			return;
++		if ((caldata->chanmode == CHANNEL_G_HT40MINUS) &&
++		    (ah->curchan->channel < caldata->channel) &&
++		    (ah->curchan->channel >= caldata->channel - 20))
++			return;
++		mci_hw->concur_tx = false;
++	} else
++		mci_hw->concur_tx = concur_tx;
++
++	if (old_concur_tx != mci_hw->concur_tx)
++		ath9k_hw_set_txpowerlimit(ah, sc->config.txpowlimit, false);
++}
++
++void ath9k_mci_update_rssi(struct ath_softc *sc)
++{
++	struct ath_hw *ah = sc->sc_ah;
++	struct ath_btcoex *btcoex = &sc->btcoex;
++	struct ath9k_hw_mci *mci_hw = &sc->sc_ah->btcoex_hw.mci;
++
++	if (!(mci_hw->config & ATH_MCI_CONFIG_CONCUR_TX))
++		return;
++
++	if (ah->stats.avgbrssi >= 40) {
++		if (btcoex->rssi_count < 0)
++			btcoex->rssi_count = 0;
++		if (++btcoex->rssi_count >= ATH_MCI_CONCUR_TX_SWITCH) {
++			btcoex->rssi_count = 0;
++			ath9k_mci_set_txpower(sc, false, true);
++		}
++	} else {
++		if (btcoex->rssi_count > 0)
++			btcoex->rssi_count = 0;
++		if (--btcoex->rssi_count <= -ATH_MCI_CONCUR_TX_SWITCH) {
++			btcoex->rssi_count = 0;
++			ath9k_mci_set_txpower(sc, false, false);
++		}
++	}
++}
+diff --git a/drivers/net/wireless/ath/ath9k/mci.h b/drivers/net/wireless/ath/ath9k/mci.h
+index e85a0e9..e5f170a 100644
+--- a/drivers/net/wireless/ath/ath9k/mci.h
++++ b/drivers/net/wireless/ath/ath9k/mci.h
+@@ -35,6 +35,7 @@
+ #define ATH_MCI_INQUIRY_PRIO         62
+ #define ATH_MCI_HI_PRIO              60
+ #define ATH_MCI_NUM_BT_CHANNELS      79
++#define ATH_MCI_CONCUR_TX_SWITCH      5
+ 
+ #define MCI_GPM_SET_CHANNEL_BIT(_p_gpm, _bt_chan)			  \
+ 	do {								  \
+@@ -151,10 +152,13 @@ void ath_mci_flush_profile(struct ath_mci_profile *mci);
+ int ath_mci_setup(struct ath_softc *sc);
+ void ath_mci_cleanup(struct ath_softc *sc);
+ void ath_mci_intr(struct ath_softc *sc);
++void ath9k_mci_update_rssi(struct ath_softc *sc);
+ 
+ #ifdef CONFIG_ATH9K_BTCOEX_SUPPORT
+ void ath_mci_enable(struct ath_softc *sc);
+ void ath9k_mci_update_wlan_channels(struct ath_softc *sc, bool allow_all);
++void ath9k_mci_set_txpower(struct ath_softc *sc, bool setchannel,
++			   bool concur_tx);
+ #else
+ static inline void ath_mci_enable(struct ath_softc *sc)
+ {
+@@ -163,6 +167,10 @@ static inline void ath9k_mci_update_wlan_channels(struct ath_softc *sc,
+ 						  bool allow_all)
+ {
+ }
++static inline void ath9k_mci_set_txpower(struct ath_softc *sc, bool setchannel,
++					 bool concur_tx)
++{
++}
+ #endif /* CONFIG_ATH9K_BTCOEX_SUPPORT */
+ 
+ #endif /* MCI_H*/
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0100-ath9k_hw-Enable-OSLA-hw-fix-for-AR9565.patch b/linux-next-cherry-picks/0100-ath9k_hw-Enable-OSLA-hw-fix-for-AR9565.patch
new file mode 100644
index 0000000..3747721
--- /dev/null
+++ b/linux-next-cherry-picks/0100-ath9k_hw-Enable-OSLA-hw-fix-for-AR9565.patch
@@ -0,0 +1,42 @@
+From 4c6231a408c1fbec714f82b4742d19f85130ba97 Mon Sep 17 00:00:00 2001
+From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Date: Mon, 15 Oct 2012 15:29:45 +0530
+Subject: [PATCH 100/110] ath9k_hw: Enable OSLA hw fix for AR9565
+
+Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/ar9003_mci.c |    3 +++
+ drivers/net/wireless/ath/ath9k/reg.h        |    4 ++++
+ 2 files changed, 7 insertions(+), 0 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/ar9003_mci.c b/drivers/net/wireless/ath/ath9k/ar9003_mci.c
+index 9aa8704..9fa6d22 100644
+--- a/drivers/net/wireless/ath/ath9k/ar9003_mci.c
++++ b/drivers/net/wireless/ath/ath9k/ar9003_mci.c
+@@ -799,6 +799,9 @@ static void ar9003_mci_osla_setup(struct ath_hw *ah, bool enable)
+ 	REG_RMW_FIELD(ah, AR_MCI_SCHD_TABLE_2,
+ 		      AR_MCI_SCHD_TABLE_2_MEM_BASED, 1);
+ 
++	if (AR_SREV_9565(ah))
++		REG_RMW_FIELD(ah, AR_MCI_MISC, AR_MCI_MISC_HW_FIX_EN, 1);
++
+ 	if (!(mci->config & ATH_MCI_CONFIG_DISABLE_AGGR_THRESH)) {
+ 		thresh = MS(mci->config, ATH_MCI_CONFIG_AGGR_THRESH);
+ 		REG_RMW_FIELD(ah, AR_BTCOEX_CTRL,
+diff --git a/drivers/net/wireless/ath/ath9k/reg.h b/drivers/net/wireless/ath/ath9k/reg.h
+index 4e6760f..c7a9ea7 100644
+--- a/drivers/net/wireless/ath/ath9k/reg.h
++++ b/drivers/net/wireless/ath/ath9k/reg.h
+@@ -2360,4 +2360,8 @@ enum {
+ #define AR_GLB_SWREG_DISCONT_MODE         0x2002c
+ #define AR_GLB_SWREG_DISCONT_EN_BT_WLAN   0x3
+ 
++#define AR_MCI_MISC                    0x1a74
++#define AR_MCI_MISC_HW_FIX_EN          0x00000001
++#define AR_MCI_MISC_HW_FIX_EN_S        0
++
+ #endif
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0101-ath9k_hw-Fix-selfgen-chainmask-for-9565.patch b/linux-next-cherry-picks/0101-ath9k_hw-Fix-selfgen-chainmask-for-9565.patch
new file mode 100644
index 0000000..332f2c0
--- /dev/null
+++ b/linux-next-cherry-picks/0101-ath9k_hw-Fix-selfgen-chainmask-for-9565.patch
@@ -0,0 +1,34 @@
+From 7d47884f306afd1d0215133685f451aaafe3ca7a Mon Sep 17 00:00:00 2001
+From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Date: Mon, 15 Oct 2012 15:29:46 +0530
+Subject: [PATCH 101/110] ath9k_hw: Fix selfgen chainmask for 9565
+
+Self generated MCI messages is configured to use chain 1. As
+ar9565 is 1x1 solution, It can not use Chain 1. Hence fix
+Chain 1 for ar9462 alone. Not doing so, could affect WLAN
+connectivity in ar9565 as LNA sharing is not informed by BT.
+
+Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/ar9003_mci.c |    4 +++-
+ 1 files changed, 3 insertions(+), 1 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/ar9003_mci.c b/drivers/net/wireless/ath/ath9k/ar9003_mci.c
+index 9fa6d22..6fbd376 100644
+--- a/drivers/net/wireless/ath/ath9k/ar9003_mci.c
++++ b/drivers/net/wireless/ath/ath9k/ar9003_mci.c
+@@ -1043,7 +1043,9 @@ void ar9003_mci_2g5g_switch(struct ath_hw *ah, bool force)
+ 
+ 		if (!(mci->config & ATH_MCI_CONFIG_DISABLE_OSLA))
+ 			ar9003_mci_osla_setup(ah, true);
+-		REG_WRITE(ah, AR_SELFGEN_MASK, 0x02);
++
++		if (AR_SREV_9462(ah))
++			REG_WRITE(ah, AR_SELFGEN_MASK, 0x02);
+ 	} else {
+ 		ar9003_mci_send_lna_take(ah, true);
+ 		udelay(5);
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0102-ath9k-Set-appropriate-bit-for-AR9565-in-btc-control-.patch b/linux-next-cherry-picks/0102-ath9k-Set-appropriate-bit-for-AR9565-in-btc-control-.patch
new file mode 100644
index 0000000..ef41528
--- /dev/null
+++ b/linux-next-cherry-picks/0102-ath9k-Set-appropriate-bit-for-AR9565-in-btc-control-.patch
@@ -0,0 +1,39 @@
+From d9575dad59de382dd1f1ddcaa6de38d9844691fe Mon Sep 17 00:00:00 2001
+From: Bala Shanmugam <bkamatch@xxxxxxxxxxxxxxxx>
+Date: Mon, 15 Oct 2012 15:29:47 +0530
+Subject: [PATCH 102/110] ath9k: Set appropriate bit for AR9565 in btc control register
+
+Signed-off-by: Bala Shanmugam <bkamatch@xxxxxxxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/ar9003_mci.c |   11 +++++++++--
+ 1 files changed, 9 insertions(+), 2 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/ar9003_mci.c b/drivers/net/wireless/ath/ath9k/ar9003_mci.c
+index 6fbd376..b2b9941 100644
+--- a/drivers/net/wireless/ath/ath9k/ar9003_mci.c
++++ b/drivers/net/wireless/ath/ath9k/ar9003_mci.c
+@@ -850,11 +850,18 @@ int ar9003_mci_reset(struct ath_hw *ah, bool en_int, bool is_2g,
+ 		 SM(1, AR_BTCOEX_CTRL_WBTIMER_EN) |
+ 		 SM(1, AR_BTCOEX_CTRL_PA_SHARED) |
+ 		 SM(1, AR_BTCOEX_CTRL_LNA_SHARED) |
+-		 SM(2, AR_BTCOEX_CTRL_NUM_ANTENNAS) |
+-		 SM(3, AR_BTCOEX_CTRL_RX_CHAIN_MASK) |
+ 		 SM(0, AR_BTCOEX_CTRL_1_CHAIN_ACK) |
+ 		 SM(0, AR_BTCOEX_CTRL_1_CHAIN_BCN) |
+ 		 SM(0, AR_BTCOEX_CTRL_ONE_STEP_LOOK_AHEAD_EN);
++	if (AR_SREV_9565(ah)) {
++		regval |= SM(1, AR_BTCOEX_CTRL_NUM_ANTENNAS) |
++			  SM(1, AR_BTCOEX_CTRL_RX_CHAIN_MASK);
++		REG_RMW_FIELD(ah, AR_BTCOEX_CTRL2,
++			      AR_BTCOEX_CTRL2_TX_CHAIN_MASK, 0x1);
++	} else {
++		regval |= SM(2, AR_BTCOEX_CTRL_NUM_ANTENNAS) |
++			  SM(3, AR_BTCOEX_CTRL_RX_CHAIN_MASK);
++	}
+ 
+ 	REG_WRITE(ah, AR_BTCOEX_CTRL, regval);
+ 
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0103-ath9k-turn-off-RXIQ-calibration-while-re-calibrating.patch b/linux-next-cherry-picks/0103-ath9k-turn-off-RXIQ-calibration-while-re-calibrating.patch
new file mode 100644
index 0000000..927379b
--- /dev/null
+++ b/linux-next-cherry-picks/0103-ath9k-turn-off-RXIQ-calibration-while-re-calibrating.patch
@@ -0,0 +1,54 @@
+From b55f6bb7c3f890c3d537516efa8746a4784c058d Mon Sep 17 00:00:00 2001
+From: Bala Shanmugam <bkamatch@xxxxxxxxxxxxxxxx>
+Date: Mon, 15 Oct 2012 15:29:48 +0530
+Subject: [PATCH 103/110] ath9k: turn off RXIQ calibration while re-calibrating radio
+
+TXIQ and RXIQ share the same data path to upload the measurement
+result, we should turn off RXIQ calibration while re-calibrating radio
+
+Signed-off-by: Bala Shanmugam <bkamatch@xxxxxxxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/ar9003_mci.c |    6 ++++++
+ drivers/net/wireless/ath/ath9k/ar9003_phy.h |    1 +
+ 2 files changed, 7 insertions(+), 0 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/ar9003_mci.c b/drivers/net/wireless/ath/ath9k/ar9003_mci.c
+index b2b9941..c46d8f1 100644
+--- a/drivers/net/wireless/ath/ath9k/ar9003_mci.c
++++ b/drivers/net/wireless/ath/ath9k/ar9003_mci.c
+@@ -750,6 +750,9 @@ int ar9003_mci_end_reset(struct ath_hw *ah, struct ath9k_channel *chan,
+ 
+ 	mci_hw->bt_state = MCI_BT_AWAKE;
+ 
++	REG_CLR_BIT(ah, AR_PHY_TIMING4,
++		    1 << AR_PHY_TIMING_CONTROL4_DO_GAIN_DC_IQ_CAL_SHIFT);
++
+ 	if (caldata) {
+ 		caldata->done_txiqcal_once = false;
+ 		caldata->done_txclcal_once = false;
+@@ -759,6 +762,9 @@ int ar9003_mci_end_reset(struct ath_hw *ah, struct ath9k_channel *chan,
+ 	if (!ath9k_hw_init_cal(ah, chan))
+ 		return -EIO;
+ 
++	REG_SET_BIT(ah, AR_PHY_TIMING4,
++		    1 << AR_PHY_TIMING_CONTROL4_DO_GAIN_DC_IQ_CAL_SHIFT);
++
+ exit:
+ 	ar9003_mci_enable_interrupt(ah);
+ 	return 0;
+diff --git a/drivers/net/wireless/ath/ath9k/ar9003_phy.h b/drivers/net/wireless/ath/ath9k/ar9003_phy.h
+index 9a48e3d..8f58523 100644
+--- a/drivers/net/wireless/ath/ath9k/ar9003_phy.h
++++ b/drivers/net/wireless/ath/ath9k/ar9003_phy.h
+@@ -32,6 +32,7 @@
+ #define AR_PHY_SPUR_REG     (AR_CHAN_BASE + 0x1c)
+ #define AR_PHY_RX_IQCAL_CORR_B0    (AR_CHAN_BASE + 0xdc)
+ #define AR_PHY_TX_IQCAL_CONTROL_3  (AR_CHAN_BASE + 0xb0)
++#define AR_PHY_TIMING_CONTROL4_DO_GAIN_DC_IQ_CAL_SHIFT 16
+ 
+ #define AR_PHY_TIMING11_SPUR_FREQ_SD    0x3FF00000
+ #define AR_PHY_TIMING11_SPUR_FREQ_SD_S  20
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0104-ath9k_hw-Disable-MCI-stat-counter-by-default-for-AR9.patch b/linux-next-cherry-picks/0104-ath9k_hw-Disable-MCI-stat-counter-by-default-for-AR9.patch
new file mode 100644
index 0000000..64966f0
--- /dev/null
+++ b/linux-next-cherry-picks/0104-ath9k_hw-Disable-MCI-stat-counter-by-default-for-AR9.patch
@@ -0,0 +1,42 @@
+From e9f9fd8cdc5fcb718e2ce778cb5e0eea27e2fdc8 Mon Sep 17 00:00:00 2001
+From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Date: Mon, 15 Oct 2012 15:29:49 +0530
+Subject: [PATCH 104/110] ath9k_hw: Disable MCI stat counter by default for AR9565
+
+Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/ar9003_mci.c |    3 +++
+ drivers/net/wireless/ath/ath9k/reg.h        |    3 +++
+ 2 files changed, 6 insertions(+), 0 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/ar9003_mci.c b/drivers/net/wireless/ath/ath9k/ar9003_mci.c
+index c46d8f1..87d9c34 100644
+--- a/drivers/net/wireless/ath/ath9k/ar9003_mci.c
++++ b/drivers/net/wireless/ath/ath9k/ar9003_mci.c
+@@ -938,6 +938,9 @@ int ar9003_mci_reset(struct ath_hw *ah, bool en_int, bool is_2g,
+ 	mci->ready = true;
+ 	ar9003_mci_prep_interface(ah);
+ 
++	if (AR_SREV_9565(ah))
++		REG_RMW_FIELD(ah, AR_MCI_DBG_CNT_CTRL,
++			      AR_MCI_DBG_CNT_CTRL_ENABLE, 0);
+ 	if (en_int)
+ 		ar9003_mci_enable_interrupt(ah);
+ 
+diff --git a/drivers/net/wireless/ath/ath9k/reg.h b/drivers/net/wireless/ath/ath9k/reg.h
+index c7a9ea7..8f40dba 100644
+--- a/drivers/net/wireless/ath/ath9k/reg.h
++++ b/drivers/net/wireless/ath/ath9k/reg.h
+@@ -2363,5 +2363,8 @@ enum {
+ #define AR_MCI_MISC                    0x1a74
+ #define AR_MCI_MISC_HW_FIX_EN          0x00000001
+ #define AR_MCI_MISC_HW_FIX_EN_S        0
++#define AR_MCI_DBG_CNT_CTRL            0x1a78
++#define AR_MCI_DBG_CNT_CTRL_ENABLE     0x00000001
++#define AR_MCI_DBG_CNT_CTRL_ENABLE_S   0
+ 
+ #endif
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0105-ath9k_hw-Fix-frequent-BT-rx-recovery.patch b/linux-next-cherry-picks/0105-ath9k_hw-Fix-frequent-BT-rx-recovery.patch
new file mode 100644
index 0000000..29ff7eb
--- /dev/null
+++ b/linux-next-cherry-picks/0105-ath9k_hw-Fix-frequent-BT-rx-recovery.patch
@@ -0,0 +1,76 @@
+From 2097fdd7ebdb1674aaf7343b7a1d6cc2758c1dff Mon Sep 17 00:00:00 2001
+From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Date: Mon, 15 Oct 2012 15:29:50 +0530
+Subject: [PATCH 105/110] ath9k_hw: Fix frequent BT rx recovery
+
+While resuming from S3, BT host issues HCI reset command and it
+causes BT firmware to busy with security key calculation. At this
+movement, WLAN detects MCI hardware error of MCI_CONT_INFO_TIMEOUT
+and then it starts the recovery sequence repeatedly. Too many
+recovery sequences would exhaust the BT kernel message pool. This
+patch imposes a duration between consecutive BT recovery procedure.
+Thus it solves BT firmware panic issue reported in AR9565.
+
+Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/ar9003_mci.c |   10 +++++++++-
+ drivers/net/wireless/ath/ath9k/ar9003_mci.h |    1 +
+ drivers/net/wireless/ath/ath9k/btcoex.h     |    1 +
+ 3 files changed, 11 insertions(+), 1 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/ar9003_mci.c b/drivers/net/wireless/ath/ath9k/ar9003_mci.c
+index 87d9c34..b04fa46 100644
+--- a/drivers/net/wireless/ath/ath9k/ar9003_mci.c
++++ b/drivers/net/wireless/ath/ath9k/ar9003_mci.c
+@@ -1203,7 +1203,7 @@ EXPORT_SYMBOL(ar9003_mci_cleanup);
+ u32 ar9003_mci_state(struct ath_hw *ah, u32 state_type)
+ {
+ 	struct ath9k_hw_mci *mci = &ah->btcoex_hw.mci;
+-	u32 value = 0;
++	u32 value = 0, tsf;
+ 	u8 query_type;
+ 
+ 	switch (state_type) {
+@@ -1261,6 +1261,14 @@ u32 ar9003_mci_state(struct ath_hw *ah, u32 state_type)
+ 		ar9003_mci_send_coex_bt_status_query(ah, true, query_type);
+ 		break;
+ 	case MCI_STATE_RECOVER_RX:
++		tsf = ath9k_hw_gettsf32(ah);
++		if ((tsf - mci->last_recovery) <= MCI_RECOVERY_DUR_TSF) {
++			ath_dbg(ath9k_hw_common(ah), MCI,
++				"(MCI) ignore Rx recovery\n");
++			break;
++		}
++		ath_dbg(ath9k_hw_common(ah), MCI, "(MCI) RECOVER RX\n");
++		mci->last_recovery = tsf;
+ 		ar9003_mci_prep_interface(ah);
+ 		mci->query_bt = true;
+ 		mci->need_flush_btinfo = true;
+diff --git a/drivers/net/wireless/ath/ath9k/ar9003_mci.h b/drivers/net/wireless/ath/ath9k/ar9003_mci.h
+index 0910310..3e51f54 100644
+--- a/drivers/net/wireless/ath/ath9k/ar9003_mci.h
++++ b/drivers/net/wireless/ath/ath9k/ar9003_mci.h
+@@ -18,6 +18,7 @@
+ #define AR9003_MCI_H
+ 
+ #define MCI_FLAG_DISABLE_TIMESTAMP      0x00000001      /* Disable time stamp */
++#define MCI_RECOVERY_DUR_TSF		(100 * 1000)    /* 100 ms */
+ 
+ /* Default remote BT device MCI COEX version */
+ #define MCI_GPM_COEX_MAJOR_VERSION_DEFAULT  3
+diff --git a/drivers/net/wireless/ath/ath9k/btcoex.h b/drivers/net/wireless/ath/ath9k/btcoex.h
+index 94e9211..2f84ab2 100644
+--- a/drivers/net/wireless/ath/ath9k/btcoex.h
++++ b/drivers/net/wireless/ath/ath9k/btcoex.h
+@@ -88,6 +88,7 @@ struct ath9k_hw_mci {
+ 	u8 bt_state;
+ 	u8 stomp_ftp;
+ 	bool concur_tx;
++	u32 last_recovery;
+ };
+ 
+ struct ath_btcoex_hw {
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0106-ath9k_hw-Fix-max-rx-rate-drop-for-AR9565.patch b/linux-next-cherry-picks/0106-ath9k_hw-Fix-max-rx-rate-drop-for-AR9565.patch
new file mode 100644
index 0000000..cc8949e
--- /dev/null
+++ b/linux-next-cherry-picks/0106-ath9k_hw-Fix-max-rx-rate-drop-for-AR9565.patch
@@ -0,0 +1,34 @@
+From 6f37ff96d3bd2a53e68131a7c10ced933815b390 Mon Sep 17 00:00:00 2001
+From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Date: Mon, 15 Oct 2012 15:29:51 +0530
+Subject: [PATCH 106/110] ath9k_hw: Fix max rx rate drop for AR9565
+
+Whenever i_coff of IQ calibration is too high, AR9565 drops max
+rx rate to MCS4. Skipping IQ update at this time can avoid this
+problem for AR9565.
+
+Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/ar9003_calib.c |    5 +++++
+ 1 files changed, 5 insertions(+), 0 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/ar9003_calib.c b/drivers/net/wireless/ath/ath9k/ar9003_calib.c
+index 84b558d..162401f 100644
+--- a/drivers/net/wireless/ath/ath9k/ar9003_calib.c
++++ b/drivers/net/wireless/ath/ath9k/ar9003_calib.c
+@@ -276,6 +276,11 @@ static void ar9003_hw_iqcalibrate(struct ath_hw *ah, u8 numChains)
+ 				offset_array[i],
+ 				REG_READ(ah, offset_array[i]));
+ 
++			if (AR_SREV_9565(ah) &&
++			    (iCoff == 63 || qCoff == 63 ||
++			     iCoff == -63 || qCoff == -63))
++				return;
++
+ 			REG_RMW_FIELD(ah, offset_array[i],
+ 				      AR_PHY_RX_IQCAL_CORR_IQCORR_Q_I_COFF,
+ 				      iCoff);
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0107-ath9k_hw-Configure-new-switch-table-for-AR9565-BTCOE.patch b/linux-next-cherry-picks/0107-ath9k_hw-Configure-new-switch-table-for-AR9565-BTCOE.patch
new file mode 100644
index 0000000..a1057ed
--- /dev/null
+++ b/linux-next-cherry-picks/0107-ath9k_hw-Configure-new-switch-table-for-AR9565-BTCOE.patch
@@ -0,0 +1,57 @@
+From 506ed95c27b9e4db521df8433860da78b4747cd8 Mon Sep 17 00:00:00 2001
+From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Date: Mon, 15 Oct 2012 15:29:52 +0530
+Subject: [PATCH 107/110] ath9k_hw: Configure new switch table for AR9565 BTCOEX
+
+Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/ar9003_eeprom.c |    2 +-
+ drivers/net/wireless/ath/ath9k/reg.h           |    4 ----
+ drivers/net/wireless/ath/ath9k/wow.c           |    2 +-
+ 3 files changed, 2 insertions(+), 6 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/ar9003_eeprom.c b/drivers/net/wireless/ath/ath9k/ar9003_eeprom.c
+index d313998..c86cb640 100644
+--- a/drivers/net/wireless/ath/ath9k/ar9003_eeprom.c
++++ b/drivers/net/wireless/ath/ath9k/ar9003_eeprom.c
+@@ -3601,7 +3601,7 @@ static void ar9003_hw_ant_ctrl_apply(struct ath_hw *ah, bool is2ghz)
+ 	 *   7:4 R/W  SWITCH_TABLE_COM_SPDT_WLAN_IDLE
+ 	 * SWITCH_TABLE_COM_SPDT_WLAN_IDLE
+ 	 */
+-	if (AR_SREV_9462_20_OR_LATER(ah)) {
++	if (AR_SREV_9462_20(ah) || AR_SREV_9565(ah)) {
+ 		value = ar9003_switch_com_spdt_get(ah, is2ghz);
+ 		REG_RMW_FIELD(ah, AR_PHY_GLB_CONTROL,
+ 				AR_SWITCH_TABLE_COM_SPDT_ALL, value);
+diff --git a/drivers/net/wireless/ath/ath9k/reg.h b/drivers/net/wireless/ath/ath9k/reg.h
+index 8f40dba..e9dec13 100644
+--- a/drivers/net/wireless/ath/ath9k/reg.h
++++ b/drivers/net/wireless/ath/ath9k/reg.h
+@@ -907,10 +907,6 @@
+ 	(((_ah)->hw_version.macVersion == AR_SREV_VERSION_9462) && \
+ 	((_ah)->hw_version.macRev == AR_SREV_REVISION_9462_20))
+ 
+-#define AR_SREV_9462_20_OR_LATER(_ah) \
+-	(((_ah)->hw_version.macVersion == AR_SREV_VERSION_9462) && \
+-	((_ah)->hw_version.macRev >= AR_SREV_REVISION_9462_20))
+-
+ #define AR_SREV_9565(_ah) \
+ 	(((_ah)->hw_version.macVersion == AR_SREV_VERSION_9565))
+ 
+diff --git a/drivers/net/wireless/ath/ath9k/wow.c b/drivers/net/wireless/ath/ath9k/wow.c
+index a483d51..9f85630 100644
+--- a/drivers/net/wireless/ath/ath9k/wow.c
++++ b/drivers/net/wireless/ath/ath9k/wow.c
+@@ -118,7 +118,7 @@ static void ath9k_wow_create_keep_alive_pattern(struct ath_hw *ah)
+ 		       (ap_mac_addr[1] << 8) | (ap_mac_addr[0]);
+ 	data_word[5] = (ap_mac_addr[5] << 8) | (ap_mac_addr[4]);
+ 
+-	if (AR_SREV_9462_20_OR_LATER(ah)) {
++	if (AR_SREV_9462_20(ah)) {
+ 		/* AR9462 2.0 has an extra descriptor word (time based
+ 		 * discard) compared to other chips */
+ 		REG_WRITE(ah, (AR_WOW_KA_DESC_WORD2 + (12 * 4)), 0);
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0108-ath9k_hw-Set-default-MCI-config-for-AR9565.patch b/linux-next-cherry-picks/0108-ath9k_hw-Set-default-MCI-config-for-AR9565.patch
new file mode 100644
index 0000000..4f72260
--- /dev/null
+++ b/linux-next-cherry-picks/0108-ath9k_hw-Set-default-MCI-config-for-AR9565.patch
@@ -0,0 +1,27 @@
+From 3c5c9d04f628135ff57eda5068c9d9513f0a94bf Mon Sep 17 00:00:00 2001
+From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Date: Mon, 15 Oct 2012 15:29:53 +0530
+Subject: [PATCH 108/110] ath9k_hw: Set default MCI config for AR9565
+
+Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/btcoex.c |    2 +-
+ 1 files changed, 1 insertions(+), 1 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/btcoex.c b/drivers/net/wireless/ath/ath9k/btcoex.c
+index 05d9be5..c90e9bc 100644
+--- a/drivers/net/wireless/ath/ath9k/btcoex.c
++++ b/drivers/net/wireless/ath/ath9k/btcoex.c
+@@ -195,7 +195,7 @@ void ath9k_hw_btcoex_init_mci(struct ath_hw *ah)
+ 	ah->btcoex_hw.mci.need_flush_btinfo = false;
+ 	ah->btcoex_hw.mci.wlan_cal_seq = 0;
+ 	ah->btcoex_hw.mci.wlan_cal_done = 0;
+-	ah->btcoex_hw.mci.config = 0x2201;
++	ah->btcoex_hw.mci.config = (AR_SREV_9462(ah)) ? 0x2201 : 0xa4c1;
+ }
+ EXPORT_SYMBOL(ath9k_hw_btcoex_init_mci);
+ 
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0109-ath9k-adjust-duty-cycle-for-FTP-profile-for-AR9565.patch b/linux-next-cherry-picks/0109-ath9k-adjust-duty-cycle-for-FTP-profile-for-AR9565.patch
new file mode 100644
index 0000000..69d98f5
--- /dev/null
+++ b/linux-next-cherry-picks/0109-ath9k-adjust-duty-cycle-for-FTP-profile-for-AR9565.patch
@@ -0,0 +1,27 @@
+From f9401b1e74f33d40d97364be5244b715e8cee6ed Mon Sep 17 00:00:00 2001
+From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Date: Mon, 15 Oct 2012 15:29:54 +0530
+Subject: [PATCH 109/110] ath9k: adjust duty cycle for FTP profile for AR9565
+
+Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/mci.c |    2 +-
+ 1 files changed, 1 insertions(+), 1 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/mci.c b/drivers/net/wireless/ath/ath9k/mci.c
+index 19dbac4..0dd2cbb 100644
+--- a/drivers/net/wireless/ath/ath9k/mci.c
++++ b/drivers/net/wireless/ath/ath9k/mci.c
+@@ -157,7 +157,7 @@ static void ath_mci_update_scheme(struct ath_softc *sc)
+ 			 * For single PAN/FTP profile, allocate 35% for BT
+ 			 * to improve WLAN throughput.
+ 			 */
+-			btcoex->duty_cycle = 35;
++			btcoex->duty_cycle = AR_SREV_9565(sc->sc_ah) ? 40 : 35;
+ 			btcoex->btcoex_period = 53;
+ 			ath_dbg(common, MCI,
+ 				"Single PAN/FTP bt period %d ms dutycycle %d\n",
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0110-ath9k-Add-new-BT-profile-info-A2DP_Voice.patch b/linux-next-cherry-picks/0110-ath9k-Add-new-BT-profile-info-A2DP_Voice.patch
new file mode 100644
index 0000000..24e5f0b
--- /dev/null
+++ b/linux-next-cherry-picks/0110-ath9k-Add-new-BT-profile-info-A2DP_Voice.patch
@@ -0,0 +1,52 @@
+From 7bf7a71e0f7ad69358d01f2a7ba7faa9428db90b Mon Sep 17 00:00:00 2001
+From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Date: Mon, 15 Oct 2012 15:29:55 +0530
+Subject: [PATCH 110/110] ath9k: Add new BT profile info A2DP_Voice
+
+When the BT connection is initiated by headset, it's possible that headset
+requests to make one A2DP and one Voice connection over the same link.
+BT firmware will send a new profile A2DP_Voice in this case. So WLAN
+has to take care of this new profile for tuning BTCOEX parameters.
+
+Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/ar9003_mci.h |    1 +
+ drivers/net/wireless/ath/ath9k/mci.h        |    2 ++
+ 2 files changed, 3 insertions(+), 0 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/ar9003_mci.h b/drivers/net/wireless/ath/ath9k/ar9003_mci.h
+index 3e51f54..66d7ab9 100644
+--- a/drivers/net/wireless/ath/ath9k/ar9003_mci.h
++++ b/drivers/net/wireless/ath/ath9k/ar9003_mci.h
+@@ -126,6 +126,7 @@ enum ath_mci_gpm_coex_profile_type {
+ 	MCI_GPM_COEX_PROFILE_HID,
+ 	MCI_GPM_COEX_PROFILE_BNEP,
+ 	MCI_GPM_COEX_PROFILE_VOICE,
++	MCI_GPM_COEX_PROFILE_A2DPVO,
+ 	MCI_GPM_COEX_PROFILE_MAX
+ };
+ 
+diff --git a/drivers/net/wireless/ath/ath9k/mci.h b/drivers/net/wireless/ath/ath9k/mci.h
+index e5f170a..0695883 100644
+--- a/drivers/net/wireless/ath/ath9k/mci.h
++++ b/drivers/net/wireless/ath/ath9k/mci.h
+@@ -70,6 +70,7 @@
+ 			_mci->num_pan++;	 \
+ 			break;			 \
+ 		case MCI_GPM_COEX_PROFILE_VOICE: \
++		case MCI_GPM_COEX_PROFILE_A2DPVO:\
+ 			_mci->num_sco++;	 \
+ 			break;			 \
+ 		default:			 \
+@@ -94,6 +95,7 @@
+ 			_mci->num_pan--;	 \
+ 			break;			 \
+ 		case MCI_GPM_COEX_PROFILE_VOICE: \
++		case MCI_GPM_COEX_PROFILE_A2DPVO:\
+ 			_mci->num_sco--;	 \
+ 			break;			 \
+ 		default:			 \
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0111-cfg80211-Disallow-HT-WEP-in-IBSS-mode.patch b/linux-next-cherry-picks/0111-cfg80211-Disallow-HT-WEP-in-IBSS-mode.patch
new file mode 100644
index 0000000..e4a39e9
--- /dev/null
+++ b/linux-next-cherry-picks/0111-cfg80211-Disallow-HT-WEP-in-IBSS-mode.patch
@@ -0,0 +1,63 @@
+From 19888b7ee52ffee74a874ad622f44ed5f9706e51 Mon Sep 17 00:00:00 2001
+From: Sujith Manoharan <c_manoha@xxxxxxxxxxxxxxxx>
+Date: Mon, 15 Oct 2012 16:43:41 +0530
+Subject: [PATCH] cfg80211: Disallow HT/WEP in IBSS mode
+
+Signed-off-by: Sujith Manoharan <c_manoha@xxxxxxxxxxxxxxxx>
+---
+ net/wireless/nl80211.c | 20 +++++++++++++++++---
+ 1 file changed, 17 insertions(+), 3 deletions(-)
+
+--- a/net/wireless/nl80211.c
++++ b/net/wireless/nl80211.c
+@@ -690,7 +690,7 @@ static int nl80211_parse_key(struct genl
+ 
+ static struct cfg80211_cached_keys *
+ nl80211_parse_connkeys(struct cfg80211_registered_device *rdev,
+-		       struct nlattr *keys)
++		       struct nlattr *keys, bool *no_ht)
+ {
+ 	struct key_parse parse;
+ 	struct nlattr *key;
+@@ -733,6 +733,12 @@ nl80211_parse_connkeys(struct cfg80211_r
+ 		result->params[parse.idx].key_len = parse.p.key_len;
+ 		result->params[parse.idx].key = result->data[parse.idx];
+ 		memcpy(result->data[parse.idx], parse.p.key, parse.p.key_len);
++
++		if (result->params[parse.idx].cipher == WLAN_CIPHER_SUITE_WEP40 ||
++		    result->params[parse.idx].cipher == WLAN_CIPHER_SUITE_WEP104) {
++			if (no_ht)
++				*no_ht = true;
++		}
+ 	}
+ 
+ 	return result;
+@@ -5318,10 +5324,18 @@ static int nl80211_join_ibss(struct sk_b
+ 		return -EINVAL;
+ 
+ 	if (ibss.privacy && info->attrs[NL80211_ATTR_KEYS]) {
++		bool no_ht = false;
++
+ 		connkeys = nl80211_parse_connkeys(rdev,
+-					info->attrs[NL80211_ATTR_KEYS]);
++					  info->attrs[NL80211_ATTR_KEYS],
++					  &no_ht);
+ 		if (IS_ERR(connkeys))
+ 			return PTR_ERR(connkeys);
++
++		if ((ibss.channel_type != NL80211_CHAN_NO_HT) && no_ht) {
++			kfree(connkeys);
++			return -EINVAL;
++		}
+ 	}
+ 
+ 	ibss.control_port =
+@@ -5621,7 +5635,7 @@ static int nl80211_connect(struct sk_buf
+ 
+ 	if (connect.privacy && info->attrs[NL80211_ATTR_KEYS]) {
+ 		connkeys = nl80211_parse_connkeys(rdev,
+-					info->attrs[NL80211_ATTR_KEYS]);
++					  info->attrs[NL80211_ATTR_KEYS], NULL);
+ 		if (IS_ERR(connkeys))
+ 			return PTR_ERR(connkeys);
+ 	}
diff --git a/linux-next-cherry-picks/0115-ath9k_hw-Enable-hw-PLL-power-save-for-AR9565.patch b/linux-next-cherry-picks/0115-ath9k_hw-Enable-hw-PLL-power-save-for-AR9565.patch
new file mode 100644
index 0000000..823ead5
--- /dev/null
+++ b/linux-next-cherry-picks/0115-ath9k_hw-Enable-hw-PLL-power-save-for-AR9565.patch
@@ -0,0 +1,49 @@
+From 844648423dcf33fed96a4eb65f783f867efbe267 Mon Sep 17 00:00:00 2001
+From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Date: Thu, 25 Oct 2012 17:16:51 +0530
+Subject: [PATCH 115/118] ath9k_hw: Enable hw PLL power save for AR9565
+
+This reduced the power consumption to half in full and network sleep.
+
+Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/ar9003_hw.c         |    4 ++--
+ .../net/wireless/ath/ath9k/ar9565_1p0_initvals.h   |    4 ++--
+ 2 files changed, 4 insertions(+), 4 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/ar9003_hw.c b/drivers/net/wireless/ath/ath9k/ar9003_hw.c
+index 0a6b7a3..0693cd9 100644
+--- a/drivers/net/wireless/ath/ath9k/ar9003_hw.c
++++ b/drivers/net/wireless/ath/ath9k/ar9003_hw.c
+@@ -328,9 +328,9 @@ static void ar9003_hw_init_mode_regs(struct ath_hw *ah)
+ 			       ar9565_1p0_Modes_lowest_ob_db_tx_gain_table);
+ 
+ 		INIT_INI_ARRAY(&ah->iniPcieSerdes,
+-			       ar9565_1p0_pciephy_pll_on_clkreq_disable_L1);
++			       ar9565_1p0_pciephy_clkreq_disable_L1);
+ 		INIT_INI_ARRAY(&ah->iniPcieSerdesLowPower,
+-			       ar9565_1p0_pciephy_pll_on_clkreq_disable_L1);
++			       ar9565_1p0_pciephy_clkreq_disable_L1);
+ 
+ 		INIT_INI_ARRAY(&ah->iniModesFastClock,
+ 				ar9565_1p0_modes_fast_clock);
+diff --git a/drivers/net/wireless/ath/ath9k/ar9565_1p0_initvals.h b/drivers/net/wireless/ath/ath9k/ar9565_1p0_initvals.h
+index 843e79f..0c2ac0c 100644
+--- a/drivers/net/wireless/ath/ath9k/ar9565_1p0_initvals.h
++++ b/drivers/net/wireless/ath/ath9k/ar9565_1p0_initvals.h
+@@ -768,9 +768,9 @@ static const u32 ar9565_1p0_Modes_lowest_ob_db_tx_gain_table[][5] = {
+ 	{0x00016054, 0x00000000, 0x00000000, 0x00000000, 0x00000000},
+ };
+ 
+-static const u32 ar9565_1p0_pciephy_pll_on_clkreq_disable_L1[][2] = {
++static const u32 ar9565_1p0_pciephy_clkreq_disable_L1[][2] = {
+ 	/* Addr      allmodes  */
+-	{0x00018c00, 0x18212ede},
++	{0x00018c00, 0x18213ede},
+ 	{0x00018c04, 0x000801d8},
+ 	{0x00018c08, 0x0003780c},
+ };
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0116-ath9k_hw-Fix-concurrent-tx-on-lower-tx-power.patch b/linux-next-cherry-picks/0116-ath9k_hw-Fix-concurrent-tx-on-lower-tx-power.patch
new file mode 100644
index 0000000..61c0571
--- /dev/null
+++ b/linux-next-cherry-picks/0116-ath9k_hw-Fix-concurrent-tx-on-lower-tx-power.patch
@@ -0,0 +1,51 @@
+From e75d4ed6a9565fcccd579316b0fd933d2191f513 Mon Sep 17 00:00:00 2001
+From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Date: Thu, 25 Oct 2012 17:16:52 +0530
+Subject: [PATCH 116/118] ath9k_hw: Fix concurrent tx on lower tx power
+
+Whenever WLAN receives scheduling msg from BT, it reduces tx power
+based on RSSI level. And then BT starts simultaneous transmission
+along with WLAN. Sometimes HW MAC compares tx power that is used
+prior to power reduction which is causing BT transmission to defer.
+
+Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/ar9003_mci.c |    5 ++++-
+ drivers/net/wireless/ath/ath9k/reg.h        |    2 ++
+ 2 files changed, 6 insertions(+), 1 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/ar9003_mci.c b/drivers/net/wireless/ath/ath9k/ar9003_mci.c
+index b04fa46..42b4412 100644
+--- a/drivers/net/wireless/ath/ath9k/ar9003_mci.c
++++ b/drivers/net/wireless/ath/ath9k/ar9003_mci.c
+@@ -881,9 +881,12 @@ int ar9003_mci_reset(struct ath_hw *ah, bool en_int, bool is_2g,
+ 	REG_RMW_FIELD(ah, AR_BTCOEX_CTRL3,
+ 		      AR_BTCOEX_CTRL3_CONT_INFO_TIMEOUT, 20);
+ 
+-	REG_RMW_FIELD(ah, AR_BTCOEX_CTRL2, AR_BTCOEX_CTRL2_RX_DEWEIGHT, 1);
++	REG_RMW_FIELD(ah, AR_BTCOEX_CTRL2, AR_BTCOEX_CTRL2_RX_DEWEIGHT, 0);
+ 	REG_RMW_FIELD(ah, AR_PCU_MISC, AR_PCU_BT_ANT_PREVENT_RX, 0);
+ 
++	/* Set the time out to 3.125ms (5 BT slots) */
++	REG_RMW_FIELD(ah, AR_BTCOEX_WL_LNA, AR_BTCOEX_WL_LNA_TIMEOUT, 0x3D090);
++
+ 	/* concurrent tx priority */
+ 	if (mci->config & ATH_MCI_CONFIG_CONCUR_TX) {
+ 		REG_RMW_FIELD(ah, AR_BTCOEX_CTRL2,
+diff --git a/drivers/net/wireless/ath/ath9k/reg.h b/drivers/net/wireless/ath/ath9k/reg.h
+index e9dec13..ad3c82c 100644
+--- a/drivers/net/wireless/ath/ath9k/reg.h
++++ b/drivers/net/wireless/ath/ath9k/reg.h
+@@ -2311,6 +2311,8 @@ enum {
+ #define AR_BTCOEX_MAX_TXPWR(_x)				(0x18c0 + ((_x) << 2))
+ #define AR_BTCOEX_WL_LNA				0x1940
+ #define AR_BTCOEX_RFGAIN_CTRL				0x1944
++#define AR_BTCOEX_WL_LNA_TIMEOUT			0x003FFFFF
++#define AR_BTCOEX_WL_LNA_TIMEOUT_S			0
+ 
+ #define AR_BTCOEX_CTRL2					0x1948
+ #define AR_BTCOEX_CTRL2_TXPWR_THRESH			0x0007F800
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0117-ath9k_hw-validate-MCI-stuck-after-RTC-wakeup.patch b/linux-next-cherry-picks/0117-ath9k_hw-validate-MCI-stuck-after-RTC-wakeup.patch
new file mode 100644
index 0000000..72ad384
--- /dev/null
+++ b/linux-next-cherry-picks/0117-ath9k_hw-validate-MCI-stuck-after-RTC-wakeup.patch
@@ -0,0 +1,38 @@
+From cdbe408da76d5cc294edb013850cc3a972d80968 Mon Sep 17 00:00:00 2001
+From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Date: Thu, 25 Oct 2012 17:16:53 +0530
+Subject: [PATCH 117/118] ath9k_hw: validate MCI stuck after RTC wakeup
+
+Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/hw.c |    6 +++---
+ 1 files changed, 3 insertions(+), 3 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/hw.c b/drivers/net/wireless/ath/ath9k/hw.c
+index 8e1559a..71cd9f0 100644
+--- a/drivers/net/wireless/ath/ath9k/hw.c
++++ b/drivers/net/wireless/ath/ath9k/hw.c
+@@ -2153,9 +2153,6 @@ static bool ath9k_hw_set_power_awake(struct ath_hw *ah)
+ 		    AR_RTC_FORCE_WAKE_EN);
+ 	udelay(50);
+ 
+-	if (ath9k_hw_mci_is_enabled(ah))
+-		ar9003_mci_set_power_awake(ah);
+-
+ 	for (i = POWER_UP_TIME / 50; i > 0; i--) {
+ 		val = REG_READ(ah, AR_RTC_STATUS) & AR_RTC_STATUS_M;
+ 		if (val == AR_RTC_STATUS_ON)
+@@ -2171,6 +2168,9 @@ static bool ath9k_hw_set_power_awake(struct ath_hw *ah)
+ 		return false;
+ 	}
+ 
++	if (ath9k_hw_mci_is_enabled(ah))
++		ar9003_mci_set_power_awake(ah);
++
+ 	REG_CLR_BIT(ah, AR_STA_ID1, AR_STA_ID1_PWR_SAV);
+ 
+ 	return true;
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0118-ath9k-Dump-BTCOEX-tuning-parameters.patch b/linux-next-cherry-picks/0118-ath9k-Dump-BTCOEX-tuning-parameters.patch
new file mode 100644
index 0000000..355d0ba
--- /dev/null
+++ b/linux-next-cherry-picks/0118-ath9k-Dump-BTCOEX-tuning-parameters.patch
@@ -0,0 +1,148 @@
+From 4df50ca869890581020b95958251bd355c1dc6b1 Mon Sep 17 00:00:00 2001
+From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Date: Thu, 25 Oct 2012 17:16:54 +0530
+Subject: [PATCH 118/118] ath9k: Dump BTCOEX tuning parameters
+
+Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/ath9k.h |    6 ++++
+ drivers/net/wireless/ath/ath9k/debug.c |   34 ++++++++++++++++++++++-
+ drivers/net/wireless/ath/ath9k/gpio.c  |   48 ++++++++++++++++++++++++++++++++
+ 3 files changed, 87 insertions(+), 1 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/ath9k.h b/drivers/net/wireless/ath/ath9k/ath9k.h
+index 18dfb76..4e125d8 100644
+--- a/drivers/net/wireless/ath/ath9k/ath9k.h
++++ b/drivers/net/wireless/ath/ath9k/ath9k.h
+@@ -494,6 +494,7 @@ void ath9k_btcoex_timer_pause(struct ath_softc *sc);
+ void ath9k_btcoex_handle_interrupt(struct ath_softc *sc, u32 status);
+ u16 ath9k_btcoex_aggr_limit(struct ath_softc *sc, u32 max_4ms_framelen);
+ void ath9k_btcoex_stop_gen_timer(struct ath_softc *sc);
++int ath9k_dump_btcoex(struct ath_softc *sc, u8 *buf, u32 len, u32 size);
+ #else
+ static inline int ath9k_init_btcoex(struct ath_softc *sc)
+ {
+@@ -520,6 +521,11 @@ static inline u16 ath9k_btcoex_aggr_limit(struct ath_softc *sc,
+ static inline void ath9k_btcoex_stop_gen_timer(struct ath_softc *sc)
+ {
+ }
++static inline int ath9k_dump_btcoex(struct ath_softc *sc, u8 *buf,
++				    u32 len, u32 size)
++{
++	return 0;
++}
+ #endif /* CONFIG_ATH9K_BTCOEX_SUPPORT */
+ 
+ struct ath9k_wow_pattern {
+diff --git a/drivers/net/wireless/ath/ath9k/debug.c b/drivers/net/wireless/ath/ath9k/debug.c
+index 6727b56..a8be94b 100644
+--- a/drivers/net/wireless/ath/ath9k/debug.c
++++ b/drivers/net/wireless/ath/ath9k/debug.c
+@@ -1586,6 +1586,35 @@ static const struct file_operations fops_samps = {
+ 
+ #endif
+ 
++#ifdef CONFIG_ATH9K_BTCOEX_SUPPORT
++static ssize_t read_file_btcoex(struct file *file, char __user *user_buf,
++				size_t count, loff_t *ppos)
++{
++	struct ath_softc *sc = file->private_data;
++	u32 len = 0, size = 1500;
++	char *buf;
++	size_t retval;
++
++	buf = kzalloc(size, GFP_KERNEL);
++	if (buf == NULL)
++		return -ENOMEM;
++
++	len = ath9k_dump_btcoex(sc, buf, len, size);
++
++	retval = simple_read_from_buffer(user_buf, count, ppos, buf, len);
++	kfree(buf);
++
++	return retval;
++}
++
++static const struct file_operations fops_btcoex = {
++	.read = read_file_btcoex,
++	.open = simple_open,
++	.owner = THIS_MODULE,
++	.llseek = default_llseek,
++};
++#endif
++
+ int ath9k_init_debug(struct ath_hw *ah)
+ {
+ 	struct ath_common *common = ath9k_hw_common(ah);
+@@ -1658,6 +1687,9 @@ int ath9k_init_debug(struct ath_hw *ah)
+ 			   sc->debug.debugfs_phy, &sc->sc_ah->gpio_val);
+ 	debugfs_create_file("diversity", S_IRUSR | S_IWUSR,
+ 			    sc->debug.debugfs_phy, sc, &fops_ant_diversity);
+-
++#ifdef CONFIG_ATH9K_BTCOEX_SUPPORT
++	debugfs_create_file("btcoex", S_IRUSR, sc->debug.debugfs_phy, sc,
++			    &fops_btcoex);
++#endif
+ 	return 0;
+ }
+diff --git a/drivers/net/wireless/ath/ath9k/gpio.c b/drivers/net/wireless/ath/ath9k/gpio.c
+index 64dde1c..a8ea57b 100644
+--- a/drivers/net/wireless/ath/ath9k/gpio.c
++++ b/drivers/net/wireless/ath/ath9k/gpio.c
+@@ -494,4 +494,52 @@ int ath9k_init_btcoex(struct ath_softc *sc)
+ 	return 0;
+ }
+ 
++int ath9k_dump_btcoex(struct ath_softc *sc, u8 *buf, u32 len, u32 size)
++{
++#define ATH_DUMP_BTCOEX(_s, _val)                                \
++	do {                                                     \
++		len += snprintf(buf + len, size - len,           \
++				"%20s : %10d\n", _s, (_val));    \
++	} while (0)
++
++	struct ath_btcoex *btcoex = &sc->btcoex;
++	struct ath_mci_profile *mci = &btcoex->mci;
++	struct ath_hw *ah = sc->sc_ah;
++	struct ath_btcoex_hw *btcoex_hw = &ah->btcoex_hw;
++	int i;
++
++	ATH_DUMP_BTCOEX("Total BT profiles", NUM_PROF(mci));
++	ATH_DUMP_BTCOEX("Number of MGMT", mci->num_mgmt);
++	ATH_DUMP_BTCOEX("Number of SCO", mci->num_sco);
++	ATH_DUMP_BTCOEX("Number of A2DP", mci->num_a2dp);
++	ATH_DUMP_BTCOEX("Number of HID", mci->num_hid);
++	ATH_DUMP_BTCOEX("Number of PAN", mci->num_pan);
++	ATH_DUMP_BTCOEX("Number of ACL", mci->num_other_acl);
++	ATH_DUMP_BTCOEX("Number of BDR", mci->num_bdr);
++	ATH_DUMP_BTCOEX("Aggr. Limit", mci->aggr_limit);
++	ATH_DUMP_BTCOEX("Stomp Type", btcoex->bt_stomp_type);
++	ATH_DUMP_BTCOEX("BTCoex Period (msec)", btcoex->btcoex_period);
++	ATH_DUMP_BTCOEX("Duty Cycle", btcoex->duty_cycle);
++	ATH_DUMP_BTCOEX("BT Wait time", btcoex->bt_wait_time);
++	ATH_DUMP_BTCOEX("Concurrent Tx", btcoex_hw->mci.concur_tx);
++	ATH_DUMP_BTCOEX("Concur RSSI count", btcoex->rssi_count);
++	len += snprintf(buf + len, size - len, "BT Weights: ");
++	for (i = 0; i < AR9300_NUM_BT_WEIGHTS; i++)
++		len += snprintf(buf + len, size - len, "%08x ",
++				btcoex_hw->bt_weight[i]);
++	len += snprintf(buf + len, size - len, "\n");
++	len += snprintf(buf + len, size - len, "WLAN Weights: ");
++	for (i = 0; i < AR9300_NUM_BT_WEIGHTS; i++)
++		len += snprintf(buf + len, size - len, "%08x ",
++				btcoex_hw->wlan_weight[i]);
++	len += snprintf(buf + len, size - len, "\n");
++	len += snprintf(buf + len, size - len, "Tx Priorities: ");
++	for (i = 0; i < ATH_BTCOEX_STOMP_MAX; i++)
++		len += snprintf(buf + len, size - len, "%08x ",
++				btcoex_hw->tx_prio[i]);
++	len += snprintf(buf + len, size - len, "\n");
++#undef ATH_DUMP_BTCOEX
++
++	return len;
++}
+ #endif /* CONFIG_ATH9K_BTCOEX_SUPPORT */
+-- 
+1.7.4.1
+
diff --git a/linux-next-cherry-picks/0119-ath9k-Test-for-TID-only-in-BlockAcks-while-checking-.patch b/linux-next-cherry-picks/0119-ath9k-Test-for-TID-only-in-BlockAcks-while-checking-.patch
new file mode 100644
index 0000000..7c2f24e
--- /dev/null
+++ b/linux-next-cherry-picks/0119-ath9k-Test-for-TID-only-in-BlockAcks-while-checking-.patch
@@ -0,0 +1,65 @@
+From 6fe7cc71bbf3a0bc28c9cec3c00bc11e81344412 Mon Sep 17 00:00:00 2001
+From: Sven Eckelmann <sven@xxxxxxxxxxxxx>
+Date: Mon, 29 Oct 2012 13:25:20 +0100
+Subject: [PATCH] ath9k: Test for TID only in BlockAcks while checking tx status
+
+The ath9k xmit functions for AMPDUs can send frames as non-aggregate in case
+only one frame is currently available. The client will then answer using a
+normal Ack instead of a BlockAck. This acknowledgement has no TID stored and
+therefore the hardware is not able to provide us the corresponding TID.
+
+The TID set by the hardware in the tx status descriptor has to be seen as
+undefined and not as a valid TID value for normal acknowledgements. Doing
+otherwise results in a massive amount of retransmissions and stalls of
+connections.
+
+Users may experience low bandwidth and complete connection stalls in
+environments with transfers using multiple TIDs.
+
+This regression was introduced in b11b160defc48e4daa283f785192ea3a23a51f8e
+("ath9k: validate the TID in the tx status information").
+
+Signed-off-by: Sven Eckelmann <sven@xxxxxxxxxxxxx>
+Signed-off-by: Simon Wunderlich <siwu@xxxxxxxxxxxxxxxxxx>
+Cc: stable@xxxxxxxxxxxxxxx
+Acked-by: Felix Fietkau <nbd@xxxxxxxxxxx>
+Signed-off-by: John W. Linville <linville@xxxxxxxxxxxxx>
+---
+ drivers/net/wireless/ath/ath9k/xmit.c |    8 ++++++--
+ 1 files changed, 6 insertions(+), 2 deletions(-)
+
+diff --git a/drivers/net/wireless/ath/ath9k/xmit.c b/drivers/net/wireless/ath/ath9k/xmit.c
+index 1ffca75..741918a 100644
+--- a/drivers/net/wireless/ath/ath9k/xmit.c
++++ b/drivers/net/wireless/ath/ath9k/xmit.c
+@@ -394,7 +394,7 @@ static void ath_tx_complete_aggr(struct ath_softc *sc, struct ath_txq *txq,
+ 	u16 seq_st = 0, acked_cnt = 0, txfail_cnt = 0, seq_first;
+ 	u32 ba[WME_BA_BMP_SIZE >> 5];
+ 	int isaggr, txfail, txpending, sendbar = 0, needreset = 0, nbad = 0;
+-	bool rc_update = true;
++	bool rc_update = true, isba;
+ 	struct ieee80211_tx_rate rates[4];
+ 	struct ath_frame_info *fi;
+ 	int nframes;
+@@ -438,13 +438,17 @@ static void ath_tx_complete_aggr(struct ath_softc *sc, struct ath_txq *txq,
+ 	tidno = ieee80211_get_qos_ctl(hdr)[0] & IEEE80211_QOS_CTL_TID_MASK;
+ 	tid = ATH_AN_2_TID(an, tidno);
+ 	seq_first = tid->seq_start;
++	isba = ts->ts_flags & ATH9K_TX_BA;
+ 
+ 	/*
+ 	 * The hardware occasionally sends a tx status for the wrong TID.
+ 	 * In this case, the BA status cannot be considered valid and all
+ 	 * subframes need to be retransmitted
++	 *
++	 * Only BlockAcks have a TID and therefore normal Acks cannot be
++	 * checked
+ 	 */
+-	if (tidno != ts->tid)
++	if (isba && tidno != ts->tid)
+ 		txok = false;
+ 
+ 	isaggr = bf_isaggr(bf);
+-- 
+1.7.4.1
+
diff --git a/linux-next-pending/0001-ath9k_hw-Enable-OSLA-hw-fix-for-AR9565.patch b/linux-next-pending/0001-ath9k_hw-Enable-OSLA-hw-fix-for-AR9565.patch
deleted file mode 100644
index 8f3e87c..0000000
--- a/linux-next-pending/0001-ath9k_hw-Enable-OSLA-hw-fix-for-AR9565.patch
+++ /dev/null
@@ -1,34 +0,0 @@
-From 09504f1ccb52e865e1be861db9c7c1adbf206614 Mon Sep 17 00:00:00 2001
-From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
-Date: Mon, 15 Oct 2012 15:29:45 +0530
-Subject: [PATCH 01/11] ath9k_hw: Enable OSLA hw fix for AR9565
-
-Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
----
- drivers/net/wireless/ath/ath9k/ar9003_mci.c |    3 +++
- drivers/net/wireless/ath/ath9k/reg.h        |    4 ++++
- 2 files changed, 7 insertions(+), 0 deletions(-)
-
---- a/drivers/net/wireless/ath/ath9k/ar9003_mci.c
-+++ b/drivers/net/wireless/ath/ath9k/ar9003_mci.c
-@@ -799,6 +799,9 @@ static void ar9003_mci_osla_setup(struct
- 	REG_RMW_FIELD(ah, AR_MCI_SCHD_TABLE_2,
- 		      AR_MCI_SCHD_TABLE_2_MEM_BASED, 1);
- 
-+	if (AR_SREV_9565(ah))
-+		REG_RMW_FIELD(ah, AR_MCI_MISC, AR_MCI_MISC_HW_FIX_EN, 1);
-+
- 	if (!(mci->config & ATH_MCI_CONFIG_DISABLE_AGGR_THRESH)) {
- 		thresh = MS(mci->config, ATH_MCI_CONFIG_AGGR_THRESH);
- 		REG_RMW_FIELD(ah, AR_BTCOEX_CTRL,
---- a/drivers/net/wireless/ath/ath9k/reg.h
-+++ b/drivers/net/wireless/ath/ath9k/reg.h
-@@ -2360,4 +2360,8 @@ enum {
- #define AR_GLB_SWREG_DISCONT_MODE         0x2002c
- #define AR_GLB_SWREG_DISCONT_EN_BT_WLAN   0x3
- 
-+#define AR_MCI_MISC                    0x1a74
-+#define AR_MCI_MISC_HW_FIX_EN          0x00000001
-+#define AR_MCI_MISC_HW_FIX_EN_S        0
-+
- #endif
diff --git a/linux-next-pending/0002-ath9k_hw-Fix-selfgen-chainmask-for-9565.patch b/linux-next-pending/0002-ath9k_hw-Fix-selfgen-chainmask-for-9565.patch
deleted file mode 100644
index 84f3447..0000000
--- a/linux-next-pending/0002-ath9k_hw-Fix-selfgen-chainmask-for-9565.patch
+++ /dev/null
@@ -1,28 +0,0 @@
-From 9f477777f199e21ecdeea4df1244f55495827ffe Mon Sep 17 00:00:00 2001
-From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
-Date: Mon, 15 Oct 2012 15:29:46 +0530
-Subject: [PATCH 02/11] ath9k_hw: Fix selfgen chainmask for 9565
-
-Self generated MCI messages is configured to use chain 1. As
-ar9565 is 1x1 solution, It can not use Chain 1. Hence fix
-Chain 1 for ar9462 alone. Not doing so, could affect WLAN
-connectivity in ar9565 as LNA sharing is not informed by BT.
-
-Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
----
- drivers/net/wireless/ath/ath9k/ar9003_mci.c |    4 +++-
- 1 files changed, 3 insertions(+), 1 deletions(-)
-
---- a/drivers/net/wireless/ath/ath9k/ar9003_mci.c
-+++ b/drivers/net/wireless/ath/ath9k/ar9003_mci.c
-@@ -1031,7 +1031,9 @@ void ar9003_mci_2g5g_switch(struct ath_h
- 
- 		if (!(mci->config & ATH_MCI_CONFIG_DISABLE_OSLA))
- 			ar9003_mci_osla_setup(ah, true);
--		REG_WRITE(ah, AR_SELFGEN_MASK, 0x02);
-+
-+		if (AR_SREV_9462(ah))
-+			REG_WRITE(ah, AR_SELFGEN_MASK, 0x02);
- 	} else {
- 		ar9003_mci_send_lna_take(ah, true);
- 		udelay(5);
diff --git a/linux-next-pending/0003-ath9k-Set-appropriate-bit-for-AR9565-in-btc-control-.patch b/linux-next-pending/0003-ath9k-Set-appropriate-bit-for-AR9565-in-btc-control-.patch
deleted file mode 100644
index 329a901..0000000
--- a/linux-next-pending/0003-ath9k-Set-appropriate-bit-for-AR9565-in-btc-control-.patch
+++ /dev/null
@@ -1,33 +0,0 @@
-From cd8098a5ee084ea3b41f2891e0a5340271988f0d Mon Sep 17 00:00:00 2001
-From: Bala Shanmugam <bkamatch@xxxxxxxxxxxxxxxx>
-Date: Mon, 15 Oct 2012 15:29:47 +0530
-Subject: [PATCH 03/11] ath9k: Set appropriate bit for AR9565 in btc control register
-
-Signed-off-by: Bala Shanmugam <bkamatch@xxxxxxxxxxxxxxxx>
----
- drivers/net/wireless/ath/ath9k/ar9003_mci.c |   11 +++++++++--
- 1 files changed, 9 insertions(+), 2 deletions(-)
-
---- a/drivers/net/wireless/ath/ath9k/ar9003_mci.c
-+++ b/drivers/net/wireless/ath/ath9k/ar9003_mci.c
-@@ -850,11 +850,18 @@ int ar9003_mci_reset(struct ath_hw *ah,
- 		 SM(1, AR_BTCOEX_CTRL_WBTIMER_EN) |
- 		 SM(1, AR_BTCOEX_CTRL_PA_SHARED) |
- 		 SM(1, AR_BTCOEX_CTRL_LNA_SHARED) |
--		 SM(2, AR_BTCOEX_CTRL_NUM_ANTENNAS) |
--		 SM(3, AR_BTCOEX_CTRL_RX_CHAIN_MASK) |
- 		 SM(0, AR_BTCOEX_CTRL_1_CHAIN_ACK) |
- 		 SM(0, AR_BTCOEX_CTRL_1_CHAIN_BCN) |
- 		 SM(0, AR_BTCOEX_CTRL_ONE_STEP_LOOK_AHEAD_EN);
-+	if (AR_SREV_9565(ah)) {
-+		regval |= SM(1, AR_BTCOEX_CTRL_NUM_ANTENNAS) |
-+			  SM(1, AR_BTCOEX_CTRL_RX_CHAIN_MASK);
-+		REG_RMW_FIELD(ah, AR_BTCOEX_CTRL2,
-+			      AR_BTCOEX_CTRL2_TX_CHAIN_MASK, 0x1);
-+	} else {
-+		regval |= SM(2, AR_BTCOEX_CTRL_NUM_ANTENNAS) |
-+			  SM(3, AR_BTCOEX_CTRL_RX_CHAIN_MASK);
-+	}
- 
- 	REG_WRITE(ah, AR_BTCOEX_CTRL, regval);
- 
diff --git a/linux-next-pending/0004-ath9k-turn-off-RXIQ-calibration-while-re-calibrating.patch b/linux-next-pending/0004-ath9k-turn-off-RXIQ-calibration-while-re-calibrating.patch
deleted file mode 100644
index 9e9819a..0000000
--- a/linux-next-pending/0004-ath9k-turn-off-RXIQ-calibration-while-re-calibrating.patch
+++ /dev/null
@@ -1,46 +0,0 @@
-From f090327eec6875ce4302173f1638a37b9a5d47b8 Mon Sep 17 00:00:00 2001
-From: Bala Shanmugam <bkamatch@xxxxxxxxxxxxxxxx>
-Date: Mon, 15 Oct 2012 15:29:48 +0530
-Subject: [PATCH 04/11] ath9k: turn off RXIQ calibration while re-calibrating radio
-
-TXIQ and RXIQ share the same data path to upload the measurement
-result, we should turn off RXIQ calibration while re-calibrating radio
-
-Signed-off-by: Bala Shanmugam <bkamatch@xxxxxxxxxxxxxxxx>
----
- drivers/net/wireless/ath/ath9k/ar9003_mci.c |    6 ++++++
- drivers/net/wireless/ath/ath9k/ar9003_phy.h |    1 +
- 2 files changed, 7 insertions(+), 0 deletions(-)
-
---- a/drivers/net/wireless/ath/ath9k/ar9003_mci.c
-+++ b/drivers/net/wireless/ath/ath9k/ar9003_mci.c
-@@ -750,6 +750,9 @@ int ar9003_mci_end_reset(struct ath_hw *
- 
- 	mci_hw->bt_state = MCI_BT_AWAKE;
- 
-+	REG_CLR_BIT(ah, AR_PHY_TIMING4,
-+		    1 << AR_PHY_TIMING_CONTROL4_DO_GAIN_DC_IQ_CAL_SHIFT);
-+
- 	if (caldata) {
- 		caldata->done_txiqcal_once = false;
- 		caldata->done_txclcal_once = false;
-@@ -759,6 +762,9 @@ int ar9003_mci_end_reset(struct ath_hw *
- 	if (!ath9k_hw_init_cal(ah, chan))
- 		return -EIO;
- 
-+	REG_SET_BIT(ah, AR_PHY_TIMING4,
-+		    1 << AR_PHY_TIMING_CONTROL4_DO_GAIN_DC_IQ_CAL_SHIFT);
-+
- exit:
- 	ar9003_mci_enable_interrupt(ah);
- 	return 0;
---- a/drivers/net/wireless/ath/ath9k/ar9003_phy.h
-+++ b/drivers/net/wireless/ath/ath9k/ar9003_phy.h
-@@ -32,6 +32,7 @@
- #define AR_PHY_SPUR_REG     (AR_CHAN_BASE + 0x1c)
- #define AR_PHY_RX_IQCAL_CORR_B0    (AR_CHAN_BASE + 0xdc)
- #define AR_PHY_TX_IQCAL_CONTROL_3  (AR_CHAN_BASE + 0xb0)
-+#define AR_PHY_TIMING_CONTROL4_DO_GAIN_DC_IQ_CAL_SHIFT 16
- 
- #define AR_PHY_TIMING11_SPUR_FREQ_SD    0x3FF00000
- #define AR_PHY_TIMING11_SPUR_FREQ_SD_S  20
diff --git a/linux-next-pending/0005-ath9k_hw-Disable-MCI-stat-counter-by-default-for-AR9.patch b/linux-next-pending/0005-ath9k_hw-Disable-MCI-stat-counter-by-default-for-AR9.patch
deleted file mode 100644
index 1d59f1f..0000000
--- a/linux-next-pending/0005-ath9k_hw-Disable-MCI-stat-counter-by-default-for-AR9.patch
+++ /dev/null
@@ -1,34 +0,0 @@
-From 7b608d7a012d967f08e8500c3e38b94d28daa4c6 Mon Sep 17 00:00:00 2001
-From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
-Date: Mon, 15 Oct 2012 15:29:49 +0530
-Subject: [PATCH 05/11] ath9k_hw: Disable MCI stat counter by default for AR9565
-
-Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
----
- drivers/net/wireless/ath/ath9k/ar9003_mci.c |    3 +++
- drivers/net/wireless/ath/ath9k/reg.h        |    3 +++
- 2 files changed, 6 insertions(+), 0 deletions(-)
-
---- a/drivers/net/wireless/ath/ath9k/ar9003_mci.c
-+++ b/drivers/net/wireless/ath/ath9k/ar9003_mci.c
-@@ -926,6 +926,9 @@ int ar9003_mci_reset(struct ath_hw *ah,
- 	mci->ready = true;
- 	ar9003_mci_prep_interface(ah);
- 
-+	if (AR_SREV_9565(ah))
-+		REG_RMW_FIELD(ah, AR_MCI_DBG_CNT_CTRL,
-+			      AR_MCI_DBG_CNT_CTRL_ENABLE, 0);
- 	if (en_int)
- 		ar9003_mci_enable_interrupt(ah);
- 
---- a/drivers/net/wireless/ath/ath9k/reg.h
-+++ b/drivers/net/wireless/ath/ath9k/reg.h
-@@ -2363,5 +2363,8 @@ enum {
- #define AR_MCI_MISC                    0x1a74
- #define AR_MCI_MISC_HW_FIX_EN          0x00000001
- #define AR_MCI_MISC_HW_FIX_EN_S        0
-+#define AR_MCI_DBG_CNT_CTRL            0x1a78
-+#define AR_MCI_DBG_CNT_CTRL_ENABLE     0x00000001
-+#define AR_MCI_DBG_CNT_CTRL_ENABLE_S   0
- 
- #endif
diff --git a/linux-next-pending/0006-ath9k_hw-Fix-frequent-BT-rx-recovery.patch b/linux-next-pending/0006-ath9k_hw-Fix-frequent-BT-rx-recovery.patch
deleted file mode 100644
index 0067334..0000000
--- a/linux-next-pending/0006-ath9k_hw-Fix-frequent-BT-rx-recovery.patch
+++ /dev/null
@@ -1,66 +0,0 @@
-From 56e95424248ae3a3f5dd92bdd7ae0446ea3776ba Mon Sep 17 00:00:00 2001
-From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
-Date: Mon, 15 Oct 2012 17:31:41 +0530
-Subject: [PATCH 06/11] ath9k_hw: Fix frequent BT rx recovery
-
-While resuming from S3, BT host issues HCI reset command and it
-causes BT firmware to busy with security key calculation. At this
-movement, WLAN detects MCI hardware error of MCI_CONT_INFO_TIMEOUT
-and then it starts the recovery sequence repeatedly. Too many
-recovery sequences would exhaust the BT kernel message pool. This
-patch imposes a duration between consecutive BT recovery procedure.
-Thus it solves BT firmware panic issue reported in AR9565.
-
-Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
----
- drivers/net/wireless/ath/ath9k/ar9003_mci.c |   10 +++++++++-
- drivers/net/wireless/ath/ath9k/ar9003_mci.h |    1 +
- drivers/net/wireless/ath/ath9k/btcoex.h     |    1 +
- 3 files changed, 11 insertions(+), 1 deletions(-)
-
---- a/drivers/net/wireless/ath/ath9k/ar9003_mci.c
-+++ b/drivers/net/wireless/ath/ath9k/ar9003_mci.c
-@@ -1191,7 +1191,7 @@ EXPORT_SYMBOL(ar9003_mci_cleanup);
- u32 ar9003_mci_state(struct ath_hw *ah, u32 state_type)
- {
- 	struct ath9k_hw_mci *mci = &ah->btcoex_hw.mci;
--	u32 value = 0;
-+	u32 value = 0, tsf;
- 	u8 query_type;
- 
- 	switch (state_type) {
-@@ -1249,6 +1249,14 @@ u32 ar9003_mci_state(struct ath_hw *ah,
- 		ar9003_mci_send_coex_bt_status_query(ah, true, query_type);
- 		break;
- 	case MCI_STATE_RECOVER_RX:
-+		tsf = ath9k_hw_gettsf32(ah);
-+		if ((tsf - mci->last_recovery) <= MCI_RECOVERY_DUR_TSF) {
-+			ath_dbg(ath9k_hw_common(ah), MCI,
-+				"(MCI) ignore Rx recovery\n");
-+			break;
-+		}
-+		ath_dbg(ath9k_hw_common(ah), MCI, "(MCI) RECOVER RX\n");
-+		mci->last_recovery = tsf;
- 		ar9003_mci_prep_interface(ah);
- 		mci->query_bt = true;
- 		mci->need_flush_btinfo = true;
---- a/drivers/net/wireless/ath/ath9k/ar9003_mci.h
-+++ b/drivers/net/wireless/ath/ath9k/ar9003_mci.h
-@@ -18,6 +18,7 @@
- #define AR9003_MCI_H
- 
- #define MCI_FLAG_DISABLE_TIMESTAMP      0x00000001      /* Disable time stamp */
-+#define MCI_RECOVERY_DUR_TSF		(100 * 1000)    /* 100 ms */
- 
- /* Default remote BT device MCI COEX version */
- #define MCI_GPM_COEX_MAJOR_VERSION_DEFAULT  3
---- a/drivers/net/wireless/ath/ath9k/btcoex.h
-+++ b/drivers/net/wireless/ath/ath9k/btcoex.h
-@@ -84,6 +84,7 @@ struct ath9k_hw_mci {
- 	u8 bt_ver_minor;
- 	u8 bt_state;
- 	u8 stomp_ftp;
-+	u32 last_recovery;
- };
- 
- struct ath_btcoex_hw {
diff --git a/linux-next-pending/0007-ath9k_hw-Fix-max-rx-rate-drop-for-AR9565.patch b/linux-next-pending/0007-ath9k_hw-Fix-max-rx-rate-drop-for-AR9565.patch
deleted file mode 100644
index 1ac6f84..0000000
--- a/linux-next-pending/0007-ath9k_hw-Fix-max-rx-rate-drop-for-AR9565.patch
+++ /dev/null
@@ -1,28 +0,0 @@
-From f02b45dc2aa6022765a18cea7ce6acff31f59897 Mon Sep 17 00:00:00 2001
-From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
-Date: Mon, 15 Oct 2012 15:29:51 +0530
-Subject: [PATCH 07/11] ath9k_hw: Fix max rx rate drop for AR9565
-
-Whenever i_coff of IQ calibration is too high, AR9565 drops max
-rx rate to MCS4. Skipping IQ update at this time can avoid this
-problem for AR9565.
-
-Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
----
- drivers/net/wireless/ath/ath9k/ar9003_calib.c |    5 +++++
- 1 files changed, 5 insertions(+), 0 deletions(-)
-
---- a/drivers/net/wireless/ath/ath9k/ar9003_calib.c
-+++ b/drivers/net/wireless/ath/ath9k/ar9003_calib.c
-@@ -276,6 +276,11 @@ static void ar9003_hw_iqcalibrate(struct
- 				offset_array[i],
- 				REG_READ(ah, offset_array[i]));
- 
-+			if (AR_SREV_9565(ah) &&
-+			    (iCoff == 63 || qCoff == 63 ||
-+			     iCoff == -63 || qCoff == -63))
-+				return;
-+
- 			REG_RMW_FIELD(ah, offset_array[i],
- 				      AR_PHY_RX_IQCAL_CORR_IQCORR_Q_I_COFF,
- 				      iCoff);
diff --git a/linux-next-pending/0008-ath9k_hw-Configure-new-switch-table-for-AR9565-BTCOE.patch b/linux-next-pending/0008-ath9k_hw-Configure-new-switch-table-for-AR9565-BTCOE.patch
deleted file mode 100644
index 2ae2a1d..0000000
--- a/linux-next-pending/0008-ath9k_hw-Configure-new-switch-table-for-AR9565-BTCOE.patch
+++ /dev/null
@@ -1,47 +0,0 @@
-From 2413be8ff29842ba6404dc69e353f481aa7e6f87 Mon Sep 17 00:00:00 2001
-From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
-Date: Mon, 15 Oct 2012 15:29:52 +0530
-Subject: [PATCH 08/11] ath9k_hw: Configure new switch table for AR9565 BTCOEX
-
-Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
----
- drivers/net/wireless/ath/ath9k/ar9003_eeprom.c |    2 +-
- drivers/net/wireless/ath/ath9k/reg.h           |    4 ----
- drivers/net/wireless/ath/ath9k/wow.c           |    2 +-
- 3 files changed, 2 insertions(+), 6 deletions(-)
-
---- a/drivers/net/wireless/ath/ath9k/ar9003_eeprom.c
-+++ b/drivers/net/wireless/ath/ath9k/ar9003_eeprom.c
-@@ -3601,7 +3601,7 @@ static void ar9003_hw_ant_ctrl_apply(str
- 	 *   7:4 R/W  SWITCH_TABLE_COM_SPDT_WLAN_IDLE
- 	 * SWITCH_TABLE_COM_SPDT_WLAN_IDLE
- 	 */
--	if (AR_SREV_9462_20_OR_LATER(ah)) {
-+	if (AR_SREV_9462_20(ah) || AR_SREV_9565(ah)) {
- 		value = ar9003_switch_com_spdt_get(ah, is2ghz);
- 		REG_RMW_FIELD(ah, AR_PHY_GLB_CONTROL,
- 				AR_SWITCH_TABLE_COM_SPDT_ALL, value);
---- a/drivers/net/wireless/ath/ath9k/reg.h
-+++ b/drivers/net/wireless/ath/ath9k/reg.h
-@@ -907,10 +907,6 @@
- 	(((_ah)->hw_version.macVersion == AR_SREV_VERSION_9462) && \
- 	((_ah)->hw_version.macRev == AR_SREV_REVISION_9462_20))
- 
--#define AR_SREV_9462_20_OR_LATER(_ah) \
--	(((_ah)->hw_version.macVersion == AR_SREV_VERSION_9462) && \
--	((_ah)->hw_version.macRev >= AR_SREV_REVISION_9462_20))
--
- #define AR_SREV_9565(_ah) \
- 	(((_ah)->hw_version.macVersion == AR_SREV_VERSION_9565))
- 
---- a/drivers/net/wireless/ath/ath9k/wow.c
-+++ b/drivers/net/wireless/ath/ath9k/wow.c
-@@ -118,7 +118,7 @@ static void ath9k_wow_create_keep_alive_
- 		       (ap_mac_addr[1] << 8) | (ap_mac_addr[0]);
- 	data_word[5] = (ap_mac_addr[5] << 8) | (ap_mac_addr[4]);
- 
--	if (AR_SREV_9462_20_OR_LATER(ah)) {
-+	if (AR_SREV_9462_20(ah)) {
- 		/* AR9462 2.0 has an extra descriptor word (time based
- 		 * discard) compared to other chips */
- 		REG_WRITE(ah, (AR_WOW_KA_DESC_WORD2 + (12 * 4)), 0);
diff --git a/linux-next-pending/0009-ath9k_hw-Set-default-MCI-config-for-AR9565.patch b/linux-next-pending/0009-ath9k_hw-Set-default-MCI-config-for-AR9565.patch
deleted file mode 100644
index 687c8db..0000000
--- a/linux-next-pending/0009-ath9k_hw-Set-default-MCI-config-for-AR9565.patch
+++ /dev/null
@@ -1,21 +0,0 @@
-From 1e902624bc2de514eb4931950fb0533010246ae8 Mon Sep 17 00:00:00 2001
-From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
-Date: Mon, 15 Oct 2012 15:29:53 +0530
-Subject: [PATCH 09/11] ath9k_hw: Set default MCI config for AR9565
-
-Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
----
- drivers/net/wireless/ath/ath9k/btcoex.c |    2 +-
- 1 files changed, 1 insertions(+), 1 deletions(-)
-
---- a/drivers/net/wireless/ath/ath9k/btcoex.c
-+++ b/drivers/net/wireless/ath/ath9k/btcoex.c
-@@ -195,7 +195,7 @@ void ath9k_hw_btcoex_init_mci(struct ath
- 	ah->btcoex_hw.mci.need_flush_btinfo = false;
- 	ah->btcoex_hw.mci.wlan_cal_seq = 0;
- 	ah->btcoex_hw.mci.wlan_cal_done = 0;
--	ah->btcoex_hw.mci.config = 0x2201;
-+	ah->btcoex_hw.mci.config = (AR_SREV_9462(ah)) ? 0x2201 : 0xa4c1;
- }
- EXPORT_SYMBOL(ath9k_hw_btcoex_init_mci);
- 
diff --git a/linux-next-pending/0010-ath9k-adjust-duty-cycle-for-FTP-profile-for-AR9565.patch b/linux-next-pending/0010-ath9k-adjust-duty-cycle-for-FTP-profile-for-AR9565.patch
deleted file mode 100644
index 24bfd02..0000000
--- a/linux-next-pending/0010-ath9k-adjust-duty-cycle-for-FTP-profile-for-AR9565.patch
+++ /dev/null
@@ -1,21 +0,0 @@
-From 31a829f68f4d5f36ea5513b3d4924c5ba372dfc8 Mon Sep 17 00:00:00 2001
-From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
-Date: Mon, 15 Oct 2012 15:29:54 +0530
-Subject: [PATCH 10/11] ath9k: adjust duty cycle for FTP profile for AR9565
-
-Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
----
- drivers/net/wireless/ath/ath9k/mci.c |    2 +-
- 1 files changed, 1 insertions(+), 1 deletions(-)
-
---- a/drivers/net/wireless/ath/ath9k/mci.c
-+++ b/drivers/net/wireless/ath/ath9k/mci.c
-@@ -150,7 +150,7 @@ static void ath_mci_update_scheme(struct
- 			 * For single PAN/FTP profile, allocate 35% for BT
- 			 * to improve WLAN throughput.
- 			 */
--			btcoex->duty_cycle = 35;
-+			btcoex->duty_cycle = AR_SREV_9565(sc->sc_ah) ? 40 : 35;
- 			btcoex->btcoex_period = 53;
- 			ath_dbg(common, MCI,
- 				"Single PAN/FTP bt period %d ms dutycycle %d\n",
diff --git a/linux-next-pending/0011-ath9k-Add-new-BT-profile-info-A2DP_Voice.patch b/linux-next-pending/0011-ath9k-Add-new-BT-profile-info-A2DP_Voice.patch
deleted file mode 100644
index 2d4d4f1..0000000
--- a/linux-next-pending/0011-ath9k-Add-new-BT-profile-info-A2DP_Voice.patch
+++ /dev/null
@@ -1,44 +0,0 @@
-From 2b175a64f5daa777c6509542e38a48dd15f8e1b4 Mon Sep 17 00:00:00 2001
-From: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
-Date: Mon, 15 Oct 2012 15:29:55 +0530
-Subject: [PATCH 11/11] ath9k: Add new BT profile info A2DP_Voice
-
-When the BT connection is initiated by headset, it's possible that headset
-requests to make one A2DP and one Voice connection over the same link.
-BT firmware will send a new profile A2DP_Voice in this case. So WLAN
-has to take care of this new profile for tuning BTCOEX parameters.
-
-Signed-off-by: Rajkumar Manoharan <rmanohar@xxxxxxxxxxxxxxxx>
----
- drivers/net/wireless/ath/ath9k/ar9003_mci.h |    1 +
- drivers/net/wireless/ath/ath9k/mci.h        |    2 ++
- 2 files changed, 3 insertions(+), 0 deletions(-)
-
---- a/drivers/net/wireless/ath/ath9k/ar9003_mci.h
-+++ b/drivers/net/wireless/ath/ath9k/ar9003_mci.h
-@@ -126,6 +126,7 @@ enum ath_mci_gpm_coex_profile_type {
- 	MCI_GPM_COEX_PROFILE_HID,
- 	MCI_GPM_COEX_PROFILE_BNEP,
- 	MCI_GPM_COEX_PROFILE_VOICE,
-+	MCI_GPM_COEX_PROFILE_A2DPVO,
- 	MCI_GPM_COEX_PROFILE_MAX
- };
- 
---- a/drivers/net/wireless/ath/ath9k/mci.h
-+++ b/drivers/net/wireless/ath/ath9k/mci.h
-@@ -49,6 +49,7 @@
- 			_mci->num_pan++;	 \
- 			break;			 \
- 		case MCI_GPM_COEX_PROFILE_VOICE: \
-+		case MCI_GPM_COEX_PROFILE_A2DPVO:\
- 			_mci->num_sco++;	 \
- 			break;			 \
- 		default:			 \
-@@ -73,6 +74,7 @@
- 			_mci->num_pan--;	 \
- 			break;			 \
- 		case MCI_GPM_COEX_PROFILE_VOICE: \
-+		case MCI_GPM_COEX_PROFILE_A2DPVO:\
- 			_mci->num_sco--;	 \
- 			break;			 \
- 		default:			 \
diff --git a/linux-next-pending/0012-cfg80211-Disallow-HT-WEP-in-IBSS-mode.patch b/linux-next-pending/0012-cfg80211-Disallow-HT-WEP-in-IBSS-mode.patch
deleted file mode 100644
index e4a39e9..0000000
--- a/linux-next-pending/0012-cfg80211-Disallow-HT-WEP-in-IBSS-mode.patch
+++ /dev/null
@@ -1,63 +0,0 @@
-From 19888b7ee52ffee74a874ad622f44ed5f9706e51 Mon Sep 17 00:00:00 2001
-From: Sujith Manoharan <c_manoha@xxxxxxxxxxxxxxxx>
-Date: Mon, 15 Oct 2012 16:43:41 +0530
-Subject: [PATCH] cfg80211: Disallow HT/WEP in IBSS mode
-
-Signed-off-by: Sujith Manoharan <c_manoha@xxxxxxxxxxxxxxxx>
----
- net/wireless/nl80211.c | 20 +++++++++++++++++---
- 1 file changed, 17 insertions(+), 3 deletions(-)
-
---- a/net/wireless/nl80211.c
-+++ b/net/wireless/nl80211.c
-@@ -690,7 +690,7 @@ static int nl80211_parse_key(struct genl
- 
- static struct cfg80211_cached_keys *
- nl80211_parse_connkeys(struct cfg80211_registered_device *rdev,
--		       struct nlattr *keys)
-+		       struct nlattr *keys, bool *no_ht)
- {
- 	struct key_parse parse;
- 	struct nlattr *key;
-@@ -733,6 +733,12 @@ nl80211_parse_connkeys(struct cfg80211_r
- 		result->params[parse.idx].key_len = parse.p.key_len;
- 		result->params[parse.idx].key = result->data[parse.idx];
- 		memcpy(result->data[parse.idx], parse.p.key, parse.p.key_len);
-+
-+		if (result->params[parse.idx].cipher == WLAN_CIPHER_SUITE_WEP40 ||
-+		    result->params[parse.idx].cipher == WLAN_CIPHER_SUITE_WEP104) {
-+			if (no_ht)
-+				*no_ht = true;
-+		}
- 	}
- 
- 	return result;
-@@ -5318,10 +5324,18 @@ static int nl80211_join_ibss(struct sk_b
- 		return -EINVAL;
- 
- 	if (ibss.privacy && info->attrs[NL80211_ATTR_KEYS]) {
-+		bool no_ht = false;
-+
- 		connkeys = nl80211_parse_connkeys(rdev,
--					info->attrs[NL80211_ATTR_KEYS]);
-+					  info->attrs[NL80211_ATTR_KEYS],
-+					  &no_ht);
- 		if (IS_ERR(connkeys))
- 			return PTR_ERR(connkeys);
-+
-+		if ((ibss.channel_type != NL80211_CHAN_NO_HT) && no_ht) {
-+			kfree(connkeys);
-+			return -EINVAL;
-+		}
- 	}
- 
- 	ibss.control_port =
-@@ -5621,7 +5635,7 @@ static int nl80211_connect(struct sk_buf
- 
- 	if (connect.privacy && info->attrs[NL80211_ATTR_KEYS]) {
- 		connkeys = nl80211_parse_connkeys(rdev,
--					info->attrs[NL80211_ATTR_KEYS]);
-+					  info->attrs[NL80211_ATTR_KEYS], NULL);
- 		if (IS_ERR(connkeys))
- 			return PTR_ERR(connkeys);
- 	}
-- 
1.7.4.1

--
To unsubscribe from this list: send the line "unsubscribe backports" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux ARM Kernel]     [Linux ARM]     [Linux Omap]     [Fedora ARM]     [IETF Annouce]     [Security]     [Bugtraq]     [Linux]     [Linux OMAP]     [Linux MIPS]     [ECOS]     [Asterisk Internet PBX]     [Linux API]

  Powered by Linux