3
0
mirror of https://git.kernel.org/pub/scm/network/wireless/iwd.git synced 2025-01-05 12:52:37 +01:00

scan: Switch all uses of ifindex to wdev_id

The ifindex is used to index the netdevs in the system (wlan, ethernet,
etc.) but we can also do wifi scanning on interfaces that have no
corresponding netdev object, like the P2P-device virtual interfaces.
Use the wdev id's to reference interfaces, the nl80211 api doesn't care
whether we use a NL80211_ATTR_IFINDEX or NL80211_ATTR_WDEV.  Only
wireless interfaces have a wdev id.
This commit is contained in:
Andrew Zaborowski 2019-07-08 16:02:59 +02:00 committed by Denis Kenzior
parent ec60b51d01
commit b3a395091d
5 changed files with 99 additions and 123 deletions

View File

@ -422,7 +422,7 @@ struct device *device_create(struct wiphy *wiphy, struct netdev *netdev)
l_info("Unable to register %s interface", l_info("Unable to register %s interface",
L_DBUS_INTERFACE_PROPERTIES); L_DBUS_INTERFACE_PROPERTIES);
scan_ifindex_add(device->index); scan_wdev_add(netdev_get_wdev_id(device->netdev));
/* /*
* register for AP roam transition watch * register for AP roam transition watch
@ -449,7 +449,7 @@ void device_remove(struct device *device)
l_dbus_unregister_object(dbus, netdev_get_path(device->netdev)); l_dbus_unregister_object(dbus, netdev_get_path(device->netdev));
scan_ifindex_remove(device->index); scan_wdev_remove(netdev_get_wdev_id(device->netdev));
netdev_frame_watch_remove(device->netdev, device->ap_roam_watch); netdev_frame_watch_remove(device->netdev, device->ap_roam_watch);
wiphy_state_watch_remove(device->wiphy, device->wiphy_rfkill_watch); wiphy_state_watch_remove(device->wiphy, device->wiphy_rfkill_watch);

View File

@ -38,7 +38,6 @@
#include "linux/nl80211.h" #include "linux/nl80211.h"
#include "src/iwd.h" #include "src/iwd.h"
#include "src/wiphy.h" #include "src/wiphy.h"
#include "src/netdev.h"
#include "src/ie.h" #include "src/ie.h"
#include "src/common.h" #include "src/common.h"
#include "src/network.h" #include "src/network.h"
@ -76,7 +75,7 @@ struct scan_request {
}; };
struct scan_context { struct scan_context {
uint32_t ifindex; uint64_t wdev_id;
/* /*
* Tells us whether a scan, our own or external, is running. * Tells us whether a scan, our own or external, is running.
* Set when scan gets triggered, cleared when scan done and * Set when scan gets triggered, cleared when scan done and
@ -118,9 +117,9 @@ static void scan_periodic_rearm(struct scan_context *sc);
static bool scan_context_match(const void *a, const void *b) static bool scan_context_match(const void *a, const void *b)
{ {
const struct scan_context *sc = a; const struct scan_context *sc = a;
uint32_t ifindex = L_PTR_TO_UINT(b); const uint64_t *wdev_id = b;
return (sc->ifindex == ifindex); return sc->wdev_id == *wdev_id;
} }
static bool scan_request_match(const void *a, const void *b) static bool scan_request_match(const void *a, const void *b)
@ -156,22 +155,17 @@ static void scan_request_failed(struct scan_context *sc,
scan_request_free(sr); scan_request_free(sr);
} }
static struct scan_context *scan_context_new(uint32_t ifindex) static struct scan_context *scan_context_new(uint64_t wdev_id)
{ {
struct netdev *netdev = netdev_find(ifindex); struct wiphy *wiphy = wiphy_find(wdev_id >> 32);
struct wiphy *wiphy;
struct scan_context *sc; struct scan_context *sc;
if (!netdev)
return NULL;
wiphy = netdev_get_wiphy(netdev);
if (!wiphy) if (!wiphy)
return NULL; return NULL;
sc = l_new(struct scan_context, 1); sc = l_new(struct scan_context, 1);
sc->ifindex = ifindex; sc->wdev_id = wdev_id;
sc->wiphy = wiphy; sc->wiphy = wiphy;
sc->state = SCAN_STATE_NOT_RUNNING; sc->state = SCAN_STATE_NOT_RUNNING;
sc->requests = l_queue_new(); sc->requests = l_queue_new();
@ -227,8 +221,8 @@ static void scan_request_triggered(struct l_genl_msg *msg, void *userdata)
} }
sc->state = sr->passive ? SCAN_STATE_PASSIVE : SCAN_STATE_ACTIVE; sc->state = sr->passive ? SCAN_STATE_PASSIVE : SCAN_STATE_ACTIVE;
l_debug("%s scan triggered for ifindex: %u", l_debug("%s scan triggered for wdev %" PRIx64,
sr->passive ? "Passive" : "Active", sc->ifindex); sr->passive ? "Passive" : "Active", sc->wdev_id);
sc->triggered = true; sc->triggered = true;
sc->started = true; sc->started = true;
@ -291,7 +285,7 @@ static struct l_genl_msg *scan_build_cmd(struct scan_context *sc,
msg = l_genl_msg_new(NL80211_CMD_TRIGGER_SCAN); msg = l_genl_msg_new(NL80211_CMD_TRIGGER_SCAN);
l_genl_msg_append_attr(msg, NL80211_ATTR_IFINDEX, 4, &sc->ifindex); l_genl_msg_append_attr(msg, NL80211_ATTR_WDEV, 8, &sc->wdev_id);
if (params->extra_ie && params->extra_ie_size) if (params->extra_ie && params->extra_ie_size)
l_genl_msg_append_attr(msg, NL80211_ATTR_IE, l_genl_msg_append_attr(msg, NL80211_ATTR_IE,
@ -425,7 +419,7 @@ static int scan_request_send_trigger(struct scan_context *sc,
return -EIO; return -EIO;
} }
static uint32_t scan_common(uint32_t ifindex, bool passive, static uint32_t scan_common(uint64_t wdev_id, bool passive,
const struct scan_parameters *params, const struct scan_parameters *params,
scan_trigger_func_t trigger, scan_trigger_func_t trigger,
scan_notify_func_t notify, void *userdata, scan_notify_func_t notify, void *userdata,
@ -434,8 +428,7 @@ static uint32_t scan_common(uint32_t ifindex, bool passive,
struct scan_context *sc; struct scan_context *sc;
struct scan_request *sr; struct scan_request *sr;
sc = l_queue_find(scan_contexts, scan_context_match, sc = l_queue_find(scan_contexts, scan_context_match, &wdev_id);
L_UINT_TO_PTR(ifindex));
if (!sc) if (!sc)
return 0; return 0;
@ -470,17 +463,17 @@ done:
return sr->id; return sr->id;
} }
uint32_t scan_passive(uint32_t ifindex, struct scan_freq_set *freqs, uint32_t scan_passive(uint64_t wdev_id, struct scan_freq_set *freqs,
scan_trigger_func_t trigger, scan_notify_func_t notify, scan_trigger_func_t trigger, scan_notify_func_t notify,
void *userdata, scan_destroy_func_t destroy) void *userdata, scan_destroy_func_t destroy)
{ {
struct scan_parameters params = { .freqs = freqs }; struct scan_parameters params = { .freqs = freqs };
return scan_common(ifindex, true, &params, trigger, notify, return scan_common(wdev_id, true, &params, trigger, notify,
userdata, destroy); userdata, destroy);
} }
uint32_t scan_active(uint32_t ifindex, uint8_t *extra_ie, size_t extra_ie_size, uint32_t scan_active(uint64_t wdev_id, uint8_t *extra_ie, size_t extra_ie_size,
scan_trigger_func_t trigger, scan_trigger_func_t trigger,
scan_notify_func_t notify, void *userdata, scan_notify_func_t notify, void *userdata,
scan_destroy_func_t destroy) scan_destroy_func_t destroy)
@ -490,26 +483,25 @@ uint32_t scan_active(uint32_t ifindex, uint8_t *extra_ie, size_t extra_ie_size,
params.extra_ie = extra_ie; params.extra_ie = extra_ie;
params.extra_ie_size = extra_ie_size; params.extra_ie_size = extra_ie_size;
return scan_common(ifindex, false, &params, return scan_common(wdev_id, false, &params,
trigger, notify, userdata, destroy); trigger, notify, userdata, destroy);
} }
uint32_t scan_active_full(uint32_t ifindex, uint32_t scan_active_full(uint64_t wdev_id,
const struct scan_parameters *params, const struct scan_parameters *params,
scan_trigger_func_t trigger, scan_notify_func_t notify, scan_trigger_func_t trigger, scan_notify_func_t notify,
void *userdata, scan_destroy_func_t destroy) void *userdata, scan_destroy_func_t destroy)
{ {
return scan_common(ifindex, false, params, return scan_common(wdev_id, false, params,
trigger, notify, userdata, destroy); trigger, notify, userdata, destroy);
} }
bool scan_cancel(uint32_t ifindex, uint32_t id) bool scan_cancel(uint64_t wdev_id, uint32_t id)
{ {
struct scan_context *sc; struct scan_context *sc;
struct scan_request *sr; struct scan_request *sr;
sc = l_queue_find(scan_contexts, scan_context_match, sc = l_queue_find(scan_contexts, scan_context_match, &wdev_id);
L_UINT_TO_PTR(ifindex));
if (!sc) if (!sc)
return false; return false;
@ -557,7 +549,7 @@ static void scan_periodic_triggered(int err, void *user_data)
return; return;
} }
l_debug("Periodic scan triggered for ifindex: %u", sc->ifindex); l_debug("Periodic scan triggered for wdev %" PRIx64, sc->wdev_id);
if (sc->sp.trigger) if (sc->sp.trigger)
sc->sp.trigger(0, sc->sp.userdata); sc->sp.trigger(0, sc->sp.userdata);
@ -590,11 +582,11 @@ static bool scan_periodic_queue(struct scan_context *sc)
sc->sp.needs_active_scan = false; sc->sp.needs_active_scan = false;
sc->sp.id = scan_active_full(sc->ifindex, &params, sc->sp.id = scan_active_full(sc->wdev_id, &params,
scan_periodic_triggered, scan_periodic_triggered,
scan_periodic_notify, sc, NULL); scan_periodic_notify, sc, NULL);
} else } else
sc->sp.id = scan_passive(sc->ifindex, NULL, sc->sp.id = scan_passive(sc->wdev_id, NULL,
scan_periodic_triggered, scan_periodic_triggered,
scan_periodic_notify, sc, NULL); scan_periodic_notify, sc, NULL);
@ -613,7 +605,7 @@ static bool scan_periodic_is_disabled(void)
return disabled; return disabled;
} }
void scan_periodic_start(uint32_t ifindex, scan_trigger_func_t trigger, void scan_periodic_start(uint64_t wdev_id, scan_trigger_func_t trigger,
scan_notify_func_t func, void *userdata) scan_notify_func_t func, void *userdata)
{ {
struct scan_context *sc; struct scan_context *sc;
@ -621,18 +613,17 @@ void scan_periodic_start(uint32_t ifindex, scan_trigger_func_t trigger,
if (scan_periodic_is_disabled()) if (scan_periodic_is_disabled())
return; return;
sc = l_queue_find(scan_contexts, scan_context_match, sc = l_queue_find(scan_contexts, scan_context_match, &wdev_id);
L_UINT_TO_PTR(ifindex));
if (!sc) { if (!sc) {
l_error("scan_periodic_start called without scan_ifindex_add"); l_error("scan_periodic_start called without scan_wdev_add");
return; return;
} }
if (sc->sp.interval) if (sc->sp.interval)
return; return;
l_debug("Starting periodic scan for ifindex: %u", ifindex); l_debug("Starting periodic scan for wdev %" PRIx64, wdev_id);
sc->sp.interval = SCAN_INIT_INTERVAL; sc->sp.interval = SCAN_INIT_INTERVAL;
sc->sp.trigger = trigger; sc->sp.trigger = trigger;
@ -643,12 +634,11 @@ void scan_periodic_start(uint32_t ifindex, scan_trigger_func_t trigger,
scan_periodic_queue(sc); scan_periodic_queue(sc);
} }
bool scan_periodic_stop(uint32_t ifindex) bool scan_periodic_stop(uint64_t wdev_id)
{ {
struct scan_context *sc; struct scan_context *sc;
sc = l_queue_find(scan_contexts, scan_context_match, sc = l_queue_find(scan_contexts, scan_context_match, &wdev_id);
L_UINT_TO_PTR(ifindex));
if (!sc) if (!sc)
return false; return false;
@ -656,13 +646,13 @@ bool scan_periodic_stop(uint32_t ifindex)
if (!sc->sp.interval) if (!sc->sp.interval)
return false; return false;
l_debug("Stopping periodic scan for ifindex: %u", ifindex); l_debug("Stopping periodic scan for wdev %" PRIx64, wdev_id);
if (sc->sp.timeout) if (sc->sp.timeout)
l_timeout_remove(sc->sp.timeout); l_timeout_remove(sc->sp.timeout);
if (sc->sp.id) { if (sc->sp.id) {
scan_cancel(ifindex, sc->sp.id); scan_cancel(wdev_id, sc->sp.id);
sc->sp.id = 0; sc->sp.id = 0;
} }
@ -680,7 +670,7 @@ static void scan_periodic_timeout(struct l_timeout *timeout, void *user_data)
{ {
struct scan_context *sc = user_data; struct scan_context *sc = user_data;
l_debug("scan_periodic_timeout: %u", sc->ifindex); l_debug("scan_periodic_timeout: %" PRIx64, sc->wdev_id);
sc->sp.interval *= 2; sc->sp.interval *= 2;
@ -989,14 +979,12 @@ static struct scan_freq_set *scan_parse_attr_scan_frequencies(
} }
static struct scan_bss *scan_parse_result(struct l_genl_msg *msg, static struct scan_bss *scan_parse_result(struct l_genl_msg *msg,
uint32_t *out_ifindex,
uint64_t *out_wdev) uint64_t *out_wdev)
{ {
struct l_genl_attr attr, nested; struct l_genl_attr attr, nested;
uint16_t type, len; uint16_t type, len;
const void *data; const void *data;
uint32_t ifindex; const uint64_t *wdev = NULL;
uint64_t wdev;
struct scan_bss *bss = NULL; struct scan_bss *bss = NULL;
if (!l_genl_attr_init(&attr, msg)) if (!l_genl_attr_init(&attr, msg))
@ -1004,18 +992,11 @@ static struct scan_bss *scan_parse_result(struct l_genl_msg *msg,
while (l_genl_attr_next(&attr, &type, &len, &data)) { while (l_genl_attr_next(&attr, &type, &len, &data)) {
switch (type) { switch (type) {
case NL80211_ATTR_IFINDEX:
if (len != sizeof(uint32_t))
return NULL;
ifindex = *((uint32_t *) data);
break;
case NL80211_ATTR_WDEV: case NL80211_ATTR_WDEV:
if (len != sizeof(uint64_t)) if (len != sizeof(uint64_t))
return NULL; return NULL;
wdev = *((uint64_t *) data); wdev = data;
break; break;
case NL80211_ATTR_BSS: case NL80211_ATTR_BSS:
@ -1030,11 +1011,13 @@ static struct scan_bss *scan_parse_result(struct l_genl_msg *msg,
if (!bss) if (!bss)
return NULL; return NULL;
if (out_ifindex) if (!wdev) {
*out_ifindex = ifindex; scan_bss_free(bss);
return NULL;
}
if (out_wdev) if (out_wdev)
*out_wdev = wdev; *out_wdev = *wdev;
return bss; return bss;
} }
@ -1177,19 +1160,19 @@ static void get_scan_callback(struct l_genl_msg *msg, void *user_data)
struct scan_results *results = user_data; struct scan_results *results = user_data;
struct scan_context *sc = results->sc; struct scan_context *sc = results->sc;
struct scan_bss *bss; struct scan_bss *bss;
uint32_t ifindex; uint64_t wdev_id;
l_debug("get_scan_callback"); l_debug("get_scan_callback");
if (!results->bss_list) if (!results->bss_list)
results->bss_list = l_queue_new(); results->bss_list = l_queue_new();
bss = scan_parse_result(msg, &ifindex, NULL); bss = scan_parse_result(msg, &wdev_id);
if (!bss) if (!bss)
return; return;
if (ifindex != sc->ifindex) { if (wdev_id != sc->wdev_id) {
l_warn("ifindex mismatch in get_scan_callback"); l_warn("wdev mismatch in get_scan_callback");
scan_bss_free(bss); scan_bss_free(bss);
return; return;
} }
@ -1318,8 +1301,8 @@ static void scan_notify(struct l_genl_msg *msg, void *user_data)
uint16_t type, len; uint16_t type, len;
const void *data; const void *data;
uint8_t cmd; uint8_t cmd;
uint32_t uninitialized_var(attr_ifindex); uint64_t uninitialized_var(attr_wdev_id);
bool have_ifindex; bool have_wdev_id;
uint32_t uninitialized_var(attr_wiphy); uint32_t uninitialized_var(attr_wiphy);
bool have_wiphy; bool have_wiphy;
struct scan_context *sc; struct scan_context *sc;
@ -1343,14 +1326,14 @@ static void scan_notify(struct l_genl_msg *msg, void *user_data)
have_wiphy = true; have_wiphy = true;
attr_wiphy = *((uint32_t *) data); attr_wiphy = *((uint32_t *) data);
break; break;
case NL80211_ATTR_IFINDEX: case NL80211_ATTR_WDEV:
if (len != sizeof(uint32_t)) { if (len != sizeof(uint64_t)) {
l_warn("Invalid interface index attribute"); l_warn("Invalid wdev index attribute");
return; return;
} }
have_ifindex = true; have_wdev_id = true;
attr_ifindex = *((uint32_t *) data); attr_wdev_id = *((uint64_t *) data);
break; break;
case NL80211_ATTR_SCAN_SSIDS: case NL80211_ATTR_SCAN_SSIDS:
active_scan = true; active_scan = true;
@ -1363,13 +1346,12 @@ static void scan_notify(struct l_genl_msg *msg, void *user_data)
return; return;
} }
if (!have_ifindex) { if (!have_wdev_id) {
l_warn("Scan results do not contain ifindex attribute"); l_warn("Scan results do not contain wdev attribute");
return; return;
} }
sc = l_queue_find(scan_contexts, scan_context_match, sc = l_queue_find(scan_contexts, scan_context_match, &attr_wdev_id);
L_UINT_TO_PTR(attr_ifindex));
if (!sc) if (!sc)
return; return;
@ -1437,8 +1419,8 @@ static void scan_notify(struct l_genl_msg *msg, void *user_data)
scan_parse_new_scan_results(msg, results); scan_parse_new_scan_results(msg, results);
scan_msg = l_genl_msg_new_sized(NL80211_CMD_GET_SCAN, 8); scan_msg = l_genl_msg_new_sized(NL80211_CMD_GET_SCAN, 8);
l_genl_msg_append_attr(scan_msg, NL80211_ATTR_IFINDEX, 4, l_genl_msg_append_attr(scan_msg, NL80211_ATTR_WDEV, 8,
&attr_ifindex); &sc->wdev_id);
sc->get_scan_cmd_id = l_genl_family_dump(nl80211, scan_msg, sc->get_scan_cmd_id = l_genl_family_dump(nl80211, scan_msg,
get_scan_callback, get_scan_callback,
results, get_scan_done); results, get_scan_done);
@ -1829,17 +1811,14 @@ void scan_freq_set_constrain(struct scan_freq_set *set,
set->channels_2ghz &= constraint->channels_2ghz; set->channels_2ghz &= constraint->channels_2ghz;
} }
bool scan_ifindex_add(uint32_t ifindex) bool scan_wdev_add(uint64_t wdev_id)
{ {
struct scan_context *sc; struct scan_context *sc;
sc = l_queue_find(scan_contexts, scan_context_match, if (l_queue_find(scan_contexts, scan_context_match, &wdev_id))
L_UINT_TO_PTR(ifindex));
if (sc)
return false; return false;
sc = scan_context_new(ifindex); sc = scan_context_new(wdev_id);
if (!sc) if (!sc)
return false; return false;
@ -1855,17 +1834,16 @@ done:
return true; return true;
} }
bool scan_ifindex_remove(uint32_t ifindex) bool scan_wdev_remove(uint64_t wdev_id)
{ {
struct scan_context *sc; struct scan_context *sc;
sc = l_queue_remove_if(scan_contexts, scan_context_match, sc = l_queue_remove_if(scan_contexts, scan_context_match, &wdev_id);
L_UINT_TO_PTR(ifindex));
if (!sc) if (!sc)
return false; return false;
l_info("Removing scan context for ifindex: %u", ifindex); l_info("Removing scan context for wdev %" PRIx64, wdev_id);
scan_context_free(sc); scan_context_free(sc);
if (l_queue_isempty(scan_contexts)) { if (l_queue_isempty(scan_contexts)) {
@ -1876,12 +1854,11 @@ bool scan_ifindex_remove(uint32_t ifindex)
return true; return true;
} }
bool scan_suspend(uint32_t ifindex) bool scan_suspend(uint64_t wdev_id)
{ {
struct scan_context *sc; struct scan_context *sc;
sc = l_queue_find(scan_contexts, scan_context_match, sc = l_queue_find(scan_contexts, scan_context_match, &wdev_id);
L_UINT_TO_PTR(ifindex));
if (!sc) if (!sc)
return false; return false;
@ -1890,12 +1867,11 @@ bool scan_suspend(uint32_t ifindex)
return true; return true;
} }
void scan_resume(uint32_t ifindex) void scan_resume(uint64_t wdev_id)
{ {
struct scan_context *sc; struct scan_context *sc;
sc = l_queue_find(scan_contexts, scan_context_match, sc = l_queue_find(scan_contexts, scan_context_match, &wdev_id);
L_UINT_TO_PTR(ifindex));
if (!sc) if (!sc)
return; return;

View File

@ -94,22 +94,22 @@ static inline bool scan_bss_addr_eq(const struct scan_bss *a1,
return !memcmp(a1->addr, a2->addr, sizeof(a1->addr)); return !memcmp(a1->addr, a2->addr, sizeof(a1->addr));
} }
uint32_t scan_passive(uint32_t ifindex, struct scan_freq_set *freqs, uint32_t scan_passive(uint64_t wdev_id, struct scan_freq_set *freqs,
scan_trigger_func_t trigger, scan_notify_func_t notify, scan_trigger_func_t trigger, scan_notify_func_t notify,
void *userdata, scan_destroy_func_t destroy); void *userdata, scan_destroy_func_t destroy);
uint32_t scan_active(uint32_t ifindex, uint8_t *extra_ie, size_t extra_ie_size, uint32_t scan_active(uint64_t wdev_id, uint8_t *extra_ie, size_t extra_ie_size,
scan_trigger_func_t trigger, scan_trigger_func_t trigger,
scan_notify_func_t notify, void *userdata, scan_notify_func_t notify, void *userdata,
scan_destroy_func_t destroy); scan_destroy_func_t destroy);
uint32_t scan_active_full(uint32_t ifindex, uint32_t scan_active_full(uint64_t wdev_id,
const struct scan_parameters *params, const struct scan_parameters *params,
scan_trigger_func_t trigger, scan_notify_func_t notify, scan_trigger_func_t trigger, scan_notify_func_t notify,
void *userdata, scan_destroy_func_t destroy); void *userdata, scan_destroy_func_t destroy);
bool scan_cancel(uint32_t ifindex, uint32_t id); bool scan_cancel(uint64_t wdev_id, uint32_t id);
void scan_periodic_start(uint32_t ifindex, scan_trigger_func_t trigger, void scan_periodic_start(uint64_t wdev_id, scan_trigger_func_t trigger,
scan_notify_func_t func, void *userdata); scan_notify_func_t func, void *userdata);
bool scan_periodic_stop(uint32_t ifindex); bool scan_periodic_stop(uint64_t wdev_id);
void scan_bss_free(struct scan_bss *bss); void scan_bss_free(struct scan_bss *bss);
int scan_bss_rank_compare(const void *a, const void *b, void *user); int scan_bss_rank_compare(const void *a, const void *b, void *user);
@ -133,8 +133,8 @@ void scan_freq_set_merge(struct scan_freq_set *to,
void scan_freq_set_constrain(struct scan_freq_set *set, void scan_freq_set_constrain(struct scan_freq_set *set,
const struct scan_freq_set *constraint); const struct scan_freq_set *constraint);
bool scan_ifindex_add(uint32_t ifindex); bool scan_wdev_add(uint64_t wdev_id);
bool scan_ifindex_remove(uint32_t ifindex); bool scan_wdev_remove(uint64_t wdev_id);
bool scan_suspend(uint32_t ifindex); bool scan_suspend(uint64_t wdev_id);
void scan_resume(uint32_t ifindex); void scan_resume(uint64_t wdev_id);

View File

@ -446,7 +446,7 @@ request_done:
/* If no more requests, resume scanning */ /* If no more requests, resume scanning */
if (l_queue_isempty(station->anqp_pending)) if (l_queue_isempty(station->anqp_pending))
scan_resume(netdev_get_ifindex(station->netdev)); scan_resume(netdev_get_wdev_id(station->netdev));
} }
static bool station_start_anqp(struct station *station, struct network *network, static bool station_start_anqp(struct station *station, struct network *network,
@ -588,7 +588,7 @@ void station_set_scan_results(struct station *station,
* scanning. * scanning.
*/ */
if (wait_for_anqp) if (wait_for_anqp)
scan_suspend(netdev_get_ifindex(station->netdev)); scan_suspend(netdev_get_wdev_id(station->netdev));
} }
static void station_reconnect(struct station *station); static void station_reconnect(struct station *station);
@ -905,9 +905,9 @@ static void periodic_scan_trigger(int err, void *user_data)
static void periodic_scan_stop(struct station *station) static void periodic_scan_stop(struct station *station)
{ {
uint32_t index = netdev_get_ifindex(station->netdev); uint64_t id = netdev_get_wdev_id(station->netdev);
scan_periodic_stop(index); scan_periodic_stop(id);
station_property_set_scanning(station, false); station_property_set_scanning(station, false);
} }
@ -924,7 +924,7 @@ static uint32_t station_scan_trigger(struct station *station,
scan_notify_func_t notify, scan_notify_func_t notify,
scan_destroy_func_t destroy) scan_destroy_func_t destroy)
{ {
uint32_t index = netdev_get_ifindex(station->netdev); uint64_t id = netdev_get_wdev_id(station->netdev);
if (wiphy_can_randomize_mac_addr(station->wiphy) || if (wiphy_can_randomize_mac_addr(station->wiphy) ||
station_needs_hidden_network_scan(station) || station_needs_hidden_network_scan(station) ||
@ -939,11 +939,11 @@ static uint32_t station_scan_trigger(struct station *station,
params.freqs = freqs; params.freqs = freqs;
return scan_active_full(index, &params, triggered, notify, return scan_active_full(id, &params, triggered, notify,
station, destroy); station, destroy);
} }
return scan_passive(index, freqs, triggered, notify, station, destroy); return scan_passive(id, freqs, triggered, notify, station, destroy);
} }
static bool station_quick_scan_results(int err, struct l_queue *bss_list, static bool station_quick_scan_results(int err, struct l_queue *bss_list,
@ -1052,7 +1052,7 @@ static const char *station_state_to_string(enum station_state state)
static void station_enter_state(struct station *station, static void station_enter_state(struct station *station,
enum station_state state) enum station_state state)
{ {
uint32_t index = netdev_get_ifindex(station->netdev); uint64_t id = netdev_get_wdev_id(station->netdev);
struct l_dbus *dbus = dbus_get_bus(); struct l_dbus *dbus = dbus_get_bus();
bool disconnected; bool disconnected;
@ -1072,7 +1072,7 @@ static void station_enter_state(struct station *station,
station_quick_scan_trigger(station); station_quick_scan_trigger(station);
break; break;
case STATION_STATE_AUTOCONNECT_FULL: case STATION_STATE_AUTOCONNECT_FULL:
scan_periodic_start(index, periodic_scan_trigger, scan_periodic_start(id, periodic_scan_trigger,
new_scan_results, station); new_scan_results, station);
break; break;
case STATION_STATE_CONNECTING: case STATION_STATE_CONNECTING:
@ -1140,7 +1140,7 @@ static void station_roam_state_clear(struct station *station)
station->roam_min_time.tv_sec = 0; station->roam_min_time.tv_sec = 0;
if (station->roam_scan_id) if (station->roam_scan_id)
scan_cancel(netdev_get_ifindex(station->netdev), scan_cancel(netdev_get_wdev_id(station->netdev),
station->roam_scan_id); station->roam_scan_id);
} }
@ -1612,7 +1612,7 @@ static void station_roam_scan(struct station *station,
params.ssid = network_get_ssid(station->connected_network); params.ssid = network_get_ssid(station->connected_network);
station->roam_scan_id = station->roam_scan_id =
scan_active_full(netdev_get_ifindex(station->netdev), &params, scan_active_full(netdev_get_wdev_id(station->netdev), &params,
station_roam_scan_triggered, station_roam_scan_triggered,
station_roam_scan_notify, station, station_roam_scan_notify, station,
station_roam_scan_destroy); station_roam_scan_destroy);
@ -2294,7 +2294,7 @@ static struct l_dbus_message *station_dbus_connect_hidden_network(
void *user_data) void *user_data)
{ {
struct station *station = user_data; struct station *station = user_data;
uint32_t index = netdev_get_ifindex(station->netdev); uint64_t id = netdev_get_wdev_id(station->netdev);
struct scan_parameters params = { struct scan_parameters params = {
.flush = true, .flush = true,
.randomize_mac_addr_hint = true, .randomize_mac_addr_hint = true,
@ -2322,7 +2322,7 @@ static struct l_dbus_message *station_dbus_connect_hidden_network(
params.ssid = ssid; params.ssid = ssid;
station->hidden_network_scan_id = scan_active_full(index, &params, station->hidden_network_scan_id = scan_active_full(id, &params,
station_hidden_network_scan_triggered, station_hidden_network_scan_triggered,
station_hidden_network_scan_results, station_hidden_network_scan_results,
station, station_hidden_network_scan_destroy); station, station_hidden_network_scan_destroy);
@ -2873,15 +2873,15 @@ static void station_free(struct station *station)
dbus_error_aborted(station->scan_pending)); dbus_error_aborted(station->scan_pending));
if (station->dbus_scan_id) if (station->dbus_scan_id)
scan_cancel(netdev_get_ifindex(station->netdev), scan_cancel(netdev_get_wdev_id(station->netdev),
station->dbus_scan_id); station->dbus_scan_id);
if (station->quick_scan_id) if (station->quick_scan_id)
scan_cancel(netdev_get_ifindex(station->netdev), scan_cancel(netdev_get_wdev_id(station->netdev),
station->quick_scan_id); station->quick_scan_id);
if (station->hidden_network_scan_id) if (station->hidden_network_scan_id)
scan_cancel(netdev_get_ifindex(station->netdev), scan_cancel(netdev_get_wdev_id(station->netdev),
station->hidden_network_scan_id); station->hidden_network_scan_id);
station_roam_state_clear(station); station_roam_state_clear(station);

View File

@ -535,7 +535,7 @@ static void wsc_cancel_scan(struct wsc *wsc)
wsc->wsc_ies = 0; wsc->wsc_ies = 0;
if (wsc->scan_id > 0) { if (wsc->scan_id > 0) {
scan_cancel(netdev_get_ifindex(wsc->netdev), wsc->scan_id); scan_cancel(netdev_get_wdev_id(wsc->netdev), wsc->scan_id);
wsc->scan_id = 0; wsc->scan_id = 0;
} }
@ -665,7 +665,7 @@ static bool push_button_scan_results(int err, struct l_queue *bss_list,
target = bss_2g; target = bss_2g;
else { else {
l_debug("No PBC APs found, running the scan again"); l_debug("No PBC APs found, running the scan again");
wsc->scan_id = scan_active(netdev_get_ifindex(wsc->netdev), wsc->scan_id = scan_active(netdev_get_wdev_id(wsc->netdev),
wsc->wsc_ies, wsc->wsc_ies_size, wsc->wsc_ies, wsc->wsc_ies_size,
NULL, push_button_scan_results, NULL, push_button_scan_results,
wsc, NULL); wsc, NULL);
@ -811,7 +811,7 @@ static bool pin_scan_results(int err, struct l_queue *bss_list, void *userdata)
if (!target) { if (!target) {
l_debug("No PIN APs found, running the scan again"); l_debug("No PIN APs found, running the scan again");
wsc->scan_id = scan_active(netdev_get_ifindex(wsc->netdev), wsc->scan_id = scan_active(netdev_get_wdev_id(wsc->netdev),
wsc->wsc_ies, wsc->wsc_ies_size, wsc->wsc_ies, wsc->wsc_ies_size,
NULL, pin_scan_results, NULL, pin_scan_results,
wsc, NULL); wsc, NULL);
@ -879,7 +879,7 @@ static bool wsc_initiate_scan(struct wsc *wsc,
if (!wsc->wsc_ies) if (!wsc->wsc_ies)
return false; return false;
wsc->scan_id = scan_active(netdev_get_ifindex(wsc->netdev), wsc->scan_id = scan_active(netdev_get_wdev_id(wsc->netdev),
wsc->wsc_ies, wsc->wsc_ies_size, wsc->wsc_ies, wsc->wsc_ies_size,
NULL, callback, wsc, NULL); NULL, callback, wsc, NULL);
if (!wsc->scan_id) { if (!wsc->scan_id) {
@ -903,7 +903,7 @@ static struct l_dbus_message *wsc_push_button(struct l_dbus *dbus,
if (wsc->pending) if (wsc->pending)
return dbus_error_busy(message); return dbus_error_busy(message);
wsc->station = station_find(netdev_get_ifindex(wsc->netdev)); wsc->station = station_find(netdev_get_wdev_id(wsc->netdev));
if (!wsc->station) if (!wsc->station)
return dbus_error_not_available(message); return dbus_error_not_available(message);