ESP32-PaxCounter/src/cyclic.cpp

146 lines
4.5 KiB
C++
Raw Normal View History

2018-07-22 20:27:58 +02:00
/* This routine is called by interrupt in regular intervals */
/* Interval can be set in paxcounter.conf (HOMECYCLE) */
// Basic config
2018-10-03 23:07:22 +02:00
#include "cyclic.h"
2018-07-22 20:27:58 +02:00
// Local logging tag
static const char TAG[] = "main";
2019-01-28 23:59:52 +01:00
time_t userUTCTime; // Seconds since the UTC epoch
unsigned long nextLoraTimeSync = millis();
2019-01-29 22:54:16 +01:00
unsigned long nextRTCTimeSync = millis() + TIME_WRITE_INTERVAL_RTC * 60000;
2018-07-22 20:27:58 +02:00
// do all housekeeping
2018-09-21 18:23:34 +02:00
void doHousekeeping() {
2018-07-25 00:17:31 +02:00
// update uptime counter
uptime();
2018-07-24 23:25:41 +02:00
2018-09-15 18:59:20 +02:00
// check if update mode trigger switch was set
if (cfg.runmode == 1)
2018-10-17 07:10:37 +02:00
do_reset();
spi_housekeeping();
lora_housekeeping();
2018-11-16 09:43:47 +01:00
2019-01-28 23:59:52 +01:00
// do cyclic time sync with LORA network
#ifdef TIME_SYNC_INTERVAL_LORA
if (millis() >= nextLoraTimeSync) {
nextLoraTimeSync = millis() + TIME_SYNC_INTERVAL_LORA *
60000; // set up next time sync period
// Schedule a network time sync request at the next possible time
LMIC_requestNetworkTime(user_request_network_time_callback, &userUTCTime);
ESP_LOGI(TAG, "LORAWAN time request scheduled");
2018-11-16 09:43:47 +01:00
}
#endif
2019-01-29 22:54:16 +01:00
// do cyclic write back system time to RTC if we have an external time source
#if (defined TIME_SYNC_INTERVAL_LORA || defined TIME_SYNC_INTERVAL_GPS) && \
defined HAS_RTC
2019-02-02 09:15:31 +01:00
if ((millis() >= nextRTCTimeSync) && (timeStatus() == timeSet)) {
2019-01-29 22:54:16 +01:00
nextRTCTimeSync = millis() + TIME_WRITE_INTERVAL_RTC *
60000; // set up next time sync period
if (!set_rtctime(now())) // epoch time
2019-01-29 22:54:16 +01:00
ESP_LOGE(TAG, "RTC set time failure");
else
ESP_LOGI(TAG, "RTC time updated");
}
#endif
// task storage debugging //
2019-01-06 19:41:42 +01:00
ESP_LOGD(TAG, "IRQhandler %d bytes left | Taskstate = %d",
uxTaskGetStackHighWaterMark(irqHandlerTask),
eTaskGetState(irqHandlerTask));
#ifdef HAS_GPS
2019-01-06 19:41:42 +01:00
ESP_LOGD(TAG, "Gpsloop %d bytes left | Taskstate = %d",
uxTaskGetStackHighWaterMark(GpsTask), eTaskGetState(GpsTask));
#endif
2018-11-25 16:05:30 +01:00
#ifdef HAS_BME
2019-01-06 19:41:42 +01:00
ESP_LOGD(TAG, "Bmeloop %d bytes left | Taskstate = %d",
uxTaskGetStackHighWaterMark(BmeTask), eTaskGetState(BmeTask));
2018-11-25 16:05:30 +01:00
#endif
#ifdef HAS_DCF77
ESP_LOGD(TAG, "DCF77loop %d bytes left | Taskstate = %d",
uxTaskGetStackHighWaterMark(DCF77Task), eTaskGetState(DCF77Task));
#endif
#if (HAS_LED != NOT_A_PIN) || defined(HAS_RGB_LED)
2019-01-06 19:41:42 +01:00
ESP_LOGD(TAG, "LEDloop %d bytes left | Taskstate = %d",
uxTaskGetStackHighWaterMark(ledLoopTask),
eTaskGetState(ledLoopTask));
#endif
2018-07-22 20:27:58 +02:00
// read battery voltage into global variable
#ifdef HAS_BATTERY_PROBE
batt_voltage = read_voltage();
ESP_LOGI(TAG, "Voltage: %dmV", batt_voltage);
#endif
2019-01-06 19:41:42 +01:00
// display BME sensor data
#ifdef HAS_BME
2019-01-06 19:41:42 +01:00
ESP_LOGI(TAG, "BME680 Temp: %.2f°C | IAQ: %.2f | IAQacc: %d",
bme_status.temperature, bme_status.iaq, bme_status.iaq_accuracy);
2018-07-22 20:27:58 +02:00
#endif
2018-12-22 14:37:47 +01:00
// check free heap memory
if (ESP.getMinFreeHeap() <= MEM_LOW) {
2018-08-04 14:37:41 +02:00
ESP_LOGI(TAG,
2018-07-22 20:27:58 +02:00
"Memory full, counter cleared (heap low water mark = %d Bytes / "
"free heap = %d bytes)",
2019-01-06 19:41:42 +01:00
ESP.getMinFreeHeap(), ESP.getFreeHeap());
SendPayload(COUNTERPORT, prio_high); // send data before clearing counters
reset_counters(); // clear macs container and reset all counters
get_salt(); // get new salt for salting hashes
2018-08-04 18:09:25 +02:00
2019-01-06 19:41:42 +01:00
if (ESP.getMinFreeHeap() <= MEM_LOW) // check again
do_reset(); // memory leak, reset device
2018-07-22 20:27:58 +02:00
}
2018-12-22 14:37:47 +01:00
// check free PSRAM memory
#ifdef BOARD_HAS_PSRAM
if (ESP.getMinFreePsram() <= MEM_LOW) {
ESP_LOGI(TAG, "PSRAM full, counter cleared");
SendPayload(COUNTERPORT, prio_high); // send data before clearing counters
reset_counters(); // clear macs container and reset all counters
get_salt(); // get new salt for salting hashes
2018-12-22 14:37:47 +01:00
if (ESP.getMinFreePsram() <= MEM_LOW) // check again
2019-01-06 19:41:42 +01:00
do_reset(); // memory leak, reset device
2018-12-22 14:37:47 +01:00
}
#endif
2018-09-21 18:23:34 +02:00
} // doHousekeeping()
2018-07-23 08:25:23 +02:00
2018-07-23 13:20:06 +02:00
// uptime counter 64bit to prevent millis() rollover after 49 days
uint64_t uptime() {
static uint32_t low32, high32;
uint32_t new_low32 = millis();
if (new_low32 < low32)
high32++;
low32 = new_low32;
return (uint64_t)high32 << 32 | low32;
}
2018-12-22 14:37:47 +01:00
uint32_t getFreeRAM() {
#ifndef BOARD_HAS_PSRAM
return ESP.getFreeHeap();
#else
return ESP.getFreePsram();
#endif
}
2018-07-23 13:20:06 +02:00
void reset_counters() {
macs.clear(); // clear all macs container
macs_total = 0; // reset all counters
macs_wifi = 0;
macs_ble = 0;
}
#ifndef VERBOSE
int redirect_log(const char *fmt, va_list args) {
// do nothing
return 0;
}
#endif