mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-05 15:38:29 -04:00
Copter: AP_Arming: print multiple failures at once.
This commit is contained in:
parent
3e246c9d25
commit
40414499fd
@ -23,11 +23,12 @@ bool AP_Arming_Copter::run_pre_arm_checks(bool display_failure)
|
|||||||
|
|
||||||
// check if motor interlock and either Emergency Stop aux switches are used
|
// check if motor interlock and either Emergency Stop aux switches are used
|
||||||
// at the same time. This cannot be allowed.
|
// at the same time. This cannot be allowed.
|
||||||
|
bool passed = true;
|
||||||
if (rc().find_channel_for_option(RC_Channel::AUX_FUNC::MOTOR_INTERLOCK) &&
|
if (rc().find_channel_for_option(RC_Channel::AUX_FUNC::MOTOR_INTERLOCK) &&
|
||||||
(rc().find_channel_for_option(RC_Channel::AUX_FUNC::MOTOR_ESTOP) ||
|
(rc().find_channel_for_option(RC_Channel::AUX_FUNC::MOTOR_ESTOP) ||
|
||||||
rc().find_channel_for_option(RC_Channel::AUX_FUNC::ARM_EMERGENCY_STOP))){
|
rc().find_channel_for_option(RC_Channel::AUX_FUNC::ARM_EMERGENCY_STOP))){
|
||||||
check_failed(display_failure, "Interlock/E-Stop Conflict");
|
check_failed(display_failure, "Interlock/E-Stop Conflict");
|
||||||
return false;
|
passed = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// check if motor interlock aux switch is in use
|
// check if motor interlock aux switch is in use
|
||||||
@ -35,17 +36,22 @@ bool AP_Arming_Copter::run_pre_arm_checks(bool display_failure)
|
|||||||
// otherwise exit immediately.
|
// otherwise exit immediately.
|
||||||
if (copter.ap.using_interlock && copter.ap.motor_interlock_switch) {
|
if (copter.ap.using_interlock && copter.ap.motor_interlock_switch) {
|
||||||
check_failed(display_failure, "Motor Interlock Enabled");
|
check_failed(display_failure, "Motor Interlock Enabled");
|
||||||
return false;
|
passed = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!disarm_switch_checks(display_failure)) {
|
if (!disarm_switch_checks(display_failure)) {
|
||||||
return false;
|
passed = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// always check motors
|
// always check motors
|
||||||
char failure_msg[50] {};
|
char failure_msg[50] {};
|
||||||
if (!copter.motors->arming_checks(ARRAY_SIZE(failure_msg), failure_msg)) {
|
if (!copter.motors->arming_checks(ARRAY_SIZE(failure_msg), failure_msg)) {
|
||||||
check_failed(display_failure, "Motors: %s", failure_msg);
|
check_failed(display_failure, "Motors: %s", failure_msg);
|
||||||
|
passed = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// If not passed all checks return false
|
||||||
|
if (!passed) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user