From 019502a36e9977a43cf6d88b10b6adefb8ea1e12 Mon Sep 17 00:00:00 2001 From: Hrudaynath Dhabe Date: Wed, 23 Oct 2019 14:12:32 +0800 Subject: [PATCH] esp_wifi: Additional code snippets in esp_wifi_scan_example --- examples/wifi/README.md | 12 ++ examples/wifi/fast_scan/CMakeLists.txt | 6 + examples/wifi/fast_scan/Makefile | 9 ++ examples/wifi/fast_scan/README.md | 11 ++ examples/wifi/fast_scan/main/CMakeLists.txt | 2 + .../wifi/fast_scan/main/Kconfig.projbuild | 68 ++++++++ examples/wifi/fast_scan/main/component.mk | 7 + examples/wifi/fast_scan/main/fast_scan.c | 123 ++++++++++++++ examples/wifi/scan/README.md | 10 +- examples/wifi/scan/main/Kconfig.projbuild | 69 +------- examples/wifi/scan/main/scan.c | 150 +++++++++++------- 11 files changed, 337 insertions(+), 130 deletions(-) create mode 100644 examples/wifi/fast_scan/CMakeLists.txt create mode 100644 examples/wifi/fast_scan/Makefile create mode 100644 examples/wifi/fast_scan/README.md create mode 100644 examples/wifi/fast_scan/main/CMakeLists.txt create mode 100644 examples/wifi/fast_scan/main/Kconfig.projbuild create mode 100644 examples/wifi/fast_scan/main/component.mk create mode 100644 examples/wifi/fast_scan/main/fast_scan.c diff --git a/examples/wifi/README.md b/examples/wifi/README.md index a7ec9c878..f08f41038 100644 --- a/examples/wifi/README.md +++ b/examples/wifi/README.md @@ -26,6 +26,18 @@ shows how to use espnow. See the [README.md](./espnow/README.md) file in the project [espnow](./espnow/). +## fast_scan + +Show how to use fast scan while connecting to an AP. + +See the [README.md](./fast_scan/README.md) file in the project [espnow](./espnow/). + +## scan + +Show how to scan for all the available APs. + +See the [README.md](./scan/README.md) file in the project [espnow](./espnow/). + # More See the [README.md](../README.md) file in the upper level [examples](../) directory for more information about examples. diff --git a/examples/wifi/fast_scan/CMakeLists.txt b/examples/wifi/fast_scan/CMakeLists.txt new file mode 100644 index 000000000..def20957a --- /dev/null +++ b/examples/wifi/fast_scan/CMakeLists.txt @@ -0,0 +1,6 @@ +# The following lines of boilerplate have to be in your project's CMakeLists +# in this exact order for cmake to work correctly +cmake_minimum_required(VERSION 3.5) + +include($ENV{IDF_PATH}/tools/cmake/project.cmake) +project(fast_scan) diff --git a/examples/wifi/fast_scan/Makefile b/examples/wifi/fast_scan/Makefile new file mode 100644 index 000000000..9c6421b13 --- /dev/null +++ b/examples/wifi/fast_scan/Makefile @@ -0,0 +1,9 @@ +# +# This is a project Makefile. It is assumed the directory this Makefile resides in is a +# project subdirectory. +# + +PROJECT_NAME := fast_scan + +include $(IDF_PATH)/make/project.mk + diff --git a/examples/wifi/fast_scan/README.md b/examples/wifi/fast_scan/README.md new file mode 100644 index 000000000..d6f21d295 --- /dev/null +++ b/examples/wifi/fast_scan/README.md @@ -0,0 +1,11 @@ +# Wifi Fast Scan Example + +This example shows how to use the scan functionality of the Wi-Fi driver of ESP32 for connecting to an AP. + +Two scan methods are supported: fast scan and all channel scan. + +* fast scan: in this mode, scan finishes right after a matching AP is detected, even if channels are not completely scanned. You can set thresholds for signal strength, as well as select desired authentication modes provided by the AP's. The Wi-Fi driver will ignore AP's that fail to meet mentioned criteria. + +* all channel scan: scan will end only after all channels are scanned; the Wi-Fi driver will store 4 of the fully matching AP's. Sort methods for AP's include rssi and authmode. After the scan, the Wi-Fi driver selects the AP that fits best based on the sort. + +After the scan, the Wi-Fi driver will try to connect. Because it needs to to allocate precious dynamic memory to store matching AP's, and, most of the cases, connect to the AP with the strongest reception, it does not need to record all the AP's matched. The number of matches stored is limited to 4 in order to limit dynamic memory usage. Among the 4 matches, AP's are allowed to carry the same SSID name and all possible authentication modes - Open, WEP, WPA and WPA2. diff --git a/examples/wifi/fast_scan/main/CMakeLists.txt b/examples/wifi/fast_scan/main/CMakeLists.txt new file mode 100644 index 000000000..f6fc61fe1 --- /dev/null +++ b/examples/wifi/fast_scan/main/CMakeLists.txt @@ -0,0 +1,2 @@ +idf_component_register(SRCS "fast_scan.c" + INCLUDE_DIRS ".") diff --git a/examples/wifi/fast_scan/main/Kconfig.projbuild b/examples/wifi/fast_scan/main/Kconfig.projbuild new file mode 100644 index 000000000..95f738919 --- /dev/null +++ b/examples/wifi/fast_scan/main/Kconfig.projbuild @@ -0,0 +1,68 @@ +menu "Example Configuration" + + config EXAMPLE_WIFI_SSID + string "WiFi SSID" + default "myssid" + help + SSID (network name) for the example to connect to. + + config EXAMPLE_WIFI_PASSWORD + string "WiFi Password" + default "mypassword" + help + WiFi password (WPA or WPA2) for the example to use. + + choice EXAMPLE_SCAN_METHOD + prompt "scan method" + default EXAMPLE_WIFI_FAST_SCAN + help + scan method for the esp32 to use + + config EXAMPLE_WIFI_FAST_SCAN + bool "fast" + config EXAMPLE_WIFI_ALL_CHANNEL_SCAN + bool "all" + endchoice + + choice EXAMPLE_SORT_METHOD + prompt "sort method" + default EXAMPLE_WIFI_CONNECT_AP_BY_SIGNAL + help + sort method for the esp32 to use + + config EXAMPLE_WIFI_CONNECT_AP_BY_SIGNAL + bool "rssi" + config EXAMPLE_WIFI_CONNECT_AP_BY_SECURITY + bool "authmode" + endchoice + + config EXAMPLE_FAST_SCAN_THRESHOLD + bool "fast scan threshold" + default y + help + wifi fast scan threshold + + config EXAMPLE_FAST_SCAN_MINIMUM_SIGNAL + int "fast scan minimum rssi" + depends on EXAMPLE_FAST_SCAN_THRESHOLD + range -127 0 + default -127 + help + rssi is use to measure the signal + + choice EXAMPLE_FAST_SCAN_WEAKEST_AUTHMODE + prompt "fast scan weakest authmode" + depends on EXAMPLE_FAST_SCAN_THRESHOLD + default EXAMPLE_FAST_SCAN_WEAKEST_AUTHMODE_OPEN + + config EXAMPLE_FAST_SCAN_WEAKEST_AUTHMODE_OPEN + bool "open" + config EXAMPLE_FAST_SCAN_WEAKEST_AUTHMODE_WEP + bool "wep" + config EXAMPLE_FAST_SCAN_WEAKEST_AUTHMODE_WPA + bool "wpa" + config EXAMPLE_FAST_SCAN_WEAKEST_AUTHMODE_WPA2 + bool "wpa2" + endchoice + +endmenu diff --git a/examples/wifi/fast_scan/main/component.mk b/examples/wifi/fast_scan/main/component.mk new file mode 100644 index 000000000..7d7b29bfd --- /dev/null +++ b/examples/wifi/fast_scan/main/component.mk @@ -0,0 +1,7 @@ +# +# "main" pseudo-component makefile. +# +# (Uses default behaviour of compiling all source files in directory, adding 'include' to include path.) + + + diff --git a/examples/wifi/fast_scan/main/fast_scan.c b/examples/wifi/fast_scan/main/fast_scan.c new file mode 100644 index 000000000..bc724126d --- /dev/null +++ b/examples/wifi/fast_scan/main/fast_scan.c @@ -0,0 +1,123 @@ +/* Scan Example + + This example code is in the Public Domain (or CC0 licensed, at your option.) + + Unless required by applicable law or agreed to in writing, this + software is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR + CONDITIONS OF ANY KIND, either express or implied. +*/ + +/* + This example shows how to use the All Channel Scan or Fast Scan to connect + to a Wi-Fi network. + + In the Fast Scan mode, the scan will stop as soon as the first network matching + the SSID is found. In this mode, an application can set threshold for the + authentication mode and the Signal strength. Networks that do not meet the + threshold requirements will be ignored. + + In the All Channel Scan mode, the scan will end only after all the channels + are scanned, and connection will start with the best network. The networks + can be sorted based on Authentication Mode or Signal Strength. The priority + for the Authentication mode is: WPA2 > WPA > WEP > Open +*/ +#include "freertos/FreeRTOS.h" +#include "freertos/event_groups.h" +#include "esp_wifi.h" +#include "esp_log.h" +#include "esp_event.h" +#include "nvs_flash.h" + +/* Set the SSID and Password via project configuration, or can set directly here */ +#define DEFAULT_SSID CONFIG_EXAMPLE_WIFI_SSID +#define DEFAULT_PWD CONFIG_EXAMPLE_WIFI_PASSWORD + +#if CONFIG_EXAMPLE_WIFI_ALL_CHANNEL_SCAN +#define DEFAULT_SCAN_METHOD WIFI_ALL_CHANNEL_SCAN +#elif CONFIG_EXAMPLE_WIFI_FAST_SCAN +#define DEFAULT_SCAN_METHOD WIFI_FAST_SCAN +#else +#define DEFAULT_SCAN_METHOD WIFI_FAST_SCAN +#endif /*CONFIG_EXAMPLE_SCAN_METHOD*/ + +#if CONFIG_EXAMPLE_WIFI_CONNECT_AP_BY_SIGNAL +#define DEFAULT_SORT_METHOD WIFI_CONNECT_AP_BY_SIGNAL +#elif CONFIG_EXAMPLE_WIFI_CONNECT_AP_BY_SECURITY +#define DEFAULT_SORT_METHOD WIFI_CONNECT_AP_BY_SECURITY +#else +#define DEFAULT_SORT_METHOD WIFI_CONNECT_AP_BY_SIGNAL +#endif /*CONFIG_EXAMPLE_SORT_METHOD*/ + +#if CONFIG_EXAMPLE_FAST_SCAN_THRESHOLD +#define DEFAULT_RSSI CONFIG_EXAMPLE_FAST_SCAN_MINIMUM_SIGNAL +#if CONFIG_EXAMPLE_FAST_SCAN_WEAKEST_AUTHMODE_OPEN +#define DEFAULT_AUTHMODE WIFI_AUTH_OPEN +#elif CONFIG_EXAMPLE_FAST_SCAN_WEAKEST_AUTHMODE_WEP +#define DEFAULT_AUTHMODE WIFI_AUTH_WEP +#elif CONFIG_EXAMPLE_FAST_SCAN_WEAKEST_AUTHMODE_WPA +#define DEFAULT_AUTHMODE WIFI_AUTH_WPA_PSK +#elif CONFIG_EXAMPLE_FAST_SCAN_WEAKEST_AUTHMODE_WPA2 +#define DEFAULT_AUTHMODE WIFI_AUTH_WPA2_PSK +#else +#define DEFAULT_AUTHMODE WIFI_AUTH_OPEN +#endif +#else +#define DEFAULT_RSSI -127 +#define DEFAULT_AUTHMODE WIFI_AUTH_OPEN +#endif /*CONFIG_EXAMPLE_FAST_SCAN_THRESHOLD*/ + +static const char *TAG = "scan"; + +static void event_handler(void* arg, esp_event_base_t event_base, + int32_t event_id, void* event_data) +{ + if (event_base == WIFI_EVENT && event_id == WIFI_EVENT_STA_START) { + esp_wifi_connect(); + } else if (event_base == WIFI_EVENT && event_id == WIFI_EVENT_STA_DISCONNECTED) { + esp_wifi_connect(); + } else if (event_base == IP_EVENT && event_id == IP_EVENT_STA_GOT_IP) { + ip_event_got_ip_t* event = (ip_event_got_ip_t*) event_data; + ESP_LOGI(TAG, "got ip: %s", ip4addr_ntoa(&event->ip_info.ip)); + } +} + + +/* Initialize Wi-Fi as sta and set scan method */ +static void fast_scan(void) +{ + tcpip_adapter_init(); + ESP_ERROR_CHECK(esp_event_loop_create_default()); + + wifi_init_config_t cfg = WIFI_INIT_CONFIG_DEFAULT(); + ESP_ERROR_CHECK(esp_wifi_init(&cfg)); + + ESP_ERROR_CHECK(esp_event_handler_register(WIFI_EVENT, ESP_EVENT_ANY_ID, &event_handler, NULL)); + ESP_ERROR_CHECK(esp_event_handler_register(IP_EVENT, IP_EVENT_STA_GOT_IP, &event_handler, NULL)); + + wifi_config_t wifi_config = { + .sta = { + .ssid = DEFAULT_SSID, + .password = DEFAULT_PWD, + .scan_method = DEFAULT_SCAN_METHOD, + .sort_method = DEFAULT_SORT_METHOD, + .threshold.rssi = DEFAULT_RSSI, + .threshold.authmode = DEFAULT_AUTHMODE, + }, + }; + ESP_ERROR_CHECK(esp_wifi_set_mode(WIFI_MODE_STA)); + ESP_ERROR_CHECK(esp_wifi_set_config(ESP_IF_WIFI_STA, &wifi_config)); + ESP_ERROR_CHECK(esp_wifi_start()); +} + +void app_main(void) +{ + // Initialize NVS + esp_err_t ret = nvs_flash_init(); + if (ret == ESP_ERR_NVS_NO_FREE_PAGES || ret == ESP_ERR_NVS_NEW_VERSION_FOUND) { + ESP_ERROR_CHECK(nvs_flash_erase()); + ret = nvs_flash_init(); + } + ESP_ERROR_CHECK( ret ); + + fast_scan(); +} diff --git a/examples/wifi/scan/README.md b/examples/wifi/scan/README.md index dec4d5ebb..0fad7f9c1 100644 --- a/examples/wifi/scan/README.md +++ b/examples/wifi/scan/README.md @@ -1,11 +1,5 @@ # Wifi SCAN Example -This example shows how to use the scan functionality of the Wi-Fi driver of ESP32. +This example shows how to scan for available set of APs. -Two scan methods are supported: fast scan and all channel scan. - -* fast scan: in this mode, scan finishes right after a matching AP is detected, even if channels are not completely scanned. You can set thresholds for signal strength, as well as select desired authentication modes provided by the AP's. The Wi-Fi driver will ignore AP's that fail to meet mentioned criteria. - -* all channel scan: scan will end only after all channels are scanned; the Wi-Fi driver will store 4 of the fully matching AP's. Sort methods for AP's include rssi and authmode. After the scan, the Wi-Fi driver selects the AP that fits best based on the sort. - -After the scan, the Wi-Fi driver will try to connect. Because it needs to to allocate precious dynamic memory to store matching AP's, and, most of the cases, connect to the AP with the strongest reception, it does not need to record all the AP's matched. The number of matches stored is limited to 4 in order to limit dynamic memory usage. Among the 4 matches, AP's are allowed to carry the same SSID name and all possible authentication modes - Open, WEP, WPA and WPA2. +* The SCAN_LIST_SIZE parameter needs to be set from the example configuration menu. It represents maximum number of scan list entries that driver can populate. \ No newline at end of file diff --git a/examples/wifi/scan/main/Kconfig.projbuild b/examples/wifi/scan/main/Kconfig.projbuild index 95f738919..9411c2141 100644 --- a/examples/wifi/scan/main/Kconfig.projbuild +++ b/examples/wifi/scan/main/Kconfig.projbuild @@ -1,68 +1,11 @@ menu "Example Configuration" - config EXAMPLE_WIFI_SSID - string "WiFi SSID" - default "myssid" + config EXAMPLE_SCAN_LIST_SIZE + int "Max size of scan list" + range 0 20 + default 10 help - SSID (network name) for the example to connect to. - - config EXAMPLE_WIFI_PASSWORD - string "WiFi Password" - default "mypassword" - help - WiFi password (WPA or WPA2) for the example to use. - - choice EXAMPLE_SCAN_METHOD - prompt "scan method" - default EXAMPLE_WIFI_FAST_SCAN - help - scan method for the esp32 to use - - config EXAMPLE_WIFI_FAST_SCAN - bool "fast" - config EXAMPLE_WIFI_ALL_CHANNEL_SCAN - bool "all" - endchoice - - choice EXAMPLE_SORT_METHOD - prompt "sort method" - default EXAMPLE_WIFI_CONNECT_AP_BY_SIGNAL - help - sort method for the esp32 to use - - config EXAMPLE_WIFI_CONNECT_AP_BY_SIGNAL - bool "rssi" - config EXAMPLE_WIFI_CONNECT_AP_BY_SECURITY - bool "authmode" - endchoice - - config EXAMPLE_FAST_SCAN_THRESHOLD - bool "fast scan threshold" - default y - help - wifi fast scan threshold - - config EXAMPLE_FAST_SCAN_MINIMUM_SIGNAL - int "fast scan minimum rssi" - depends on EXAMPLE_FAST_SCAN_THRESHOLD - range -127 0 - default -127 - help - rssi is use to measure the signal - - choice EXAMPLE_FAST_SCAN_WEAKEST_AUTHMODE - prompt "fast scan weakest authmode" - depends on EXAMPLE_FAST_SCAN_THRESHOLD - default EXAMPLE_FAST_SCAN_WEAKEST_AUTHMODE_OPEN - - config EXAMPLE_FAST_SCAN_WEAKEST_AUTHMODE_OPEN - bool "open" - config EXAMPLE_FAST_SCAN_WEAKEST_AUTHMODE_WEP - bool "wep" - config EXAMPLE_FAST_SCAN_WEAKEST_AUTHMODE_WPA - bool "wpa" - config EXAMPLE_FAST_SCAN_WEAKEST_AUTHMODE_WPA2 - bool "wpa2" - endchoice + The size of array that will be used to retrieve the list of access points. endmenu + diff --git a/examples/wifi/scan/main/scan.c b/examples/wifi/scan/main/scan.c index 0f54d8e3e..a3ab6253e 100644 --- a/examples/wifi/scan/main/scan.c +++ b/examples/wifi/scan/main/scan.c @@ -21,6 +21,7 @@ can be sorted based on Authentication Mode or Signal Strength. The priority for the Authentication mode is: WPA2 > WPA > WEP > Open */ +#include #include "freertos/FreeRTOS.h" #include "freertos/event_groups.h" #include "esp_wifi.h" @@ -28,59 +29,87 @@ #include "esp_event.h" #include "nvs_flash.h" -/* Set the SSID and Password via project configuration, or can set directly here */ -#define DEFAULT_SSID CONFIG_EXAMPLE_WIFI_SSID -#define DEFAULT_PWD CONFIG_EXAMPLE_WIFI_PASSWORD - -#if CONFIG_EXAMPLE_WIFI_ALL_CHANNEL_SCAN -#define DEFAULT_SCAN_METHOD WIFI_ALL_CHANNEL_SCAN -#elif CONFIG_EXAMPLE_WIFI_FAST_SCAN -#define DEFAULT_SCAN_METHOD WIFI_FAST_SCAN -#else -#define DEFAULT_SCAN_METHOD WIFI_FAST_SCAN -#endif /*CONFIG_EXAMPLE_SCAN_METHOD*/ - -#if CONFIG_EXAMPLE_WIFI_CONNECT_AP_BY_SIGNAL -#define DEFAULT_SORT_METHOD WIFI_CONNECT_AP_BY_SIGNAL -#elif CONFIG_EXAMPLE_WIFI_CONNECT_AP_BY_SECURITY -#define DEFAULT_SORT_METHOD WIFI_CONNECT_AP_BY_SECURITY -#else -#define DEFAULT_SORT_METHOD WIFI_CONNECT_AP_BY_SIGNAL -#endif /*CONFIG_EXAMPLE_SORT_METHOD*/ - -#if CONFIG_EXAMPLE_FAST_SCAN_THRESHOLD -#define DEFAULT_RSSI CONFIG_EXAMPLE_FAST_SCAN_MINIMUM_SIGNAL -#if CONFIG_EXAMPLE_FAST_SCAN_WEAKEST_AUTHMODE_OPEN -#define DEFAULT_AUTHMODE WIFI_AUTH_OPEN -#elif CONFIG_EXAMPLE_FAST_SCAN_WEAKEST_AUTHMODE_WEP -#define DEFAULT_AUTHMODE WIFI_AUTH_WEP -#elif CONFIG_EXAMPLE_FAST_SCAN_WEAKEST_AUTHMODE_WPA -#define DEFAULT_AUTHMODE WIFI_AUTH_WPA_PSK -#elif CONFIG_EXAMPLE_FAST_SCAN_WEAKEST_AUTHMODE_WPA2 -#define DEFAULT_AUTHMODE WIFI_AUTH_WPA2_PSK -#else -#define DEFAULT_AUTHMODE WIFI_AUTH_OPEN -#endif -#else -#define DEFAULT_RSSI -127 -#define DEFAULT_AUTHMODE WIFI_AUTH_OPEN -#endif /*CONFIG_EXAMPLE_FAST_SCAN_THRESHOLD*/ +#define DEFAULT_SCAN_LIST_SIZE CONFIG_EXAMPLE_SCAN_LIST_SIZE static const char *TAG = "scan"; -static void event_handler(void* arg, esp_event_base_t event_base, - int32_t event_id, void* event_data) +static void print_auth_mode(int authmode) { - if (event_base == WIFI_EVENT && event_id == WIFI_EVENT_STA_START) { - esp_wifi_connect(); - } else if (event_base == WIFI_EVENT && event_id == WIFI_EVENT_STA_DISCONNECTED) { - esp_wifi_connect(); - } else if (event_base == IP_EVENT && event_id == IP_EVENT_STA_GOT_IP) { - ip_event_got_ip_t* event = (ip_event_got_ip_t*) event_data; - ESP_LOGI(TAG, "got ip: %s", ip4addr_ntoa(&event->ip_info.ip)); + switch (authmode) { + case WIFI_AUTH_OPEN: + ESP_LOGI(TAG, "Authmode \tWIFI_AUTH_OPEN"); + break; + case WIFI_AUTH_WEP: + ESP_LOGI(TAG, "Authmode \tWIFI_AUTH_WEP"); + break; + case WIFI_AUTH_WPA_PSK: + ESP_LOGI(TAG, "Authmode \tWIFI_AUTH_WPA_PSK"); + break; + case WIFI_AUTH_WPA2_PSK: + ESP_LOGI(TAG, "Authmode \tWIFI_AUTH_WPA2_PSK"); + break; + case WIFI_AUTH_WPA_WPA2_PSK: + ESP_LOGI(TAG, "Authmode \tWIFI_AUTH_WPA_WPA2_PSK"); + break; + case WIFI_AUTH_WPA2_ENTERPRISE: + ESP_LOGI(TAG, "Authmode \tWIFI_AUTH_WPA2_ENTERPRISE"); + break; + default: + ESP_LOGI(TAG, "Authmode \tWIFI_AUTH_UNKNOWN"); + break; } } +static void print_cipher_type(int pairwise_cipher, int group_cipher) +{ + switch (pairwise_cipher) { + case WIFI_CIPHER_TYPE_NONE: + ESP_LOGI(TAG, "Pairwise Cipher \tWIFI_CIPHER_TYPE_NONE"); + break; + case WIFI_CIPHER_TYPE_WEP40: + ESP_LOGI(TAG, "Pairwise Cipher \tWIFI_CIPHER_TYPE_WEP40"); + break; + case WIFI_CIPHER_TYPE_WEP104: + ESP_LOGI(TAG, "Pairwise Cipher \tWIFI_CIPHER_TYPE_WEP104"); + break; + case WIFI_CIPHER_TYPE_TKIP: + ESP_LOGI(TAG, "Pairwise Cipher \tWIFI_CIPHER_TYPE_TKIP"); + break; + case WIFI_CIPHER_TYPE_CCMP: + ESP_LOGI(TAG, "Pairwise Cipher \tWIFI_CIPHER_TYPE_CCMP"); + break; + case WIFI_CIPHER_TYPE_TKIP_CCMP: + ESP_LOGI(TAG, "Pairwise Cipher \tWIFI_CIPHER_TYPE_TKIP_CCMP"); + break; + default: + ESP_LOGI(TAG, "Pairwise Cipher \tWIFI_CIPHER_TYPE_UNKNOWN"); + break; + } + + switch (group_cipher) { + case WIFI_CIPHER_TYPE_NONE: + ESP_LOGI(TAG, "Group Cipher \tWIFI_CIPHER_TYPE_NONE"); + break; + case WIFI_CIPHER_TYPE_WEP40: + ESP_LOGI(TAG, "Group Cipher \tWIFI_CIPHER_TYPE_WEP40"); + break; + case WIFI_CIPHER_TYPE_WEP104: + ESP_LOGI(TAG, "Group Cipher \tWIFI_CIPHER_TYPE_WEP104"); + break; + case WIFI_CIPHER_TYPE_TKIP: + ESP_LOGI(TAG, "Group Cipher \tWIFI_CIPHER_TYPE_TKIP"); + break; + case WIFI_CIPHER_TYPE_CCMP: + ESP_LOGI(TAG, "Group Cipher \tWIFI_CIPHER_TYPE_CCMP"); + break; + case WIFI_CIPHER_TYPE_TKIP_CCMP: + ESP_LOGI(TAG, "Group Cipher \tWIFI_CIPHER_TYPE_TKIP_CCMP"); + break; + default: + ESP_LOGI(TAG, "Group Cipher \tWIFI_CIPHER_TYPE_UNKNOWN"); + break; + } +} /* Initialize Wi-Fi as sta and set scan method */ static void wifi_scan(void) @@ -91,22 +120,25 @@ static void wifi_scan(void) wifi_init_config_t cfg = WIFI_INIT_CONFIG_DEFAULT(); ESP_ERROR_CHECK(esp_wifi_init(&cfg)); - ESP_ERROR_CHECK(esp_event_handler_register(WIFI_EVENT, ESP_EVENT_ANY_ID, &event_handler, NULL)); - ESP_ERROR_CHECK(esp_event_handler_register(IP_EVENT, IP_EVENT_STA_GOT_IP, &event_handler, NULL)); + uint16_t number = DEFAULT_SCAN_LIST_SIZE; + wifi_ap_record_t ap_info[DEFAULT_SCAN_LIST_SIZE]; + memset(ap_info, 0, sizeof(ap_info)); - wifi_config_t wifi_config = { - .sta = { - .ssid = DEFAULT_SSID, - .password = DEFAULT_PWD, - .scan_method = DEFAULT_SCAN_METHOD, - .sort_method = DEFAULT_SORT_METHOD, - .threshold.rssi = DEFAULT_RSSI, - .threshold.authmode = DEFAULT_AUTHMODE, - }, - }; ESP_ERROR_CHECK(esp_wifi_set_mode(WIFI_MODE_STA)); - ESP_ERROR_CHECK(esp_wifi_set_config(ESP_IF_WIFI_STA, &wifi_config)); ESP_ERROR_CHECK(esp_wifi_start()); + ESP_ERROR_CHECK(esp_wifi_scan_start(NULL, true)); + ESP_ERROR_CHECK(esp_wifi_scan_get_ap_records(&number, ap_info)); + + for (int i = 0; i < DEFAULT_SCAN_LIST_SIZE; i++) { + ESP_LOGI(TAG, "SSID \t\t%s", ap_info[i].ssid); + ESP_LOGI(TAG, "RSSI \t\t%d", ap_info[i].rssi); + print_auth_mode(ap_info[i].authmode); + if (ap_info[i].authmode != WIFI_AUTH_WEP) { + print_cipher_type(ap_info[i].pairwise_cipher, ap_info[i].group_cipher); + } + ESP_LOGI(TAG, "Channel \t\t%d\n", ap_info[i].primary); + } + } void app_main(void)