From 5c15c1e4d2a0571fd968302dd0a91bcb4c263efc Mon Sep 17 00:00:00 2001 From: Peter Barker Date: Tue, 6 Jun 2017 17:18:15 +1000 Subject: [PATCH] AP_BoardConfig: add public method returning true if on sensor error --- libraries/AP_BoardConfig/AP_BoardConfig.cpp | 3 +++ libraries/AP_BoardConfig/AP_BoardConfig.h | 7 ++++++- 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/libraries/AP_BoardConfig/AP_BoardConfig.cpp b/libraries/AP_BoardConfig/AP_BoardConfig.cpp index d092a60f49..91efad7164 100644 --- a/libraries/AP_BoardConfig/AP_BoardConfig.cpp +++ b/libraries/AP_BoardConfig/AP_BoardConfig.cpp @@ -226,8 +226,11 @@ void AP_BoardConfig::init_safety() /* notify user of a fatal startup error related to available sensors. */ +bool AP_BoardConfig::_in_sensor_config_error; + void AP_BoardConfig::sensor_config_error(const char *reason) { + _in_sensor_config_error = true; /* to give the user the opportunity to connect to USB we keep repeating the error. The mavlink delay callback is initialised diff --git a/libraries/AP_BoardConfig/AP_BoardConfig.h b/libraries/AP_BoardConfig/AP_BoardConfig.h index 963dbdeab1..f2708f123b 100644 --- a/libraries/AP_BoardConfig/AP_BoardConfig.h +++ b/libraries/AP_BoardConfig/AP_BoardConfig.h @@ -44,7 +44,10 @@ public: // notify user of a fatal startup error related to available sensors. static void sensor_config_error(const char *reason); - + // permit other libraries (in particular, GCS_MAVLink) to detect + // that we're never going to boot properly: + static bool in_sensor_config_error(void) { return _in_sensor_config_error; } + #if CONFIG_HAL_BOARD == HAL_BOARD_PX4 || CONFIG_HAL_BOARD == HAL_BOARD_VRBRAIN // public method to start a driver static bool px4_start_driver(main_fn_t main_function, const char *name, const char *arguments); @@ -149,6 +152,8 @@ private: #endif // HAL_BOARD_PX4 || HAL_BOARD_VRBRAIN + static bool _in_sensor_config_error; + // target temperarure for IMU in Celsius, or -1 to disable AP_Int8 _imu_target_temperature; };