[RFC] extract seqno from sta->last_seq_ctrl
Michal Kazior
michal.kazior at tieto.com
Mon Jul 28 03:13:43 PDT 2014
On 27 July 2014 19:51, Denton Gentry <denton.gentry at gmail.com> wrote:
> [Sending to ath10k list as I think ath10k is the only impacted driver right now]
>
> I believe there is a minor problem in
> [PATCH v2] mac80211: add support for Rx reordering offloading
> http://www.spinics.net/lists/linux-wireless/msg124812.html
>
> sta->last_seq_ctrl is the seq_ctrl field from the last seen packet. To
> get the sequence number it needs to be byteswapped and shifted 4 bits;
> patch below.
Good catch!
> This mostly impacts Windows clients, because Windows sends 100-200
> frames before sending ADDBA. This results in a starting seqno which is
> quite large due to the 4 bit shift, and the ieee80211_sn_less() check
> at the top of ieee80211_sta_manage_reorder_buf drops subsequent frames
> until the sequence number catches up.
>
>
> From d0647db58d13533e5441c07f95b23e912976c87b Mon Sep 17 00:00:00 2001
> From: Denton Gentry <denton.gentry at gmail.com>
> Date: Sun, 27 Jul 2014 08:24:36 -0700
> Subject: [PATCH] extract seqno from sta->last_seq_ctrl
You're missing "mac80211: " prefix. Also this message doesn't seem to
tell much. I'd probably entitle it "mac80211: fix start_seq_num in Rx
reorder offload" and then follow that with details (what/why).
>
> This depends on:
> * [PATCH v2] mac80211: add support for Rx reordering offloading
This shouldn't be in the commit log.
>
> sta->last_seq_ctrl is the seq_ctrl field from the last
> header seen, need to byteswap and shift it 4 bits to
> extract the sequence number.
>
> net/mac80211/iface.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/net/mac80211/iface.c b/net/mac80211/iface.c
> index 77cd025..1903220 100644
> --- a/net/mac80211/iface.c
> +++ b/net/mac80211/iface.c
> @@ -1171,7 +1171,7 @@ static void ieee80211_iface_work(struct work_struct *work)
> mutex_lock(&local->sta_mtx);
> sta = sta_info_get_bss(sdata, rx_agg->addr);
> if (sta) {
> - u16 last_seq = sta->last_seq_ctrl[rx_agg->tid];
> + u16 last_seq =
> le16_to_cpu(sta->last_seq_ctrl[rx_agg->tid]) >> 4;
The byteswap is already in place (Johannes fixed it).
The bitshift should be done with IEEE80211_SEQ_TO_SN macro.
Once you fix the commit log and rebase your patch you should submit
this to linux-wireless mailing list.
Michał
More information about the ath10k
mailing list