mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-06 16:08:28 -04:00
Rover: Skid steering disarming fixes
I have disabled steering disarming for skid steering rovers. Its perfectly reasonable for a skid steering rover to go hard left on the spot without any throttle and the user wouldn't want the rover to disarm during this procedure. If you disarm from the GCS for a skid steering rover we also ensure the steering channel is disabled.
This commit is contained in:
parent
501284f65a
commit
094d571196
@ -18,6 +18,9 @@ void Rover::set_control_channels(void)
|
|||||||
// For a rover safety is TRIM throttle
|
// For a rover safety is TRIM throttle
|
||||||
if (!arming.is_armed() && arming.arming_required() == AP_Arming::YES_MIN_PWM) {
|
if (!arming.is_armed() && arming.arming_required() == AP_Arming::YES_MIN_PWM) {
|
||||||
hal.rcout->set_safety_pwm(1UL<<(rcmap.throttle()-1), channel_throttle->get_radio_trim());
|
hal.rcout->set_safety_pwm(1UL<<(rcmap.throttle()-1), channel_throttle->get_radio_trim());
|
||||||
|
if (g.skid_steer_out) {
|
||||||
|
hal.rcout->set_safety_pwm(1UL<<(rcmap.roll()-1), channel_steer->get_radio_trim());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// setup correct scaling for ESCs like the UAVCAN PX4ESC which
|
// setup correct scaling for ESCs like the UAVCAN PX4ESC which
|
||||||
@ -42,6 +45,9 @@ void Rover::init_rc_out()
|
|||||||
|
|
||||||
if (arming.arming_required() != AP_Arming::YES_ZERO_PWM) {
|
if (arming.arming_required() != AP_Arming::YES_ZERO_PWM) {
|
||||||
channel_throttle->enable_out();
|
channel_throttle->enable_out();
|
||||||
|
if (g.skid_steer_out) {
|
||||||
|
channel_steer->enable_out();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
RC_Channel::output_trim_all();
|
RC_Channel::output_trim_all();
|
||||||
@ -55,6 +61,9 @@ void Rover::init_rc_out()
|
|||||||
// full speed backward.
|
// full speed backward.
|
||||||
if (arming.arming_required() == AP_Arming::YES_MIN_PWM) {
|
if (arming.arming_required() == AP_Arming::YES_MIN_PWM) {
|
||||||
hal.rcout->set_safety_pwm(1UL<<(rcmap.throttle()-1), channel_throttle->get_radio_trim());
|
hal.rcout->set_safety_pwm(1UL<<(rcmap.throttle()-1), channel_throttle->get_radio_trim());
|
||||||
|
if (g.skid_steer_out) {
|
||||||
|
hal.rcout->set_safety_pwm(1UL<<(rcmap.roll()-1), channel_steer->get_radio_trim());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -96,8 +105,10 @@ void Rover::rudder_arm_disarm_check()
|
|||||||
// not at full right rudder
|
// not at full right rudder
|
||||||
rudder_arm_timer = 0;
|
rudder_arm_timer = 0;
|
||||||
}
|
}
|
||||||
} else if (!motor_active()) {
|
} else if (!motor_active() & !g.skid_steer_out) {
|
||||||
// when armed and motor not active (not moving), full left rudder starts disarming counter
|
// when armed and motor not active (not moving), full left rudder starts disarming counter
|
||||||
|
// This is disabled for skid steering otherwise when tring to turn a skid steering rover around
|
||||||
|
// the rover would disarm
|
||||||
if (channel_steer->get_control_in() < -4000) {
|
if (channel_steer->get_control_in() < -4000) {
|
||||||
uint32_t now = millis();
|
uint32_t now = millis();
|
||||||
|
|
||||||
|
@ -528,6 +528,9 @@ bool Rover::disarm_motors(void)
|
|||||||
}
|
}
|
||||||
if (arming.arming_required() == AP_Arming::YES_ZERO_PWM) {
|
if (arming.arming_required() == AP_Arming::YES_ZERO_PWM) {
|
||||||
channel_throttle->disable_out();
|
channel_throttle->disable_out();
|
||||||
|
if (g.skid_steer_out) {
|
||||||
|
channel_steer->disable_out();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (control_mode != AUTO) {
|
if (control_mode != AUTO) {
|
||||||
// reset the mission on disarm if we are not in auto
|
// reset the mission on disarm if we are not in auto
|
||||||
|
Loading…
Reference in New Issue
Block a user