Re: [PATCH v4 1/4] Produce system time from correlated clocksource

From: Christopher Hall
Date: Mon Oct 19 2015 - 20:18:45 EST


Thomas,

On Thu, 15 Oct 2015 01:15:57 -0700, Thomas Gleixner <tglx@xxxxxxxxxxxxx> wrote:
>
> > +#define SHADOW_HISTORY_DEPTH 7
>
> And that number is 7 because?

Due to power of 2 it will be 8 instead. As above the useful history is 8-2*1
ms (1 ms is the minimum jiffy length). Array size 4 would not be enough
history for the DSP which requires 4 ms of history, in the worst case.

And how exactly becomes 7 magically 8?

I'm making the array size a power of two, per your suggestion.

In my view, the candidate array sizes are 4 and 8. But the DSP driver code requires that it be at least 8. Here is my reasoning:

The number of shadow_timekeeper array elements that contain useful history is n-2 where n is the size of the shadow_timekeeper array. This is true because shadow_timekeeper[shadow_index] is a copy of tk_core.timekeeper (this isn't history). The next entry of the shadow_timekeeper array may be in-flight and contain invalid information, because update_wall_time() makes changes to the next entry of shadow timekeeper outside of the sequence lock. If that occurs, get_correlated_timestamp() would not be notified of this change through a change in sequence number.

Combining these two requirements, the candidate array sizes and their effective history sizes is:

Array Size Effective History (in elements)
========== ===============================
4 2
8 6
16 14

update_wall_clock() checks that the number of elapsed cycles is >= tk->cycle_interval before performing any updates to shadow_timekeeper. The minimum cycle count (and minimum time) that is contained in each history element is equal to cycle_interval which represents a time period of 1/HZ seconds. The smallest configurable period for cycle_interval is 1 ms (in cycles). Each history element, therefore, is guaranteed to contain 1 ms of history for all kernel configurations. For correct operation of the DSP using the proposed ART->system time API we need at least 4 ms of history. To guarantee this much history is available, the array size needs to be 8.

Array Size Minimum Effective History (in ms)
========== =================================
4 2
8 6 <----
16 14

Does this make sense for the choice of array size 8?

Make it a seperate function which can hand in the information and
leave the PTP specific sample/conversion function alone.

OK. The audio driver code will conform to the original correlated clocksource API.

FYI, I will be away from work and email until 10/28. Any responses will be delayed until then.

Thanks,
Chris
--
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/