mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-03 14:38:30 -04:00
HAL_SITL: allow delay from other than main thread
This commit is contained in:
parent
3cd6d8cac7
commit
3fc6968700
@ -185,7 +185,11 @@ void SITL_State::_fdm_input_step(void)
|
||||
void SITL_State::wait_clock(uint64_t wait_time_usec)
|
||||
{
|
||||
while (AP_HAL::micros64() < wait_time_usec) {
|
||||
if (hal.scheduler->in_main_thread()) {
|
||||
_fdm_input_step();
|
||||
} else {
|
||||
usleep(1000);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -31,6 +31,15 @@ Scheduler::Scheduler(SITL_State *sitlState) :
|
||||
|
||||
void Scheduler::init()
|
||||
{
|
||||
_main_ctx = pthread_self();
|
||||
}
|
||||
|
||||
bool Scheduler::in_main_thread() const
|
||||
{
|
||||
if (!_in_timer_proc && !_in_io_proc && pthread_self() == _main_ctx) {
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
void Scheduler::delay_microseconds(uint16_t usec)
|
||||
@ -51,10 +60,12 @@ void Scheduler::delay(uint16_t ms)
|
||||
delay_microseconds(1000);
|
||||
ms--;
|
||||
if (_min_delay_cb_ms <= ms) {
|
||||
if (in_main_thread()) {
|
||||
call_delay_cb();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void Scheduler::register_timer_process(AP_HAL::MemberProc proc)
|
||||
{
|
||||
|
@ -26,7 +26,7 @@ public:
|
||||
|
||||
void register_timer_failsafe(AP_HAL::Proc, uint32_t period_us);
|
||||
|
||||
bool in_main_thread() const override { return !_in_timer_proc && !_in_io_proc; };
|
||||
bool in_main_thread() const override;
|
||||
void system_initialized();
|
||||
|
||||
void reboot(bool hold_in_bootloader);
|
||||
@ -78,5 +78,6 @@ private:
|
||||
bool _initialized;
|
||||
uint64_t _stopped_clock_usec;
|
||||
uint64_t _last_io_run;
|
||||
pthread_t _main_ctx;
|
||||
};
|
||||
#endif // CONFIG_HAL_BOARD
|
||||
|
Loading…
Reference in New Issue
Block a user