From 7831113f8446eeb4b1826461c5df29d09554a3d5 Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Mon, 14 Oct 2013 08:45:58 +1100 Subject: [PATCH] AP_InertialSensor: yield the CPU for the right time in wait_for_sample() this improves timing performance --- libraries/AP_InertialSensor/AP_InertialSensor_PX4.cpp | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/libraries/AP_InertialSensor/AP_InertialSensor_PX4.cpp b/libraries/AP_InertialSensor/AP_InertialSensor_PX4.cpp index e8f97f8c2c..24f5a06b69 100644 --- a/libraries/AP_InertialSensor/AP_InertialSensor_PX4.cpp +++ b/libraries/AP_InertialSensor/AP_InertialSensor_PX4.cpp @@ -159,7 +159,13 @@ bool AP_InertialSensor_PX4::wait_for_sample(uint16_t timeout_ms) } uint32_t start = hal.scheduler->millis(); while ((hal.scheduler->millis() - start) < timeout_ms) { - hal.scheduler->delay_microseconds(100); + uint64_t tnow = hrt_absolute_time(); + // we spin for the last timing_lag microseconds. Before that + // we yield the CPU to allow IO to happen + const uint16_t timing_lag = 400; + if (_last_sample_timestamp + _sample_time_usec > tnow+timing_lag) { + hal.scheduler->delay_microseconds(_last_sample_timestamp + _sample_time_usec - (tnow+timing_lag)); + } if (sample_available()) { return true; }