mirror of
https://github.com/esphome/esphome.git
synced 2024-11-27 17:27:59 +01:00
rollback helpers
This commit is contained in:
parent
46090db5a9
commit
e8bf7f10dd
2 changed files with 38 additions and 49 deletions
|
@ -54,10 +54,6 @@
|
||||||
#include <WiFi.h> // for macAddress()
|
#include <WiFi.h> // for macAddress()
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef USE_ZEPHYR
|
|
||||||
#include <zephyr/random/random.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
namespace esphome {
|
namespace esphome {
|
||||||
|
|
||||||
static const char *const TAG = "helpers";
|
static const char *const TAG = "helpers";
|
||||||
|
@ -193,39 +189,39 @@ uint32_t fnv1_hash(const std::string &str) {
|
||||||
return hash;
|
return hash;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t random_uint32() {
|
|
||||||
#ifdef USE_ESP32
|
#ifdef USE_ESP32
|
||||||
return esp_random();
|
uint32_t random_uint32() { return esp_random(); }
|
||||||
#elif defined(USE_ESP8266)
|
#elif defined(USE_ESP8266)
|
||||||
return os_random();
|
uint32_t random_uint32() { return os_random(); }
|
||||||
#elif defined(USE_RP2040)
|
#elif defined(USE_RP2040)
|
||||||
|
uint32_t random_uint32() {
|
||||||
uint32_t result = 0;
|
uint32_t result = 0;
|
||||||
for (uint8_t i = 0; i < 32; i++) {
|
for (uint8_t i = 0; i < 32; i++) {
|
||||||
result <<= 1;
|
result <<= 1;
|
||||||
result |= rosc_hw->randombit;
|
result |= rosc_hw->randombit;
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
|
}
|
||||||
#elif defined(USE_LIBRETINY)
|
#elif defined(USE_LIBRETINY)
|
||||||
return rand();
|
uint32_t random_uint32() { return rand(); }
|
||||||
#elif defined(USE_HOST)
|
#elif defined(USE_HOST)
|
||||||
|
uint32_t random_uint32() {
|
||||||
std::random_device dev;
|
std::random_device dev;
|
||||||
std::mt19937 rng(dev());
|
std::mt19937 rng(dev());
|
||||||
std::uniform_int_distribution<uint32_t> dist(0, std::numeric_limits<uint32_t>::max());
|
std::uniform_int_distribution<uint32_t> dist(0, std::numeric_limits<uint32_t>::max());
|
||||||
return dist(rng);
|
return dist(rng);
|
||||||
#elif defined(USE_ZEPHYR)
|
|
||||||
return rand(); // NOLINT(cert-msc30-c,cert-msc50-cpp)
|
|
||||||
#else
|
|
||||||
#error "No random source available for this configuration."
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
float random_float() { return static_cast<float>(random_uint32()) / static_cast<float>(UINT32_MAX); }
|
float random_float() { return static_cast<float>(random_uint32()) / static_cast<float>(UINT32_MAX); }
|
||||||
bool random_bytes(uint8_t *data, size_t len) {
|
|
||||||
#ifdef USE_ESP32
|
#ifdef USE_ESP32
|
||||||
|
bool random_bytes(uint8_t *data, size_t len) {
|
||||||
esp_fill_random(data, len);
|
esp_fill_random(data, len);
|
||||||
return true;
|
return true;
|
||||||
|
}
|
||||||
#elif defined(USE_ESP8266)
|
#elif defined(USE_ESP8266)
|
||||||
return os_get_random(data, len) == 0;
|
bool random_bytes(uint8_t *data, size_t len) { return os_get_random(data, len) == 0; }
|
||||||
#elif defined(USE_RP2040)
|
#elif defined(USE_RP2040)
|
||||||
|
bool random_bytes(uint8_t *data, size_t len) {
|
||||||
while (len-- != 0) {
|
while (len-- != 0) {
|
||||||
uint8_t result = 0;
|
uint8_t result = 0;
|
||||||
for (uint8_t i = 0; i < 8; i++) {
|
for (uint8_t i = 0; i < 8; i++) {
|
||||||
|
@ -235,10 +231,14 @@ bool random_bytes(uint8_t *data, size_t len) {
|
||||||
*data++ = result;
|
*data++ = result;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
}
|
||||||
#elif defined(USE_LIBRETINY)
|
#elif defined(USE_LIBRETINY)
|
||||||
|
bool random_bytes(uint8_t *data, size_t len) {
|
||||||
lt_rand_bytes(data, len);
|
lt_rand_bytes(data, len);
|
||||||
return true;
|
return true;
|
||||||
|
}
|
||||||
#elif defined(USE_HOST)
|
#elif defined(USE_HOST)
|
||||||
|
bool random_bytes(uint8_t *data, size_t len) {
|
||||||
FILE *fp = fopen("/dev/urandom", "r");
|
FILE *fp = fopen("/dev/urandom", "r");
|
||||||
if (fp == nullptr) {
|
if (fp == nullptr) {
|
||||||
ESP_LOGW(TAG, "Could not open /dev/urandom, errno=%d", errno);
|
ESP_LOGW(TAG, "Could not open /dev/urandom, errno=%d", errno);
|
||||||
|
@ -251,13 +251,8 @@ bool random_bytes(uint8_t *data, size_t len) {
|
||||||
}
|
}
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
return true;
|
return true;
|
||||||
#elif defined(USE_ZEPHYR)
|
|
||||||
sys_rand_get(data, len);
|
|
||||||
return true;
|
|
||||||
#else
|
|
||||||
#error "No random source available for this configuration."
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
// Strings
|
// Strings
|
||||||
|
|
||||||
|
@ -629,16 +624,13 @@ void hsv_to_rgb(int hue, float saturation, float value, float &red, float &green
|
||||||
#if defined(USE_ESP8266) || defined(USE_RP2040) || defined(USE_HOST)
|
#if defined(USE_ESP8266) || defined(USE_RP2040) || defined(USE_HOST)
|
||||||
// ESP8266 doesn't have mutexes, but that shouldn't be an issue as it's single-core and non-preemptive OS.
|
// ESP8266 doesn't have mutexes, but that shouldn't be an issue as it's single-core and non-preemptive OS.
|
||||||
Mutex::Mutex() {}
|
Mutex::Mutex() {}
|
||||||
|
Mutex::~Mutex() {}
|
||||||
void Mutex::lock() {}
|
void Mutex::lock() {}
|
||||||
bool Mutex::try_lock() { return true; }
|
bool Mutex::try_lock() { return true; }
|
||||||
void Mutex::unlock() {}
|
void Mutex::unlock() {}
|
||||||
#elif defined(USE_ZEPHYR)
|
|
||||||
Mutex::Mutex() { k_mutex_init(&this->handle_); }
|
|
||||||
void Mutex::lock() { k_mutex_lock(&this->handle_, K_FOREVER); }
|
|
||||||
bool Mutex::try_lock() { return k_mutex_lock(&this->handle_, K_NO_WAIT) == 0; }
|
|
||||||
void Mutex::unlock() { k_mutex_unlock(&this->handle_); }
|
|
||||||
#elif defined(USE_ESP32) || defined(USE_LIBRETINY)
|
#elif defined(USE_ESP32) || defined(USE_LIBRETINY)
|
||||||
Mutex::Mutex() { handle_ = xSemaphoreCreateMutex(); }
|
Mutex::Mutex() { handle_ = xSemaphoreCreateMutex(); }
|
||||||
|
Mutex::~Mutex() {}
|
||||||
void Mutex::lock() { xSemaphoreTake(this->handle_, portMAX_DELAY); }
|
void Mutex::lock() { xSemaphoreTake(this->handle_, portMAX_DELAY); }
|
||||||
bool Mutex::try_lock() { return xSemaphoreTake(this->handle_, 0) == pdTRUE; }
|
bool Mutex::try_lock() { return xSemaphoreTake(this->handle_, 0) == pdTRUE; }
|
||||||
void Mutex::unlock() { xSemaphoreGive(this->handle_); }
|
void Mutex::unlock() { xSemaphoreGive(this->handle_); }
|
||||||
|
@ -672,11 +664,13 @@ void HighFrequencyLoopRequester::stop() {
|
||||||
}
|
}
|
||||||
bool HighFrequencyLoopRequester::is_high_frequency() { return num_requests > 0; }
|
bool HighFrequencyLoopRequester::is_high_frequency() { return num_requests > 0; }
|
||||||
|
|
||||||
void get_mac_address_raw(uint8_t *mac) { // NOLINT(readability-non-const-parameter)
|
|
||||||
#if defined(USE_HOST)
|
#if defined(USE_HOST)
|
||||||
|
void get_mac_address_raw(uint8_t *mac) { // NOLINT(readability-non-const-parameter)
|
||||||
static const uint8_t esphome_host_mac_address[6] = USE_ESPHOME_HOST_MAC_ADDRESS;
|
static const uint8_t esphome_host_mac_address[6] = USE_ESPHOME_HOST_MAC_ADDRESS;
|
||||||
memcpy(mac, esphome_host_mac_address, sizeof(esphome_host_mac_address));
|
memcpy(mac, esphome_host_mac_address, sizeof(esphome_host_mac_address));
|
||||||
|
}
|
||||||
#elif defined(USE_ESP32)
|
#elif defined(USE_ESP32)
|
||||||
|
void get_mac_address_raw(uint8_t *mac) { // NOLINT(readability-non-const-parameter)
|
||||||
#if defined(CONFIG_SOC_IEEE802154_SUPPORTED)
|
#if defined(CONFIG_SOC_IEEE802154_SUPPORTED)
|
||||||
// When CONFIG_SOC_IEEE802154_SUPPORTED is defined, esp_efuse_mac_get_default
|
// When CONFIG_SOC_IEEE802154_SUPPORTED is defined, esp_efuse_mac_get_default
|
||||||
// returns the 802.15.4 EUI-64 address, so we read directly from eFuse instead.
|
// returns the 802.15.4 EUI-64 address, so we read directly from eFuse instead.
|
||||||
|
@ -692,23 +686,20 @@ void get_mac_address_raw(uint8_t *mac) { // NOLINT(readability-non-const-parame
|
||||||
esp_efuse_mac_get_default(mac);
|
esp_efuse_mac_get_default(mac);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
#elif defined(USE_ESP8266)
|
|
||||||
wifi_get_macaddr(STATION_IF, mac);
|
|
||||||
#elif defined(USE_RP2040) && defined(USE_WIFI)
|
|
||||||
WiFi.macAddress(mac);
|
|
||||||
#elif defined(USE_LIBRETINY)
|
|
||||||
WiFi.macAddress(mac);
|
|
||||||
#elif defined(USE_NRF52)
|
|
||||||
mac[0] = ((NRF_FICR->DEVICEADDR[1] & 0xFFFF) >> 8) | 0xC0;
|
|
||||||
mac[1] = NRF_FICR->DEVICEADDR[1] & 0xFFFF;
|
|
||||||
mac[2] = NRF_FICR->DEVICEADDR[0] >> 24;
|
|
||||||
mac[3] = NRF_FICR->DEVICEADDR[0] >> 16;
|
|
||||||
mac[4] = NRF_FICR->DEVICEADDR[0] >> 8;
|
|
||||||
mac[5] = NRF_FICR->DEVICEADDR[0];
|
|
||||||
#else
|
|
||||||
// this should be an error, but that messes with CI checks. #error No mac address method defined
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
#elif defined(USE_ESP8266)
|
||||||
|
void get_mac_address_raw(uint8_t *mac) { // NOLINT(readability-non-const-parameter)
|
||||||
|
wifi_get_macaddr(STATION_IF, mac);
|
||||||
|
}
|
||||||
|
#elif defined(USE_RP2040) && defined(USE_WIFI)
|
||||||
|
void get_mac_address_raw(uint8_t *mac) { // NOLINT(readability-non-const-parameter)
|
||||||
|
WiFi.macAddress(mac);
|
||||||
|
}
|
||||||
|
#elif defined(USE_LIBRETINY)
|
||||||
|
void get_mac_address_raw(uint8_t *mac) { // NOLINT(readability-non-const-parameter)
|
||||||
|
WiFi.macAddress(mac);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
std::string get_mac_address() {
|
std::string get_mac_address() {
|
||||||
uint8_t mac[6];
|
uint8_t mac[6];
|
||||||
|
|
|
@ -8,7 +8,6 @@
|
||||||
#include <type_traits>
|
#include <type_traits>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include <limits>
|
#include <limits>
|
||||||
#include <array>
|
|
||||||
|
|
||||||
#include "esphome/core/optional.h"
|
#include "esphome/core/optional.h"
|
||||||
|
|
||||||
|
@ -22,8 +21,6 @@
|
||||||
#elif defined(USE_LIBRETINY)
|
#elif defined(USE_LIBRETINY)
|
||||||
#include <FreeRTOS.h>
|
#include <FreeRTOS.h>
|
||||||
#include <semphr.h>
|
#include <semphr.h>
|
||||||
#elif defined(USE_ZEPHYR)
|
|
||||||
#include <zephyr/kernel.h>
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define HOT __attribute__((hot))
|
#define HOT __attribute__((hot))
|
||||||
|
@ -549,6 +546,7 @@ class Mutex {
|
||||||
public:
|
public:
|
||||||
Mutex();
|
Mutex();
|
||||||
Mutex(const Mutex &) = delete;
|
Mutex(const Mutex &) = delete;
|
||||||
|
~Mutex();
|
||||||
void lock();
|
void lock();
|
||||||
bool try_lock();
|
bool try_lock();
|
||||||
void unlock();
|
void unlock();
|
||||||
|
@ -556,10 +554,10 @@ class Mutex {
|
||||||
Mutex &operator=(const Mutex &) = delete;
|
Mutex &operator=(const Mutex &) = delete;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
#if defined(USE_ZEPHYR)
|
#if defined(USE_ESP32) || defined(USE_LIBRETINY)
|
||||||
k_mutex handle_;
|
|
||||||
#elif defined(USE_ESP32) || defined(USE_LIBRETINY)
|
|
||||||
SemaphoreHandle_t handle_;
|
SemaphoreHandle_t handle_;
|
||||||
|
#else
|
||||||
|
void *handle_; // d-pointer to store private data on new platforms
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue