From 65adf5b4a9126874ee145c642fa1fce8eb165e21 Mon Sep 17 00:00:00 2001 From: Peter Barker Date: Wed, 6 Jan 2021 11:15:48 +1100 Subject: [PATCH] ArduCopter: add do_disarm_checks boolean to disarm call this creates symmetry between arming and disarming, at least as far as the top-level arm() and disarm() calls are concerned. --- ArduCopter/AP_Arming.cpp | 11 +++++++++-- ArduCopter/AP_Arming.h | 2 +- ArduCopter/GCS_Mavlink.cpp | 5 ----- ArduCopter/GCS_Mavlink.h | 2 -- 4 files changed, 10 insertions(+), 10 deletions(-) diff --git a/ArduCopter/AP_Arming.cpp b/ArduCopter/AP_Arming.cpp index 31f970808e..76e3cb3b5f 100644 --- a/ArduCopter/AP_Arming.cpp +++ b/ArduCopter/AP_Arming.cpp @@ -872,14 +872,21 @@ bool AP_Arming_Copter::arm(const AP_Arming::Method method, const bool do_arming_ } // arming.disarm - disarm motors -bool AP_Arming_Copter::disarm(const AP_Arming::Method method) +bool AP_Arming_Copter::disarm(const AP_Arming::Method method, bool do_disarm_checks) { // return immediately if we are already disarmed if (!copter.motors->armed()) { return true; } - if (!AP_Arming::disarm(method)) { + // do not allow disarm via mavlink if we think we are flying: + if (do_disarm_checks && + method == AP_Arming::Method::MAVLINK && + !copter.ap.land_complete) { + return false; + } + + if (!AP_Arming::disarm(method, do_disarm_checks)) { return false; } diff --git a/ArduCopter/AP_Arming.h b/ArduCopter/AP_Arming.h index b55a9de865..7576bad68b 100644 --- a/ArduCopter/AP_Arming.h +++ b/ArduCopter/AP_Arming.h @@ -23,7 +23,7 @@ public: bool rc_calibration_checks(bool display_failure) override; - bool disarm(AP_Arming::Method method) override; + bool disarm(AP_Arming::Method method, bool do_disarm_checks=true) override; bool arm(AP_Arming::Method method, bool do_arming_checks=true) override; protected: diff --git a/ArduCopter/GCS_Mavlink.cpp b/ArduCopter/GCS_Mavlink.cpp index df6c3f55f6..41a624673e 100644 --- a/ArduCopter/GCS_Mavlink.cpp +++ b/ArduCopter/GCS_Mavlink.cpp @@ -689,11 +689,6 @@ MAV_RESULT GCS_MAVLINK_Copter::handle_command_mount(const mavlink_command_long_t return GCS_MAVLINK::handle_command_mount(packet); } -bool GCS_MAVLINK_Copter::allow_disarm() const -{ - return copter.ap.land_complete; -} - MAV_RESULT GCS_MAVLINK_Copter::handle_command_long_packet(const mavlink_command_long_t &packet) { switch(packet.command) { diff --git a/ArduCopter/GCS_Mavlink.h b/ArduCopter/GCS_Mavlink.h index 396673b966..2c8a381c81 100644 --- a/ArduCopter/GCS_Mavlink.h +++ b/ArduCopter/GCS_Mavlink.h @@ -43,8 +43,6 @@ protected: virtual MAV_VTOL_STATE vtol_state() const override { return MAV_VTOL_STATE_MC; }; virtual MAV_LANDED_STATE landed_state() const override; - bool allow_disarm() const override; - private: void handleMessage(const mavlink_message_t &msg) override;