From: Sanjay Kumar Koduri <[email protected]>

Currently, software scan in mac80211 is used by drivers, which don't
implement hardware scan. However some drivers which have implemented
hardware scan may also sometimes want to use software scan in mac80211.
Such drivers can return '-EPERM' and ask mac80211 to fallback to
software scan with this patch.

Signed-off-by: Sanjay Kumar konduri <[email protected]>
Signed-off-by: Siva Rebbagondla <[email protected]>
Signed-off-by: Sushant Kumar Mishra <[email protected]>
---
changes in v3: Set SCAN_HW_CANCELLED bit, before SW_SCAN triggered.
changes in v2: Nothing
---
 net/mac80211/scan.c | 7 ++++++-
 1 file changed, 6 insertions(+), 1 deletion(-)

diff --git a/net/mac80211/scan.c b/net/mac80211/scan.c
index 2e917a6..bb1029b 100644
--- a/net/mac80211/scan.c
+++ b/net/mac80211/scan.c
@@ -412,7 +412,7 @@ static void __ieee80211_scan_completed(struct ieee80211_hw 
*hw, bool aborted)
        /* Set power back to normal operating levels. */
        ieee80211_hw_config(local, 0);
 
-       if (!hw_scan) {
+       if (!test_bit(SCAN_SW_SCANNING, &local->scanning)) {
                ieee80211_configure_filter(local);
                drv_sw_scan_complete(local, scan_sdata);
                ieee80211_offchannel_return(local);
@@ -686,6 +686,11 @@ static int __ieee80211_start_scan(struct 
ieee80211_sub_if_data *sdata,
        if (local->ops->hw_scan) {
                WARN_ON(!ieee80211_prep_hw_scan(local));
                rc = drv_hw_scan(local, sdata, local->hw_scan_req);
+               if (rc == -EPERM) {
+                       set_bit(SCAN_HW_CANCELLED, &local->scanning);
+                       __set_bit(SCAN_SW_SCANNING, &local->scanning);
+                       rc = ieee80211_start_sw_scan(local, sdata);
+               }
        } else {
                rc = ieee80211_start_sw_scan(local, sdata);
        }
-- 
2.5.5

Reply via email to