Skip to content

Commit

Permalink
AP_Rangefinder: added a rate-limited and a compile-out option for the…
Browse files Browse the repository at this point in the history
… error reporting
  • Loading branch information
magicrub committed Mar 15, 2024
1 parent 97be9a6 commit ccdd769
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 2 deletions.
14 changes: 12 additions & 2 deletions libraries/AP_RangeFinder/AP_RangeFinder_Ainstein_LR_D1.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,10 @@

#if AP_RANGEFINDER_AINSTEIN_LR_D1_ENABLED

#ifndef AP_RANGEFINDER_AINSTEIN_LR_D1_SHOW_MALFUNCTIONS
#define AP_RANGEFINDER_AINSTEIN_LR_D1_SHOW_MALFUNCTIONS 1
#endif

#include "AP_RangeFinder_Ainstein_LR_D1.h"
#include <GCS_MAVLink/GCS.h>

Expand Down Expand Up @@ -69,10 +73,14 @@ bool AP_RangeFinder_Ainstein_LR_D1::get_reading(float &reading_m)

has_data = true;

if (malfunction_alert_prev != malfunction_alert) {
#if AP_RANGEFINDER_AINSTEIN_LR_D1_SHOW_MALFUNCTIONS
const uint32_t now_ms = AP_HAL::millis();
if (malfunction_alert_prev != malfunction_alert && now_ms - malfunction_alert_last_send_ms >= 1000) {
malfunction_alert_prev = malfunction_alert;
malfunction_alert_last_send_ms = now_ms;
report_malfunction(malfunction_alert);
}
#endif

/* From datasheet:
Altitude measurements associated with a SNR value
Expand Down Expand Up @@ -101,6 +109,7 @@ bool AP_RangeFinder_Ainstein_LR_D1::get_reading(float &reading_m)
return has_data;
}

#if AP_RANGEFINDER_AINSTEIN_LR_D1_SHOW_MALFUNCTIONS
void AP_RangeFinder_Ainstein_LR_D1::report_malfunction(const uint8_t _malfunction_alert_) {
if (_malfunction_alert_ & static_cast<uint8_t>(MalfunctionAlert::Temperature)) {
GCS_SEND_TEXT(MAV_SEVERITY_WARNING, "RangeFinder: Temperature alert");
Expand All @@ -115,5 +124,6 @@ void AP_RangeFinder_Ainstein_LR_D1::report_malfunction(const uint8_t _malfunctio
GCS_SEND_TEXT(MAV_SEVERITY_WARNING, "RangeFinder: Altitude reading overflow alert");
}
}
#endif // AP_RANGEFINDER_AINSTEIN_LR_D1_SHOW_MALFUNCTIONS

#endif
#endif // AP_RANGEFINDER_AINSTEIN_LR_D1_ENABLED
1 change: 1 addition & 0 deletions libraries/AP_RangeFinder/AP_RangeFinder_Ainstein_LR_D1.h
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,7 @@ class AP_RangeFinder_Ainstein_LR_D1 : public AP_RangeFinder_Backend_Serial

static constexpr uint8_t PACKET_SIZE = 32;
uint8_t malfunction_alert_prev;
uint32_t malfunction_alert_last_send_ms;
int8_t signal_quality_pct = RangeFinder::SIGNAL_QUALITY_UNKNOWN;
};
#endif

0 comments on commit ccdd769

Please sign in to comment.