Commit eb9b64e3 authored by Felix Fietkau's avatar Felix Fietkau Committed by Johannes Berg

mac80211: fix memory accounting with A-MSDU aggregation

skb->truesize can change due to memory reallocation or when adding extra
fragments. Adjust fq->memory_usage accordingly
Signed-off-by: default avatarFelix Fietkau <nbd@nbd.name>
Acked-by: default avatarToke Høiland-Jørgensen <toke@redhat.com>
Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
parent 08a75a88
...@@ -3221,6 +3221,7 @@ static bool ieee80211_amsdu_aggregate(struct ieee80211_sub_if_data *sdata, ...@@ -3221,6 +3221,7 @@ static bool ieee80211_amsdu_aggregate(struct ieee80211_sub_if_data *sdata,
u8 max_subframes = sta->sta.max_amsdu_subframes; u8 max_subframes = sta->sta.max_amsdu_subframes;
int max_frags = local->hw.max_tx_fragments; int max_frags = local->hw.max_tx_fragments;
int max_amsdu_len = sta->sta.max_amsdu_len; int max_amsdu_len = sta->sta.max_amsdu_len;
int orig_truesize;
__be16 len; __be16 len;
void *data; void *data;
bool ret = false; bool ret = false;
...@@ -3261,6 +3262,7 @@ static bool ieee80211_amsdu_aggregate(struct ieee80211_sub_if_data *sdata, ...@@ -3261,6 +3262,7 @@ static bool ieee80211_amsdu_aggregate(struct ieee80211_sub_if_data *sdata,
if (!head || skb_is_gso(head)) if (!head || skb_is_gso(head))
goto out; goto out;
orig_truesize = head->truesize;
orig_len = head->len; orig_len = head->len;
if (skb->len + head->len > max_amsdu_len) if (skb->len + head->len > max_amsdu_len)
...@@ -3318,6 +3320,7 @@ static bool ieee80211_amsdu_aggregate(struct ieee80211_sub_if_data *sdata, ...@@ -3318,6 +3320,7 @@ static bool ieee80211_amsdu_aggregate(struct ieee80211_sub_if_data *sdata,
*frag_tail = skb; *frag_tail = skb;
out_recalc: out_recalc:
fq->memory_usage += head->truesize - orig_truesize;
if (head->len != orig_len) { if (head->len != orig_len) {
flow->backlog += head->len - orig_len; flow->backlog += head->len - orig_len;
tin->backlog_bytes += head->len - orig_len; tin->backlog_bytes += head->len - orig_len;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment