Hi,

On 2026-03-06 11:47:10 -0800, Lukas Fittl wrote:
> > But maybe we should just do the stupid thing and figure out the multiplier 
> > as
> > such:
> >
> >   ns_to_cycles = tsc_via_rdtsc / to_ns(clock_gettime(CLOCK_BOOTTIME))
> >
> > in some quick experiments that ends up with a very good estimate.  There 
> > would
> > have to be an awful long gap between the rdtsc and clock_gettime() 
> > computation
> > for the frequency to be meaningfully inaccurate.
> 
> I think as long as the TSC counter and the clock boottime start at the
> same moment, that should work. But I'm not sure if we can rely on that
> to be the case in virtualized environments? I can do some more
> testing.

I did some testing, and unfortunately it's not good enough. There are several
issues:

- The tsc counter starts earlier than the OS, by enough to make counter
  initially not quite right. It's not that bad on a laptop with a quick boot
  time, but on a server with slower bios time initialization (e.g. due to
  training of more memory) it's worse.

- If the server is rebooted not through a hard reset (the typical default),
  but through something like kexec (which does not go through bios again), the
  tsc counter is not reset.



> Alternatively, we could consider doing it like the Kernel does it for
> its calibration loop, and wait 1 second of wall time, and then see how
> far the TSC counter has advanced.

Yea, I think we need a calibration loop, unfortunately. But I think it should
be doable to make it a lot quicker than waiting one second.  I'm thinking of
something like a loop that measures the the clock cycles and relative time
(using clock_gettime()) since the start and does so until the frequency
estimate predicts the time results closely.  I think should be a few 10s of
milliseconds at most.


> FWIW, I ended up getting an x86 machine to be able to test these
> things better, and got myself an AMD CPU.

Dedication...


> Well, turns out that my
> non-virtualized AMD CPU ("AMD Ryzen™ AI Max+ 395") does not provide
> the TSC frequency via CPUID, at all :(

I can repro that on a somewhat older Zen 4 (7840U) laptop CPU.


> Instead on newer AMD CPUs you can use an MSR to get the TSC frequency,
> see [2]

:(

Greetings,

Andres Freund


Reply via email to