P2P: Fix fast IP address allocation for invitation of a persistent group
Allocate static IPv4 address in EAPOL frames during 4-way handshake
instead of DHCP when using P2P invitation. wpa_s->current_bss needs to
be set for the P2P specific IP address assignment mechanism to be used
in wpa_supplicant_rsn_supp_set_config(). This worked for the initial P2P
connection, but not for some cases reinvoking a persistent group.
Since there is only one AP (P2P GO) in the P2P client case, the
conditions added in commit 4d3be9cdd1
("Postpone updating of
wpa_s->current_bss till association event") are not needed and the
easiest approach for this is to allow current_bss to be set for
p2p_in_invitation cases. If the GO P2P Interface Address (BSSID) could
be determined for all the related cases, this could be addressed a bit
more cleanly by setting the go_bssid argument for
wpas_start_p2p_client(), but that can be left as a possible future step.
Signed-off-by: tzu-meng wang <tzu-meng.wang@mediatek.com>
This commit is contained in:
parent
0ae087994c
commit
ed56dfc339
1 changed files with 5 additions and 1 deletions
|
@ -4527,7 +4527,11 @@ static void wpas_start_assoc_cb(struct wpa_radio_work *work, int deinit)
|
||||||
eapol_sm_invalidate_cached_session(wpa_s->eapol);
|
eapol_sm_invalidate_cached_session(wpa_s->eapol);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!wpas_driver_bss_selection(wpa_s) || ssid->bssid_set) {
|
if (!wpas_driver_bss_selection(wpa_s) ||
|
||||||
|
#ifdef CONFIG_P2P
|
||||||
|
wpa_s->p2p_in_invitation ||
|
||||||
|
#endif /* CONFIG_P2P */
|
||||||
|
ssid->bssid_set) {
|
||||||
wpa_s->current_bss = bss;
|
wpa_s->current_bss = bss;
|
||||||
#ifdef CONFIG_HS20
|
#ifdef CONFIG_HS20
|
||||||
hs20_configure_frame_filters(wpa_s);
|
hs20_configure_frame_filters(wpa_s);
|
||||||
|
|
Loading…
Reference in a new issue