[Intel-gfx] [RFC 0/4] GPU/CPU timestamps correlation for relating OA samples with system events

Sagar Arun Kamble sagar.a.kamble at intel.com
Fri Dec 22 05:26:03 UTC 2017



On 12/22/2017 10:45 AM, Sagar Arun Kamble wrote:
>
>
>
> On 12/7/2017 1:32 AM, Lionel Landwerlin wrote:
>> I've put together some trival IGT tests : 
>> https://github.com/djdeath/intel-gpu-tools/commits/wip/djdeath/cpu-timestamps
>> With a few changes which I pointed in the review : 
>> https://github.com/djdeath/linux/commit/d0e4cf4d3f464491b4ffe97d112284d1ce73656d
>>
>> Put together it seems to work relatively well.
>> There is still a small drift happening between the 2 timestamps. I've 
>> noticed over a 160ms of OA reports, there is a accumulated difference 
>> of ~35us between the GPU timestamp and cpu timestamps.
>> I may be doing something wrong with the scaling in the tests, or 
>> maybe there is an issue in the kernel, or both.
> Went through the testcase. scaled_gpu_delta calculation is same as 
> what timecounter does in kernel for calculating system_time corresponding
> to gpu timestamp hence we don't see much of delta between these two 
> times/time deltas.
> Ideally we should be testing the system time delta by sampling system 
> time and gpu timestamp atomically (which isn't feasible unless we do 
> some precise adjustments)
> I have attempted to check these two times/delta by sampling them in 
> debugfs and reading over variable periods manually and checking the delta.
> https://github.com/sakamble/i915-timestamp-support/commit/03be3056752d7b05a02cd01f5c20b3fcfcf18395
>
> It is showing that delta is less than 10us in most cases for 30min and 
> occasionally around 20-30us. Again this delta might be because of 
> initial time setting as well.
> timecounter initializing system time and gpu clocks as pair should be 
> highly accurate for which I have currently taken 350us start offset.
>
> I think gpu timestamp clock is highly stable as seen in my testing on 
> SKL. I think this clock is used for calculations in GuC too so will
> be good to get confirmation about the stability of this clock from 
> them and HW team.
>
>    systemd-udevd-169   [001] ....     3.035812: i915_driver_load: sys 
> start time: 1512308011156099790
>
>    systemd-udevd-169   [001] d...     3.036012: 
> i915_cyclecounter_read: 52025098974
>
>              cat-1654  [001] ....    52.407957: 
> i915_cyclecounter_read: 52617562292
>
>              cat-1654  [001] ....    52.407958: i915_timestamp_info: 
> sys time: 1512308060527894638
>
>              cat-1654  [001] ....    52.407958: i915_timestamp_info: 
> ts: 52617562292 device time: 1512308060528043050
>
>              cat-1684  [001] ....   177.239733: 
> i915_cyclecounter_read: 54115543581
>
>              cat-1684  [001] ....   177.239736: i915_timestamp_info: 
> sys time: 1512308185359666602
>
>              cat-1684  [001] ....   177.239737: i915_timestamp_info: 
> ts: 54115543581 device time: 1512308185359817372
>
>              cat-1693  [001] ....   329.820374: 
> i915_cyclecounter_read: 55946511277
>
>              cat-1693  [001] ....   329.820377: i915_timestamp_info: 
> sys time: 1512308337940301732
>
>              cat-1693  [001] ....   329.820378: i915_timestamp_info: 
> ts: 55946511277 device time: 1512308337940458996
>
>
> <delta between system time delta and gpu time delta for above two 
> samples (177, 329) = 6494ns>
>
>
>              cat-1702  [001] ....   506.980313: 
> i915_cyclecounter_read: 58072430542
>
>              cat-1702  [001] ....   506.980315: i915_timestamp_info: 
> sys time: 1512308515100233102
>
>              cat-1702  [001] ....   506.980317: i915_timestamp_info: 
> ts: 58072430542 device time: 1512308515100398084
>
> <delta between system time delta and gpu time delta for above two 
> samples (329, 506) = 6494ns>
>
Fixing typo here:
<delta between system time delta and gpu time delta for above two 
samples (329, 506) = 7718ns>
>>
>> I'll build the GPUTop parts and see if the results make sense.
>>
>> Thanks!,
>>
>> -
>> Lionel
>>
>> On 15/11/17 12:13, Sagar Arun Kamble wrote:
>>> We can compute system time corresponding to GPU timestamp by taking a
>>> reference point (CPU monotonic time, GPU timestamp) and then adding
>>> delta time computed using timecounter/cyclecounter support in kernel.
>>> We have to configure cyclecounter with the GPU timestamp frequency.
>>> Earlier approach that was based on cross-timestamp is not needed. It
>>> was being used to approximate the frequency based on invalid 
>>> assumptions
>>> (possibly drift was being seen in the time due to precision issue).
>>> The precision of time from GPU clocks is already in ns and timecounter
>>> takes care of it as verified over variable durations.
>>>
>>> This series adds base timecounter/cyclecounter changes and changes to
>>> get GPU and CPU timestamps in OA samples.
>>>
>>> Sagar Arun Kamble (1):
>>>    drm/i915/perf: Add support to correlate GPU timestamp with system 
>>> time
>>>
>>> Sourab Gupta (3):
>>>    drm/i915/perf: Add support for collecting 64 bit timestamps with OA
>>>      reports
>>>    drm/i915/perf: Extract raw GPU timestamps from OA reports
>>>    drm/i915/perf: Send system clock monotonic time in perf samples
>>>
>>>   drivers/gpu/drm/i915/i915_drv.h  |  11 ++++
>>>   drivers/gpu/drm/i915/i915_perf.c | 124 
>>> ++++++++++++++++++++++++++++++++++++++-
>>>   drivers/gpu/drm/i915/i915_reg.h  |   6 ++
>>>   include/uapi/drm/i915_drm.h      |  14 +++++
>>>   4 files changed, 154 insertions(+), 1 deletion(-)
>>>
>>
>
>
>
> _______________________________________________
> Intel-gfx mailing list
> Intel-gfx at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/intel-gfx

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.freedesktop.org/archives/intel-gfx/attachments/20171222/e5d79f0c/attachment.html>


More information about the Intel-gfx mailing list