Date: Mon, 11 Oct 2021 11:58:24 +0300 From: Konstantin Belousov <kostikbel@gmail.com> To: Sebastian Huber <sebastian.huber@embedded-brains.de> Cc: FreeBSD Hackers <freebsd-hackers@freebsd.org> Subject: Re: Large timecounter delta handling Message-ID: <YWP8sNfY0i4VNunS@kib.kiev.ua> In-Reply-To: <5318327d-d247-bb73-81d9-967c4ae18d32@embedded-brains.de> References: <5318327d-d247-bb73-81d9-967c4ae18d32@embedded-brains.de>
next in thread | previous in thread | raw e-mail | index | archive | help
On Mon, Oct 11, 2021 at 09:53:31AM +0200, Sebastian Huber wrote: > Hello, > > I synchronize currently the port of the FreeBSD timecounters to RTEMS. I > have to write test cases for all code we use in RTEMS. In 2020 some code was > added to fix integer overflow issues with large time deltas while getting > the time from a timehand. > > https://github.com/freebsd/freebsd-src/commit/6cf2362e2c7e9061611f93a48ec654a5b7451d6b#diff-8b8e2f8e41e6a847f14ab08c7d50454c20a4a135f2c2241d91687c0832c1d99e > > If a time delta obtained by tc_delta(th) is greater than or equal to > th->th_large_delta, then some extra calculation is carried out. > > The th->th_large_delta is computed like this > > scale = (uint64_t)1 << 63; > scale += (th->th_adjustment / 1024) * 2199; > scale /= th->th_counter->tc_frequency; > th->th_scale = scale * 2; > th->th_large_delta = MIN(((uint64_t)1 << 63) / scale, UINT_MAX); > > If we ignore the th->th_adjustment (== 0), then we have ideally > > scale = 2**64 / f > th->th_large_delta = MIN( f / 2, UINT_MAX ) > > Does this mean that we only need the large delta processing if a timehand > was not updated for about 0.5s? I do not understand your question. We need large_delta to handle overflows in bintime_off(). tc_large_delta is computed in advance during windup to avoid this calculation in time reading code. Your question is more like "under which conditions we switch to use tc_large_delta path in bintime_off()?" Then it is mostly right, that long intervals between tc_windup() calls would trigger it, and it seems that indeed it is around 0.5 sec. If you have a controlled environment, just skip some tc_windup() calls to see.
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?YWP8sNfY0i4VNunS>