ESPHome 2026.6.0-dev
Loading...
Searching...
No Matches
safe_mode.h
Go to the documentation of this file.
1#pragma once
2
7
8#if defined(USE_ESP32) && defined(USE_OTA_ROLLBACK)
9#include <esp_ota_ops.h>
10#endif
11
12namespace esphome::safe_mode {
13
15constexpr uint32_t RTC_KEY = 233825507UL;
16
18class SafeModeComponent final : public Component {
19 public:
20 bool should_enter_safe_mode(uint8_t num_attempts, uint32_t enable_time, uint32_t boot_is_good_after);
21
23 void set_safe_mode_pending(const bool &pending);
25
26 void dump_config() override;
27 float get_setup_priority() const override;
28 void loop() override;
29
30 void clean_rtc();
31
32 void on_safe_shutdown() override;
33
34 void mark_successful();
35
36#ifdef USE_SAFE_MODE_CALLBACK
37 template<typename F> void add_on_safe_mode_callback(F &&callback) {
38 this->safe_mode_callback_.add(std::forward<F>(callback));
39 }
40#endif
41
42 protected:
45
46 // Group all 4-byte aligned members together to avoid padding
51#if defined(USE_ESP32) && defined(USE_OTA_ROLLBACK)
52 esp_ota_img_states_t ota_state_{ESP_OTA_IMG_UNDEFINED}; // 4-byte enum
53#endif
54 // Group 1-byte members together to minimize padding
55 bool boot_successful_{false};
57#if defined(USE_ESP32) && defined(USE_OTA_ROLLBACK)
59#endif
60 // Larger objects at the end
62#ifdef USE_SAFE_MODE_CALLBACK
63 StaticCallbackManager<ESPHOME_SAFE_MODE_CALLBACK_COUNT, void()> safe_mode_callback_{};
64#endif
65
67 0x5afe5afe;
68};
69
70} // namespace esphome::safe_mode
CallbackManager backed by StaticVector for compile-time-known callback counts.
Definition helpers.h:1748
SafeModeComponent provides a safe way to recover from repeated boot failures.
Definition safe_mode.h:18
bool should_enter_safe_mode(uint8_t num_attempts, uint32_t enable_time, uint32_t boot_is_good_after)
uint32_t safe_mode_enable_time_
The time safe mode should remain active for.
Definition safe_mode.h:48
bool boot_successful_
set to true after boot is considered successful
Definition safe_mode.h:55
uint32_t safe_mode_start_time_
stores when safe mode was enabled
Definition safe_mode.h:50
void add_on_safe_mode_callback(F &&callback)
Definition safe_mode.h:37
uint32_t safe_mode_boot_is_good_after_
The amount of time after which the boot is considered successful.
Definition safe_mode.h:47
float get_setup_priority() const override
StaticCallbackManager< ESPHOME_SAFE_MODE_CALLBACK_COUNT, void()> safe_mode_callback_
Definition safe_mode.h:63
esp_ota_img_states_t ota_state_
Definition safe_mode.h:52
void set_safe_mode_pending(const bool &pending)
Set to true if the next startup will enter safe mode.
static const uint32_t ENTER_SAFE_MODE_MAGIC
a magic number to indicate that safe mode should be entered on next boot
Definition safe_mode.h:66
mopeka_std_values val[3]
constexpr uint32_t RTC_KEY
RTC key for storing boot loop counter - used by safe_mode and preferences backends.
Definition safe_mode.h:15
static void uint32_t