2020-01-18 18:41:08 +01:00
|
|
|
From: Markus Theil <markus.theil@tu-ilmenau.de>
|
|
|
|
Date: Wed, 18 Dec 2019 15:27:36 +0100
|
|
|
|
Subject: [PATCH] mac80211: fix tx status for no ack cases
|
|
|
|
|
|
|
|
Before this patch, frames which where successfully transmitted without
|
|
|
|
requiring acks where accounted as lost frames.
|
|
|
|
|
|
|
|
Signed-off-by: Markus Theil <markus.theil@tu-ilmenau.de>
|
|
|
|
Link: https://lore.kernel.org/r/20191218142736.15843-1-markus.theil@tu-ilmenau.de
|
|
|
|
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
|
|
|
|
---
|
|
|
|
|
|
|
|
--- a/net/mac80211/status.c
|
|
|
|
+++ b/net/mac80211/status.c
|
2020-08-07 19:02:57 +02:00
|
|
|
@@ -718,6 +718,7 @@ static void __ieee80211_tx_status(struct
|
2020-01-18 18:41:08 +01:00
|
|
|
int rates_idx;
|
|
|
|
bool send_to_cooked;
|
|
|
|
bool acked;
|
|
|
|
+ bool noack_success;
|
|
|
|
struct ieee80211_bar *bar;
|
|
|
|
int shift = 0;
|
|
|
|
int tid = IEEE80211_NUM_TIDS;
|
2020-08-07 19:02:57 +02:00
|
|
|
@@ -735,6 +736,8 @@ static void __ieee80211_tx_status(struct
|
2020-01-18 18:41:08 +01:00
|
|
|
clear_sta_flag(sta, WLAN_STA_SP);
|
|
|
|
|
|
|
|
acked = !!(info->flags & IEEE80211_TX_STAT_ACK);
|
|
|
|
+ noack_success = !!(info->flags &
|
|
|
|
+ IEEE80211_TX_STAT_NOACK_TRANSMITTED);
|
|
|
|
|
|
|
|
/* mesh Peer Service Period support */
|
|
|
|
if (ieee80211_vif_is_mesh(&sta->sdata->vif) &&
|
2020-08-07 19:02:57 +02:00
|
|
|
@@ -799,12 +802,12 @@ static void __ieee80211_tx_status(struct
|
2020-01-18 18:41:08 +01:00
|
|
|
ieee80211_handle_filtered_frame(local, sta, skb);
|
|
|
|
return;
|
|
|
|
} else {
|
|
|
|
- if (!acked)
|
|
|
|
+ if (!acked && !noack_success)
|
|
|
|
sta->status_stats.retry_failed++;
|
|
|
|
sta->status_stats.retry_count += retry_count;
|
|
|
|
|
|
|
|
if (ieee80211_is_data_present(fc)) {
|
|
|
|
- if (!acked)
|
|
|
|
+ if (!acked && !noack_success)
|
|
|
|
sta->status_stats.msdu_failed[tid]++;
|
|
|
|
|
|
|
|
sta->status_stats.msdu_retries[tid] +=
|
2020-08-07 19:02:57 +02:00
|
|
|
@@ -825,7 +828,7 @@ static void __ieee80211_tx_status(struct
|
2020-05-04 22:39:52 +02:00
|
|
|
acked, info->status.tx_time);
|
2020-01-18 18:41:08 +01:00
|
|
|
|
|
|
|
if (ieee80211_hw_check(&local->hw, REPORTS_TX_ACK_STATUS)) {
|
|
|
|
- if (info->flags & IEEE80211_TX_STAT_ACK) {
|
|
|
|
+ if (acked) {
|
|
|
|
if (sta->status_stats.lost_packets)
|
|
|
|
sta->status_stats.lost_packets = 0;
|
|
|
|
|
2020-08-07 19:02:57 +02:00
|
|
|
@@ -833,6 +836,8 @@ static void __ieee80211_tx_status(struct
|
2020-01-18 18:41:08 +01:00
|
|
|
if (test_sta_flag(sta, WLAN_STA_TDLS_PEER_AUTH))
|
|
|
|
sta->status_stats.last_tdls_pkt_time =
|
|
|
|
jiffies;
|
|
|
|
+ } else if (noack_success) {
|
|
|
|
+ /* nothing to do here, do not account as lost */
|
|
|
|
} else {
|
|
|
|
ieee80211_lost_packet(sta, info);
|
|
|
|
}
|
2020-08-07 19:02:57 +02:00
|
|
|
@@ -958,7 +963,7 @@ void ieee80211_tx_status_ext(struct ieee
|
2020-01-18 18:41:08 +01:00
|
|
|
|
|
|
|
sta = container_of(pubsta, struct sta_info, sta);
|
|
|
|
|
|
|
|
- if (!acked)
|
|
|
|
+ if (!acked && !noack_success)
|
|
|
|
sta->status_stats.retry_failed++;
|
|
|
|
sta->status_stats.retry_count += retry_count;
|
|
|
|
|
2020-08-07 19:02:57 +02:00
|
|
|
@@ -973,6 +978,8 @@ void ieee80211_tx_status_ext(struct ieee
|
2020-01-18 18:41:08 +01:00
|
|
|
sta->status_stats.last_tdls_pkt_time = jiffies;
|
|
|
|
} else if (test_sta_flag(sta, WLAN_STA_PS_STA)) {
|
|
|
|
return;
|
|
|
|
+ } else if (noack_success) {
|
|
|
|
+ /* nothing to do here, do not account as lost */
|
|
|
|
} else {
|
|
|
|
ieee80211_lost_packet(sta, info);
|
|
|
|
}
|