57 typedef etl::delegate<void(etl::timer::id::type)> event_callback_type;
68 etl::message_router_id_t destination_router_id_ = etl::imessage_router::ALL_MESSAGE_ROUTERS)
70 etl::timer::id::type
id = etl::timer::id::NO_TIMER;
72 bool is_space = (number_of_registered_timers < Max_Timers);
77 if (!router_.is_null_router())
80 for (uint_least8_t i = 0U; i < Max_Timers; ++i)
82 timer_data&
timer = timer_array[i];
84 if (
timer.
id == etl::timer::id::NO_TIMER)
86 TInterruptGuard guard;
90 new (&
timer) timer_data(i, message_, router_, period_, repeating_, destination_router_id_);
91 ++number_of_registered_timers;
109 if (id_ != etl::timer::id::NO_TIMER)
111 timer_data&
timer = timer_array[id_];
113 if (
timer.
id != etl::timer::id::NO_TIMER)
115 if (
timer.is_active())
117 TInterruptGuard guard;
120 active_list.remove(
timer.
id,
true);
121 remove_callback.call_if(
timer.
id);
125 new (&
timer) timer_data();
126 --number_of_registered_timers;
157 TInterruptGuard guard;
163 for (
int i = 0; i < Max_Timers; ++i)
165 new (&timer_array[i]) timer_data();
168 number_of_registered_timers = 0U;
177 bool tick(uint32_t count)
182 bool has_active = !active_list.empty();
186 while (has_active && (count >= active_list.front().delta))
188 timer_data&
timer = active_list.front();
190 count -=
timer.delta;
192 active_list.remove(
timer.
id,
true);
193 remove_callback.call_if(
timer.
id);
195 if (
timer.p_router != ETL_NULLPTR)
197 timer.p_router->receive(
timer.destination_router_id, *(
timer.p_message));
203 timer.delta = timer.period;
204 active_list.insert(timer.id);
205 insert_callback.call_if(timer.id);
208 has_active = !active_list.empty();
214 active_list.front().delta -= count;
227 bool start(etl::timer::id::type id_,
bool immediate_ =
false)
232 if (id_ != etl::timer::id::NO_TIMER)
234 timer_data&
timer = timer_array[id_];
237 if (
timer.
id != etl::timer::id::NO_TIMER)
240 if (
timer.period != etl::timer::state::Inactive)
242 TInterruptGuard guard;
245 if (
timer.is_active())
247 active_list.remove(
timer.
id,
false);
248 remove_callback.call_if(
timer.
id);
253 insert_callback.call_if(
timer.
id);
266 bool stop(etl::timer::id::type id_)
271 if (id_ != etl::timer::id::NO_TIMER)
273 timer_data&
timer = timer_array[id_];
276 if (
timer.
id != etl::timer::id::NO_TIMER)
278 if (
timer.is_active())
280 TInterruptGuard guard;
283 active_list.remove(
timer.
id,
false);
284 remove_callback.call_if(
timer.
id);
301 timer_array[id_].period = period_;
311 bool set_mode(etl::timer::id::type id_,
bool repeating_)
315 timer_array[id_].repeating = repeating_;
327 TInterruptGuard guard;
329 return !active_list.empty();
338 uint32_t delta =
static_cast<uint32_t
>(etl::timer::interval::No_Active_Interval);
340 TInterruptGuard guard;
343 if (!active_list.empty())
345 delta = active_list.front().delta;
356 insert_callback = insert_;
364 remove_callback = remove_;
368 void clear_insert_callback()
370 insert_callback.clear();
374 void clear_remove_callback()
376 remove_callback.clear();
387 : p_message(ETL_NULLPTR)
388 , p_router(ETL_NULLPTR)
390 , delta(etl::timer::state::Inactive)
391 , destination_router_id(etl::imessage_bus::ALL_MESSAGE_ROUTERS)
392 , id(etl::timer::id::NO_TIMER)
393 , previous(etl::timer::id::NO_TIMER)
394 , next(etl::timer::id::NO_TIMER)
400 timer_data(etl::timer::id::type id_,
405 etl::message_router_id_t destination_router_id_ = etl::imessage_bus::ALL_MESSAGE_ROUTERS)
406 : p_message(&message_)
407 , p_router(&irouter_)
409 , delta(etl::timer::state::Inactive)
410 , destination_router_id(destination_router_id_)
412 , previous(etl::timer::id::NO_TIMER)
413 , next(etl::timer::id::NO_TIMER)
414 , repeating(repeating_)
423 return delta != etl::timer::state::Inactive;
431 delta = etl::timer::state::Inactive;
438 etl::message_router_id_t destination_router_id;
439 etl::timer::id::type id;
440 uint_least8_t previous;
455 : timer_array(timer_array_)
456 , active_list(timer_array_)
458 , number_of_registered_timers(0U)
459 , 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 event_callback_type insert_callback;
666 event_callback_type remove_callback;
670 const uint_least8_t Max_Timers;