Commit a49edd12 authored by Stone Piao's avatar Stone Piao Committed by Ben Hutchings

mwifiex: fix WPS eapol handshake failure

commit f03ba7e9 upstream.

After association, STA will go through eapol handshake with WPS
enabled AP. It's observed that WPS handshake fails with some 11n
AP. The reason for the failure is that the eapol packet is sent
via 11n frame aggregation.

The eapol packet should be sent directly without 11n aggregation.

This patch fixes the problem by adding WPS session control while
dequeuing Tx packets for transmission.
Signed-off-by: default avatarStone Piao <piaoyun@marvell.com>
Signed-off-by: default avatarAvinash Patil <patila@marvell.com>
Signed-off-by: default avatarBing Zhao <bzhao@marvell.com>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
[bwh: Backported to 3.2: reformat the if-statement per earlier
 upstream commit c65a30f3]
Signed-off-by: default avatarBen Hutchings <ben@decadent.org.uk>
parent 7b6d20c1
...@@ -1211,10 +1211,12 @@ mwifiex_dequeue_tx_packet(struct mwifiex_adapter *adapter) ...@@ -1211,10 +1211,12 @@ mwifiex_dequeue_tx_packet(struct mwifiex_adapter *adapter)
return 0; return 0;
} }
if (!ptr->is_11n_enabled || mwifiex_is_ba_stream_setup(priv, ptr, tid) if (!ptr->is_11n_enabled ||
|| ((priv->sec_info.wpa_enabled mwifiex_is_ba_stream_setup(priv, ptr, tid) ||
|| priv->sec_info.wpa2_enabled) && !priv->wpa_is_gtk_set) priv->wps.session_enable ||
) { ((priv->sec_info.wpa_enabled ||
priv->sec_info.wpa2_enabled) &&
!priv->wpa_is_gtk_set)) {
mwifiex_send_single_packet(priv, ptr, ptr_index, flags); mwifiex_send_single_packet(priv, ptr, ptr_index, flags);
/* ra_list_spinlock has been freed in /* ra_list_spinlock has been freed in
mwifiex_send_single_packet() */ mwifiex_send_single_packet() */
......
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