From 50396e29da97e13af658387c6da7bdffe80ff3cd Mon Sep 17 00:00:00 2001 From: Jeffin Mammen Date: Fri, 23 Aug 2013 16:01:30 +0300 Subject: [PATCH] WPS: Add PBC mode activated/disabled events This makes it easier to track PBC state on the registrar. Signed-hostap: Jouni Malinen --- src/ap/wps_hostapd.c | 6 ++++++ src/common/wpa_ctrl.h | 4 ++++ src/wps/wps.h | 10 ++++++++++ src/wps/wps_common.c | 18 ++++++++++++++++++ src/wps/wps_i.h | 2 ++ src/wps/wps_registrar.c | 2 ++ wpa_supplicant/wps_supplicant.c | 6 ++++++ 7 files changed, 48 insertions(+) diff --git a/src/ap/wps_hostapd.c b/src/ap/wps_hostapd.c index a3950d3d3..b5ecb6bc2 100644 --- a/src/ap/wps_hostapd.c +++ b/src/ap/wps_hostapd.c @@ -775,6 +775,12 @@ static void hostapd_wps_event_cb(void *ctx, enum wps_event event, case WPS_EV_PBC_TIMEOUT: wpa_msg(hapd->msg_ctx, MSG_INFO, WPS_EVENT_TIMEOUT); break; + case WPS_EV_PBC_ACTIVE: + wpa_msg(hapd->msg_ctx, MSG_INFO, WPS_EVENT_ACTIVE); + break; + case WPS_EV_PBC_DISABLE: + wpa_msg(hapd->msg_ctx, MSG_INFO, WPS_EVENT_DISABLE); + break; case WPS_EV_ER_AP_ADD: break; case WPS_EV_ER_AP_REMOVE: diff --git a/src/common/wpa_ctrl.h b/src/common/wpa_ctrl.h index 0ab4b7f51..af716176d 100644 --- a/src/common/wpa_ctrl.h +++ b/src/common/wpa_ctrl.h @@ -84,6 +84,10 @@ extern "C" { #define WPS_EVENT_SUCCESS "WPS-SUCCESS " /** WPS enrollment attempt timed out and was terminated */ #define WPS_EVENT_TIMEOUT "WPS-TIMEOUT " +/* PBC mode was activated */ +#define WPS_EVENT_ACTIVE "WPS-PBC-ACTIVE " +/* PBC mode was disabled */ +#define WPS_EVENT_DISABLE "WPS-PBC-DISABLE " #define WPS_EVENT_ENROLLEE_SEEN "WPS-ENROLLEE-SEEN " diff --git a/src/wps/wps.h b/src/wps/wps.h index a301b51bb..8d9535b0c 100644 --- a/src/wps/wps.h +++ b/src/wps/wps.h @@ -419,6 +419,16 @@ enum wps_event { */ WPS_EV_PBC_TIMEOUT, + /** + * WPS_EV_PBC_ACTIVE - PBC mode was activated + */ + WPS_EV_PBC_ACTIVE, + + /** + * WPS_EV_PBC_DISABLE - PBC mode was disabled + */ + WPS_EV_PBC_DISABLE, + /** * WPS_EV_ER_AP_ADD - ER: AP added */ diff --git a/src/wps/wps_common.c b/src/wps/wps_common.c index 4e4da5ec4..8c54a1533 100644 --- a/src/wps/wps_common.c +++ b/src/wps/wps_common.c @@ -322,6 +322,24 @@ void wps_pbc_timeout_event(struct wps_context *wps) } +void wps_pbc_active_event(struct wps_context *wps) +{ + if (wps->event_cb == NULL) + return; + + wps->event_cb(wps->cb_ctx, WPS_EV_PBC_ACTIVE, NULL); +} + + +void wps_pbc_disable_event(struct wps_context *wps) +{ + if (wps->event_cb == NULL) + return; + + wps->event_cb(wps->cb_ctx, WPS_EV_PBC_DISABLE, NULL); +} + + #ifdef CONFIG_WPS_OOB struct wpabuf * wps_get_oob_cred(struct wps_context *wps) diff --git a/src/wps/wps_i.h b/src/wps/wps_i.h index 413379ba9..17cf39690 100644 --- a/src/wps/wps_i.h +++ b/src/wps/wps_i.h @@ -139,6 +139,8 @@ void wps_success_event(struct wps_context *wps); void wps_pwd_auth_fail_event(struct wps_context *wps, int enrollee, int part); void wps_pbc_overlap_event(struct wps_context *wps); void wps_pbc_timeout_event(struct wps_context *wps); +void wps_pbc_active_event(struct wps_context *wps); +void wps_pbc_disable_event(struct wps_context *wps); struct wpabuf * wps_build_wsc_ack(struct wps_data *wps); struct wpabuf * wps_build_wsc_nack(struct wps_data *wps); diff --git a/src/wps/wps_registrar.c b/src/wps/wps_registrar.c index 48128935a..c37051cc3 100644 --- a/src/wps/wps_registrar.c +++ b/src/wps/wps_registrar.c @@ -1001,6 +1001,7 @@ int wps_registrar_button_pushed(struct wps_registrar *reg, (u8 *) "\xff\xff\xff\xff\xff\xff"); wps_registrar_selected_registrar_changed(reg, 0); + wps_pbc_active_event(reg->wps); eloop_cancel_timeout(wps_registrar_set_selected_timeout, reg, NULL); eloop_cancel_timeout(wps_registrar_pbc_timeout, reg, NULL); eloop_register_timeout(WPS_PBC_WALK_TIME, 0, wps_registrar_pbc_timeout, @@ -1014,6 +1015,7 @@ static void wps_registrar_pbc_completed(struct wps_registrar *reg) wpa_printf(MSG_DEBUG, "WPS: PBC completed - stopping PBC mode"); eloop_cancel_timeout(wps_registrar_pbc_timeout, reg, NULL); wps_registrar_stop_pbc(reg); + wps_pbc_disable_event(reg->wps); } diff --git a/wpa_supplicant/wps_supplicant.c b/wpa_supplicant/wps_supplicant.c index 44b935a3a..452ce8ee6 100644 --- a/wpa_supplicant/wps_supplicant.c +++ b/wpa_supplicant/wps_supplicant.c @@ -807,6 +807,12 @@ static void wpa_supplicant_wps_event(void *ctx, enum wps_event event, break; case WPS_EV_PBC_TIMEOUT: break; + case WPS_EV_PBC_ACTIVE: + wpa_msg(wpa_s, MSG_INFO, WPS_EVENT_ACTIVE); + break; + case WPS_EV_PBC_DISABLE: + wpa_msg(wpa_s, MSG_INFO, WPS_EVENT_DISABLE); + break; case WPS_EV_ER_AP_ADD: wpa_supplicant_wps_event_er_ap_add(wpa_s, &data->ap); break;