Re: gettimeofday() resolution in Linux?

From: Jack Harvard
Date: Thu Apr 10 2008 - 11:59:29 EST


On Thu, Apr 10, 2008 at 4:04 PM, Lennart Sorensen
<lsorense@xxxxxxxxxxxxxxxxxxx> wrote:
> On Thu, Apr 10, 2008 at 03:40:59PM +0100, Jack Harvard wrote:
> > I would like to ask a few questions about how Linux keeps time.
> >
> > As far as I understand,
> > 1. Linux's time resolution is 10ms, as defined by HZ=100.
>
> The timer resolution, not the time resolution.
>

ahh...that's right, gettimeofday resolution can be 1/f_proc_clk, which
will certainly be finer than 1us for processors clocked at 1mhz or
above. thanks a lot...

>
> > 2. gettimeofday() can get time in microseconds, but I'm not sure about
> > the accuracy of the time finer than 10ms. Sometimes gettimeofday( )
> > can even give me microseconds results rolled backwards in time, which
> > I suspect could be caused by its accuracy. My question here is "how
> > accurate is the time from gettimeofday()"
>
> On many systems gettimeofday uses the TSC, but on many multicore systems
> the TSC on each core may be out of sync, in which case the cpu you are
> running on may give a different gettimeofday result than another cpu,
> which is probably a bad thing for some processes.
>
>

Perhaps X86 processors work like this - using the TSC for
gettimeofday, how about ARM processors? how can i determine how
reliable the results are from gettimeofday for arm? i.e., whether
they are of microsecond accuracy or otherwise...

Here is an example of gettimeofday results, the time rolls back
sometimes...first timestamp is start time...second timestamp is end
time
# # ./gettimeofday
timestamp (us): 215922277
timestamp (us): 215923120 (diff) 843
# # ./gettimeofday
timestamp (us): 216158623
timestamp (us): 216153181 (diff) -5442
# # ./gettimeofday
timestamp (us): 216430758
timestamp (us): 216423223 (diff) -7535
# # ./gettimeofday
timestamp (us): 216665947
timestamp (us): 216663171 (diff) -2776
# # ./gettimeofday
timestamp (us): 216944243
timestamp (us): 216943023 (diff) -1220

> > 3. If I want to increase the time resolution to 1ms, I can possibly
> > change HZ=1000, but if I want 1usec resolution, how can I do that? It
> > would be too busy for the processor to handle so frequent timer
> > interrupts if I just increase HZ=1000000.
>
> I don't think that would work well.
>
> --
> Len Sorensen
>
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/