[igt-dev] [PATCH i-g-t] i915/perf: Skip OA testing on systems too old

Chris Wilson chris at chris-wilson.co.uk
Mon Dec 16 11:02:51 UTC 2019


Quoting Lionel Landwerlin (2019-12-16 10:41:40)
> On 16/12/2019 12:27, Chris Wilson wrote:
> > Quoting Lionel Landwerlin (2019-12-16 10:06:53)
> >> On 16/12/2019 11:56, Chris Wilson wrote:
> >>
> >>      Quoting Lionel Landwerlin (2019-12-16 09:46:56)
> >>
> >>          On 16/12/2019 11:34, Chris Wilson wrote:
> >>
> >>              Don't flat out fail if the system doesn't support OA, just skip.
> >>
> >>              Closes: https://gitlab.freedesktop.org/drm/intel/issues/834
> >>              Signed-off-by: Chris Wilson <chris at chris-wilson.co.uk>
> >>              ---
> >>                tests/perf.c | 4 +---
> >>                1 file changed, 1 insertion(+), 3 deletions(-)
> >>
> >>              diff --git a/tests/perf.c b/tests/perf.c
> >>              index f5dd6051e..12f552743 100644
> >>              --- a/tests/perf.c
> >>              +++ b/tests/perf.c
> >>              @@ -884,11 +884,9 @@ init_sys_info(void)
> >>                    const char *test_set_uuid = NULL;
> >>                    char buf[256];
> >>
> >>              -     igt_assert_neq(devid, 0);
> >>              -
> >>                    timestamp_frequency = get_cs_timestamp_frequency();
> >>                    igt_debug("timestamp_frequency = %lu\n", timestamp_frequency);
> >>              -     igt_assert_neq(timestamp_frequency, 0);
> >>              +     igt_require(timestamp_frequency);
> >>
> >>
> >>          This requires a kernel version more recent (4.16) than when perf support
> >>          was added (4.13).
> >>
> >>          Is this what you intended?
> >>
> >>      You have a fatal assert there. I am just changing it so that it skips
> >>      when not supported as no testing is being performed.
> >>      -Chris
> >>
> >> I think there might be a problem in i915 if this returns 0.
> > It should return 0 for gen3 before Pineview.
> >
> > However, since it returns i915->rawclk_freq on pnv and g4x, it should
> > have a value except that i915->cs_timestamp_freq is set in
> > intel_device_info_runtime_init (i915_driver_hw_probe) before the
> > rawclk_freq is set (i915_driver_modeset_probe).
> >
> > Not sure the best approach to straighten out that mess... Just delaying
> > setting cs_timestamp_freq to i915_driver_register seems to be the best
> > idea.
> > -Chris
> 
> That's what I remember reading from old specs (cs timestamp = a factor 
> of rawclk).
> 
> So I was expecting to always get a value.
> 
> 
> Can we call intel_update_rawclk() in read_timestamp_frequency() just for 
> the <= gen4 case?

It's only defined for g4x & pnv and later. It doesn't cover earlier
gen4/gen3/gen2, so still we have 0.
-Chris


More information about the igt-dev mailing list