mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-24 17:48:35 -04:00
AP_HAL_ChibiOS: correct neopixel bitwidth
Use 64-bit timestamps for dshot send checks
This commit is contained in:
parent
29ba1a84d3
commit
b5a0db8721
@ -1002,6 +1002,7 @@ void RCOutput::set_group_mode(pwm_group &group)
|
||||
case MODE_PROFILED:
|
||||
{
|
||||
uint8_t bits_per_pixel = 24;
|
||||
uint32_t bit_width = NEOP_BIT_WIDTH_TICKS;
|
||||
bool active_high = true;
|
||||
|
||||
if (!start_led_thread()) {
|
||||
@ -1011,6 +1012,7 @@ void RCOutput::set_group_mode(pwm_group &group)
|
||||
|
||||
if (group.current_mode == MODE_PROFILED) {
|
||||
bits_per_pixel = 25;
|
||||
bit_width = PROFI_BIT_WIDTH_TICKS;
|
||||
active_high = false;
|
||||
}
|
||||
|
||||
@ -1025,7 +1027,7 @@ void RCOutput::set_group_mode(pwm_group &group)
|
||||
// calculate min time between pulses taking into account the DMAR parallelism
|
||||
const uint32_t pulse_time_us = 1000000UL * bit_length / rate;
|
||||
|
||||
if (!setup_group_DMA(group, rate, NEOP_BIT_WIDTH_TICKS, active_high, buffer_length, pulse_time_us, false)) {
|
||||
if (!setup_group_DMA(group, rate, bit_width, active_high, buffer_length, pulse_time_us, false)) {
|
||||
group.current_mode = MODE_PWM_NONE;
|
||||
break;
|
||||
}
|
||||
@ -1608,7 +1610,8 @@ bool RCOutput::serial_led_send(pwm_group &group)
|
||||
}
|
||||
|
||||
#ifndef DISABLE_DSHOT
|
||||
if (irq.waiter || (group.dshot_state != DshotState::IDLE && group.dshot_state != DshotState::RECV_COMPLETE)) {
|
||||
if (irq.waiter || (group.dshot_state != DshotState::IDLE && group.dshot_state != DshotState::RECV_COMPLETE)
|
||||
|| AP_HAL::micros64() - group.last_dmar_send_us < (group.dshot_pulse_time_us + 50)) {
|
||||
// doing serial output or DMAR input, don't send DShot pulses
|
||||
return false;
|
||||
}
|
||||
|
@ -405,7 +405,7 @@ private:
|
||||
#endif
|
||||
// are we safe to send another pulse?
|
||||
bool can_send_dshot_pulse() const {
|
||||
return is_dshot_protocol(current_mode) && AP_HAL::micros() - last_dmar_send_us > (dshot_pulse_time_us + 50);
|
||||
return is_dshot_protocol(current_mode) && AP_HAL::micros64() - last_dmar_send_us > (dshot_pulse_time_us + 50);
|
||||
}
|
||||
|
||||
// return whether the group channel is both enabled in the group and for output
|
||||
|
Loading…
Reference in New Issue
Block a user