[Intel-wired-lan] [PATCH v4 1/4] Produce system time from correlated clocksource
Stanton, Kevin B
kevin.b.stanton at intel.com
Tue Nov 3 19:18:10 UTC 2015
On Wed, 21 Oct 2015, Thomas Gleixner wrote:
> On Tue, 20 Oct 2015, John Stultz wrote:
>> Being able to have various hardware sharing a time base is quite
>> useful, and methods for correlating timestamps together are useful.
>> But I don't yet really understand why its important that we can
>> translate a hardware timestamp from some time in the past to the
>> correct system time in the past without error.
>If your device can only provide timestamps from the past, then
>having access to the history is important if you want to have
I hope this can be solved in timekeeping. But first, a quick
The timestamp pair (including the ART snapshot, as described
previously) is captured simultaneously by the hardware
resulting, effectively, in a (PTP,TSC) pair, or
(AudioPosition,TSC) pair. The in-the-past-TSC value needs to be
converted to system time so that it can be used by applications,
without exposing the underlying ART or TSC.
Note: ART is architectural, defined as part of Invariant
Timekeeping in the current SDM, so this isn't a one-off
To convert a past TSC timestamp to system time 'correctly' (in a
mathematical sense), a history of monotonic rate adjustments
since that time in the past must be maintained.
Regarding the amount of history, as Chris mentioned (and
in the context of new Intel hardware) LAN timestamp pairs are
a few microseconds in the past (no history would be required),
but for timestamps captured by the audio DSP, unfortunately,
they can be a small number of *milliseconds* in the past by the
time they're available to the audio driver (some history
required to convert accurately). I'm told that 4ms of adjustment
history accommodates known hardware.
Getting this 'correct' in one place (timekeeping) seems a lot
better than unnecessarily introducing inaccuracy via software
sampling (and extrapolation) or leaving it to each driver to do
it themselves, and to do it differently (and/or do it wrongly).
More information about the Intel-wired-lan