|
@@ -21,7 +21,6 @@
|
|
|
#include "esp_wps.h"
|
|
#include "esp_wps.h"
|
|
|
#include "esp_event_loop.h"
|
|
#include "esp_event_loop.h"
|
|
|
#include "nvs_flash.h"
|
|
#include "nvs_flash.h"
|
|
|
-#include <string.h>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*set wps mode via "make menuconfig"*/
|
|
/*set wps mode via "make menuconfig"*/
|
|
@@ -33,7 +32,6 @@
|
|
|
#define WPS_TEST_MODE WPS_TYPE_DISABLE
|
|
#define WPS_TEST_MODE WPS_TYPE_DISABLE
|
|
|
#endif /*CONFIG_EXAMPLE_WPS_TYPE_PBC*/
|
|
#endif /*CONFIG_EXAMPLE_WPS_TYPE_PBC*/
|
|
|
|
|
|
|
|
-#define MAX_RETRY_ATTEMPTS 2
|
|
|
|
|
|
|
|
|
|
#ifndef PIN2STR
|
|
#ifndef PIN2STR
|
|
|
#define PIN2STR(a) (a)[0], (a)[1], (a)[2], (a)[3], (a)[4], (a)[5], (a)[6], (a)[7]
|
|
#define PIN2STR(a) (a)[0], (a)[1], (a)[2], (a)[3], (a)[4], (a)[5], (a)[6], (a)[7]
|
|
@@ -43,14 +41,9 @@
|
|
|
|
|
|
|
|
static const char *TAG = "example_wps";
|
|
static const char *TAG = "example_wps";
|
|
|
static esp_wps_config_t config = WPS_CONFIG_INIT_DEFAULT(WPS_TEST_MODE);
|
|
static esp_wps_config_t config = WPS_CONFIG_INIT_DEFAULT(WPS_TEST_MODE);
|
|
|
-static wifi_config_t wps_ap_creds[MAX_WPS_AP_CRED];
|
|
|
|
|
-static int s_ap_creds_num = 0;
|
|
|
|
|
-static int s_retry_num = 0;
|
|
|
|
|
|
|
|
|
|
static esp_err_t event_handler(void *ctx, system_event_t *event)
|
|
static esp_err_t event_handler(void *ctx, system_event_t *event)
|
|
|
{
|
|
{
|
|
|
- static int ap_idx = 1;
|
|
|
|
|
-
|
|
|
|
|
switch(event->event_id) {
|
|
switch(event->event_id) {
|
|
|
case SYSTEM_EVENT_STA_START:
|
|
case SYSTEM_EVENT_STA_START:
|
|
|
ESP_LOGI(TAG, "SYSTEM_EVENT_STA_START");
|
|
ESP_LOGI(TAG, "SYSTEM_EVENT_STA_START");
|
|
@@ -61,51 +54,16 @@ static esp_err_t event_handler(void *ctx, system_event_t *event)
|
|
|
ip4addr_ntoa(&event->event_info.got_ip.ip_info.ip));
|
|
ip4addr_ntoa(&event->event_info.got_ip.ip_info.ip));
|
|
|
break;
|
|
break;
|
|
|
case SYSTEM_EVENT_STA_DISCONNECTED:
|
|
case SYSTEM_EVENT_STA_DISCONNECTED:
|
|
|
- ESP_LOGI(TAG, "SYSTEM_EVENT_STA_DISCONNECTED");
|
|
|
|
|
- if (s_retry_num < MAX_RETRY_ATTEMPTS) {
|
|
|
|
|
- ESP_ERROR_CHECK(esp_wifi_connect());
|
|
|
|
|
- s_retry_num++;
|
|
|
|
|
- } else if (ap_idx < s_ap_creds_num) {
|
|
|
|
|
- /* Try the next AP credential if first one fails */
|
|
|
|
|
-
|
|
|
|
|
- if (ap_idx < s_ap_creds_num) {
|
|
|
|
|
- ESP_LOGI(TAG, "Connecting to SSID: %s, Passphrase: %s",
|
|
|
|
|
- wps_ap_creds[ap_idx].sta.ssid, wps_ap_creds[ap_idx].sta.password);
|
|
|
|
|
- ESP_ERROR_CHECK(esp_wifi_set_config(ESP_IF_WIFI_STA, &wps_ap_creds[ap_idx++]) );
|
|
|
|
|
- ESP_ERROR_CHECK(esp_wifi_connect());
|
|
|
|
|
- }
|
|
|
|
|
- s_retry_num = 0;
|
|
|
|
|
- } else {
|
|
|
|
|
- ESP_LOGI(TAG, "Failed to connect!");
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
|
|
+ ESP_LOGI(TAG, "SYSTEM_EVENT_STA_DISCONNECTED");
|
|
|
|
|
+ ESP_ERROR_CHECK(esp_wifi_connect());
|
|
|
break;
|
|
break;
|
|
|
case SYSTEM_EVENT_STA_WPS_ER_SUCCESS:
|
|
case SYSTEM_EVENT_STA_WPS_ER_SUCCESS:
|
|
|
/*point: the function esp_wifi_wps_start() only get ssid & password
|
|
/*point: the function esp_wifi_wps_start() only get ssid & password
|
|
|
* so call the function esp_wifi_connect() here
|
|
* so call the function esp_wifi_connect() here
|
|
|
* */
|
|
* */
|
|
|
ESP_LOGI(TAG, "SYSTEM_EVENT_STA_WPS_ER_SUCCESS");
|
|
ESP_LOGI(TAG, "SYSTEM_EVENT_STA_WPS_ER_SUCCESS");
|
|
|
- {
|
|
|
|
|
- wifi_event_sta_wps_er_success_t *evt = &event->event_info.sta_er_success;
|
|
|
|
|
- int i;
|
|
|
|
|
- if (evt && evt->ap_cred_cnt > 1) {
|
|
|
|
|
- s_ap_creds_num = evt->ap_cred_cnt;
|
|
|
|
|
- for (i = 0; i < s_ap_creds_num; i++) {
|
|
|
|
|
- memcpy(wps_ap_creds[i].sta.ssid, evt->ap_cred[i].ssid, sizeof(evt->ap_cred[i].ssid));
|
|
|
|
|
- memcpy(wps_ap_creds[i].sta.password, evt->ap_cred[i].passphrase, sizeof(evt->ap_cred[i].passphrase));
|
|
|
|
|
- }
|
|
|
|
|
- /* If multiple AP credentials are received from WPS, connect with first one */
|
|
|
|
|
- ESP_LOGI(TAG, "Connecting to SSID: %s, Passphrase: %s", wps_ap_creds[0].sta.ssid, wps_ap_creds[0].sta.password);
|
|
|
|
|
- ESP_ERROR_CHECK(esp_wifi_set_config(ESP_IF_WIFI_STA, &wps_ap_creds[0]) );
|
|
|
|
|
- }
|
|
|
|
|
- /*
|
|
|
|
|
- * If only one AP credential is received from WPS, there will be no event data and
|
|
|
|
|
- * esp_wifi_set_config() is already called by WPS modules for backward compatibility
|
|
|
|
|
- * with legacy apps. So directly attempt connection here.
|
|
|
|
|
- */
|
|
|
|
|
- ESP_ERROR_CHECK(esp_wifi_wps_disable());
|
|
|
|
|
- ESP_ERROR_CHECK(esp_wifi_connect());
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ ESP_ERROR_CHECK(esp_wifi_wps_disable());
|
|
|
|
|
+ ESP_ERROR_CHECK(esp_wifi_connect());
|
|
|
break;
|
|
break;
|
|
|
case SYSTEM_EVENT_STA_WPS_ER_FAILED:
|
|
case SYSTEM_EVENT_STA_WPS_ER_FAILED:
|
|
|
ESP_LOGI(TAG, "SYSTEM_EVENT_STA_WPS_ER_FAILED");
|
|
ESP_LOGI(TAG, "SYSTEM_EVENT_STA_WPS_ER_FAILED");
|