From 4871bbf40325f5c08a7defd82d607bab9ac43e34 Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Sun, 15 Apr 2018 15:33:40 +1000 Subject: [PATCH] HAL_ChibiOS: make soft serial for RC serial more efficient using system ticks halves the IRQ time --- libraries/AP_HAL_ChibiOS/RCOutput.cpp | 12 ++++++------ libraries/AP_HAL_ChibiOS/RCOutput.h | 6 +++--- 2 files changed, 9 insertions(+), 9 deletions(-) diff --git a/libraries/AP_HAL_ChibiOS/RCOutput.cpp b/libraries/AP_HAL_ChibiOS/RCOutput.cpp index d79a1f7c77..9d5d3a6542 100644 --- a/libraries/AP_HAL_ChibiOS/RCOutput.cpp +++ b/libraries/AP_HAL_ChibiOS/RCOutput.cpp @@ -1101,7 +1101,7 @@ bool RCOutput::serial_write_bytes(const uint8_t *bytes, uint16_t len) */ void RCOutput::serial_bit_irq(void) { - uint32_t now = AP_HAL::micros(); + systime_t now = chVTGetSystemTimeX(); uint8_t bit = palReadLine(irq.line); bool send_signal = false; @@ -1116,12 +1116,12 @@ void RCOutput::serial_bit_irq(void) send_signal = true; } else { irq.nbits = 1; - irq.byte_start_us = now; + irq.byte_start_tick = now; irq.bitmask = 0; } } else { - uint32_t dt = now - irq.byte_start_us; - uint8_t bitnum = (dt+(irq.bit_time_us/2)) / irq.bit_time_us; + systime_t dt = now - irq.byte_start_tick; + uint8_t bitnum = (dt+(irq.bit_time_tick/2)) / irq.bit_time_tick; if (bitnum > 10) { bitnum = 10; @@ -1137,7 +1137,7 @@ void RCOutput::serial_bit_irq(void) irq.byteval = irq.bitmask & 0x3FF; irq.bitmask = 0; irq.nbits = 1; - irq.byte_start_us = now; + irq.byte_start_tick = now; } } irq.last_bit = bit; @@ -1205,7 +1205,7 @@ uint16_t RCOutput::serial_read_bytes(uint8_t *buf, uint16_t len) irq.nbits = 0; irq.bitmask = 0; irq.byteval = 0; - irq.bit_time_us = serial_group->serial.bit_time_us; + irq.bit_time_tick = serial_group->serial.bit_time_us; irq.last_bit = 0; irq.waiter = chThdGetSelfX(); diff --git a/libraries/AP_HAL_ChibiOS/RCOutput.h b/libraries/AP_HAL_ChibiOS/RCOutput.h index 6b173312d8..21f1fa9ac4 100644 --- a/libraries/AP_HAL_ChibiOS/RCOutput.h +++ b/libraries/AP_HAL_ChibiOS/RCOutput.h @@ -169,7 +169,7 @@ private: ioline_t line; // time the current byte started - uint32_t byte_start_us; + systime_t byte_start_tick; // number of bits we have read in this byte uint8_t nbits; @@ -180,8 +180,8 @@ private: // value of completed byte (includes start and stop bits) uint16_t byteval; - // expected time per bit - uint32_t bit_time_us; + // expected time per bit in system ticks + systime_t bit_time_tick; // the bit value of the last bit received uint8_t last_bit;