WPS: Set Request Type properly into WPS IE in ProbeReq/AssocReq
This commit is contained in:
parent
b8a8c299c8
commit
b01c18a8ef
6 changed files with 26 additions and 15 deletions
|
@ -174,7 +174,7 @@ const u8 * wps_get_uuid_e(const u8 *buf, size_t len)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
struct wpabuf * wps_build_assoc_req_ie(void)
|
struct wpabuf * wps_build_assoc_req_ie(u8 req_type)
|
||||||
{
|
{
|
||||||
struct wpabuf *ie;
|
struct wpabuf *ie;
|
||||||
u8 *len;
|
u8 *len;
|
||||||
|
@ -190,7 +190,7 @@ struct wpabuf * wps_build_assoc_req_ie(void)
|
||||||
wpabuf_put_be32(ie, WPS_DEV_OUI_WFA);
|
wpabuf_put_be32(ie, WPS_DEV_OUI_WFA);
|
||||||
|
|
||||||
if (wps_build_version(ie) ||
|
if (wps_build_version(ie) ||
|
||||||
wps_build_req_type(ie, WPS_REQ_ENROLLEE)) {
|
wps_build_req_type(ie, req_type)) {
|
||||||
wpabuf_free(ie);
|
wpabuf_free(ie);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -202,7 +202,7 @@ struct wpabuf * wps_build_assoc_req_ie(void)
|
||||||
|
|
||||||
|
|
||||||
struct wpabuf * wps_build_probe_req_ie(int pbc, struct wps_device_data *dev,
|
struct wpabuf * wps_build_probe_req_ie(int pbc, struct wps_device_data *dev,
|
||||||
const u8 *uuid)
|
const u8 *uuid, u8 req_type)
|
||||||
{
|
{
|
||||||
struct wpabuf *ie;
|
struct wpabuf *ie;
|
||||||
u8 *len;
|
u8 *len;
|
||||||
|
@ -225,7 +225,7 @@ struct wpabuf * wps_build_probe_req_ie(int pbc, struct wps_device_data *dev,
|
||||||
WPS_CONFIG_KEYPAD;
|
WPS_CONFIG_KEYPAD;
|
||||||
|
|
||||||
if (wps_build_version(ie) ||
|
if (wps_build_version(ie) ||
|
||||||
wps_build_req_type(ie, WPS_REQ_ENROLLEE) ||
|
wps_build_req_type(ie, req_type) ||
|
||||||
wps_build_config_methods(ie, methods) ||
|
wps_build_config_methods(ie, methods) ||
|
||||||
wps_build_uuid_e(ie, uuid) ||
|
wps_build_uuid_e(ie, uuid) ||
|
||||||
wps_build_primary_dev_type(dev, ie) ||
|
wps_build_primary_dev_type(dev, ie) ||
|
||||||
|
|
|
@ -79,9 +79,9 @@ struct wpabuf * wps_get_msg(struct wps_data *wps, u8 *op_code);
|
||||||
int wps_is_selected_pbc_registrar(const u8 *buf, size_t len);
|
int wps_is_selected_pbc_registrar(const u8 *buf, size_t len);
|
||||||
int wps_is_selected_pin_registrar(const u8 *buf, size_t len);
|
int wps_is_selected_pin_registrar(const u8 *buf, size_t len);
|
||||||
const u8 * wps_get_uuid_e(const u8 *buf, size_t len);
|
const u8 * wps_get_uuid_e(const u8 *buf, size_t len);
|
||||||
struct wpabuf * wps_build_assoc_req_ie(void);
|
struct wpabuf * wps_build_assoc_req_ie(u8 req_type);
|
||||||
struct wpabuf * wps_build_probe_req_ie(int pbc, struct wps_device_data *dev,
|
struct wpabuf * wps_build_probe_req_ie(int pbc, struct wps_device_data *dev,
|
||||||
const u8 *uuid);
|
const u8 *uuid, u8 req_type);
|
||||||
|
|
||||||
|
|
||||||
struct wps_registrar_config {
|
struct wps_registrar_config {
|
||||||
|
|
|
@ -20,6 +20,7 @@
|
||||||
#include "wpa_supplicant_i.h"
|
#include "wpa_supplicant_i.h"
|
||||||
#include "mlme.h"
|
#include "mlme.h"
|
||||||
#include "wps/wps.h"
|
#include "wps/wps.h"
|
||||||
|
#include "wps_supplicant.h"
|
||||||
|
|
||||||
|
|
||||||
static void wpa_supplicant_gen_assoc_event(struct wpa_supplicant *wpa_s)
|
static void wpa_supplicant_gen_assoc_event(struct wpa_supplicant *wpa_s)
|
||||||
|
@ -42,7 +43,7 @@ static void wpa_supplicant_gen_assoc_event(struct wpa_supplicant *wpa_s)
|
||||||
|
|
||||||
|
|
||||||
#ifdef CONFIG_WPS
|
#ifdef CONFIG_WPS
|
||||||
static int wpas_wps_in_use(struct wpa_config *conf)
|
static int wpas_wps_in_use(struct wpa_config *conf, u8 *req_type)
|
||||||
{
|
{
|
||||||
struct wpa_ssid *ssid;
|
struct wpa_ssid *ssid;
|
||||||
int wps = 0;
|
int wps = 0;
|
||||||
|
@ -52,6 +53,7 @@ static int wpas_wps_in_use(struct wpa_config *conf)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
wps = 1;
|
wps = 1;
|
||||||
|
*req_type = wpas_wps_get_req_type(ssid);
|
||||||
if (!ssid->eap.phase1)
|
if (!ssid->eap.phase1)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
@ -72,6 +74,9 @@ static void wpa_supplicant_scan(void *eloop_ctx, void *timeout_ctx)
|
||||||
const u8 *extra_ie = NULL;
|
const u8 *extra_ie = NULL;
|
||||||
size_t extra_ie_len = 0;
|
size_t extra_ie_len = 0;
|
||||||
int wps = 0;
|
int wps = 0;
|
||||||
|
#ifdef CONFIG_WPS
|
||||||
|
u8 req_type = 0;
|
||||||
|
#endif /* CONFIG_WPS */
|
||||||
|
|
||||||
if (wpa_s->disconnected && !wpa_s->scan_req)
|
if (wpa_s->disconnected && !wpa_s->scan_req)
|
||||||
return;
|
return;
|
||||||
|
@ -159,7 +164,7 @@ static void wpa_supplicant_scan(void *eloop_ctx, void *timeout_ctx)
|
||||||
wpa_s->prev_scan_ssid = BROADCAST_SSID_SCAN;
|
wpa_s->prev_scan_ssid = BROADCAST_SSID_SCAN;
|
||||||
|
|
||||||
#ifdef CONFIG_WPS
|
#ifdef CONFIG_WPS
|
||||||
wps = wpas_wps_in_use(wpa_s->conf);
|
wps = wpas_wps_in_use(wpa_s->conf, &req_type);
|
||||||
#endif /* CONFIG_WPS */
|
#endif /* CONFIG_WPS */
|
||||||
|
|
||||||
if (wpa_s->scan_res_tried == 0 && wpa_s->conf->ap_scan == 1 &&
|
if (wpa_s->scan_res_tried == 0 && wpa_s->conf->ap_scan == 1 &&
|
||||||
|
@ -176,7 +181,7 @@ static void wpa_supplicant_scan(void *eloop_ctx, void *timeout_ctx)
|
||||||
#ifdef CONFIG_WPS
|
#ifdef CONFIG_WPS
|
||||||
if (wps) {
|
if (wps) {
|
||||||
wps_ie = wps_build_probe_req_ie(wps == 2, &wpa_s->wps->dev,
|
wps_ie = wps_build_probe_req_ie(wps == 2, &wpa_s->wps->dev,
|
||||||
wpa_s->conf->uuid);
|
wpa_s->conf->uuid, req_type);
|
||||||
if (wps_ie) {
|
if (wps_ie) {
|
||||||
extra_ie = wpabuf_head(wps_ie);
|
extra_ie = wpabuf_head(wps_ie);
|
||||||
extra_ie_len = wpabuf_len(wps_ie);
|
extra_ie_len = wpabuf_len(wps_ie);
|
||||||
|
|
|
@ -1012,7 +1012,8 @@ void wpa_supplicant_associate(struct wpa_supplicant *wpa_s,
|
||||||
}
|
}
|
||||||
#ifdef CONFIG_WPS
|
#ifdef CONFIG_WPS
|
||||||
} else if (ssid->key_mgmt & WPA_KEY_MGMT_WPS) {
|
} else if (ssid->key_mgmt & WPA_KEY_MGMT_WPS) {
|
||||||
struct wpabuf *wps_ie = wps_build_assoc_req_ie();
|
struct wpabuf *wps_ie;
|
||||||
|
wps_ie = wps_build_assoc_req_ie(wpas_wps_get_req_type(ssid));
|
||||||
if (wps_ie && wpabuf_len(wps_ie) <= sizeof(wpa_ie)) {
|
if (wps_ie && wpabuf_len(wps_ie) <= sizeof(wpa_ie)) {
|
||||||
wpa_ie_len = wpabuf_len(wps_ie);
|
wpa_ie_len = wpabuf_len(wps_ie);
|
||||||
os_memcpy(wpa_ie, wpabuf_head(wps_ie), wpa_ie_len);
|
os_memcpy(wpa_ie, wpabuf_head(wps_ie), wpa_ie_len);
|
||||||
|
|
|
@ -18,6 +18,7 @@
|
||||||
#include "ieee802_11_defs.h"
|
#include "ieee802_11_defs.h"
|
||||||
#include "wpa_common.h"
|
#include "wpa_common.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
#include "eap_peer/eap.h"
|
||||||
#include "wpa_supplicant_i.h"
|
#include "wpa_supplicant_i.h"
|
||||||
#include "wps/wps.h"
|
#include "wps/wps.h"
|
||||||
#include "wps/wps_defs.h"
|
#include "wps/wps_defs.h"
|
||||||
|
@ -171,9 +172,13 @@ static int wpa_supplicant_wps_cred(void *ctx,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void * wpas_wps_get_cred_cb(void)
|
u8 wpas_wps_get_req_type(struct wpa_ssid *ssid)
|
||||||
{
|
{
|
||||||
return wpa_supplicant_wps_cred;
|
if (eap_is_wps_pbc_enrollee(&ssid->eap) ||
|
||||||
|
eap_is_wps_pin_enrollee(&ssid->eap))
|
||||||
|
return WPS_REQ_ENROLLEE;
|
||||||
|
else
|
||||||
|
return WPS_REQ_REGISTRAR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
int wpas_wps_init(struct wpa_supplicant *wpa_s);
|
int wpas_wps_init(struct wpa_supplicant *wpa_s);
|
||||||
void wpas_wps_deinit(struct wpa_supplicant *wpa_s);
|
void wpas_wps_deinit(struct wpa_supplicant *wpa_s);
|
||||||
int wpas_wps_eapol_cb(struct wpa_supplicant *wpa_s);
|
int wpas_wps_eapol_cb(struct wpa_supplicant *wpa_s);
|
||||||
void * wpas_wps_get_cred_cb(void);
|
u8 wpas_wps_get_req_type(struct wpa_ssid *ssid);
|
||||||
|
|
||||||
#else /* CONFIG_WPS */
|
#else /* CONFIG_WPS */
|
||||||
|
|
||||||
|
@ -38,9 +38,9 @@ static inline int wpas_wps_eapol_cb(struct wpa_supplicant *wpa_s)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void * wpas_wps_get_cred_cb(void)
|
u8 wpas_wps_get_req_type(struct wpa_ssid *ssid)
|
||||||
{
|
{
|
||||||
return NULL;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* CONFIG_WPS */
|
#endif /* CONFIG_WPS */
|
||||||
|
|
Loading…
Reference in a new issue