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:
@ -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;
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user