Added Power Saving for NRF52 companions

This commit is contained in:
Kevin Le
2026-04-10 10:45:26 +07:00
parent 23f48e025f
commit 6b1099161c
3 changed files with 21 additions and 4 deletions
+8
View File
@@ -2222,3 +2222,11 @@ bool MyMesh::advert() {
return false;
}
}
// To check if there is pending work
bool MyMesh::hasPendingWork() const {
#if defined(WITH_BRIDGE)
if (bridge.isRunning()) return true; // bridge needs WiFi radio, can't sleep
#endif
return _mgr->getOutboundTotal() > 0;
}
+3
View File
@@ -175,6 +175,9 @@ public:
sensors.setSettingValue("gps_interval", interval_str);
}
}
// To check if there is pending work
bool hasPendingWork() const;
#endif
private:
+10 -4
View File
@@ -248,13 +248,19 @@ void loop() {
#endif
rtc_clock.tick();
if (!the_mesh.hasPendingWork()) {
#if defined(NRF52_PLATFORM)
board.sleep(0); // nrf ignores seconds param, sleeps whenever possible
#endif
}
#if defined(ESP32) && defined(WIFI_SSID)
// Safely attempt to reconnect every 10 seconds if flagged
if (wifi_needs_reconnect && (millis() - last_wifi_reconnect_attempt > 10000)) {
WIFI_DEBUG_PRINTLN("Attempting manual WiFi reconnect...");
WiFi.disconnect();
WiFi.reconnect();
last_wifi_reconnect_attempt = millis();
WIFI_DEBUG_PRINTLN("Attempting manual WiFi reconnect...");
WiFi.disconnect();
WiFi.reconnect();
last_wifi_reconnect_attempt = millis();
}
#endif
}