diff options
author | Stefan Sperling <stsp@cvs.openbsd.org> | 2020-07-21 08:39:00 +0000 |
---|---|---|
committer | Stefan Sperling <stsp@cvs.openbsd.org> | 2020-07-21 08:39:00 +0000 |
commit | a02431f689b429b7a00c5292661a7cc298f19b3d (patch) | |
tree | 898adc0e5e0eb70c37782ef8f878a95f650bc590 /sys/net80211/ieee80211_node.h | |
parent | f0129c6f60ba44937b9aef20e315408ed4927e29 (diff) |
Improve processing of lost frames during 802.11 Rx aggregation.
Make ieee80211_input_ba() skip one missing frame at the head of the Rx block
ack (BA) window once the rest of the window has filled up with pending frames.
This avoids having to wait for the BA window gap timeout handler to run in
order to make progress in such situations.
Simplify the BA gap timeout handler by deferring the actual flushing of the
BA window buffer to the regular input path. The timeout handler now simply
advances the BA window across any missing frames at the head of the window,
and if_input() is no longer called from the context of this timeout handler.
The window will be flushed once another frame arrives.
Packet loss under streamy traffic conditions and during Rx bursts is reduced.
Much less stuttering, more stable tcpbench, and easier flight in Minecraft.
tested by phessler@, Martin Vahlensieck, jmc@, Uwe Werler, and myself
Diffstat (limited to 'sys/net80211/ieee80211_node.h')
-rw-r--r-- | sys/net80211/ieee80211_node.h | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/sys/net80211/ieee80211_node.h b/sys/net80211/ieee80211_node.h index 4256a8add05..510eb534ae7 100644 --- a/sys/net80211/ieee80211_node.h +++ b/sys/net80211/ieee80211_node.h @@ -1,4 +1,4 @@ -/* $OpenBSD: ieee80211_node.h,v 1.86 2020/05/31 09:11:12 stsp Exp $ */ +/* $OpenBSD: ieee80211_node.h,v 1.87 2020/07/21 08:38:59 stsp Exp $ */ /* $NetBSD: ieee80211_node.h,v 1.9 2004/04/30 22:57:32 dyoung Exp $ */ /*- @@ -226,6 +226,13 @@ struct ieee80211_rx_ba { u_int16_t ba_head; struct timeout ba_gap_to; #define IEEE80211_BA_GAP_TIMEOUT 300 /* msec */ + + /* + * Counter for frames forced to wait in the reordering buffer + * due to a leading gap caused by one or more missing frames. + */ + int ba_gapwait; + /* Counter for consecutive frames which missed the BA window. */ int ba_winmiss; /* Sequence number of previous frame which missed the BA window. */ |