diff options
author | Kevin O'Connor <kevin@koconnor.net> | 2017-03-27 16:38:01 -0400 |
---|---|---|
committer | Kevin O'Connor <kevin@koconnor.net> | 2017-03-30 11:24:42 -0400 |
commit | 6d05dd07f59ef21dc81a299e865cdee1fc1d3f8e (patch) | |
tree | 5eb3eab42f4a7e0abe0c5b790cee9938a1f65564 /src/generic | |
parent | 7436ec093acc6f45e0fc2389de7294be43e3f0a8 (diff) | |
download | kutter-6d05dd07f59ef21dc81a299e865cdee1fc1d3f8e.tar.gz kutter-6d05dd07f59ef21dc81a299e865cdee1fc1d3f8e.tar.xz kutter-6d05dd07f59ef21dc81a299e865cdee1fc1d3f8e.zip |
sched: Move timer dispatch loop to board code
Rename sched_timer_kick() to sched_timer_dispatch() and move its loop
into its callers in the board code. This eliminates the need to
export timer_try_set_next() from the board code.
Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
Diffstat (limited to 'src/generic')
-rw-r--r-- | src/generic/misc.h | 1 | ||||
-rw-r--r-- | src/generic/timer.c | 16 |
2 files changed, 15 insertions, 2 deletions
diff --git a/src/generic/misc.h b/src/generic/misc.h index bc3223e7..e8a13c00 100644 --- a/src/generic/misc.h +++ b/src/generic/misc.h @@ -13,7 +13,6 @@ uint32_t timer_from_us(uint32_t us); uint8_t timer_is_before(uint32_t time1, uint32_t time2); uint32_t timer_read_time(void); void timer_periodic(void); -uint8_t timer_try_set_next(unsigned int next); size_t alloc_maxsize(size_t reqsize); diff --git a/src/generic/timer.c b/src/generic/timer.c index 5185ed54..fba56051 100644 --- a/src/generic/timer.c +++ b/src/generic/timer.c @@ -49,7 +49,7 @@ static uint32_t timer_repeat_until; // Set the next timer wake time (in absolute clock ticks) or return 1 // if the next timer is too close to schedule. Caller must disable // irqs. -uint8_t +static int timer_try_set_next(unsigned int next) { uint32_t now = timer_read_time(); @@ -84,6 +84,20 @@ fail: shutdown("Rescheduled timer in the past"); } +// Invoke timers - called from board irq code. +void +timer_dispatch_many(void) +{ + for (;;) { + uint32_t next_waketime = sched_timer_dispatch(); + + // Schedule next timer event (or run next timer if it's ready) + int res = timer_try_set_next(next_waketime); + if (res) + break; + } +} + // Periodic background task that temporarily boosts priority of // timers. This helps prioritize timers when tasks are idling. static void |