mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-05-05 14:40:12 -04:00
wcn36xx: cancel pending scan request when interface goes down
When the network interface goes down while a scan request is still pending that can't be stopped due to firmware hickups, wcn->scan_req remains set, even though the hardware is deinitialized. This results in -EBUSY for all scan requests after the interface was brought up again. Fix this by explicitly completing pending scan requests in wcn36xx_stop(). Signed-off-by: Daniel Mack <daniel@zonque.org> Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
This commit is contained in:
@@ -353,6 +353,19 @@ static void wcn36xx_stop(struct ieee80211_hw *hw)
|
||||
|
||||
wcn36xx_dbg(WCN36XX_DBG_MAC, "mac stop\n");
|
||||
|
||||
cancel_work_sync(&wcn->scan_work);
|
||||
|
||||
mutex_lock(&wcn->scan_lock);
|
||||
if (wcn->scan_req) {
|
||||
struct cfg80211_scan_info scan_info = {
|
||||
.aborted = true,
|
||||
};
|
||||
|
||||
ieee80211_scan_completed(wcn->hw, &scan_info);
|
||||
}
|
||||
wcn->scan_req = NULL;
|
||||
mutex_unlock(&wcn->scan_lock);
|
||||
|
||||
wcn36xx_debugfs_exit(wcn);
|
||||
wcn36xx_smd_stop(wcn);
|
||||
wcn36xx_dxe_deinit(wcn);
|
||||
|
||||
Reference in New Issue
Block a user