mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-04 23:18:28 -04:00
AP_Baro: fix bug in alt error arming check
get_altitude_difference already subtracts MSL altitude
This commit is contained in:
parent
9853fc4a65
commit
33fafed63c
@ -1088,7 +1088,8 @@ bool AP_Baro::arming_checks(size_t buflen, char *buffer) const
|
|||||||
const auto &gps = AP::gps();
|
const auto &gps = AP::gps();
|
||||||
if (_alt_error_max > 0 && gps.status() >= AP_GPS::GPS_Status::GPS_OK_FIX_3D) {
|
if (_alt_error_max > 0 && gps.status() >= AP_GPS::GPS_Status::GPS_OK_FIX_3D) {
|
||||||
const float alt_amsl = gps.location().alt*0.01;
|
const float alt_amsl = gps.location().alt*0.01;
|
||||||
const float alt_pressure = get_altitude_difference(SSL_AIR_PRESSURE, get_pressure());
|
// note the addition of _field_elevation_active as this is subtracted in get_altitude_difference()
|
||||||
|
const float alt_pressure = get_altitude_difference(SSL_AIR_PRESSURE, get_pressure()) + _field_elevation_active;
|
||||||
const float error = fabsf(alt_amsl - alt_pressure);
|
const float error = fabsf(alt_amsl - alt_pressure);
|
||||||
if (error > _alt_error_max) {
|
if (error > _alt_error_max) {
|
||||||
hal.util->snprintf(buffer, buflen, "GPS alt error %.0fm (see BARO_ALTERR_MAX)", error);
|
hal.util->snprintf(buffer, buflen, "GPS alt error %.0fm (see BARO_ALTERR_MAX)", error);
|
||||||
|
Loading…
Reference in New Issue
Block a user