#pragma once #include #if CONFIG_HAL_BOARD == HAL_BOARD_SITL #include "AP_HAL_SITL_Namespace.h" #include #define SITL_SCHEDULER_MAX_TIMER_PROCS 4 /* Scheduler implementation: */ class HALSITL::Scheduler : public AP_HAL::Scheduler { public: explicit Scheduler(SITL_State *sitlState); static Scheduler *from(AP_HAL::Scheduler *scheduler) { return static_cast(scheduler); } /* AP_HAL::Scheduler methods */ void init(); void delay(uint16_t ms); void delay_microseconds(uint16_t us); void register_delay_callback(AP_HAL::Proc, uint16_t min_time_ms); void register_timer_process(AP_HAL::MemberProc); void register_io_process(AP_HAL::MemberProc); void suspend_timer_procs(); void resume_timer_procs(); void register_timer_failsafe(AP_HAL::Proc, uint32_t period_us); bool in_main_thread() const override { return !_in_timer_proc && !_in_io_proc; }; void system_initialized(); void reboot(bool hold_in_bootloader); bool interrupts_are_blocked(void) { return _nested_atomic_ctr != 0; } void sitl_begin_atomic() { _nested_atomic_ctr++; } void sitl_end_atomic(); static void timer_event() { _run_timer_procs(true); _run_io_procs(true); } uint64_t stopped_clock_usec() const { return _stopped_clock_usec; } private: SITL_State *_sitlState; uint8_t _nested_atomic_ctr; AP_HAL::Proc _delay_cb; uint16_t _min_delay_cb_ms; static AP_HAL::Proc _failsafe; static void _run_timer_procs(bool called_from_isr); static void _run_io_procs(bool called_from_isr); static volatile bool _timer_suspended; static volatile bool _timer_event_missed; static AP_HAL::MemberProc _timer_proc[SITL_SCHEDULER_MAX_TIMER_PROCS]; static AP_HAL::MemberProc _io_proc[SITL_SCHEDULER_MAX_TIMER_PROCS]; static uint8_t _num_timer_procs; static uint8_t _num_io_procs; static bool _in_timer_proc; static bool _in_io_proc; void stop_clock(uint64_t time_usec); bool _initialized; uint64_t _stopped_clock_usec; uint64_t _last_io_run; }; #endif // CONFIG_HAL_BOARD