mirror of
https://git.kernel.org/pub/scm/network/wireless/iwd.git
synced 2025-01-08 15:52:32 +01:00
station: reload settings in 'netconfig_after_roam' case
If netconfig is canceled before completion (when roaming) the settings are freed and never loaded again once netconfig is started post-roam. Now after a roam make sure to re-load the settings and start netconfig.
This commit is contained in:
parent
ccb29663cc
commit
ef27f87dbe
@ -2055,6 +2055,20 @@ static void station_netconfig_event_handler(enum netconfig_event event,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool netconfig_after_roam(struct station *station)
|
||||||
|
{
|
||||||
|
const struct network *network = station_get_connected_network(station);
|
||||||
|
|
||||||
|
/* Netconfig was reset which frees all settings, reload now */
|
||||||
|
if (!netconfig_load_settings(station->netconfig,
|
||||||
|
network_get_settings(network)))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
return netconfig_configure(station->netconfig,
|
||||||
|
station_netconfig_event_handler,
|
||||||
|
station);
|
||||||
|
}
|
||||||
|
|
||||||
static void station_roamed(struct station *station)
|
static void station_roamed(struct station *station)
|
||||||
{
|
{
|
||||||
station->roam_scan_full = false;
|
station->roam_scan_full = false;
|
||||||
@ -2086,9 +2100,7 @@ static void station_roamed(struct station *station)
|
|||||||
/* Re-enable netconfig if it never finished on the last BSS */
|
/* Re-enable netconfig if it never finished on the last BSS */
|
||||||
if (station->netconfig_after_roam) {
|
if (station->netconfig_after_roam) {
|
||||||
station->netconfig_after_roam = false;
|
station->netconfig_after_roam = false;
|
||||||
L_WARN_ON(!netconfig_configure(station->netconfig,
|
L_WARN_ON(!netconfig_after_roam(station));
|
||||||
station_netconfig_event_handler,
|
|
||||||
station));
|
|
||||||
} else
|
} else
|
||||||
station_enter_state(station, STATION_STATE_CONNECTED);
|
station_enter_state(station, STATION_STATE_CONNECTED);
|
||||||
}
|
}
|
||||||
@ -2126,9 +2138,7 @@ static void station_roam_failed(struct station *station)
|
|||||||
/* Re-enable netconfig if needed, even on a failed roam */
|
/* Re-enable netconfig if needed, even on a failed roam */
|
||||||
if (station->netconfig_after_roam) {
|
if (station->netconfig_after_roam) {
|
||||||
station->netconfig_after_roam = false;
|
station->netconfig_after_roam = false;
|
||||||
L_WARN_ON(!netconfig_configure(station->netconfig,
|
L_WARN_ON(!netconfig_after_roam(station));
|
||||||
station_netconfig_event_handler,
|
|
||||||
station));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
Loading…
Reference in New Issue
Block a user