2017-09-28 16:17:06 +08:00
|
|
|
/* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
2019-11-15 23:56:16 +08:00
|
|
|
This example shows how to scan for available set of APs.
|
2017-09-28 16:17:06 +08:00
|
|
|
*/
|
2019-10-23 14:12:32 +08:00
|
|
|
#include <string.h>
|
2017-09-28 16:17:06 +08:00
|
|
|
#include "freertos/FreeRTOS.h"
|
|
|
|
#include "freertos/event_groups.h"
|
|
|
|
#include "esp_wifi.h"
|
|
|
|
#include "esp_log.h"
|
2018-11-20 18:26:53 +08:00
|
|
|
#include "esp_event.h"
|
2017-09-28 16:17:06 +08:00
|
|
|
#include "nvs_flash.h"
|
2024-03-29 18:40:49 +05:30
|
|
|
#include "regex.h"
|
2017-09-28 16:17:06 +08:00
|
|
|
|
2019-10-23 14:12:32 +08:00
|
|
|
#define DEFAULT_SCAN_LIST_SIZE CONFIG_EXAMPLE_SCAN_LIST_SIZE
|
2017-09-28 16:17:06 +08:00
|
|
|
|
2024-03-29 18:40:49 +05:30
|
|
|
#ifdef CONFIG_EXAMPLE_USE_SCAN_CHANNEL_BITMAP
|
|
|
|
#define USE_CHANNEL_BTIMAP 1
|
|
|
|
#define CHANNEL_LIST_SIZE 3
|
|
|
|
static uint8_t channel_list[CHANNEL_LIST_SIZE] = {1, 6, 11};
|
|
|
|
#endif /*CONFIG_EXAMPLE_USE_SCAN_CHANNEL_BITMAP*/
|
|
|
|
|
2017-09-28 16:17:06 +08:00
|
|
|
static const char *TAG = "scan";
|
|
|
|
|
2019-10-23 14:12:32 +08:00
|
|
|
static void print_auth_mode(int authmode)
|
2017-09-28 16:17:06 +08:00
|
|
|
{
|
2019-10-23 14:12:32 +08:00
|
|
|
switch (authmode) {
|
|
|
|
case WIFI_AUTH_OPEN:
|
|
|
|
ESP_LOGI(TAG, "Authmode \tWIFI_AUTH_OPEN");
|
|
|
|
break;
|
2022-06-14 11:31:52 +05:30
|
|
|
case WIFI_AUTH_OWE:
|
|
|
|
ESP_LOGI(TAG, "Authmode \tWIFI_AUTH_OWE");
|
|
|
|
break;
|
2019-10-23 14:12:32 +08:00
|
|
|
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;
|
2023-09-11 11:12:59 +05:30
|
|
|
case WIFI_AUTH_ENTERPRISE:
|
|
|
|
ESP_LOGI(TAG, "Authmode \tWIFI_AUTH_ENTERPRISE");
|
2019-10-23 14:12:32 +08:00
|
|
|
break;
|
2020-05-15 17:24:51 +05:30
|
|
|
case WIFI_AUTH_WPA3_PSK:
|
|
|
|
ESP_LOGI(TAG, "Authmode \tWIFI_AUTH_WPA3_PSK");
|
|
|
|
break;
|
|
|
|
case WIFI_AUTH_WPA2_WPA3_PSK:
|
|
|
|
ESP_LOGI(TAG, "Authmode \tWIFI_AUTH_WPA2_WPA3_PSK");
|
|
|
|
break;
|
2023-09-11 11:12:59 +05:30
|
|
|
case WIFI_AUTH_WPA3_ENT_192:
|
|
|
|
ESP_LOGI(TAG, "Authmode \tWIFI_AUTH_WPA3_ENT_192");
|
|
|
|
break;
|
2019-10-23 14:12:32 +08:00
|
|
|
default:
|
|
|
|
ESP_LOGI(TAG, "Authmode \tWIFI_AUTH_UNKNOWN");
|
|
|
|
break;
|
2017-09-28 16:17:06 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-10-23 14:12:32 +08:00
|
|
|
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;
|
2023-04-26 14:26:49 +05:30
|
|
|
case WIFI_CIPHER_TYPE_AES_CMAC128:
|
|
|
|
ESP_LOGI(TAG, "Pairwise Cipher \tWIFI_CIPHER_TYPE_AES_CMAC128");
|
|
|
|
break;
|
|
|
|
case WIFI_CIPHER_TYPE_SMS4:
|
|
|
|
ESP_LOGI(TAG, "Pairwise Cipher \tWIFI_CIPHER_TYPE_SMS4");
|
|
|
|
break;
|
|
|
|
case WIFI_CIPHER_TYPE_GCMP:
|
|
|
|
ESP_LOGI(TAG, "Pairwise Cipher \tWIFI_CIPHER_TYPE_GCMP");
|
|
|
|
break;
|
|
|
|
case WIFI_CIPHER_TYPE_GCMP256:
|
|
|
|
ESP_LOGI(TAG, "Pairwise Cipher \tWIFI_CIPHER_TYPE_GCMP256");
|
|
|
|
break;
|
2019-10-23 14:12:32 +08:00
|
|
|
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;
|
2023-04-26 14:26:49 +05:30
|
|
|
case WIFI_CIPHER_TYPE_SMS4:
|
|
|
|
ESP_LOGI(TAG, "Group Cipher \tWIFI_CIPHER_TYPE_SMS4");
|
|
|
|
break;
|
|
|
|
case WIFI_CIPHER_TYPE_GCMP:
|
|
|
|
ESP_LOGI(TAG, "Group Cipher \tWIFI_CIPHER_TYPE_GCMP");
|
|
|
|
break;
|
|
|
|
case WIFI_CIPHER_TYPE_GCMP256:
|
|
|
|
ESP_LOGI(TAG, "Group Cipher \tWIFI_CIPHER_TYPE_GCMP256");
|
|
|
|
break;
|
2019-10-23 14:12:32 +08:00
|
|
|
default:
|
|
|
|
ESP_LOGI(TAG, "Group Cipher \tWIFI_CIPHER_TYPE_UNKNOWN");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2018-11-20 18:26:53 +08:00
|
|
|
|
2024-03-29 18:40:49 +05:30
|
|
|
#ifdef USE_CHANNEL_BTIMAP
|
|
|
|
static void array_2_channel_bitmap(const uint8_t channel_list[], const uint8_t channel_list_size, wifi_scan_config_t *scan_config) {
|
|
|
|
|
|
|
|
for(uint8_t i = 0; i < channel_list_size; i++) {
|
|
|
|
uint8_t channel = channel_list[i];
|
|
|
|
scan_config->channel_bitmap.ghz_2_channels |= (1 << channel);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif /*USE_CHANNEL_BTIMAP*/
|
|
|
|
|
|
|
|
|
2017-11-15 14:59:13 +05:30
|
|
|
/* Initialize Wi-Fi as sta and set scan method */
|
2017-09-28 16:17:06 +08:00
|
|
|
static void wifi_scan(void)
|
|
|
|
{
|
2019-11-29 10:54:02 +01:00
|
|
|
ESP_ERROR_CHECK(esp_netif_init());
|
2018-11-20 18:26:53 +08:00
|
|
|
ESP_ERROR_CHECK(esp_event_loop_create_default());
|
2019-10-17 11:36:34 +02:00
|
|
|
esp_netif_t *sta_netif = esp_netif_create_default_wifi_sta();
|
|
|
|
assert(sta_netif);
|
2017-11-15 13:04:21 +05:30
|
|
|
|
2017-09-28 16:17:06 +08:00
|
|
|
wifi_init_config_t cfg = WIFI_INIT_CONFIG_DEFAULT();
|
|
|
|
ESP_ERROR_CHECK(esp_wifi_init(&cfg));
|
2018-11-20 18:26:53 +08:00
|
|
|
|
2019-10-23 14:12:32 +08:00
|
|
|
uint16_t number = DEFAULT_SCAN_LIST_SIZE;
|
|
|
|
wifi_ap_record_t ap_info[DEFAULT_SCAN_LIST_SIZE];
|
2019-11-15 23:56:16 +08:00
|
|
|
uint16_t ap_count = 0;
|
2019-10-23 14:12:32 +08:00
|
|
|
memset(ap_info, 0, sizeof(ap_info));
|
|
|
|
|
2024-03-29 18:40:49 +05:30
|
|
|
|
2017-09-28 16:17:06 +08:00
|
|
|
ESP_ERROR_CHECK(esp_wifi_set_mode(WIFI_MODE_STA));
|
|
|
|
ESP_ERROR_CHECK(esp_wifi_start());
|
2024-03-29 18:40:49 +05:30
|
|
|
|
|
|
|
#ifdef USE_CHANNEL_BTIMAP
|
|
|
|
wifi_scan_config_t *scan_config = (wifi_scan_config_t *)calloc(1,sizeof(wifi_scan_config_t));
|
|
|
|
if (!scan_config) {
|
|
|
|
ESP_LOGE(TAG, "Memory Allocation for scan config failed!");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
array_2_channel_bitmap(channel_list, CHANNEL_LIST_SIZE, scan_config);
|
|
|
|
esp_wifi_scan_start(scan_config, true);
|
2024-07-17 17:33:58 +05:30
|
|
|
free(scan_config);
|
2024-03-29 18:40:49 +05:30
|
|
|
|
|
|
|
#else
|
2021-01-14 19:33:10 +08:00
|
|
|
esp_wifi_scan_start(NULL, true);
|
2024-03-29 18:40:49 +05:30
|
|
|
#endif /*USE_CHANNEL_BTIMAP*/
|
|
|
|
|
2023-10-17 17:55:54 +08:00
|
|
|
ESP_LOGI(TAG, "Max AP number ap_info can hold = %u", number);
|
2019-11-15 23:56:16 +08:00
|
|
|
ESP_ERROR_CHECK(esp_wifi_scan_get_ap_num(&ap_count));
|
2024-04-28 20:00:37 +08:00
|
|
|
ESP_ERROR_CHECK(esp_wifi_scan_get_ap_records(&number, ap_info));
|
2023-10-17 17:55:54 +08:00
|
|
|
ESP_LOGI(TAG, "Total APs scanned = %u, actual AP number ap_info holds = %u", ap_count, number);
|
|
|
|
for (int i = 0; i < number; i++) {
|
2019-10-23 14:12:32 +08:00
|
|
|
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);
|
|
|
|
}
|
2023-06-09 02:56:11 +08:00
|
|
|
ESP_LOGI(TAG, "Channel \t\t%d", ap_info[i].primary);
|
2019-10-23 14:12:32 +08:00
|
|
|
}
|
2017-09-28 16:17:06 +08:00
|
|
|
}
|
|
|
|
|
2019-07-16 16:33:30 +07:00
|
|
|
void app_main(void)
|
2017-09-28 16:17:06 +08:00
|
|
|
{
|
|
|
|
// Initialize NVS
|
|
|
|
esp_err_t ret = nvs_flash_init();
|
2018-07-25 20:41:09 +05:30
|
|
|
if (ret == ESP_ERR_NVS_NO_FREE_PAGES || ret == ESP_ERR_NVS_NEW_VERSION_FOUND) {
|
2017-09-28 16:17:06 +08:00
|
|
|
ESP_ERROR_CHECK(nvs_flash_erase());
|
|
|
|
ret = nvs_flash_init();
|
|
|
|
}
|
|
|
|
ESP_ERROR_CHECK( ret );
|
|
|
|
|
|
|
|
wifi_scan();
|
|
|
|
}
|