aboutsummaryrefslogtreecommitdiffstats
path: root/src/generic/timer.c
diff options
context:
space:
mode:
authorKevin O'Connor <kevin@koconnor.net>2017-03-27 16:38:01 -0400
committerKevin O'Connor <kevin@koconnor.net>2017-03-30 11:24:42 -0400
commit6d05dd07f59ef21dc81a299e865cdee1fc1d3f8e (patch)
tree5eb3eab42f4a7e0abe0c5b790cee9938a1f65564 /src/generic/timer.c
parent7436ec093acc6f45e0fc2389de7294be43e3f0a8 (diff)
downloadkutter-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/timer.c')
-rw-r--r--src/generic/timer.c16
1 files changed, 15 insertions, 1 deletions
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