dbus: Reorder deauthentication and cleanup calls when removing a network
Valgrind indicates reference to already freed memory if function wpa_config_remove_network() is called prior to calling wpa_supplicant_deauthenticate(), and this can lead to a crash. Inverting the call order fixes the problem. Signed-off-by: Hannu Mallat <hannu.mallat@jollamobile.com>
This commit is contained in:
parent
0878241778
commit
316f92cd33
1 changed files with 9 additions and 10 deletions
|
@ -1583,16 +1583,6 @@ DBusMessage * wpas_dbus_handler_remove_network(DBusMessage *message,
|
||||||
|
|
||||||
wpas_notify_network_removed(wpa_s, ssid);
|
wpas_notify_network_removed(wpa_s, ssid);
|
||||||
|
|
||||||
if (wpa_config_remove_network(wpa_s->conf, id) < 0) {
|
|
||||||
wpa_printf(MSG_ERROR,
|
|
||||||
"wpas_dbus_handler_remove_network[dbus]: "
|
|
||||||
"error occurred when removing network %d", id);
|
|
||||||
reply = wpas_dbus_error_unknown_error(
|
|
||||||
message, "error removing the specified network on "
|
|
||||||
"this interface.");
|
|
||||||
goto out;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ssid == wpa_s->current_ssid)
|
if (ssid == wpa_s->current_ssid)
|
||||||
wpa_supplicant_deauthenticate(wpa_s,
|
wpa_supplicant_deauthenticate(wpa_s,
|
||||||
WLAN_REASON_DEAUTH_LEAVING);
|
WLAN_REASON_DEAUTH_LEAVING);
|
||||||
|
@ -1603,6 +1593,15 @@ DBusMessage * wpas_dbus_handler_remove_network(DBusMessage *message,
|
||||||
wpa_supplicant_req_scan(wpa_s, 0, 0);
|
wpa_supplicant_req_scan(wpa_s, 0, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (wpa_config_remove_network(wpa_s->conf, id) < 0) {
|
||||||
|
wpa_printf(MSG_ERROR,
|
||||||
|
"wpas_dbus_handler_remove_network[dbus]: "
|
||||||
|
"error occurred when removing network %d", id);
|
||||||
|
reply = wpas_dbus_error_unknown_error(
|
||||||
|
message, "error removing the specified network on "
|
||||||
|
"this interface.");
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
out:
|
out:
|
||||||
os_free(iface);
|
os_free(iface);
|
||||||
|
|
Loading…
Reference in a new issue