1
0
mirror of https://github.com/esp8266/Arduino.git synced 2025-06-15 00:02:49 +03:00

WiFi scanning (incomplete) and diagnostics

This commit is contained in:
Ivan Grokhotkov
2014-12-19 01:41:35 +03:00
parent 6c344ffbb1
commit eb98948d49
2 changed files with 70 additions and 14 deletions

View File

@ -69,6 +69,8 @@ int ESP8266WiFiClass::begin(const char* ssid, const char *passphrase)
else else
*conf.password = 0; *conf.password = 0;
conf.bssid_set = 0;
ETS_UART_INTR_DISABLE(); ETS_UART_INTR_DISABLE();
wifi_station_set_config(&conf); wifi_station_set_config(&conf);
wifi_station_connect(); wifi_station_connect();
@ -201,6 +203,11 @@ char* ESP8266WiFiClass::SSID()
// return WiFiDrv::getCurrentEncryptionType(); // return WiFiDrv::getCurrentEncryptionType();
// } // }
extern "C"
{
typedef STAILQ_HEAD(, bss_info) bss_info_head_t;
}
void ESP8266WiFiClass::_scanDone(void* result, int status) void ESP8266WiFiClass::_scanDone(void* result, int status)
{ {
if (status != OK) if (status != OK)
@ -210,9 +217,11 @@ void ESP8266WiFiClass::_scanDone(void* result, int status)
} }
else else
{ {
ESP8266WiFiClass::_scanResult = result;
int i = 0; int i = 0;
for (bss_info* it = reinterpret_cast<bss_info*>(result); it; it = STAILQ_NEXT(it, next), ++i); bss_info_head_t* head = reinterpret_cast<bss_info_head_t*>(result);
ESP8266WiFiClass::_scanResult = STAILQ_FIRST(head);
for (bss_info* it = STAILQ_FIRST(head); it; it = STAILQ_NEXT(it, next), ++i);
ESP8266WiFiClass::_scanCount = i; ESP8266WiFiClass::_scanCount = i;
} }
esp_schedule(); esp_schedule();
@ -233,7 +242,7 @@ int8_t ESP8266WiFiClass::scanNetworks()
if (ESP8266WiFiClass::_scanResult) if (ESP8266WiFiClass::_scanResult)
{ {
bss_info* it = reinterpret_cast<bss_info*>(ESP8266WiFiClass::_scanResult); struct bss_info* it = reinterpret_cast<bss_info*>(ESP8266WiFiClass::_scanResult);
ESP8266WiFiClass::_scanResult = 0; ESP8266WiFiClass::_scanResult = 0;
ESP8266WiFiClass::_scanCount = 0; ESP8266WiFiClass::_scanCount = 0;
while(it) while(it)
@ -256,25 +265,27 @@ int8_t ESP8266WiFiClass::scanNetworks()
void * ESP8266WiFiClass::_getScanInfoByIndex(int i) void * ESP8266WiFiClass::_getScanInfoByIndex(int i)
{ {
if (!ESP8266WiFiClass::_scanResult || i > ESP8266WiFiClass::_scanCount) if (!ESP8266WiFiClass::_scanResult || i > ESP8266WiFiClass::_scanCount)
{
return 0; return 0;
}
struct bss_info* it = reinterpret_cast<struct bss_info*>(ESP8266WiFiClass::_scanResult); struct bss_info* it = reinterpret_cast<bss_info*>(ESP8266WiFiClass::_scanResult);
for (; i && it; --i) while(i > 0 && it)
{
it = STAILQ_NEXT(it, next); it = STAILQ_NEXT(it, next);
--i;
if (!it) }
return 0;
return it; return it;
} }
char* ESP8266WiFiClass::SSID(uint8_t i) const char* ESP8266WiFiClass::SSID(uint8_t i)
{ {
struct bss_info* it = reinterpret_cast<struct bss_info*>(_getScanInfoByIndex(i)); struct bss_info* it = reinterpret_cast<struct bss_info*>(_getScanInfoByIndex(i));
if (!it) if (!it)
return 0; return 0;
return reinterpret_cast<char*>(it->ssid); return reinterpret_cast<const char*>(it->ssid);
} }
int32_t ESP8266WiFiClass::RSSI(uint8_t i) int32_t ESP8266WiFiClass::RSSI(uint8_t i)
@ -345,6 +356,48 @@ int ESP8266WiFiClass::hostByName(const char* aHostname, IPAddress& aResult)
return (aResult != 0) ? 1 : 0; return (aResult != 0) ? 1 : 0;
} }
void ESP8266WiFiClass::printDiag(Print& p)
{
const char* modes[] = {"NULL", "STA", "AP", "STA+AP"};
p.print("Mode: ");
p.println(modes[wifi_get_opmode()]);
const char* phymodes[] = {"", "B", "G", "N"};
p.print("PHY mode: ");
p.println(phymodes[(int) wifi_get_phy_mode()]);
p.print("Channel: ");
p.println(wifi_get_channel());
p.print("AP id: ");
p.println(wifi_station_get_current_ap_id());
p.print("Status: ");
p.println(wifi_station_get_connect_status());
p.print("Auto connect: ");
p.println(wifi_station_get_auto_connect());
static struct station_config conf;
wifi_station_get_config(&conf);
const char* ssid = reinterpret_cast<const char*>(conf.ssid);
p.print("SSID (");
p.print(strlen(ssid));
p.print("): ");
p.println(ssid);
const char* passphrase = reinterpret_cast<const char*>(conf.password);
p.print("Passphrase (");
p.print(strlen(passphrase));
p.print("): ");
p.println(passphrase);
p.print("BSSID set: ");
p.println(conf.bssid_set);
}
size_t ESP8266WiFiClass::_scanCount = 0; size_t ESP8266WiFiClass::_scanCount = 0;
void* ESP8266WiFiClass::_scanResult = 0; void* ESP8266WiFiClass::_scanResult = 0;

View File

@ -22,7 +22,7 @@
#ifndef WiFi_h #ifndef WiFi_h
#define WiFi_h #define WiFi_h
#include <inttypes.h> #include <stdint.h>
extern "C" { extern "C" {
#include "include/wl_definitions.h" #include "include/wl_definitions.h"
@ -151,7 +151,7 @@ public:
* *
* return: ssid string of the specified item on the networks scanned list * return: ssid string of the specified item on the networks scanned list
*/ */
char* SSID(uint8_t networkItem); const char* SSID(uint8_t networkItem);
/* /*
* Return the encryption type of the networks discovered during the scanNetworks * Return the encryption type of the networks discovered during the scanNetworks
@ -187,6 +187,9 @@ public:
*/ */
int hostByName(const char* aHostname, IPAddress& aResult); int hostByName(const char* aHostname, IPAddress& aResult);
void printDiag(Print& dest);
friend class WiFiClient; friend class WiFiClient;
friend class WiFiServer; friend class WiFiServer;