From 26d279e165d9571e0ed4e5791080b648035b4e47 Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Thu, 15 Mar 2018 19:55:50 +1100 Subject: [PATCH] HAL_ChibiOS: improve DShot timing accuracy --- libraries/AP_HAL_ChibiOS/RCOutput.cpp | 8 ++++---- libraries/AP_HAL_ChibiOS/RCOutput.h | 1 + 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/libraries/AP_HAL_ChibiOS/RCOutput.cpp b/libraries/AP_HAL_ChibiOS/RCOutput.cpp index 2492977fd8..1a05cc3f26 100644 --- a/libraries/AP_HAL_ChibiOS/RCOutput.cpp +++ b/libraries/AP_HAL_ChibiOS/RCOutput.cpp @@ -414,8 +414,8 @@ void RCOutput::set_output_mode(uint16_t mask, enum output_mode mode) const uint32_t bit_period = 19; // configure timer driver for DMAR at requested rate pwmStop(group.pwm_drv); - group.pwm_cfg.frequency = rate * bit_period; - group.pwm_cfg.period = bit_period; + group.pwm_cfg.frequency = rate * bit_period * dshot_clockmul; + group.pwm_cfg.period = bit_period * dshot_clockmul; group.pwm_cfg.dier = TIM_DIER_UDE; group.pwm_cfg.cr2 = 0; pwmStart(group.pwm_drv, &group.pwm_cfg); @@ -623,8 +623,8 @@ uint16_t RCOutput::create_dshot_packet(const uint16_t value) */ void RCOutput::fill_DMA_buffer_dshot(uint32_t *buffer, uint8_t stride, uint16_t packet) { - const uint8_t DSHOT_MOTOR_BIT_0 = 7; - const uint8_t DSHOT_MOTOR_BIT_1 = 14; + const uint8_t DSHOT_MOTOR_BIT_0 = 7 * dshot_clockmul; + const uint8_t DSHOT_MOTOR_BIT_1 = 14 * dshot_clockmul; for (uint16_t i = 0; i < 16; i++) { buffer[i * stride] = (packet & 0x8000) ? DSHOT_MOTOR_BIT_1 : DSHOT_MOTOR_BIT_0; packet <<= 1; diff --git a/libraries/AP_HAL_ChibiOS/RCOutput.h b/libraries/AP_HAL_ChibiOS/RCOutput.h index 331df2fca5..5fbd4cf22b 100644 --- a/libraries/AP_HAL_ChibiOS/RCOutput.h +++ b/libraries/AP_HAL_ChibiOS/RCOutput.h @@ -134,6 +134,7 @@ private: DShot handling */ const uint8_t dshot_post = 2; + const uint8_t dshot_clockmul = 2; const uint16_t dshot_bit_length = 16 + dshot_post; const uint16_t dshot_buffer_length = dshot_bit_length*4*sizeof(uint32_t); uint32_t dshot_pulse_time_us;