Added battery low warning message

This commit is contained in:
2026-03-27 18:28:00 +01:00
parent df0d3aef33
commit 3ea71788c2
10 changed files with 80 additions and 3 deletions

View File

@@ -31,6 +31,7 @@ int battery::init() {
vehicle_config config;
config_global_read(config);
_cal = config.vbat_calibration;
_low = config.vbat_low;
}
int battery::loop(unsigned long timeout_ms) {
@@ -39,6 +40,12 @@ int battery::loop(unsigned long timeout_ms) {
_vbat = _cal * adc_read;
vbat_global_write(_vbat);
if (_vbat < _low) {
if (_warning_sent == 0 || millis() > _warning_sent + _warning_timeout) {
router::send(MOD_LCD, TASK_DISPLAY_MSG_BAT_LOW, 2000);
_warning_sent = millis();
}
}
}
Task active_task;
int res = _queue.pop(active_task);
@@ -60,6 +67,7 @@ int battery::loop(unsigned long timeout_ms) {
vehicle_config config;
config_global_read(config);
_cal = config.vbat_calibration;
_low = config.vbat_low;
break;
}

View File

@@ -16,6 +16,9 @@ private:
ring_buffer<Task, 16> _queue;
double _vbat = 0;
double _cal = 0;
double _low = 0;
unsigned long _warning_sent = 0;
unsigned long _warning_timeout = 10000;
unsigned long _update_interval = 1000;
unsigned long _last_read = 0;
int calibrate(const Task& task);

View File

@@ -116,6 +116,10 @@ cmd::command_id cmd::parse_command_name(const char *input) {
return CMD_BATTERY_PRINT_VBAT;
}
if (strcmp(input, "BATTERY_SET_LOW") == 0) {
return CMD_BATTERY_SET_LOW;
}
return CMD_UNKNOWN;
}
@@ -411,6 +415,27 @@ int cmd::handle_battery_print_vbat(unsigned short argc) {
#endif
}
int cmd::handle_battery_set_low(unsigned short argc, char* argv[]) {
if (argc != 2) {
#ifdef ERROR
if (_logger != nullptr) {
_logger->error("BATTERY_SET_LOW expects 1 argument");
}
#endif
return 1;
}
double low = strtod(argv[1], nullptr);
uint32_t task_data;
memcpy(&task_data, &low, sizeof(uint32_t));
#ifdef INFO
if (_logger != nullptr) {
_logger->info("Setting warning level for VBAT");
}
#endif
router::send(MOD_CFG, TASK_CONFIG_VBAT_SET_LOW, task_data);
return 0;
}
int cmd::handle_unknown_command(unsigned short argc, char *argv[]) {
#ifdef ERROR
if (_logger != nullptr) {
@@ -458,6 +483,9 @@ int cmd::dispatch_command(command_id command, unsigned short argc, char *argv[])
case CMD_BATTERY_PRINT_VBAT:
return this->handle_battery_print_vbat(argc);
case CMD_BATTERY_SET_LOW:
return this->handle_battery_set_low(argc, argv);
case CMD_UNKNOWN:
default:

View File

@@ -6,11 +6,11 @@
#include <Arduino.h>
#include <avr/wdt.h>
#include "base/module_base.h"
#include "base/ring_buffer.h"
#include "base/task.h"
#include "custom_types.h"
#include "modules/logger/system_logger.h"
#include "base/task.h"
#include "base/ring_buffer.h"
#include "base/module_base.h"
class cmd : public module_base {
private:
@@ -27,6 +27,7 @@ private:
CMD_DISPLAY_DRIVER_PRIMARY,
CMD_BATTERY_CAL,
CMD_BATTERY_PRINT_VBAT,
CMD_BATTERY_SET_LOW,
};
HardwareSerial *_data_stream;
@@ -57,6 +58,7 @@ private:
int handle_display_driver_primary(unsigned short argc);
int handle_battery_cal(unsigned short argc, char *argv[]);
int handle_battery_print_vbat(unsigned short argc);
int handle_battery_set_low(unsigned short argc, char *argv[]);
int handle_unknown_command(unsigned short argc, char *argv[]);
public:

View File

@@ -104,6 +104,11 @@ int config::write_vbat_cal(double val) {
return this->write_cfg();
}
int config::write_vbat_low(double val) {
_config.vbat_low = val;
return this->write_cfg();
}
config::config() : _logger(nullptr), _valid_config(true) {}
config::config(system_logger *logger) : _logger(logger), _valid_config(true) {}
@@ -246,6 +251,13 @@ int config::handle_active_task(unsigned long timeout_ms) {
this->task_complete();
}
case TASK_CONFIG_VBAT_SET_LOW: {
double low_value;
memcpy(&low_value, &_active_task.data, sizeof(double));
int res = this->write_vbat_low(low_value);
this->task_complete();
}
default:
break;
}

View File

@@ -48,6 +48,7 @@ private:
int delete_track(unsigned short idx);
int reset_cfg();
int write_vbat_cal(double val);
int write_vbat_low(double val);
public:
int push(const Task &task) override;

View File

@@ -61,6 +61,7 @@ bool lcd::is_message_task(task_type type) {
case TASK_DISPLAY_MSG_GPS_FIX:
case TASK_DISPLAY_MSG_TRACK_DETECT_OK:
case TASK_DISPLAY_MSG_CONFIG_NO_TRACKS:
case TASK_DISPLAY_MSG_BAT_LOW:
return true;
default:
@@ -203,6 +204,15 @@ int lcd::render_msg_config_no_tracks() {
return 0;
}
int lcd::render_msg_battery_low() {
this->clear();
_display->setCursor(2, 1);
this->print("BATTERY WARNING");
_display->setCursor(6, 2);
this->print("VBAT LOW");
return 0;
}
int lcd::push(const Task &task) {
return _queue.push(task);
}
@@ -399,6 +409,10 @@ int lcd::loop(unsigned long timeout_ms) {
case TASK_DISPLAY_MSG_CONFIG_NO_TRACKS:
activate_message(screen::msg_config_no_tracks, next_task.data);
break;
case TASK_DISPLAY_MSG_BAT_LOW:
activate_message(screen::msg_battery_low, next_task.data);
break;
default:
break;
@@ -449,6 +463,10 @@ int lcd::loop(unsigned long timeout_ms) {
case screen::msg_config_no_tracks:
this->render_msg_config_no_tracks();
break;
case screen::msg_battery_low:
this->render_msg_battery_low();
break;
default:
break;

View File

@@ -25,6 +25,7 @@ typedef enum lcd_screen {
msg_gps_fix,
msg_track_detect_ok,
msg_config_no_tracks,
msg_battery_low,
} lcd_screen;
} // namespace screen
@@ -66,6 +67,7 @@ private:
int render_msg_gps_fix();
int render_msg_track_detect_ok();
int render_msg_config_no_tracks();
int render_msg_battery_low();
public:
int push(const Task &task) override;