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

wiphy: Use network_autoconnect

This commit is contained in:
Denis Kenzior 2016-05-16 14:24:47 -05:00
parent 8e8b2caa9a
commit dcadf4d2f8

View File

@ -639,67 +639,10 @@ static bool netdev_match(const void *a, const void *b)
return (netdev->index == index); return (netdev->index == index);
} }
static bool netdev_try_autoconnect(struct netdev *netdev,
struct network *network,
struct scan_bss *bss)
{
struct wiphy *wiphy = netdev->wiphy;
switch (network_get_security(network)) {
case SECURITY_NONE:
break;
case SECURITY_PSK:
{
uint16_t pairwise_ciphers, group_ciphers;
const char *psk;
size_t len;
bss_get_supported_ciphers(bss,
&pairwise_ciphers, &group_ciphers);
if (!wiphy_select_cipher(wiphy, pairwise_ciphers) ||
!wiphy_select_cipher(wiphy, group_ciphers)) {
l_debug("Cipher mis-match");
return false;
}
if (network->ask_psk)
return false;
network_settings_load(network);
psk = l_settings_get_value(network->settings, "Security",
"PreSharedKey");
/* TODO: Blacklist the network from auto-connect */
if (!psk)
return false;
l_free(network->psk);
network->psk = l_util_from_hexstring(psk, &len);
if (network->psk && len != 32) {
l_free(network->psk);
network->psk = NULL;
return false;
}
break;
}
case SECURITY_8021X:
network_settings_load(network);
break;
default:
return false;
}
device_connect_network(netdev, network, bss, NULL);
return true;
}
static void netdev_autoconnect_next(struct netdev *netdev) static void netdev_autoconnect_next(struct netdev *netdev)
{ {
struct autoconnect_entry *entry; struct autoconnect_entry *entry;
bool r; int r;
while ((entry = l_queue_pop_head(netdev->autoconnect_list))) { while ((entry = l_queue_pop_head(netdev->autoconnect_list))) {
l_debug("Considering autoconnecting to BSS '%s' with SSID: %s," l_debug("Considering autoconnecting to BSS '%s' with SSID: %s,"
@ -709,10 +652,11 @@ static void netdev_autoconnect_next(struct netdev *netdev)
entry->bss->frequency, entry->rank, entry->bss->frequency, entry->rank,
entry->bss->signal_strength); entry->bss->signal_strength);
r = netdev_try_autoconnect(netdev, entry->network, entry->bss); /* TODO: Blacklist the network from auto-connect */
r = network_autoconnect(entry->network, entry->bss);
l_free(entry); l_free(entry);
if (r) if (!r)
return; return;
} }
} }