mirror of
https://github.com/esphome/esphome.git
synced 2025-01-10 19:47:47 +01:00
Support ESP8266 Arduino 3.0.0 (#1897)
Co-authored-by: Otto Winter <otto@otto-winter.com>
This commit is contained in:
parent
92bbedfa5a
commit
a80f9ed336
@ -237,7 +237,7 @@ optional<float> FilterOutValueFilter::new_value(float value) {
|
|||||||
return value;
|
return value;
|
||||||
} else {
|
} else {
|
||||||
int8_t accuracy = this->parent_->get_accuracy_decimals();
|
int8_t accuracy = this->parent_->get_accuracy_decimals();
|
||||||
float accuracy_mult = pow10f(accuracy);
|
float accuracy_mult = powf(10.0f, accuracy);
|
||||||
float rounded_filter_out = roundf(accuracy_mult * this->value_to_filter_out_);
|
float rounded_filter_out = roundf(accuracy_mult * this->value_to_filter_out_);
|
||||||
float rounded_value = roundf(accuracy_mult * value);
|
float rounded_value = roundf(accuracy_mult * value);
|
||||||
if (rounded_filter_out == rounded_value)
|
if (rounded_filter_out == rounded_value)
|
||||||
|
@ -10,6 +10,10 @@
|
|||||||
#include <wpa2_enterprise.h>
|
#include <wpa2_enterprise.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef WIFI_IS_OFF_AT_BOOT // Identifies ESP8266 Arduino 3.0.0
|
||||||
|
#define ARDUINO_ESP8266_RELEASE_3
|
||||||
|
#endif
|
||||||
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#include "lwip/err.h"
|
#include "lwip/err.h"
|
||||||
#include "lwip/dns.h"
|
#include "lwip/dns.h"
|
||||||
@ -18,6 +22,12 @@ extern "C" {
|
|||||||
#if LWIP_IPV6
|
#if LWIP_IPV6
|
||||||
#include "lwip/netif.h" // struct netif
|
#include "lwip/netif.h" // struct netif
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef ARDUINO_ESP8266_RELEASE_3
|
||||||
|
#include "LwipDhcpServer.h"
|
||||||
|
#define wifi_softap_set_dhcps_lease(lease) dhcpSoftAP.set_dhcps_lease(lease)
|
||||||
|
#define wifi_softap_set_dhcps_lease_time(time) dhcpSoftAP.set_dhcps_lease_time(time)
|
||||||
|
#define wifi_softap_set_dhcps_offer_option(offer, mode) dhcpSoftAP.set_dhcps_offer_option(offer, mode)
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#include "esphome/core/helpers.h"
|
#include "esphome/core/helpers.h"
|
||||||
@ -649,6 +659,10 @@ bool WiFiComponent::wifi_ap_ip_config_(optional<ManualIP> manual_ip) {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef ARDUINO_ESP8266_RELEASE_3
|
||||||
|
dhcpSoftAP.begin(&info);
|
||||||
|
#endif
|
||||||
|
|
||||||
struct dhcps_lease lease {};
|
struct dhcps_lease lease {};
|
||||||
IPAddress start_address = info.ip.addr;
|
IPAddress start_address = info.ip.addr;
|
||||||
start_address[3] += 99;
|
start_address[3] += 99;
|
||||||
|
@ -28,6 +28,7 @@ ARDUINO_VERSION_ESP32 = {
|
|||||||
# See also https://github.com/platformio/platform-espressif8266/releases
|
# See also https://github.com/platformio/platform-espressif8266/releases
|
||||||
ARDUINO_VERSION_ESP8266 = {
|
ARDUINO_VERSION_ESP8266 = {
|
||||||
"dev": "https://github.com/platformio/platform-espressif8266.git",
|
"dev": "https://github.com/platformio/platform-espressif8266.git",
|
||||||
|
"3.0.0": "platformio/espressif8266@3.0.0",
|
||||||
"2.7.4": "platformio/espressif8266@2.6.2",
|
"2.7.4": "platformio/espressif8266@2.6.2",
|
||||||
"2.7.3": "platformio/espressif8266@2.6.1",
|
"2.7.3": "platformio/espressif8266@2.6.1",
|
||||||
"2.7.2": "platformio/espressif8266@2.6.0",
|
"2.7.2": "platformio/espressif8266@2.6.0",
|
||||||
|
@ -105,7 +105,7 @@ std::string truncate_string(const std::string &s, size_t length) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
std::string value_accuracy_to_string(float value, int8_t accuracy_decimals) {
|
std::string value_accuracy_to_string(float value, int8_t accuracy_decimals) {
|
||||||
auto multiplier = float(pow10(accuracy_decimals));
|
auto multiplier = float(powf(10.0f, accuracy_decimals));
|
||||||
float value_rounded = roundf(value * multiplier) / multiplier;
|
float value_rounded = roundf(value * multiplier) / multiplier;
|
||||||
char tmp[32]; // should be enough, but we should maybe improve this at some point.
|
char tmp[32]; // should be enough, but we should maybe improve this at some point.
|
||||||
dtostrf(value_rounded, 0, uint8_t(std::max(0, int(accuracy_decimals))), tmp);
|
dtostrf(value_rounded, 0, uint8_t(std::max(0, int(accuracy_decimals))), tmp);
|
||||||
|
Loading…
Reference in New Issue
Block a user