mirror of
https://github.com/esphome/esphome.git
synced 2026-01-20 18:09:10 -07:00
* Socket refactor and SSL * esp-idf temp * Fixes * Echo component and noise * Add noise API transport support * Updates * ESP-IDF * Complete * Fixes * Fixes * Versions update * New i2c APIs * Complete i2c refactor * SPI migration * Revert ESP Preferences migration, too complex for now * OTA support * Remove echo again * Remove ssl again * GPIOFlags updates * Rename esphal and ICACHE_RAM_ATTR * Make ESP32 arduino compilable again * Fix GPIO flags * Complete pin registry refactor and fixes * Fixes to make test1 compile * Remove sdkconfig file * Ignore sdkconfig file * Fixes in reviewing * Make test2 compile * Make test4 compile * Make test5 compile * Run clang-format * Fix lint errors * Use esp-idf APIs instead of btStart * Another round of fixes * Start implementing ESP8266 * Make test3 compile * Guard esp8266 code * Lint * Reformat * Fixes * Fixes v2 * more fixes * ESP-IDF tidy target * Convert ARDUINO_ARCH_ESPxx * Update WiFiSignalSensor * Update time ifdefs * OTA needs millis from hal * RestartSwitch needs delay from hal * ESP-IDF Uart * Fix OTA blank password * Allow setting sdkconfig * Fix idf partitions and allow setting sdkconfig from yaml * Re-add read/write compat APIs and fix esp8266 uart * Fix esp8266 store log strings in flash * Fix ESP32 arduino preferences not initialized * Update ifdefs * Change how sdkconfig change is detected * Add checks to ci-custom and fix them * Run clang-format * Add esp-idf clang-tidy target and fix errors * Fixes from clang-tidy idf round 2 * Fixes from compiling tests with esp-idf * Run clang-format * Switch test5.yaml to esp-idf * Implement ESP8266 Preferences * Lint * Re-do PIO package version selection a bit * Fix arduinoespressif32 package version * Fix unit tests * Lint * Lint fixes * Fix readv/writev not defined * Fix graphing component * Re-add all old options from core/config.py Co-authored-by: Jesse Hills <3060199+jesserockz@users.noreply.github.com>
235 lines
6.5 KiB
C++
235 lines
6.5 KiB
C++
#include "debug_component.h"
|
|
#include "esphome/core/log.h"
|
|
#include "esphome/core/helpers.h"
|
|
#include "esphome/core/defines.h"
|
|
#include "esphome/core/version.h"
|
|
|
|
#ifdef USE_ESP32
|
|
#include <rom/rtc.h>
|
|
#include <esp_idf_version.h>
|
|
#endif
|
|
|
|
#ifdef USE_ARDUINO
|
|
#include <Esp.h>
|
|
#endif
|
|
|
|
#ifdef USE_ESP_IDF
|
|
#include <esp_heap_caps.h>
|
|
#include <esp_system.h>
|
|
#endif
|
|
|
|
namespace esphome {
|
|
namespace debug {
|
|
|
|
static const char *const TAG = "debug";
|
|
|
|
void DebugComponent::dump_config() {
|
|
#ifndef ESPHOME_LOG_HAS_DEBUG
|
|
ESP_LOGE(TAG, "Debug Component requires debug log level!");
|
|
this->status_set_error();
|
|
return;
|
|
#endif
|
|
|
|
ESP_LOGD(TAG, "ESPHome version %s", ESPHOME_VERSION);
|
|
#ifdef USE_ARDUINO
|
|
this->free_heap_ = ESP.getFreeHeap(); // NOLINT(readability-static-accessed-through-instance)
|
|
#elif defined(USE_ESP_IDF)
|
|
this->free_heap_ = heap_caps_get_free_size(MALLOC_CAP_INTERNAL);
|
|
#endif
|
|
ESP_LOGD(TAG, "Free Heap Size: %u bytes", this->free_heap_);
|
|
|
|
#ifdef USE_ARDUINO
|
|
const char *flash_mode;
|
|
switch (ESP.getFlashChipMode()) { // NOLINT(readability-static-accessed-through-instance)
|
|
case FM_QIO:
|
|
flash_mode = "QIO";
|
|
break;
|
|
case FM_QOUT:
|
|
flash_mode = "QOUT";
|
|
break;
|
|
case FM_DIO:
|
|
flash_mode = "DIO";
|
|
break;
|
|
case FM_DOUT:
|
|
flash_mode = "DOUT";
|
|
break;
|
|
#ifdef USE_ESP32
|
|
case FM_FAST_READ:
|
|
flash_mode = "FAST_READ";
|
|
break;
|
|
case FM_SLOW_READ:
|
|
flash_mode = "SLOW_READ";
|
|
break;
|
|
#endif
|
|
default:
|
|
flash_mode = "UNKNOWN";
|
|
}
|
|
// NOLINTNEXTLINE(readability-static-accessed-through-instance)
|
|
ESP_LOGD(TAG, "Flash Chip: Size=%ukB Speed=%uMHz Mode=%s", ESP.getFlashChipSize() / 1024,
|
|
ESP.getFlashChipSpeed() / 1000000, flash_mode);
|
|
#endif // USE_ARDUINO
|
|
|
|
#ifdef USE_ESP32
|
|
esp_chip_info_t info;
|
|
esp_chip_info(&info);
|
|
const char *model;
|
|
switch (info.model) {
|
|
case CHIP_ESP32:
|
|
model = "ESP32";
|
|
break;
|
|
default:
|
|
model = "UNKNOWN";
|
|
}
|
|
std::string features;
|
|
if (info.features & CHIP_FEATURE_EMB_FLASH) {
|
|
features += "EMB_FLASH,";
|
|
info.features &= ~CHIP_FEATURE_EMB_FLASH;
|
|
}
|
|
if (info.features & CHIP_FEATURE_WIFI_BGN) {
|
|
features += "WIFI_BGN,";
|
|
info.features &= ~CHIP_FEATURE_WIFI_BGN;
|
|
}
|
|
if (info.features & CHIP_FEATURE_BLE) {
|
|
features += "BLE,";
|
|
info.features &= ~CHIP_FEATURE_BLE;
|
|
}
|
|
if (info.features & CHIP_FEATURE_BT) {
|
|
features += "BT,";
|
|
info.features &= ~CHIP_FEATURE_BT;
|
|
}
|
|
if (info.features)
|
|
features += "Other:" + uint64_to_string(info.features);
|
|
ESP_LOGD(TAG, "Chip: Model=%s, Features=%s Cores=%u, Revision=%u", model, features.c_str(), info.cores,
|
|
info.revision);
|
|
|
|
ESP_LOGD(TAG, "ESP-IDF Version: %s", esp_get_idf_version());
|
|
|
|
uint64_t chip_mac = 0LL;
|
|
esp_efuse_mac_get_default((uint8_t *) (&chip_mac));
|
|
std::string mac = uint64_to_string(chip_mac);
|
|
ESP_LOGD(TAG, "EFuse MAC: %s", mac.c_str());
|
|
|
|
const char *reset_reason;
|
|
switch (rtc_get_reset_reason(0)) {
|
|
case POWERON_RESET:
|
|
reset_reason = "Power On Reset";
|
|
break;
|
|
case SW_RESET:
|
|
reset_reason = "Software Reset Digital Core";
|
|
break;
|
|
case OWDT_RESET:
|
|
reset_reason = "Watch Dog Reset Digital Core";
|
|
break;
|
|
case DEEPSLEEP_RESET:
|
|
reset_reason = "Deep Sleep Reset Digital Core";
|
|
break;
|
|
case SDIO_RESET:
|
|
reset_reason = "SLC Module Reset Digital Core";
|
|
break;
|
|
case TG0WDT_SYS_RESET:
|
|
reset_reason = "Timer Group 0 Watch Dog Reset Digital Core";
|
|
break;
|
|
case TG1WDT_SYS_RESET:
|
|
reset_reason = "Timer Group 1 Watch Dog Reset Digital Core";
|
|
break;
|
|
case RTCWDT_SYS_RESET:
|
|
reset_reason = "RTC Watch Dog Reset Digital Core";
|
|
break;
|
|
case INTRUSION_RESET:
|
|
reset_reason = "Intrusion Reset CPU";
|
|
break;
|
|
case TGWDT_CPU_RESET:
|
|
reset_reason = "Timer Group Reset CPU";
|
|
break;
|
|
case SW_CPU_RESET:
|
|
reset_reason = "Software Reset CPU";
|
|
break;
|
|
case RTCWDT_CPU_RESET:
|
|
reset_reason = "RTC Watch Dog Reset CPU";
|
|
break;
|
|
case EXT_CPU_RESET:
|
|
reset_reason = "External CPU Reset";
|
|
break;
|
|
case RTCWDT_BROWN_OUT_RESET:
|
|
reset_reason = "Voltage Unstable Reset";
|
|
break;
|
|
case RTCWDT_RTC_RESET:
|
|
reset_reason = "RTC Watch Dog Reset Digital Core And RTC Module";
|
|
break;
|
|
default:
|
|
reset_reason = "Unknown Reset Reason";
|
|
}
|
|
ESP_LOGD(TAG, "Reset Reason: %s", reset_reason);
|
|
|
|
const char *wakeup_reason;
|
|
switch (rtc_get_wakeup_cause()) {
|
|
case NO_SLEEP:
|
|
wakeup_reason = "No Sleep";
|
|
break;
|
|
case EXT_EVENT0_TRIG:
|
|
wakeup_reason = "External Event 0";
|
|
break;
|
|
case EXT_EVENT1_TRIG:
|
|
wakeup_reason = "External Event 1";
|
|
break;
|
|
case GPIO_TRIG:
|
|
wakeup_reason = "GPIO";
|
|
break;
|
|
case TIMER_EXPIRE:
|
|
wakeup_reason = "Wakeup Timer";
|
|
break;
|
|
case SDIO_TRIG:
|
|
wakeup_reason = "SDIO";
|
|
break;
|
|
case MAC_TRIG:
|
|
wakeup_reason = "MAC";
|
|
break;
|
|
case UART0_TRIG:
|
|
wakeup_reason = "UART0";
|
|
break;
|
|
case UART1_TRIG:
|
|
wakeup_reason = "UART1";
|
|
break;
|
|
case TOUCH_TRIG:
|
|
wakeup_reason = "Touch";
|
|
break;
|
|
case SAR_TRIG:
|
|
wakeup_reason = "SAR";
|
|
break;
|
|
case BT_TRIG:
|
|
wakeup_reason = "BT";
|
|
break;
|
|
default:
|
|
wakeup_reason = "Unknown";
|
|
}
|
|
ESP_LOGD(TAG, "Wakeup Reason: %s", wakeup_reason);
|
|
#endif
|
|
|
|
#if defined(USE_ESP8266) && !defined(CLANG_TIDY)
|
|
ESP_LOGD(TAG, "Chip ID: 0x%08X", ESP.getChipId());
|
|
ESP_LOGD(TAG, "SDK Version: %s", ESP.getSdkVersion());
|
|
ESP_LOGD(TAG, "Core Version: %s", ESP.getCoreVersion().c_str());
|
|
ESP_LOGD(TAG, "Boot Version=%u Mode=%u", ESP.getBootVersion(), ESP.getBootMode());
|
|
ESP_LOGD(TAG, "CPU Frequency: %u", ESP.getCpuFreqMHz());
|
|
ESP_LOGD(TAG, "Flash Chip ID=0x%08X", ESP.getFlashChipId());
|
|
ESP_LOGD(TAG, "Reset Reason: %s", ESP.getResetReason().c_str());
|
|
ESP_LOGD(TAG, "Reset Info: %s", ESP.getResetInfo().c_str());
|
|
#endif
|
|
}
|
|
void DebugComponent::loop() {
|
|
#ifdef USE_ARDUINO
|
|
uint32_t new_free_heap = ESP.getFreeHeap(); // NOLINT(readability-static-accessed-through-instance)
|
|
#elif defined(USE_ESP_IDF)
|
|
uint32_t new_free_heap = heap_caps_get_free_size(MALLOC_CAP_INTERNAL);
|
|
#endif
|
|
if (new_free_heap < this->free_heap_ / 2) {
|
|
this->free_heap_ = new_free_heap;
|
|
ESP_LOGD(TAG, "Free Heap Size: %u bytes", this->free_heap_);
|
|
this->status_momentary_warning("heap", 1000);
|
|
}
|
|
}
|
|
float DebugComponent::get_setup_priority() const { return setup_priority::LATE; }
|
|
|
|
} // namespace debug
|
|
} // namespace esphome
|