mirror of https://gitee.com/openkylin/linux.git
mwifiex: abort remaining scan commands when association started
A full-channel scan is split to multiple scan commands in driver before they are sent to firmware. When each scan result is back the SSID entries are parsed and informed to cfg80211 directly. It's observed that sometimes userspace may initiate association as soon as the target AP is found. During the 4-way handshake firmware may go off-channel to scan the remaining channels. This causes the 4-way handshake to fail. Fix it by checking 'scan_block' flag and aborting the remaining scan in this case. 'scan_block' flag is set after association and before 4-way handshake. It gets cleared after 4-way handshake is completed. Tested-by: Jason Abele <jabele@chromium.org> Signed-off-by: Bing Zhao <bzhao@marvell.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
parent
75ab753d77
commit
4c1079e158
|
@ -1793,7 +1793,8 @@ int mwifiex_ret_802_11_scan(struct mwifiex_private *priv,
|
|||
dev_dbg(adapter->dev, "info: scan already aborted\n");
|
||||
}
|
||||
} else {
|
||||
if (priv->scan_aborting && !priv->scan_request) {
|
||||
if ((priv->scan_aborting && !priv->scan_request) ||
|
||||
priv->scan_block) {
|
||||
spin_unlock_irqrestore(&adapter->scan_pending_q_lock,
|
||||
flags);
|
||||
adapter->scan_delay_cnt = MWIFIEX_MAX_SCAN_DELAY_CNT;
|
||||
|
|
Loading…
Reference in New Issue