mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-24 12:49:47 +07:00
iwlwifi: mvm: don't warn on normal BAR sending
This flow happens when we get a failed single Tx response on an AMPDU queue. In this case, the frame won't be sent any more. So we need to move the window on the recipient side. This is done by a BAR. Now if we are in the following case: 10, 12 and 13 are ACKed and 11 isn't. 10 11 12 13. V X V V Then, 11 will be sent 16 times as an MPDU (as oppsed to A-MPDU). If this failed, we are entering the flow described above. So we need to send a BAR with ssn = 12. But in this case, the scheduler will tell us to free frames up to 13 (included). So, it is perfectly possible to get a failed single Tx response on an AMPDU queue that makes the scheduler's ssn jump by more than 1 single packet. Signed-off-by: Emmanuel Grumbach <emmanuel.grumbach@intel.com> Signed-off-by: Johannes Berg <johannes.berg@intel.com>
This commit is contained in:
parent
8101a7f065
commit
2470b36e84
@ -607,12 +607,8 @@ static void iwl_mvm_rx_tx_cmd_single(struct iwl_mvm *mvm,
|
|||||||
|
|
||||||
/* Single frame failure in an AMPDU queue => send BAR */
|
/* Single frame failure in an AMPDU queue => send BAR */
|
||||||
if (txq_id >= IWL_FIRST_AMPDU_QUEUE &&
|
if (txq_id >= IWL_FIRST_AMPDU_QUEUE &&
|
||||||
!(info->flags & IEEE80211_TX_STAT_ACK)) {
|
!(info->flags & IEEE80211_TX_STAT_ACK))
|
||||||
/* there must be only one skb in the skb_list */
|
|
||||||
WARN_ON_ONCE(skb_freed > 1 ||
|
|
||||||
!skb_queue_empty(&skbs));
|
|
||||||
info->flags |= IEEE80211_TX_STAT_AMPDU_NO_BACK;
|
info->flags |= IEEE80211_TX_STAT_AMPDU_NO_BACK;
|
||||||
}
|
|
||||||
|
|
||||||
/* W/A FW bug: seq_ctl is wrong when the queue is flushed */
|
/* W/A FW bug: seq_ctl is wrong when the queue is flushed */
|
||||||
if (status == TX_STATUS_FAIL_FIFO_FLUSHED) {
|
if (status == TX_STATUS_FAIL_FIFO_FLUSHED) {
|
||||||
|
Loading…
Reference in New Issue
Block a user