123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126 |
- /*
- *
- * Sebastien L. 2023, sle118@hotmail.com
- * Philippe G. 2023, philippe_44@outlook.com
- *
- * This software is released under the MIT License.
- * https://opensource.org/licenses/MIT
- *
- * License Overview:
- * ----------------
- * The MIT License is a permissive open source license. As a user of this software, you are free to:
- * - Use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of this software.
- * - Use the software for private, commercial, or any other purposes.
- *
- * Conditions:
- * - You must include the above copyright notice and this permission notice in all
- * copies or substantial portions of the Software.
- *
- * The MIT License offers a high degree of freedom and is well-suited for both open source and
- * commercial applications. It places minimal restrictions on how the software can be used,
- * modified, and redistributed. For more details on the MIT License, please refer to the link above.
- */
- #pragma once
- #include "esp_partition.h"
- #include "esp_system.h"
- #ifdef __cplusplus
- extern "C" {
- #endif
- uint32_t bootstate_read_counter(void);
- /**
- * @fn uint32_t bootstate_uptate_counter(int32_t xValue)
- * Updates the boot state counter.
- *
- * Increments the RebootCounter by 'xValue'. If 'xValue' is 0, or if RebootCounter
- * exceeds 100, it resets both RebootCounter and RecoveryRebootCounter to 0.
- * Additionally, updates the RecoveryRebootCounter based on the recovery state.
- *
- * @param xValue The value to increment the RebootCounter.
- * @return The updated value of the RebootCounter.
- */
- uint32_t bootstate_uptate_counter(int32_t xValue);
- /**
- * @fn void bootstate_handle_boot(void)
- * Handles the boot state logic on system startup.
- *
- * This function manages boot states based on cold boot indicators, recovery states, and reboot counters.
- * It includes logic for handling regular and recovery boots, and manages the boot counter's logic
- * for different scenarios such as factory resets or configuration erasures.
- */
- void bootstate_handle_boot(void);
- /**
- * @fn esp_err_t guided_boot(esp_partition_subtype_t partition_subtype)
- * Performs a guided boot to a specified partition subtype.
- *
- * This function attempts to reboot the device to a specified partition subtype.
- * It includes logic to handle different scenarios based on the current running state
- * (normal or recovery) and the target partition subtype.
- *
- * @param partition_subtype The target partition subtype to boot to.
- * @return ESP_OK on successful execution, or an ESP_ERR code on failure.
- */
- esp_err_t guided_boot(esp_partition_subtype_t partition_subtype);
- /**
- * @fn esp_err_t guided_restart_ota(void)
- * Initiates a guided restart to an OTA (Over The Air) update partition.
- *
- * This function logs the intention to boot to the Squeezelite OTA partition and then
- * calls guided_boot to execute the reboot. It always returns ESP_FAIL as the system
- * is expected to reboot and not return from the function.
- *
- * @return ESP_FAIL to indicate the function should not return as a reboot is expected.
- */
- esp_err_t guided_restart_ota(void);
- /**
- * @fn esp_err_t guided_factory(void)
- * Initiates a guided restart to the factory partition.
- *
- * This function logs the intention to boot to the recovery partition and then
- * calls guided_boot to execute the reboot. It always returns ESP_FAIL as the system
- * is expected to reboot and not return from the function.
- *
- * @return ESP_FAIL to indicate the function should not return as a reboot is expected.
- */
- esp_err_t guided_factory(void);
- /**
- * @fn void simple_restart(void)
- * Performs a simple system restart.
- *
- * This function logs a reboot message, attempts to commit any pending configurations,
- * waits for a short duration, and then triggers a system restart using `esp_restart`.
- */
- void simple_restart(void);
- /**
- * @fn bool is_restarting(void)
- * Checks if the system is in the process of restarting.
- *
- * @return `true` if the system is currently restarting, `false` otherwise.
- */
- bool is_restarting(void);
- /**
- * @var extern bool is_recovery_running
- * Indicates whether the system is currently running in recovery mode.
- *
- * This variable is used to determine the current operating mode of the system.
- * It should be set to `true` when the system is operating in recovery mode, and
- * `false` otherwise. As an external variable, it is likely defined and managed
- * in another file/module.
- */
- extern bool is_recovery_running;
- #ifdef __cplusplus
- }
- #endif
|