P2P: Set global->p2p_group_formation in wpas_p2p_join_start() for p2pdev

When a dedicated P2P device interface is used, the
global->p2p_group_formation was not set in wpas_p2p_join_start() if no
separate group interface is used. This would cause that in case of a
failure in group formation, the cleaning of p2p_in_provisioning is done
on the wrong interface. Furthermore, P2P_CANCEL command could not be
used to stop such a group-join operation. Fix this by setting the
global->p2p_group_formation correctly in case that the group interface
is reusing wpa_s->parent.

Signed-off-by: Adiel Aloni <adiel.aloni@intel.com>
This commit is contained in:
Aloni, Adiel 2017-08-21 19:36:22 +03:00 committed by Jouni Malinen
parent 7f90a850ff
commit dc9b7d217c

View file

@ -5107,7 +5107,8 @@ static int wpas_p2p_join_start(struct wpa_supplicant *wpa_s, int freq,
os_memcpy(group->p2p_pin, wpa_s->p2p_pin,
sizeof(group->p2p_pin));
group->p2p_wps_method = wpa_s->p2p_wps_method;
} else {
}
/*
* Need to mark the current interface for p2p_group_formation
* when a separate group interface is not used. This is needed
@ -5115,8 +5116,8 @@ static int wpas_p2p_join_start(struct wpa_supplicant *wpa_s, int freq,
* wpas_p2p_init_group_interface() addresses this for the case
* where a separate group interface is used.
*/
wpa_s->global->p2p_group_formation = wpa_s;
}
if (group == wpa_s->parent)
wpa_s->global->p2p_group_formation = group;
group->p2p_in_provisioning = 1;
group->p2p_fallback_to_go_neg = wpa_s->p2p_fallback_to_go_neg;