AP_BattMonitor: DroneCAN: allow battery reset if not using CAN SoC

This commit is contained in:
Iampete1 2023-06-23 23:40:05 +01:00 committed by Andrew Tridgell
parent 7e94eb39ff
commit 9b54dee7a6
2 changed files with 41 additions and 6 deletions

View File

@ -256,15 +256,22 @@ void AP_BattMonitor_DroneCAN::read()
} }
} }
// Return true if the DroneCAN state of charge should be used.
// Return false if state of charge should be calculated locally by counting mah.
bool AP_BattMonitor_DroneCAN::use_CAN_SoC() const
{
// a UAVCAN battery monitor may not be able to supply a state of charge. If it can't then
// the user can set the option to use current integration in the backend instead.
// SOC of 127 is used as an invalid SOC flag ie system configuration errors or SOC estimation unavailable
return !(option_is_set(AP_BattMonitor_Params::Options::Ignore_UAVCAN_SoC) ||
_mppt.is_detected ||
(_soc == 127));
}
/// capacity_remaining_pct - returns true if the percentage is valid and writes to percentage argument /// capacity_remaining_pct - returns true if the percentage is valid and writes to percentage argument
bool AP_BattMonitor_DroneCAN::capacity_remaining_pct(uint8_t &percentage) const bool AP_BattMonitor_DroneCAN::capacity_remaining_pct(uint8_t &percentage) const
{ {
if ((uint32_t(_params._options.get()) & uint32_t(AP_BattMonitor_Params::Options::Ignore_UAVCAN_SoC)) || if (!use_CAN_SoC()) {
_mppt.is_detected ||
_soc == 127) {
// a UAVCAN battery monitor may not be able to supply a state of charge. If it can't then
// the user can set the option to use current integration in the backend instead.
// SOC of 127 is used as an invalid SOC flag ie system configuration errors or SOC estimation unavailable
return AP_BattMonitor_Backend::capacity_remaining_pct(percentage); return AP_BattMonitor_Backend::capacity_remaining_pct(percentage);
} }
@ -277,6 +284,27 @@ bool AP_BattMonitor_DroneCAN::capacity_remaining_pct(uint8_t &percentage) const
return true; return true;
} }
// reset remaining percentage to given value
bool AP_BattMonitor_DroneCAN::reset_remaining(float percentage)
{
if (use_CAN_SoC()) {
// Cannot reset external state of charge
return false;
}
WITH_SEMAPHORE(_sem_battmon);
if (!AP_BattMonitor_Backend::reset_remaining(percentage)) {
// Base class reset failed
return false;
}
// Reset interim state that is used internally, this is then copied back to the main state in the read() call
_interim_state.consumed_mah = _state.consumed_mah;
_interim_state.consumed_wh = _state.consumed_wh;
return true;
}
/// get_cycle_count - return true if cycle count can be provided and fills in cycles argument /// get_cycle_count - return true if cycle count can be provided and fills in cycles argument
bool AP_BattMonitor_DroneCAN::get_cycle_count(uint16_t &cycles) const bool AP_BattMonitor_DroneCAN::get_cycle_count(uint16_t &cycles) const
{ {

View File

@ -54,6 +54,9 @@ public:
void mppt_set_powered_state(bool power_on) override; void mppt_set_powered_state(bool power_on) override;
// reset remaining percentage to given value
bool reset_remaining(float percentage) override;
private: private:
void handle_battery_info(const uavcan_equipment_power_BatteryInfo &msg); void handle_battery_info(const uavcan_equipment_power_BatteryInfo &msg);
void handle_battery_info_aux(const ardupilot_equipment_power_BatteryInfoAux &msg); void handle_battery_info_aux(const ardupilot_equipment_power_BatteryInfoAux &msg);
@ -79,6 +82,10 @@ private:
static const char* mppt_fault_string(const MPPT_FaultFlags fault); static const char* mppt_fault_string(const MPPT_FaultFlags fault);
#endif #endif
// Return true if the DroneCAN state of charge should be used.
// Return false if state of charge should be calculated locally by counting mah.
bool use_CAN_SoC() const;
AP_BattMonitor::BattMonitor_State _interim_state; AP_BattMonitor::BattMonitor_State _interim_state;
BattMonitor_DroneCAN_Type _type; BattMonitor_DroneCAN_Type _type;