P2P: Allow WPS_PBC command on GO to select on P2P Device Address
An optional parameter, p2p_dev_addr, can now be given to WPS_PBC command on P2P GO to indicate that only the P2P device with the specified P2P Device Address is allowed to connect using PBC. If any other device tries to use PBC, a session overlap is indicated and the negotiation is rejected with M2D. The command format for specifying the address is "WPS_PBC p2p_dev_addr=<address>", e.g., WPS_PBC p2p_dev_addr=02:03:04:05:06:07 In addition, show the PBC session overlap indication as a WPS failure event on an AP/GO interface. This particular new case shows up as "WPS-FAIL msg=4 config_error=12".
This commit is contained in:
parent
379ff7b9d4
commit
d601247ca9
14 changed files with 92 additions and 18 deletions
|
@ -517,11 +517,13 @@ void wpa_supplicant_ap_rx_eapol(struct wpa_supplicant *wpa_s,
|
|||
|
||||
#ifdef CONFIG_WPS
|
||||
|
||||
int wpa_supplicant_ap_wps_pbc(struct wpa_supplicant *wpa_s, const u8 *bssid)
|
||||
int wpa_supplicant_ap_wps_pbc(struct wpa_supplicant *wpa_s, const u8 *bssid,
|
||||
const u8 *p2p_dev_addr)
|
||||
{
|
||||
if (!wpa_s->ap_iface)
|
||||
return -1;
|
||||
return hostapd_wps_button_pushed(wpa_s->ap_iface->bss[0]);
|
||||
return hostapd_wps_button_pushed(wpa_s->ap_iface->bss[0],
|
||||
p2p_dev_addr);
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -21,7 +21,8 @@ int wpa_supplicant_create_ap(struct wpa_supplicant *wpa_s,
|
|||
void wpa_supplicant_ap_deinit(struct wpa_supplicant *wpa_s);
|
||||
void wpa_supplicant_ap_rx_eapol(struct wpa_supplicant *wpa_s,
|
||||
const u8 *src_addr, const u8 *buf, size_t len);
|
||||
int wpa_supplicant_ap_wps_pbc(struct wpa_supplicant *wpa_s, const u8 *bssid);
|
||||
int wpa_supplicant_ap_wps_pbc(struct wpa_supplicant *wpa_s, const u8 *bssid,
|
||||
const u8 *p2p_dev_addr);
|
||||
int wpa_supplicant_ap_wps_pin(struct wpa_supplicant *wpa_s, const u8 *bssid,
|
||||
const char *pin, char *buf, size_t buflen);
|
||||
int wpa_supplicant_ap_wps_cancel(struct wpa_supplicant *wpa_s);
|
||||
|
|
|
@ -213,10 +213,21 @@ static int wpa_supplicant_ctrl_iface_wps_pbc(struct wpa_supplicant *wpa_s,
|
|||
char *cmd)
|
||||
{
|
||||
u8 bssid[ETH_ALEN], *_bssid = bssid;
|
||||
u8 p2p_dev_addr[ETH_ALEN], *_p2p_dev_addr = NULL;
|
||||
|
||||
if (cmd == NULL || os_strcmp(cmd, "any") == 0)
|
||||
if (cmd == NULL || os_strcmp(cmd, "any") == 0) {
|
||||
_bssid = NULL;
|
||||
else if (hwaddr_aton(cmd, bssid)) {
|
||||
#ifdef CONFIG_P2P
|
||||
} else if (os_strncmp(cmd, "p2p_dev_addr=", 13) == 0) {
|
||||
if (hwaddr_aton(cmd + 13, p2p_dev_addr)) {
|
||||
wpa_printf(MSG_DEBUG, "CTRL_IFACE WPS_PBC: invalid "
|
||||
"P2P Device Address '%s'",
|
||||
cmd + 13);
|
||||
return -1;
|
||||
}
|
||||
_p2p_dev_addr = p2p_dev_addr;
|
||||
#endif /* CONFIG_P2P */
|
||||
} else if (hwaddr_aton(cmd, bssid)) {
|
||||
wpa_printf(MSG_DEBUG, "CTRL_IFACE WPS_PBC: invalid BSSID '%s'",
|
||||
cmd);
|
||||
return -1;
|
||||
|
@ -224,7 +235,7 @@ static int wpa_supplicant_ctrl_iface_wps_pbc(struct wpa_supplicant *wpa_s,
|
|||
|
||||
#ifdef CONFIG_AP
|
||||
if (wpa_s->ap_iface)
|
||||
return wpa_supplicant_ap_wps_pbc(wpa_s, _bssid);
|
||||
return wpa_supplicant_ap_wps_pbc(wpa_s, _bssid, _p2p_dev_addr);
|
||||
#endif /* CONFIG_AP */
|
||||
|
||||
return wpas_wps_start_pbc(wpa_s, _bssid, 0);
|
||||
|
|
|
@ -857,7 +857,8 @@ static void p2p_go_configured(void *ctx, void *data)
|
|||
return;
|
||||
}
|
||||
if (params->wps_method == WPS_PBC)
|
||||
wpa_supplicant_ap_wps_pbc(wpa_s, params->peer_interface_addr);
|
||||
wpa_supplicant_ap_wps_pbc(wpa_s, params->peer_interface_addr,
|
||||
NULL);
|
||||
else if (wpa_s->p2p_pin[0])
|
||||
wpa_supplicant_ap_wps_pin(wpa_s, params->peer_interface_addr,
|
||||
wpa_s->p2p_pin, NULL, 0);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue