mirror of
https://git.kernel.org/pub/scm/network/wireless/iwd.git
synced 2025-01-05 12:52:37 +01:00
knownnetworks: make known frequencies its own module
The known frequency file was being loaded at the end of the known networks initialization routine. This allowed all known networks to be properly loaded, but since hotspot depends on known networks, its initalization would be run afterwards meaning the frequency loading would not have been finding any hotspot networks. To fix this a new module was added inside known networks which depends on hotspot. This means that first known networks will initialize, then hotspot, then the frequency file would be loaded.
This commit is contained in:
parent
c1890c6b06
commit
ef209c305b
@ -781,7 +781,7 @@ static struct network_info *find_network_info_from_path(const char *path)
|
|||||||
return search.info;
|
return search.info;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void known_network_frequencies_load(void)
|
static int known_network_frequencies_load(void)
|
||||||
{
|
{
|
||||||
char **groups;
|
char **groups;
|
||||||
struct l_queue *known_frequencies;
|
struct l_queue *known_frequencies;
|
||||||
@ -790,7 +790,7 @@ static void known_network_frequencies_load(void)
|
|||||||
known_freqs = storage_known_frequencies_load();
|
known_freqs = storage_known_frequencies_load();
|
||||||
if (!known_freqs) {
|
if (!known_freqs) {
|
||||||
l_debug("No known frequency file found.");
|
l_debug("No known frequency file found.");
|
||||||
return;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
groups = l_settings_get_groups(known_freqs);
|
groups = l_settings_get_groups(known_freqs);
|
||||||
@ -822,6 +822,8 @@ next:
|
|||||||
}
|
}
|
||||||
|
|
||||||
l_strv_free(groups);
|
l_strv_free(groups);
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -931,8 +933,6 @@ static int known_networks_init(void)
|
|||||||
|
|
||||||
closedir(dir);
|
closedir(dir);
|
||||||
|
|
||||||
known_network_frequencies_load();
|
|
||||||
|
|
||||||
storage_dir_watch = l_dir_watch_new(storage_dir,
|
storage_dir_watch = l_dir_watch_new(storage_dir,
|
||||||
known_networks_watch_cb, NULL,
|
known_networks_watch_cb, NULL,
|
||||||
known_networks_watch_destroy);
|
known_networks_watch_destroy);
|
||||||
@ -950,11 +950,22 @@ static void known_networks_exit(void)
|
|||||||
l_queue_destroy(known_networks, network_info_free);
|
l_queue_destroy(known_networks, network_info_free);
|
||||||
known_networks = NULL;
|
known_networks = NULL;
|
||||||
|
|
||||||
l_settings_free(known_freqs);
|
|
||||||
|
|
||||||
l_dbus_unregister_interface(dbus, IWD_KNOWN_NETWORK_INTERFACE);
|
l_dbus_unregister_interface(dbus, IWD_KNOWN_NETWORK_INTERFACE);
|
||||||
|
|
||||||
watchlist_destroy(&known_network_watches);
|
watchlist_destroy(&known_network_watches);
|
||||||
}
|
}
|
||||||
|
|
||||||
IWD_MODULE(known_networks, known_networks_init, known_networks_exit)
|
IWD_MODULE(known_networks, known_networks_init, known_networks_exit)
|
||||||
|
|
||||||
|
static void known_frequencies_exit(void)
|
||||||
|
{
|
||||||
|
l_settings_free(known_freqs);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Since the known frequency file should only be read in after all known
|
||||||
|
* networks are loaded (including hotspots) we need to create another module
|
||||||
|
* here which depends on hotspot.
|
||||||
|
*/
|
||||||
|
IWD_MODULE(known_frequencies, known_network_frequencies_load, known_frequencies_exit)
|
||||||
|
IWD_MODULE_DEPENDS(known_frequencies, hotspot)
|
||||||
|
Loading…
Reference in New Issue
Block a user