|
@@ -4507,14 +4507,22 @@ int wpas_p2p_in_progress(struct wpa_supplicant *wpa_s)
|
|
|
|
|
|
void wpas_p2p_network_removed(struct wpa_supplicant *wpa_s,
|
|
|
struct wpa_ssid *ssid)
|
|
|
-
|
|
|
{
|
|
|
if (wpa_s->p2p_in_provisioning && ssid->p2p_group &&
|
|
|
eloop_cancel_timeout(wpas_p2p_group_formation_timeout,
|
|
|
wpa_s->parent, NULL) > 0) {
|
|
|
+ /**
|
|
|
+ * Remove the network by scheduling the group formation
|
|
|
+ * timeout to happen immediately. The teardown code
|
|
|
+ * needs to be scheduled to run asynch later so that we
|
|
|
+ * don't delete data from under ourselves unexpectedly.
|
|
|
+ * Calling wpas_p2p_group_formation_timeout directly
|
|
|
+ * causes a series of crashes in WPS failure scenarios.
|
|
|
+ */
|
|
|
wpa_printf(MSG_DEBUG, "P2P: Canceled group formation due to "
|
|
|
"P2P group network getting removed");
|
|
|
- wpas_p2p_group_formation_timeout(wpa_s->parent, NULL);
|
|
|
+ eloop_register_timeout(0, 0, wpas_p2p_group_formation_timeout,
|
|
|
+ wpa_s->parent, NULL);
|
|
|
}
|
|
|
}
|
|
|
|