From 5cbd810e41e5ef02f312aa7b696f99a522dcb418 Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Sun, 8 Jan 2023 12:49:53 +1100 Subject: [PATCH] AC_AttitudeControl: fixed time wrap bug in is_active_xy() this failed at 70 minutes --- libraries/AC_AttitudeControl/AC_PosControl.cpp | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/libraries/AC_AttitudeControl/AC_PosControl.cpp b/libraries/AC_AttitudeControl/AC_PosControl.cpp index 72458ea93a..1ed4ea3d5d 100644 --- a/libraries/AC_AttitudeControl/AC_PosControl.cpp +++ b/libraries/AC_AttitudeControl/AC_PosControl.cpp @@ -589,7 +589,8 @@ void AC_PosControl::stop_vel_xy_stabilisation() // is_active_xy - returns true if the xy position controller has bee n run in the previous 5 loop times bool AC_PosControl::is_active_xy() const { - return ((AP::ins().get_last_update_usec() - _last_update_xy_us) <= _dt * 1500000.0); + const uint32_t dt_us = AP::ins().get_last_update_usec() - _last_update_xy_us; + return dt_us <= _dt * 1500000.0; } /// update_xy_controller - runs the horizontal position controller correcting position, velocity and acceleration errors. @@ -903,7 +904,8 @@ void AC_PosControl::update_pos_offset_z(float pos_offset_z) // is_active_z - returns true if the z position controller has been run in the previous 5 loop times bool AC_PosControl::is_active_z() const { - return ((AP::ins().get_last_update_usec() - _last_update_z_us) <= _dt * 1500000.0); + const uint32_t dt_us = AP::ins().get_last_update_usec() - _last_update_z_us; + return dt_us <= _dt * 1500000.0; } /// update_z_controller - runs the vertical position controller correcting position, velocity and acceleration errors.