From 4fd13d52058964bdd334c428a18e8935fd8e37bd Mon Sep 17 00:00:00 2001 From: Michael du Breuil Date: Tue, 25 Jul 2017 10:58:24 -0700 Subject: [PATCH] Plane: Support landing terminations on landing backends that support it --- ArduPlane/afs_plane.cpp | 20 ++++++++++++-------- 1 file changed, 12 insertions(+), 8 deletions(-) diff --git a/ArduPlane/afs_plane.cpp b/ArduPlane/afs_plane.cpp index 6083d18e25..20b782e1b3 100644 --- a/ArduPlane/afs_plane.cpp +++ b/ArduPlane/afs_plane.cpp @@ -17,14 +17,18 @@ void AP_AdvancedFailsafe_Plane::terminate_vehicle(void) { plane.g2.servo_channels.disable_passthrough(true); - // and all aux channels - SRV_Channels::set_output_scaled(SRV_Channel::k_flap_auto, 100); - SRV_Channels::set_output_scaled(SRV_Channel::k_flap, 100); - SRV_Channels::set_output_scaled(SRV_Channel::k_aileron, SERVO_MAX); - SRV_Channels::set_output_scaled(SRV_Channel::k_rudder, SERVO_MAX); - SRV_Channels::set_output_scaled(SRV_Channel::k_elevator, SERVO_MAX); - SRV_Channels::set_output_limit(SRV_Channel::k_manual, SRV_Channel::SRV_CHANNEL_LIMIT_TRIM); - SRV_Channels::set_output_limit(SRV_Channel::k_none, SRV_Channel::SRV_CHANNEL_LIMIT_TRIM); + if (_terminate_action == TERMINATE_ACTION_LAND) { + plane.landing.terminate(); + } else { + // aerodynamic termination is the default approach to termination + SRV_Channels::set_output_scaled(SRV_Channel::k_flap_auto, 100); + SRV_Channels::set_output_scaled(SRV_Channel::k_flap, 100); + SRV_Channels::set_output_scaled(SRV_Channel::k_aileron, SERVO_MAX); + SRV_Channels::set_output_scaled(SRV_Channel::k_rudder, SERVO_MAX); + SRV_Channels::set_output_scaled(SRV_Channel::k_elevator, SERVO_MAX); + SRV_Channels::set_output_limit(SRV_Channel::k_manual, SRV_Channel::SRV_CHANNEL_LIMIT_TRIM); + SRV_Channels::set_output_limit(SRV_Channel::k_none, SRV_Channel::SRV_CHANNEL_LIMIT_TRIM); + } plane.servos_output();