Sometimes AP sends TDLS setup response as AMSDU packet.
As driver doesn't parse it and update peer station's 11n
capability in this case, AMPDU doesn't get setup.

This patch calls mwifiex_process_tdls_action_frame() in
AMSDU Rx path to fix the problem.

Signed-off-by: Amitkumar Karwar <akar...@marvell.com>
Signed-off-by: Cathy Luo <c...@marvell.com>
---
 drivers/net/wireless/marvell/mwifiex/11n_rxreorder.c | 10 ++++++++++
 1 file changed, 10 insertions(+)

diff --git a/drivers/net/wireless/marvell/mwifiex/11n_rxreorder.c 
b/drivers/net/wireless/marvell/mwifiex/11n_rxreorder.c
index b3970a8..09578c6 100644
--- a/drivers/net/wireless/marvell/mwifiex/11n_rxreorder.c
+++ b/drivers/net/wireless/marvell/mwifiex/11n_rxreorder.c
@@ -48,7 +48,17 @@ static int mwifiex_11n_dispatch_amsdu_pkt(struct 
mwifiex_private *priv,
                                         priv->wdev.iftype, 0, false);
 
                while (!skb_queue_empty(&list)) {
+                       struct rx_packet_hdr *rx_hdr;
+
                        rx_skb = __skb_dequeue(&list);
+                       rx_hdr = (struct rx_packet_hdr *)rx_skb->data;
+                       if (ISSUPP_TDLS_ENABLED(priv->adapter->fw_cap_info) &&
+                           ntohs(rx_hdr->eth803_hdr.h_proto) == ETH_P_TDLS) {
+                               mwifiex_process_tdls_action_frame(priv,
+                                                                 (u8 *)rx_hdr,
+                                                                 skb->len);
+                       }
+
                        ret = mwifiex_recv_packet(priv, rx_skb);
                        if (ret == -1)
                                mwifiex_dbg(priv->adapter, ERROR,
-- 
1.8.1.4

--
To unsubscribe from this list: send the line "unsubscribe linux-wireless" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to