mirror of
https://github.com/sle118/squeezelite-esp32.git
synced 2025-12-10 13:37:03 +03:00
Start of 5.X work
This commit is contained in:
126
components/tools/bootstate.h
Normal file
126
components/tools/bootstate.h
Normal file
@@ -0,0 +1,126 @@
|
||||
/*
|
||||
*
|
||||
* 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
|
||||
Reference in New Issue
Block a user