mirror of
https://git.kernel.org/pub/scm/network/wireless/iwd.git
synced 2024-12-31 23:42:52 +01:00
scan: Simplify scan_finished
There are similar operations being performed but with different callbacks and userdata, depending on whether 'sr' is NULL or not. Optimize the function flow slightly to make if-else unnecessary. While here, update the comment. periodic scans are now scheduled only based on the periodic timeout timer.
This commit is contained in:
parent
1fd6aba43c
commit
bef550df81
32
src/scan.c
32
src/scan.c
@ -1703,32 +1703,32 @@ static void scan_finished(struct scan_context *sc,
|
|||||||
struct scan_request *sr)
|
struct scan_request *sr)
|
||||||
{
|
{
|
||||||
bool new_owner = false;
|
bool new_owner = false;
|
||||||
|
scan_notify_func_t callback = sr ? sr->callback : sc->sp.callback;
|
||||||
|
void *userdata = sr ? sr->userdata : sc->sp.userdata;
|
||||||
|
|
||||||
if (bss_list)
|
if (bss_list)
|
||||||
discover_hidden_network_bsses(sc, bss_list);
|
discover_hidden_network_bsses(sc, bss_list);
|
||||||
|
|
||||||
if (sr) {
|
if (sr)
|
||||||
l_queue_remove(sc->requests, sr);
|
l_queue_remove(sc->requests, sr);
|
||||||
|
|
||||||
if (sr->callback)
|
if (callback)
|
||||||
new_owner = sr->callback(err, bss_list,
|
new_owner = callback(err, bss_list, freqs, userdata);
|
||||||
freqs, sr->userdata);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Can start a new scan now that we've removed this one from
|
|
||||||
* the queue. If this were an external scan request (sr NULL)
|
|
||||||
* then the SCAN_FINISHED or SCAN_ABORTED handler would have
|
|
||||||
* taken care of sending the next command for a new or ongoing
|
|
||||||
* scan, or scheduling the next periodic scan.
|
|
||||||
*/
|
|
||||||
wiphy_radio_work_done(sc->wiphy, sr->work.id);
|
|
||||||
} else if (sc->sp.callback)
|
|
||||||
new_owner = sc->sp.callback(err, bss_list,
|
|
||||||
freqs, sc->sp.userdata);
|
|
||||||
|
|
||||||
if (bss_list && !new_owner)
|
if (bss_list && !new_owner)
|
||||||
l_queue_destroy(bss_list,
|
l_queue_destroy(bss_list,
|
||||||
(l_queue_destroy_func_t) scan_bss_free);
|
(l_queue_destroy_func_t) scan_bss_free);
|
||||||
|
|
||||||
|
if (!sr)
|
||||||
|
return;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Can start a new scan now that we've removed this one from the
|
||||||
|
* queue. If this were an external scan request (sr NULL) then the
|
||||||
|
* SCAN_FINISHED or SCAN_ABORTED handler would have taken care of
|
||||||
|
* sending the next command for a new or ongoing scan.
|
||||||
|
*/
|
||||||
|
wiphy_radio_work_done(sc->wiphy, sr->work.id);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void get_scan_done(void *user)
|
static void get_scan_done(void *user)
|
||||||
|
Loading…
Reference in New Issue
Block a user