Files
crosspoint-reader-mod/lib/hal/HalPowerManager.cpp

85 lines
2.2 KiB
C++
Raw Permalink Normal View History

2026-02-12 13:19:37 +01:00
#include "HalPowerManager.h"
#include <Logging.h>
#include <WiFi.h>
2026-02-12 13:12:13 +01:00
#include <esp_sleep.h>
#include "HalGPIO.h"
void HalPowerManager::begin() {
pinMode(BAT_GPIO0, INPUT);
normalFreq = getCpuFrequencyMhz();
modeMutex = xSemaphoreCreateMutex();
assert(modeMutex != nullptr);
2026-02-12 13:12:13 +01:00
}
void HalPowerManager::setPowerSaving(bool enabled) {
if (normalFreq <= 0) {
return;
2026-02-12 13:12:13 +01:00
}
if (enabled) {
if (WiFi.getMode() != WIFI_MODE_NULL) {
enabled = false;
}
xSemaphoreTake(modeMutex, portMAX_DELAY);
const LockMode mode = currentLockMode;
xSemaphoreGive(modeMutex);
if (mode == NormalSpeed) {
enabled = false;
}
}
2026-02-12 13:12:13 +01:00
if (enabled && !isLowPower) {
LOG_DBG("PWR", "Going to low-power mode");
2026-02-12 13:12:13 +01:00
if (!setCpuFrequencyMhz(LOW_POWER_FREQ)) {
LOG_DBG("PWR", "Failed to set CPU frequency = %d MHz", LOW_POWER_FREQ);
2026-02-12 13:12:13 +01:00
return;
}
}
if (!enabled && isLowPower) {
LOG_DBG("PWR", "Restoring normal CPU frequency");
2026-02-12 13:12:13 +01:00
if (!setCpuFrequencyMhz(normalFreq)) {
LOG_DBG("PWR", "Failed to set CPU frequency = %d MHz", normalFreq);
2026-02-12 13:12:13 +01:00
return;
}
}
isLowPower = enabled;
}
// RAII Lock implementation
HalPowerManager::Lock::Lock() {
xSemaphoreTake(powerManager.modeMutex, portMAX_DELAY);
powerManager.currentLockMode = NormalSpeed;
valid = true;
if (powerManager.isLowPower) {
powerManager.setPowerSaving(false);
}
xSemaphoreGive(powerManager.modeMutex);
}
HalPowerManager::Lock::~Lock() {
if (!valid) return;
xSemaphoreTake(powerManager.modeMutex, portMAX_DELAY);
powerManager.currentLockMode = None;
xSemaphoreGive(powerManager.modeMutex);
}
2026-02-12 13:19:37 +01:00
void HalPowerManager::startDeepSleep(HalGPIO& gpio) const {
2026-02-12 13:12:13 +01:00
// Ensure that the power button has been released to avoid immediately turning back on if you're holding it
while (gpio.isPressed(HalGPIO::BTN_POWER)) {
delay(50);
gpio.update();
}
// Arm the wakeup trigger *after* the button is released
esp_deep_sleep_enable_gpio_wakeup(1ULL << InputManager::POWER_BUTTON_PIN, ESP_GPIO_WAKEUP_GPIO_LOW);
// Enter Deep Sleep
esp_deep_sleep_start();
}
int HalPowerManager::getBatteryPercentage() const {
static const BatteryMonitor battery = BatteryMonitor(BAT_GPIO0);
return battery.readPercentage();
}