mac80211: advance the state machine immediately if no delay is needed
Instead of queueing the scan work again without delay just process the next state immediately. Signed-off-by: Helmut Schaa <helmut.schaa@googlemail.com> Acked-by: Johannes Berg <johannes@sipsolutions.net> Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
parent
7d3be3cc48
commit
f502d09b75
@ -587,15 +587,21 @@ void ieee80211_scan_work(struct work_struct *work)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (local->scan_state) {
|
/*
|
||||||
case SCAN_SET_CHANNEL:
|
* as long as no delay is required advance immediately
|
||||||
if (ieee80211_scan_state_set_channel(local, &next_delay))
|
* without scheduling a new work
|
||||||
return;
|
*/
|
||||||
break;
|
do {
|
||||||
case SCAN_SEND_PROBE:
|
switch (local->scan_state) {
|
||||||
ieee80211_scan_state_send_probe(local, &next_delay);
|
case SCAN_SET_CHANNEL:
|
||||||
break;
|
if (ieee80211_scan_state_set_channel(local, &next_delay))
|
||||||
}
|
return;
|
||||||
|
break;
|
||||||
|
case SCAN_SEND_PROBE:
|
||||||
|
ieee80211_scan_state_send_probe(local, &next_delay);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} while (next_delay == 0);
|
||||||
|
|
||||||
queue_delayed_work(local->hw.workqueue, &local->scan_work,
|
queue_delayed_work(local->hw.workqueue, &local->scan_work,
|
||||||
next_delay);
|
next_delay);
|
||||||
|
Loading…
Reference in New Issue
Block a user