[igt-dev] [PATCH i-g-t] Avoid caching ioctl during fork
vikassri07
vikas.srivastava at intel.com
Wed Oct 19 08:31:23 UTC 2022
Both gem_exec_flush and gem_ctx_engines require the SET_CACHING ioctl
for some subtests. The ioctl itself, called by gem_set_caching, is
wrapped in an igt_require, forcing a skip when the ioctl fails. MTL
currently fails this check with -EOPNOTSUPP 100% of the time.
Normally, the ioctl failing and causing a test skip wouldn't be a
problem. Howerver, the failing call to the ioctl is made within a
forked child process in some cases, which causes an error to occur. By
checking whether or not caching is supported before these cases occur,
the resulting error can be downgraded to a graceful skip.
v2: The gem_ctx_engines subtest does not require using gem_set_caching
if the domain is moved from CPU to WC, so the ioctl was removed from
the execution path.
v3: Replace gem_mmap__cpu with gem_mmap__device_coherent instead of
gem_mmap__wc in gem_ctx_engines.c
v4: Fix formatting
References: VLK-34086
Signed-off-by: vikas.srivastava <vikas.srivastava at intel.com>
Signed-off-by: Jonathan Cavitt <jonathan.cavitt at intel.com>
Author: Jonathan Cavitt <jonathan.cavitt at intel.com>
Acked-by: Priyanka Dandamudi <priyanka.dandamudi at intel.com>
CC: Fei Yang <fei.yang at intel.com>
CC: Chris Wilson <chris.p.wilson at intel.com>
---
tests/i915/gem_ctx_engines.c | 11 ++++-------
1 file changed, 4 insertions(+), 7 deletions(-)
diff --git a/tests/i915/gem_ctx_engines.c b/tests/i915/gem_ctx_engines.c
index b0646516..e9cc25d6 100644
--- a/tests/i915/gem_ctx_engines.c
+++ b/tests/i915/gem_ctx_engines.c
@@ -492,12 +492,10 @@ static void independent(int i915, const intel_ctx_t *base_ctx,
}
param.ctx_id = gem_context_create(i915);
gem_context_set_param(i915, ¶m);
-
- if (!gem_has_lmem(i915))
- gem_set_caching(i915, results.handle, I915_CACHING_CACHED);
- map = gem_mmap__cpu(i915, results.handle, 0, 4096, PROT_READ);
+
+ map = gem_mmap__device_coherent(i915, results.handle, 0, 4096, PROT_READ);
gem_set_domain(i915, results.handle,
- I915_GEM_DOMAIN_CPU, I915_GEM_DOMAIN_CPU);
+ I915_GEM_DOMAIN_WC, I915_GEM_DOMAIN_WC);
for (int i = 0; i < I915_EXEC_RING_MASK + 1; i++) {
struct drm_i915_gem_exec_object2 obj[2] = {
@@ -515,8 +513,7 @@ static void independent(int i915, const intel_ctx_t *base_ctx,
uint32_t *cs;
int j = 0;
- cs = gem_mmap__cpu(i915, obj[1].handle, 0, 4096, PROT_WRITE);
-
+ cs = gem_mmap__device_coherent(i915, obj[1].handle, 0, 4096, PROT_WRITE);
cs[j] = 0x24 << 23 | 1; /* SRM */
if (has_64bit_reloc)
cs[j]++;
--
2.25.1
More information about the igt-dev
mailing list