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:
parent
14ca3c98aa
commit
80c764d321
1 changed files with 13 additions and 0 deletions
|
@ -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);
|
||||
|
|
Loading…
Add table
Reference in a new issue