ESPHome 2026.1.4
Loading...
Searching...
No Matches
debug_libretiny.cpp
Go to the documentation of this file.
1#include "debug_component.h"
2#ifdef USE_LIBRETINY
3#include "esphome/core/log.h"
4
5namespace esphome {
6namespace debug {
7
8static const char *const TAG = "debug";
9
10const char *DebugComponent::get_reset_reason_(std::span<char, RESET_REASON_BUFFER_SIZE> buffer) {
11 // Return the static string directly
12 return lt_get_reboot_reason_name(lt_get_reboot_reason());
13}
14
15const char *DebugComponent::get_wakeup_cause_(std::span<char, RESET_REASON_BUFFER_SIZE> buffer) { return ""; }
16
17uint32_t DebugComponent::get_free_heap_() { return lt_heap_get_free(); }
18
19size_t DebugComponent::get_device_info_(std::span<char, DEVICE_INFO_BUFFER_SIZE> buffer, size_t pos) {
20 constexpr size_t size = DEVICE_INFO_BUFFER_SIZE;
21 char *buf = buffer.data();
22
23 char reason_buffer[RESET_REASON_BUFFER_SIZE];
24 const char *reset_reason = get_reset_reason_(std::span<char, RESET_REASON_BUFFER_SIZE>(reason_buffer));
25 uint32_t flash_kib = lt_flash_get_size() / 1024;
26 uint32_t ram_kib = lt_ram_get_size() / 1024;
27 uint32_t mac_id = lt_cpu_get_mac_id();
28
29 ESP_LOGD(TAG,
30 "LibreTiny Version: %s\n"
31 "Chip: %s (%04x) @ %u MHz\n"
32 "Chip ID: 0x%06" PRIX32 "\n"
33 "Board: %s\n"
34 "Flash: %" PRIu32 " KiB / RAM: %" PRIu32 " KiB\n"
35 "Reset Reason: %s",
36 lt_get_version(), lt_cpu_get_model_name(), lt_cpu_get_model(), lt_cpu_get_freq_mhz(), mac_id,
37 lt_get_board_code(), flash_kib, ram_kib, reset_reason);
38
39 pos = buf_append(buf, size, pos, "|Version: %s", LT_BANNER_STR + 10);
40 pos = buf_append(buf, size, pos, "|Reset Reason: %s", reset_reason);
41 pos = buf_append(buf, size, pos, "|Chip Name: %s", lt_cpu_get_model_name());
42 pos = buf_append(buf, size, pos, "|Chip ID: 0x%06" PRIX32, mac_id);
43 pos = buf_append(buf, size, pos, "|Flash: %" PRIu32 " KiB", flash_kib);
44 pos = buf_append(buf, size, pos, "|RAM: %" PRIu32 " KiB", ram_kib);
45
46 return pos;
47}
48
50#ifdef USE_SENSOR
51 if (this->block_sensor_ != nullptr) {
52 this->block_sensor_->publish_state(lt_heap_get_max_alloc());
53 }
54#endif
55}
56
57} // namespace debug
58} // namespace esphome
59#endif
size_t get_device_info_(std::span< char, DEVICE_INFO_BUFFER_SIZE > buffer, size_t pos)
const char * get_wakeup_cause_(std::span< char, RESET_REASON_BUFFER_SIZE > buffer)
const char * get_reset_reason_(std::span< char, RESET_REASON_BUFFER_SIZE > buffer)
void publish_state(float state)
Publish a new state to the front-end.
Definition sensor.cpp:76
size_t size_t pos
Providing packet encoding functions for exchanging data with a remote host.
Definition a01nyub.cpp:7