56 typedef etl::delegate<void(etl::timer::id::type)> event_callback_type;
65 etl::timer::id::type
id = etl::timer::id::NO_TIMER;
67 bool is_space = (number_of_registered_timers < Max_Timers);
72 for (uint_least8_t i = 0U; i < Max_Timers; ++i)
76 if (
timer.
id == etl::timer::id::NO_TIMER)
80 ++number_of_registered_timers;
97 if (id_ != etl::timer::id::NO_TIMER)
101 if (
timer.
id != etl::timer::id::NO_TIMER)
103 if (
timer.is_active())
106 active_list.remove(
timer.
id,
false);
107 remove_callback.call_if(
timer.
id);
113 --number_of_registered_timers;
147 for (uint8_t i = 0U; i < Max_Timers; ++i)
152 number_of_registered_timers = 0;
161 bool tick(uint32_t count)
165 if (process_semaphore == 0U)
168 bool has_active = !active_list.empty();
172 while (has_active && (count >= active_list.front().delta))
174 timer_data&
timer = active_list.front();
176 count -=
timer.delta;
178 active_list.remove(
timer.
id,
true);
179 remove_callback.call_if(
timer.
id);
181 if (
timer.callback.is_valid())
190 timer.delta = timer.period;
191 active_list.insert(timer.id);
192 insert_callback.call_if(timer.id);
195 has_active = !active_list.empty();
201 active_list.front().delta -= count;
215 bool start(etl::timer::id::type id_,
bool immediate_ =
false)
220 if (id_ != etl::timer::id::NO_TIMER)
225 if (
timer.
id != etl::timer::id::NO_TIMER)
228 if (
timer.period != etl::timer::state::Inactive)
231 if (
timer.is_active())
233 active_list.remove(
timer.
id,
false);
234 remove_callback.call_if(
timer.
id);
239 insert_callback.call_if(
timer.
id);
253 bool stop(etl::timer::id::type id_)
258 if (id_ != etl::timer::id::NO_TIMER)
263 if (
timer.
id != etl::timer::id::NO_TIMER)
265 if (
timer.is_active())
268 active_list.remove(
timer.
id,
false);
269 remove_callback.call_if(
timer.
id);
287 timer_array[id_].period = period_;
297 bool set_mode(etl::timer::id::type id_,
bool repeating_)
301 timer_array[id_].repeating = repeating_;
314 bool result = !active_list.empty();
326 uint32_t delta =
static_cast<uint32_t
>(etl::timer::interval::No_Active_Interval);
329 if (!active_list.empty())
331 delta = active_list.front().delta;
347 if (is_valid_timer_id(id_))
355 if (
timer.
id != etl::timer::id::NO_TIMER)
357 result =
timer.is_active();
371 insert_callback = insert_;
379 remove_callback = remove_;
383 void clear_insert_callback()
385 insert_callback.clear();
389 void clear_remove_callback()
391 remove_callback.clear();
404 , delta(etl::timer::state::Inactive)
405 , id(etl::timer::id::NO_TIMER)
406 , previous(etl::timer::id::NO_TIMER)
407 , next(etl::timer::id::NO_TIMER)
416 callback_type callback_,
419 : callback(callback_)
421 , delta(
etl::
timer::state::Inactive)
423 , previous(
etl::
timer::id::NO_TIMER)
425 , repeating(repeating_)
434 return delta != etl::timer::state::Inactive;
442 delta = etl::timer::state::Inactive;
448 etl::timer::id::type id;
449 uint_least8_t previous;
464 : timer_array(timer_array_)
465 , active_list(timer_array_)
467 , process_semaphore(0U)
468 , number_of_registered_timers(0U)
469 , Max_Timers(Max_Timers_)
478 bool is_valid_timer_id(etl::timer::id::type id_)
const
480 return (id_ < Max_Timers);
491 timer_list(timer_data* ptimers_)
492 : head(
etl::timer::id::NO_TIMER)
493 , tail(
etl::timer::id::NO_TIMER)
494 , current(
etl::timer::id::NO_TIMER)
502 return head == etl::timer::id::NO_TIMER;
508 void insert(etl::timer::id::type id_)
510 timer_data& timer = ptimers[id_];
512 if (head == etl::timer::id::NO_TIMER)
517 timer.previous = etl::timer::id::NO_TIMER;
518 timer.next = etl::timer::id::NO_TIMER;
523 etl::timer::id::type test_id = begin();
525 while (test_id != etl::timer::id::NO_TIMER)
527 timer_data& test = ptimers[test_id];
530 if (timer.delta <= test.delta)
538 timer.previous = test.previous;
539 test.previous = timer.id;
540 timer.next = test.id;
543 test.delta -= timer.delta;
545 if (timer.previous != etl::timer::id::NO_TIMER)
547 ptimers[timer.previous].next = timer.id;
553 timer.delta -= test.delta;
556 test_id = next(test_id);
560 if (test_id == etl::timer::id::NO_TIMER)
563 ptimers[tail].next = timer.id;
564 timer.previous = tail;
565 timer.next = etl::timer::id::NO_TIMER;
572 void remove(etl::timer::id::type id_,
bool has_expired)
574 timer_data& timer = ptimers[id_];
582 ptimers[timer.previous].next = timer.next;
587 tail = timer.previous;
591 ptimers[timer.next].previous = timer.previous;
597 if (timer.next != etl::timer::id::NO_TIMER)
599 ptimers[timer.next].delta += timer.delta;
603 timer.previous = etl::timer::id::NO_TIMER;
604 timer.next = etl::timer::id::NO_TIMER;
605 timer.delta = etl::timer::state::Inactive;
611 return ptimers[head];
615 const timer_data& front()
const
617 return ptimers[head];
621 etl::timer::id::type begin()
628 etl::timer::id::type previous(etl::timer::id::type last)
630 current = ptimers[last].previous;
635 etl::timer::id::type next(etl::timer::id::type last)
637 current = ptimers[last].next;
644 etl::timer::id::type
id = begin();
646 while (
id != etl::timer::id::NO_TIMER)
648 timer_data& timer = ptimers[id];
650 timer.next = etl::timer::id::NO_TIMER;
653 head = etl::timer::id::NO_TIMER;
654 tail = etl::timer::id::NO_TIMER;
655 current = etl::timer::id::NO_TIMER;
660 etl::timer::id::type head;
661 etl::timer::id::type tail;
662 etl::timer::id::type current;
664 timer_data*
const ptimers;
671 timer_list active_list;
674 mutable TSemaphore process_semaphore;
675 uint_least8_t number_of_registered_timers;
677 event_callback_type insert_callback;
678 event_callback_type remove_callback;
682 const uint_least8_t Max_Timers;