diff options
author | Stanislaw Gruszka <sgruszka@redhat.com> | 2012-12-03 06:59:04 -0500 |
---|---|---|
committer | Johannes Berg <johannes.berg@intel.com> | 2012-12-05 03:57:19 -0500 |
commit | ab9d6e4ffe192427ce9e93d4f927b0faaa8a941e (patch) | |
tree | 261c4999fc12f5d945459c45a959933e31446708 /drivers/net/wireless | |
parent | 5b632fe85ec82e5c43740b52e74c66df50a37db3 (diff) |
Revert: "rt2x00: Don't let mac80211 send a BAR when an AMPDU subframe fails"
This revert:
commit be03d4a45c09ee5100d3aaaedd087f19bc20d01f
Author: Andreas Hartmann <andihartmann@01019freenet.de>
Date: Tue Apr 17 00:25:28 2012 +0200
rt2x00: Don't let mac80211 send a BAR when an AMPDU subframe fails
To fix problem workaround by above commit use
IEEE80211_HW_TEARDOWN_AGGR_ON_BAR_FAIL flag (see change log for
"mac80211: introduce IEEE80211_HW_TEARDOWN_AGGR_ON_BAR_FAIL" patch).
Resolve: https://bugzilla.kernel.org/show_bug.cgi?id=42828
Bisected-by: Francisco Pina Martins <f.pinamartins@gmail.com>
Cc: stable@vger.kernel.org
Signed-off-by: Stanislaw Gruszka <sgruszka@redhat.com>
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Diffstat (limited to 'drivers/net/wireless')
-rw-r--r-- | drivers/net/wireless/rt2x00/rt2800lib.c | 3 | ||||
-rw-r--r-- | drivers/net/wireless/rt2x00/rt2x00dev.c | 7 |
2 files changed, 5 insertions, 5 deletions
diff --git a/drivers/net/wireless/rt2x00/rt2800lib.c b/drivers/net/wireless/rt2x00/rt2800lib.c index 3bc206d06cd1..e0002697a2b7 100644 --- a/drivers/net/wireless/rt2x00/rt2800lib.c +++ b/drivers/net/wireless/rt2x00/rt2800lib.c | |||
@@ -5090,7 +5090,8 @@ static int rt2800_probe_hw_mode(struct rt2x00_dev *rt2x00dev) | |||
5090 | IEEE80211_HW_SUPPORTS_PS | | 5090 | IEEE80211_HW_SUPPORTS_PS | |
5091 | IEEE80211_HW_PS_NULLFUNC_STACK | | 5091 | IEEE80211_HW_PS_NULLFUNC_STACK | |
5092 | IEEE80211_HW_AMPDU_AGGREGATION | | 5092 | IEEE80211_HW_AMPDU_AGGREGATION | |
5093 | IEEE80211_HW_REPORTS_TX_ACK_STATUS; | 5093 | IEEE80211_HW_REPORTS_TX_ACK_STATUS | |
5094 | IEEE80211_HW_TEARDOWN_AGGR_ON_BAR_FAIL; | ||
5094 | 5095 | ||
5095 | /* | 5096 | /* |
5096 | * Don't set IEEE80211_HW_HOST_BROADCAST_PS_BUFFERING for USB devices | 5097 | * Don't set IEEE80211_HW_HOST_BROADCAST_PS_BUFFERING for USB devices |
diff --git a/drivers/net/wireless/rt2x00/rt2x00dev.c b/drivers/net/wireless/rt2x00/rt2x00dev.c index 67d167993d45..07202f11be3c 100644 --- a/drivers/net/wireless/rt2x00/rt2x00dev.c +++ b/drivers/net/wireless/rt2x00/rt2x00dev.c | |||
@@ -392,10 +392,9 @@ void rt2x00lib_txdone(struct queue_entry *entry, | |||
392 | tx_info->flags |= IEEE80211_TX_STAT_AMPDU; | 392 | tx_info->flags |= IEEE80211_TX_STAT_AMPDU; |
393 | tx_info->status.ampdu_len = 1; | 393 | tx_info->status.ampdu_len = 1; |
394 | tx_info->status.ampdu_ack_len = success ? 1 : 0; | 394 | tx_info->status.ampdu_ack_len = success ? 1 : 0; |
395 | /* | 395 | |
396 | * TODO: Need to tear down BA session here | 396 | if (!success) |
397 | * if not successful. | 397 | tx_info->flags |= IEEE80211_TX_STAT_AMPDU_NO_BACK; |
398 | */ | ||
399 | } | 398 | } |
400 | 399 | ||
401 | if (rate_flags & IEEE80211_TX_RC_USE_RTS_CTS) { | 400 | if (rate_flags & IEEE80211_TX_RC_USE_RTS_CTS) { |