59 typedef etl::delegate<void(etl::timer::id::type)> event_callback_type;
67 etl::message_router_id_t destination_router_id_ = etl::imessage_router::ALL_MESSAGE_ROUTERS)
69 etl::timer::id::type
id = etl::timer::id::NO_TIMER;
71 bool is_space = (number_of_registered_timers < Max_Timers);
76 if (!router_.is_null_router())
79 for (uint_least8_t i = 0U; i < Max_Timers; ++i)
83 if (
timer.
id == etl::timer::id::NO_TIMER)
86 new (&
timer)
timer_data(i, message_, router_, period_, repeating_, destination_router_id_);
87 ++number_of_registered_timers;
105 if (id_ != etl::timer::id::NO_TIMER)
109 if (
timer.
id != etl::timer::id::NO_TIMER)
111 if (
timer.is_active())
114 active_list.remove(
timer.
id,
true);
115 remove_callback.call_if(
timer.
id);
121 --number_of_registered_timers;
155 for (
int i = 0; i < Max_Timers; ++i)
160 number_of_registered_timers = 0U;
169 bool tick(uint32_t count)
176 bool has_active = !active_list.empty();
180 while (has_active && (count >= active_list.front().delta))
182 timer_data&
timer = active_list.front();
184 count -=
timer.delta;
186 active_list.remove(
timer.
id,
true);
187 remove_callback.call_if(
timer.
id);
189 if (
timer.p_router != ETL_NULLPTR)
191 timer.p_router->receive(
timer.destination_router_id, *(
timer.p_message));
196 timer.delta = timer.period;
197 active_list.insert(timer.id);
198 insert_callback.call_if(timer.id);
201 has_active = !active_list.empty();
207 active_list.front().delta -= count;
223 bool start(etl::timer::id::type id_,
bool immediate_ =
false)
228 if (id_ != etl::timer::id::NO_TIMER)
233 if (
timer.
id != etl::timer::id::NO_TIMER)
236 if (
timer.period != etl::timer::state::Inactive)
239 if (
timer.is_active())
241 active_list.remove(
timer.
id,
false);
242 remove_callback.call_if(
timer.
id);
247 insert_callback.call_if(
timer.
id);
261 bool stop(etl::timer::id::type id_)
266 if (id_ != etl::timer::id::NO_TIMER)
271 if (
timer.
id != etl::timer::id::NO_TIMER)
273 if (
timer.is_active())
276 active_list.remove(
timer.
id,
false);
277 remove_callback.call_if(
timer.
id);
295 timer_array[id_].period = period_;
305 bool set_mode(etl::timer::id::type id_,
bool repeating_)
309 timer_array[id_].repeating = repeating_;
319 void set_locks(try_lock_type try_lock_, lock_type lock_, unlock_type unlock_)
321 try_lock = try_lock_;
332 bool result = !active_list.empty();
345 uint32_t delta =
static_cast<uint32_t
>(etl::timer::interval::No_Active_Interval);
348 if (!active_list.empty())
350 delta = active_list.front().delta;
362 insert_callback = insert_;
370 remove_callback = remove_;
374 void clear_insert_callback()
376 insert_callback.clear();
380 void clear_remove_callback()
382 remove_callback.clear();
393 : p_message(ETL_NULLPTR)
394 , p_router(ETL_NULLPTR)
396 , delta(etl::timer::state::Inactive)
397 , destination_router_id(etl::imessage_bus::ALL_MESSAGE_ROUTERS)
398 , id(etl::timer::id::NO_TIMER)
399 , previous(etl::timer::id::NO_TIMER)
400 , next(etl::timer::id::NO_TIMER)
407 etl::message_router_id_t destination_router_id_ = etl::imessage_bus::ALL_MESSAGE_ROUTERS)
408 : p_message(&message_)
409 , p_router(&irouter_)
411 , delta(etl::timer::state::Inactive)
412 , destination_router_id(destination_router_id_)
414 , previous(etl::timer::id::NO_TIMER)
415 , next(etl::timer::id::NO_TIMER)
416 , repeating(repeating_)
425 return delta != etl::timer::state::Inactive;
433 delta = etl::timer::state::Inactive;
440 etl::message_router_id_t destination_router_id;
441 etl::timer::id::type id;
442 uint_least8_t previous;
457 : timer_array(timer_array_)
458 , active_list(timer_array_)
460 , number_of_registered_timers(0U)
461 , Max_Timers(Max_Timers_)
480 timer_list(timer_data* ptimers_)
491 return head == etl::timer::id::NO_TIMER;
497 void insert(etl::timer::id::type id_)
499 timer_data& timer = ptimers[id_];
501 if (head == etl::timer::id::NO_TIMER)
506 timer.previous = etl::timer::id::NO_TIMER;
507 timer.next = etl::timer::id::NO_TIMER;
512 etl::timer::id::type test_id = begin();
514 while (test_id != etl::timer::id::NO_TIMER)
516 timer_data& test = ptimers[test_id];
519 if (timer.delta <= test.delta)
527 timer.previous = test.previous;
528 test.previous = timer.id;
529 timer.next = test.id;
532 test.delta -= timer.delta;
534 if (timer.previous != etl::timer::id::NO_TIMER)
536 ptimers[timer.previous].next = timer.id;
542 timer.delta -= test.delta;
545 test_id = next(test_id);
549 if (test_id == etl::timer::id::NO_TIMER)
552 ptimers[tail].next = timer.id;
553 timer.previous = tail;
554 timer.next = etl::timer::id::NO_TIMER;
561 void remove(etl::timer::id::type id_,
bool has_expired)
563 timer_data& timer = ptimers[id_];
571 ptimers[timer.previous].next = timer.next;
576 tail = timer.previous;
580 ptimers[timer.next].previous = timer.previous;
586 if (timer.next != etl::timer::id::NO_TIMER)
588 ptimers[timer.next].delta += timer.delta;
592 timer.previous = etl::timer::id::NO_TIMER;
593 timer.next = etl::timer::id::NO_TIMER;
594 timer.delta = etl::timer::state::Inactive;
600 return ptimers[head];
604 const timer_data& front()
const
606 return ptimers[head];
610 etl::timer::id::type begin()
617 etl::timer::id::type previous(etl::timer::id::type last)
619 current = ptimers[last].previous;
624 etl::timer::id::type next(etl::timer::id::type last)
626 current = ptimers[last].next;
633 etl::timer::id::type
id = begin();
635 while (
id != etl::timer::id::NO_TIMER)
637 timer_data& timer = ptimers[id];
639 timer.next = etl::timer::id::NO_TIMER;
642 head = etl::timer::id::NO_TIMER;
643 tail = etl::timer::id::NO_TIMER;
644 current = etl::timer::id::NO_TIMER;
649 etl::timer::id::type head;
650 etl::timer::id::type tail;
651 etl::timer::id::type current;
653 timer_data*
const ptimers;
660 timer_list active_list;
663 uint_least8_t number_of_registered_timers;
665 try_lock_type try_lock;
669 event_callback_type insert_callback;
670 event_callback_type remove_callback;
674 const uint_least8_t Max_Timers;
etl::timer::id::type register_timer(const etl::imessage &message_, etl::imessage_router &router_, uint32_t period_, bool repeating_, etl::message_router_id_t destination_router_id_=etl::imessage_router::ALL_MESSAGE_ROUTERS)
Register a timer.
Definition message_timer_locked.h:66