[igt-dev] [PATCH v2 1/1] test/gem_create: limit set_pat to GEN12+ platforms

Andi Shyti andi.shyti at linux.intel.com
Tue Jun 6 17:44:15 UTC 2023


Hi Kamil,

> > > >  tests/i915/gem_create.c | 8 +++++++-
> > > >  1 file changed, 7 insertions(+), 1 deletion(-)
> > > > 
> > > > diff --git a/tests/i915/gem_create.c b/tests/i915/gem_create.c
> > > > index e9e8216d2b..a3428e5890 100644
> > > > --- a/tests/i915/gem_create.c
> > > > +++ b/tests/i915/gem_create.c
> > > > @@ -657,6 +657,7 @@ static void create_ext_set_pat(int fd)
> > > >  		.base = { .name = I915_GEM_CREATE_EXT_SET_PAT },
> > > >  		.pat_index = 65,
> > > >  	};
> > > > +	uint32_t devid = intel_get_drm_devid(fd);
> > > >  	struct drm_i915_gem_caching arg;
> > > >  	uint64_t size;
> > > >  	uint32_t handle;
> > > > @@ -670,8 +671,13 @@ static void create_ext_set_pat(int fd)
> > > >  	 * With a valid PAT index specified, returning -EINVAL here
> > > >  	 * indicates set_pat extension is not supported
> > > >  	 */
> > > > -	if (ret == -EINVAL)
> > > > +	if (!IS_METEORLAKE(devid)) {
> > 
> > Put here
> > 		if (ret == -EINVAL)
> > 			igt_skip("EXT_SET_PAT unsupported\n");
> > 
> > > > +		igt_assert(ret == -ENODEV);
> > -------------------------^ ------- ^
> > On unsupported or older driver this returns -22 (-EINVAL),
> > I tested on Skylake gen9 iGPU. Btw better use:
> 
> It's not merged yet. Once the patch will be merged then we will
> have -ENODEV.

In the kernel this will be:

+	/* Limiting the extension only to Meteor Lake */
+	if (!IS_METEORLAKE(i915))
+		return -ENODEV;

But it's not merged yet.

Andi

> -EINVAL comes from future old kernels that don't have this api
> merged.
> 
> Anyway, makes sense to check for -EINVAL first.
> 
> Thanks for the review, will send v3 soon.
> 
> Andi


More information about the igt-dev mailing list