Commit 4a0e45a7 authored by Lior David's avatar Lior David Committed by Kalle Valo

wil6210: do not start regular scan on stopped p2p device

The driver should not allow starting any type of scan on a stopped
P2P device. Current implementation only checked social scan.
Signed-off-by: default avatarLior David <qca_liord@qca.qualcomm.com>
Signed-off-by: default avatarMaya Erez <qca_merez@qca.qualcomm.com>
Signed-off-by: default avatarKalle Valo <kvalo@qca.qualcomm.com>
parent f2de576d
...@@ -390,22 +390,23 @@ static int wil_cfg80211_scan(struct wiphy *wiphy, ...@@ -390,22 +390,23 @@ static int wil_cfg80211_scan(struct wiphy *wiphy,
} }
mutex_unlock(&wil->p2p_wdev_mutex); mutex_unlock(&wil->p2p_wdev_mutex);
/* social scan on P2P_DEVICE is handled as p2p search */ if (wdev->iftype == NL80211_IFTYPE_P2P_DEVICE) {
if (wdev->iftype == NL80211_IFTYPE_P2P_DEVICE &&
wil_p2p_is_social_scan(request)) {
if (!wil->p2p.p2p_dev_started) { if (!wil->p2p.p2p_dev_started) {
wil_err(wil, "P2P search requested on stopped P2P device\n"); wil_err(wil, "P2P search requested on stopped P2P device\n");
rc = -EIO; rc = -EIO;
goto out; goto out;
} }
wil->scan_request = request; /* social scan on P2P_DEVICE is handled as p2p search */
wil->radio_wdev = wdev; if (wil_p2p_is_social_scan(request)) {
rc = wil_p2p_search(wil, request); wil->scan_request = request;
if (rc) { wil->radio_wdev = wdev;
wil->radio_wdev = wil_to_wdev(wil); rc = wil_p2p_search(wil, request);
wil->scan_request = NULL; if (rc) {
wil->radio_wdev = wil_to_wdev(wil);
wil->scan_request = NULL;
}
goto out;
} }
goto out;
} }
(void)wil_p2p_stop_discovery(wil); (void)wil_p2p_stop_discovery(wil);
......
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