From c7da76627c4c5479ed91bd6709e17abc22691b84 Mon Sep 17 00:00:00 2001 From: gdisirio Date: Mon, 1 Dec 2014 10:29:36 +0000 Subject: git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@7551 35acf78f-673a-0410-8e92-d51de3d6d3f4 --- os/rt/include/chvt.h | 24 +++++++++++++++++++----- os/rt/src/chvt.c | 11 ++++++++--- 2 files changed, 27 insertions(+), 8 deletions(-) (limited to 'os') diff --git a/os/rt/include/chvt.h b/os/rt/include/chvt.h index 9538474c9..1d7c8c545 100644 --- a/os/rt/include/chvt.h +++ b/os/rt/include/chvt.h @@ -464,11 +464,21 @@ static inline void chVTDoTickI(void) { } #else /* CH_CFG_ST_TIMEDELTA > 0 */ virtual_timer_t *vtp; - systime_t now = chVTGetSystemTimeX(); - systime_t delta = now - ch.vtlist.vt_lasttime; + systime_t now; - while ((vtp = ch.vtlist.vt_next)->vt_delta <= delta) { + while (true) { vtfunc_t fn; + systime_t delta; + + /* Getting the current system time and calculating the time window since + the last time has expired.*/ + now = chVTGetSystemTimeX(); + delta = now - ch.vtlist.vt_lasttime; + + /* The next element is outside the current time window, the loop + is stopped here.*/ + if ((vtp = ch.vtlist.vt_next)->vt_delta > delta) + break; /* The "last time" becomes this timer's expiration time.*/ delta -= vtp->vt_delta; @@ -491,8 +501,12 @@ static inline void chVTDoTickI(void) { port_timer_stop_alarm(); } else { - /* Updating the alarm to the next deadline.*/ - port_timer_set_alarm(now + vtp->vt_delta); + /* Updating the alarm to the next deadline, deadline that must not be + closer in time than the minimum time delta.*/ + if (vtp->vt_delta >= CH_CFG_ST_TIMEDELTA) + port_timer_set_alarm(now + vtp->vt_delta); + else + port_timer_set_alarm(now + CH_CFG_ST_TIMEDELTA); } #endif /* CH_CFG_ST_TIMEDELTA > 0 */ } diff --git a/os/rt/src/chvt.c b/os/rt/src/chvt.c index 4fd154e57..de33e7b9c 100644 --- a/os/rt/src/chvt.c +++ b/os/rt/src/chvt.c @@ -180,9 +180,14 @@ void chVTDoResetI(virtual_timer_t *vtp) { port_timer_stop_alarm(); } else { - /* The alarm is set to the next element in the delta list.*/ - port_timer_set_alarm(ch.vtlist.vt_lasttime + - ch.vtlist.vt_next->vt_delta); + /* Updating the alarm to the next deadline, deadline that must not be + closer in time than the minimum time delta.*/ + if (ch.vtlist.vt_next->vt_delta >= CH_CFG_ST_TIMEDELTA) + port_timer_set_alarm(ch.vtlist.vt_lasttime + + ch.vtlist.vt_next->vt_delta); + else + port_timer_set_alarm(ch.vtlist.vt_lasttime + + CH_CFG_ST_TIMEDELTA); } } #endif /* CH_CFG_ST_TIMEDELTA > 0 */ -- cgit v1.2.3