mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-11 10:28:29 -04:00
AP_Arming: add pre-arm check of disabled servo channels
This commit is contained in:
parent
0d096985db
commit
c53e507978
@ -809,6 +809,23 @@ bool AP_Arming::servo_checks(bool report) const
|
||||
check_failed(report, "SERVO%d_MAX is less than SERVO%d_TRIM", i + 1, i + 1);
|
||||
check_passed = false;
|
||||
}
|
||||
|
||||
// check functions using PWM are enabled
|
||||
if (SRV_Channels::get_disabled_channel_mask() & 1U<<i) {
|
||||
const SRV_Channel::Aux_servo_function_t ch_function = c->get_function();
|
||||
|
||||
// motors, e-stoppable functions, neopixels and ProfiLEDs may be digital outputs and thus can be disabled
|
||||
const bool disabled_ok = SRV_Channel::is_motor(ch_function) ||
|
||||
SRV_Channel::should_e_stop(ch_function) ||
|
||||
(ch_function >= SRV_Channel::k_LED_neopixel1 && ch_function <= SRV_Channel::k_LED_neopixel4) ||
|
||||
(ch_function >= SRV_Channel::k_ProfiLED_1 && ch_function <= SRV_Channel::k_ProfiLED_Clock);
|
||||
|
||||
// for all other functions raise a pre-arm failure
|
||||
if (!disabled_ok) {
|
||||
check_failed(report, "SERVO%u_FUNCTION=%u on disabled channel", i + 1, (unsigned)ch_function);
|
||||
check_passed = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#if HAL_WITH_IO_MCU
|
||||
|
Loading…
Reference in New Issue
Block a user