From 8c47a3d2683ec119eebf109f375a93bd2514079a Mon Sep 17 00:00:00 2001 From: Peter Barker Date: Thu, 2 Mar 2023 14:08:27 +1100 Subject: [PATCH] AP_Mount: allow gimbals other than primary to be retracted/neutralised --- libraries/AP_Mount/AP_Mount.cpp | 28 ++++++++++++---------------- 1 file changed, 12 insertions(+), 16 deletions(-) diff --git a/libraries/AP_Mount/AP_Mount.cpp b/libraries/AP_Mount/AP_Mount.cpp index 4d80ed05c1..1772cf00d8 100644 --- a/libraries/AP_Mount/AP_Mount.cpp +++ b/libraries/AP_Mount/AP_Mount.cpp @@ -279,22 +279,6 @@ MAV_RESULT AP_Mount::handle_command_do_mount_control(const mavlink_command_long_ MAV_RESULT AP_Mount::handle_command_do_gimbal_manager_pitchyaw(const mavlink_command_long_t &packet) { - if (!check_primary()) { - return MAV_RESULT_FAILED; - } - - // check flags for change to RETRACT - uint32_t flags = (uint32_t)packet.param5; - if ((flags & GIMBAL_MANAGER_FLAGS_RETRACT) > 0) { - _backends[_primary]->set_mode(MAV_MOUNT_MODE_RETRACT); - return MAV_RESULT_ACCEPTED; - } - // check flags for change to NEUTRAL - if ((flags & GIMBAL_MANAGER_FLAGS_NEUTRAL) > 0) { - _backends[_primary]->set_mode(MAV_MOUNT_MODE_NEUTRAL); - return MAV_RESULT_ACCEPTED; - } - // check gimbal device id. 0 is primary, 1 is 1st gimbal, 2 is 2nd gimbal, etc if ((packet.param7 < 0) || (packet.param7 > AP_MOUNT_MAX_INSTANCES)) { return MAV_RESULT_FAILED; @@ -304,6 +288,18 @@ MAV_RESULT AP_Mount::handle_command_do_gimbal_manager_pitchyaw(const mavlink_com return MAV_RESULT_FAILED; } + // check flags for change to RETRACT + uint32_t flags = (uint32_t)packet.param5; + if ((flags & GIMBAL_MANAGER_FLAGS_RETRACT) > 0) { + _backends[gimbal_instance]->set_mode(MAV_MOUNT_MODE_RETRACT); + return MAV_RESULT_ACCEPTED; + } + // check flags for change to NEUTRAL + if ((flags & GIMBAL_MANAGER_FLAGS_NEUTRAL) > 0) { + _backends[gimbal_instance]->set_mode(MAV_MOUNT_MODE_NEUTRAL); + return MAV_RESULT_ACCEPTED; + } + // param1 : pitch_angle (in degrees) // param2 : yaw angle (in degrees) const float pitch_angle_deg = packet.param1;