mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-05 07:28:29 -04:00
Sub: Bugfix for external baro failsafe handling when no baro is
connected at boot
This commit is contained in:
parent
9bdf971336
commit
131e1bdef5
@ -233,6 +233,7 @@ private:
|
|||||||
enum HomeState home_state : 2; // home status (unset, set, locked)
|
enum HomeState home_state : 2; // home status (unset, set, locked)
|
||||||
uint8_t at_bottom : 1; // true if we are at the bottom
|
uint8_t at_bottom : 1; // true if we are at the bottom
|
||||||
uint8_t at_surface : 1; // true if we are at the surface
|
uint8_t at_surface : 1; // true if we are at the surface
|
||||||
|
uint8_t depth_sensor_present: 1; // true if there is a depth sensor detected at boot
|
||||||
};
|
};
|
||||||
uint32_t value;
|
uint32_t value;
|
||||||
} ap;
|
} ap;
|
||||||
|
@ -9,7 +9,7 @@
|
|||||||
bool Sub::althold_init()
|
bool Sub::althold_init()
|
||||||
{
|
{
|
||||||
#if CONFIG_HAL_BOARD != HAL_BOARD_SITL
|
#if CONFIG_HAL_BOARD != HAL_BOARD_SITL
|
||||||
if (!sensor_health.depth) { // can't hold depth without a depth sensor, exit immediately.
|
if (!ap.depth_sensor_present || failsafe.sensor_health) { // can't hold depth without a depth sensor, exit immediately.
|
||||||
gcs_send_text(MAV_SEVERITY_WARNING, "BAD DEPTH");
|
gcs_send_text(MAV_SEVERITY_WARNING, "BAD DEPTH");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
bool Sub::surface_init()
|
bool Sub::surface_init()
|
||||||
{
|
{
|
||||||
#if CONFIG_HAL_BOARD != HAL_BOARD_SITL
|
#if CONFIG_HAL_BOARD != HAL_BOARD_SITL
|
||||||
if (!sensor_health.depth) { // can't hold depth without a depth sensor, exit immediately.
|
if (!ap.depth_sensor_present || failsafe.sensor_health) { // can't hold depth without a depth sensor, exit immediately.
|
||||||
gcs_send_text(MAV_SEVERITY_WARNING, "BAD DEPTH");
|
gcs_send_text(MAV_SEVERITY_WARNING, "BAD DEPTH");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -66,6 +66,10 @@ void Sub::mainloop_failsafe_check()
|
|||||||
|
|
||||||
void Sub::failsafe_sensors_check(void)
|
void Sub::failsafe_sensors_check(void)
|
||||||
{
|
{
|
||||||
|
if (!ap.depth_sensor_present) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// We need a depth sensor to do any sort of auto z control
|
// We need a depth sensor to do any sort of auto z control
|
||||||
if (sensor_health.depth) {
|
if (sensor_health.depth) {
|
||||||
failsafe.sensor_health = false;
|
failsafe.sensor_health = false;
|
||||||
@ -99,7 +103,6 @@ void Sub::failsafe_ekf_check(void)
|
|||||||
failsafe.ekf = false;
|
failsafe.ekf = false;
|
||||||
AP_Notify::flags.ekf_bad = false;
|
AP_Notify::flags.ekf_bad = false;
|
||||||
return;
|
return;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
float posVar, hgtVar, tasVar;
|
float posVar, hgtVar, tasVar;
|
||||||
|
@ -15,7 +15,9 @@ void Sub::read_barometer(void)
|
|||||||
Log_Write_Baro();
|
Log_Write_Baro();
|
||||||
}
|
}
|
||||||
|
|
||||||
sensor_health.depth = barometer.healthy(depth_sensor_idx);
|
if (ap.depth_sensor_present) {
|
||||||
|
sensor_health.depth = barometer.healthy(depth_sensor_idx);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sub::init_rangefinder(void)
|
void Sub::init_rangefinder(void)
|
||||||
|
@ -24,7 +24,7 @@ void Sub::update_surface_and_bottom_detector()
|
|||||||
// check that we are not moving up or down
|
// check that we are not moving up or down
|
||||||
bool vel_stationary = velocity.z > -0.05 && velocity.z < 0.05;
|
bool vel_stationary = velocity.z > -0.05 && velocity.z < 0.05;
|
||||||
|
|
||||||
if (sensor_health.depth) { // we can use the external pressure sensor for a very accurate and current measure of our z axis position
|
if (ap.depth_sensor_present && sensor_health.depth) { // we can use the external pressure sensor for a very accurate and current measure of our z axis position
|
||||||
current_depth = barometer.get_altitude(); // cm
|
current_depth = barometer.get_altitude(); // cm
|
||||||
|
|
||||||
|
|
||||||
|
@ -123,8 +123,7 @@ void Sub::init_ardupilot()
|
|||||||
USERHOOK_INIT
|
USERHOOK_INIT
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// read Baro pressure at ground
|
// Init baro and determine if we have external (depth) pressure sensor
|
||||||
//-----------------------------
|
|
||||||
init_barometer(false);
|
init_barometer(false);
|
||||||
barometer.update();
|
barometer.update();
|
||||||
|
|
||||||
@ -132,12 +131,13 @@ void Sub::init_ardupilot()
|
|||||||
if (barometer.get_type(i) == AP_Baro::BARO_TYPE_WATER) {
|
if (barometer.get_type(i) == AP_Baro::BARO_TYPE_WATER) {
|
||||||
barometer.set_primary_baro(i);
|
barometer.set_primary_baro(i);
|
||||||
depth_sensor_idx = i;
|
depth_sensor_idx = i;
|
||||||
sensor_health.depth = barometer.healthy(i);
|
ap.depth_sensor_present = true;
|
||||||
break;
|
sensor_health.depth = barometer.healthy(depth_sensor_idx); // initialize health flag
|
||||||
|
break; // Go with the first one we find
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!sensor_health.depth) {
|
if (!ap.depth_sensor_present) {
|
||||||
// We only have onboard baro
|
// We only have onboard baro
|
||||||
// No external underwater depth sensor detected
|
// No external underwater depth sensor detected
|
||||||
barometer.set_primary_baro(0);
|
barometer.set_primary_baro(0);
|
||||||
|
Loading…
Reference in New Issue
Block a user