mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-03 06:28:27 -04:00
HAL_Linux: reduce delay(ms) jitter
Fix delay(1) rarely returning immediately. On my RPi4, this once per 5-20k calls that worked. Reduce the last call to microsleep according to the remaining time needed in the last loop iteration.
This commit is contained in:
parent
0007c7dce0
commit
bf1d364201
@ -173,15 +173,20 @@ void Scheduler::delay(uint16_t ms)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint64_t start = AP_HAL::millis64();
|
if (ms == 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
while ((AP_HAL::millis64() - start) < ms) {
|
uint64_t now = AP_HAL::micros64();
|
||||||
|
uint64_t end = now + 1000UL * ms + 1U;
|
||||||
|
do {
|
||||||
// this yields the CPU to other apps
|
// this yields the CPU to other apps
|
||||||
microsleep(1000);
|
microsleep(MIN(1000UL, end-now));
|
||||||
if (in_main_thread() && _min_delay_cb_ms <= ms) {
|
if (in_main_thread() && _min_delay_cb_ms <= ms) {
|
||||||
call_delay_cb();
|
call_delay_cb();
|
||||||
}
|
}
|
||||||
}
|
now = AP_HAL::micros64();
|
||||||
|
} while (now < end);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Scheduler::delay_microseconds(uint16_t us)
|
void Scheduler::delay_microseconds(uint16_t us)
|
||||||
|
Loading…
Reference in New Issue
Block a user