fix water

This commit is contained in:
2026-03-25 20:52:23 +01:00
parent a0240d744c
commit aebce5ac44
4 changed files with 42 additions and 31 deletions

View File

@@ -1,30 +1,39 @@
#include "water_data_queue.h"
#include <Arduino.h>
QueueHandle_t waterDataQueue = nullptr;
SemaphoreHandle_t waterDataMutex = nullptr;
WaterData latestWaterDataCache = {0.0f, 0.0f, 0.0f};
void initWaterDataQueue() {
// Create queue that can hold 5 WaterData structures
waterDataQueue = xQueueCreate(5, sizeof(WaterData));
void initWaterDataSync() {
// Create mutex for thread-safe access to latest data cache
waterDataMutex = xSemaphoreCreateMutex();
if (waterDataQueue == nullptr) {
Serial.println("Failed to create water data queue");
if (waterDataMutex == nullptr) {
Serial.println("Failed to create water data mutex");
}
}
void updateLatestWaterData(const WaterData& newData) {
// Update the cache with new data (called by producer)
if (xSemaphoreTake(waterDataMutex, pdMS_TO_TICKS(10)) == pdTRUE) {
latestWaterDataCache = newData;
xSemaphoreGive(waterDataMutex);
}
}
WaterData getLatestWaterData() {
WaterData latestData;
WaterData result;
// Try to receive the latest data without blocking
if (xQueueReceive(waterDataQueue, &latestData, 0) == pdPASS) {
// Put the data back in the queue so other consumers can get it too
xQueueSendToBack(waterDataQueue, &latestData, 0);
return latestData;
// Always return the latest cached data
if (xSemaphoreTake(waterDataMutex, pdMS_TO_TICKS(10)) == pdTRUE) {
result = latestWaterDataCache; // Copy the latest data
xSemaphoreGive(waterDataMutex);
return result;
}
// Return default values if queue is empty
latestData.level = 0.0f;
latestData.liters = 0.0f;
latestData.percentage = 0.0f;
return latestData;
// Fallback: if mutex fails, return default values
result.level = 0.0f;
result.liters = 0.0f;
result.percentage = 0.0f;
return result;
}

View File

@@ -1,12 +1,16 @@
#pragma once
#include "global_data.h"
#include "freertos/queue.h"
#include "freertos/semphr.h"
// Create a queue handle for WaterData
extern QueueHandle_t waterDataQueue;
// Mutex and cache for thread-safe water data access
extern SemaphoreHandle_t waterDataMutex;
extern WaterData latestWaterDataCache;
// Initialize the water data queue
void initWaterDataQueue();
// Initialize the water data synchronization
void initWaterDataSync();
// Helper function to get latest water data
WaterData getLatestWaterData();
// Helper function to get latest water data (always returns most recent)
WaterData getLatestWaterData();
// Internal function for producer to update latest data
void updateLatestWaterData(const WaterData& newData);

View File

@@ -60,8 +60,8 @@ void setup()
LOG(ELOG_LEVEL_DEBUG, "Init Sensor");
init_sensor();
LOG(ELOG_LEVEL_DEBUG, "Init Water Data Queue");
initWaterDataQueue();
LOG(ELOG_LEVEL_DEBUG, "Init Water Data Sync");
initWaterDataSync();
LOG(ELOG_LEVEL_DEBUG, "Beginning LittleFS");
LittleFS.begin(FORMAT_LITTLEFS_IF_FAILED);

View File

@@ -106,16 +106,14 @@ void read_sensor_task(void* parameter)
shunt_data.shunt_voltage = shunt_voltage;
shunt_data.shunt_current = shunt_current;
// Create water data structure and send to queue
// Create water data structure and update latest data
WaterData current_water_data;
current_water_data.level = cm_over_zero;
current_water_data.liters = liters;
current_water_data.percentage = percentage_rounded;
// Send to queue, don't block if queue is full
if (waterDataQueue != nullptr) {
xQueueSendToBack(waterDataQueue, &current_water_data, 0);
}
// Update the latest water data (thread-safe)
updateLatestWaterData(current_water_data);
delay(20000);
}