aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEyal Shapira <eyal@wizery.com>2011-12-20 07:55:38 -0500
committerLuciano Coelho <coelho@ti.com>2011-12-20 15:30:16 -0500
commitee91d1855137ba9c16d1e7815d562056c3f55e7f (patch)
tree17e428e7f057f005484613fa2407a78a4e172968
parentfea2a613cf33ee0662e413e2f5697bed36d5029e (diff)
wl12xx: mark no sched scan only after FW event
stop sched scan isn't an immediate operation and we need to wait for PERIODIC_SCAN_COMPLETE_EVENT_ID after sending a stop before changing internal state and notifying upper layers. Not doing this caused problems when canceling an existing sched scan and immediately requesting to start a new one with a different configuration as the FW was still in the middle of the previous sched scan. Signed-off-by: Eyal Shapira <eyal@wizery.com> Signed-off-by: Luciano Coelho <coelho@ti.com>
-rw-r--r--drivers/net/wireless/wl12xx/event.c2
-rw-r--r--drivers/net/wireless/wl12xx/scan.c1
2 files changed, 1 insertions, 2 deletions
diff --git a/drivers/net/wireless/wl12xx/event.c b/drivers/net/wireless/wl12xx/event.c
index 00ce794eebae..d3280df68f5d 100644
--- a/drivers/net/wireless/wl12xx/event.c
+++ b/drivers/net/wireless/wl12xx/event.c
@@ -267,8 +267,8 @@ static int wl1271_event_process(struct wl1271 *wl, struct event_mailbox *mbox)
267 wl1271_debug(DEBUG_EVENT, "PERIODIC_SCAN_COMPLETE_EVENT " 267 wl1271_debug(DEBUG_EVENT, "PERIODIC_SCAN_COMPLETE_EVENT "
268 "(status 0x%0x)", mbox->scheduled_scan_status); 268 "(status 0x%0x)", mbox->scheduled_scan_status);
269 if (wl->sched_scanning) { 269 if (wl->sched_scanning) {
270 wl1271_scan_sched_scan_stop(wl);
271 ieee80211_sched_scan_stopped(wl->hw); 270 ieee80211_sched_scan_stopped(wl->hw);
271 wl->sched_scanning = false;
272 } 272 }
273 } 273 }
274 274
diff --git a/drivers/net/wireless/wl12xx/scan.c b/drivers/net/wireless/wl12xx/scan.c
index 05dca0c1d442..e24111ececc5 100644
--- a/drivers/net/wireless/wl12xx/scan.c
+++ b/drivers/net/wireless/wl12xx/scan.c
@@ -754,7 +754,6 @@ void wl1271_scan_sched_scan_stop(struct wl1271 *wl)
754 wl1271_error("failed to send sched scan stop command"); 754 wl1271_error("failed to send sched scan stop command");
755 goto out_free; 755 goto out_free;
756 } 756 }
757 wl->sched_scanning = false;
758 757
759out_free: 758out_free:
760 kfree(stop); 759 kfree(stop);