Switch from simple iteration over all potential engines to using
macro __for_each_physical_engine which only returns engines that are
actually present.

For each context (as it is created) call gem_context_set_all_engines
so that execbuf will interpret the engine specification in the new way.

Signed-off-by: Dale B Stimson <[email protected]>
---
 tests/i915/gem_ctx_isolation.c | 41 ++++++++++++++++++++++++++--------
 1 file changed, 32 insertions(+), 9 deletions(-)

diff --git a/tests/i915/gem_ctx_isolation.c b/tests/i915/gem_ctx_isolation.c
index 25113b054..31a20ed3a 100644
--- a/tests/i915/gem_ctx_isolation.c
+++ b/tests/i915/gem_ctx_isolation.c
@@ -240,6 +240,25 @@ static bool ignore_register(uint32_t offset)
        return false;
 }
 
+/*
+ * context_create_plus_all_engines - Same as gem_context_create plus setup.
+ *
+ * This is a convenience function that may be called instead of the sequence
+ * of gem_context_create followed by gem_context_set_all_engines.
+ * If gem_has_engine_topology(), then function gem_context_set_all_engines
+ * indicates that future execbuf calls for this context should interpret the
+ * engine specification in a gem_engine_topology-compatible way.
+ */
+static uint32_t context_create_plus_all_engines(int fd)
+{
+       uint32_t ctx;
+
+       ctx = gem_context_create(fd);
+       gem_context_set_all_engines(fd, ctx);
+
+       return ctx;
+}
+
 static void tmpl_regs(int fd,
                      uint32_t ctx,
                      const struct intel_execution_engine2 *e,
@@ -586,7 +605,8 @@ static void nonpriv(int fd,
                igt_spin_t *spin = NULL;
                uint32_t ctx, regs[2], tmpl;
 
-               ctx = gem_context_create(fd);
+               ctx = context_create_plus_all_engines(fd);
+
                tmpl = read_regs(fd, ctx, e, flags);
                regs[0] = read_regs(fd, ctx, e, flags);
 
@@ -599,7 +619,7 @@ static void nonpriv(int fd,
                write_regs(fd, ctx, e, flags, values[v]);
 
                if (flags & DIRTY2) {
-                       uint32_t sw = gem_context_create(fd);
+                       uint32_t sw = context_create_plus_all_engines(fd);
                        igt_spin_t *syncpt, *dirt;
 
                        /* Explicit sync to keep the switch between write/read 
*/
@@ -668,7 +688,7 @@ static void isolation(int fd,
                igt_spin_t *spin = NULL;
                uint32_t ctx[2], regs[2], tmp;
 
-               ctx[0] = gem_context_create(fd);
+               ctx[0] = context_create_plus_all_engines(fd);
                regs[0] = read_regs(fd, ctx[0], e, flags);
 
                spin = igt_spin_new(fd, .ctx = ctx[0], .engine = e->flags);
@@ -687,7 +707,7 @@ static void isolation(int fd,
                 * the default values from this context, but if goes badly we
                 * see the corruption from the previous context instead!
                 */
-               ctx[1] = gem_context_create(fd);
+               ctx[1] = context_create_plus_all_engines(fd);
                regs[1] = read_regs(fd, ctx[1], e, flags);
 
                if (flags & DIRTY2) {
@@ -727,7 +747,7 @@ static void isolation(int fd,
 static void inject_reset_context(int fd, const struct intel_execution_engine2 
*e)
 {
        struct igt_spin_factory opts = {
-               .ctx = gem_context_create(fd),
+               .ctx = context_create_plus_all_engines(fd),
                .engine = e->flags,
                .flags = IGT_SPIN_FAST,
        };
@@ -775,11 +795,11 @@ static void preservation(int fd,
 
        gem_quiescent_gpu(fd);
 
-       ctx[num_values] = gem_context_create(fd);
+       ctx[num_values] = context_create_plus_all_engines(fd);
        spin = igt_spin_new(fd, .ctx = ctx[num_values], .engine = e->flags);
        regs[num_values][0] = read_regs(fd, ctx[num_values], e, flags);
        for (int v = 0; v < num_values; v++) {
-               ctx[v] = gem_context_create(fd);
+               ctx[v] = context_create_plus_all_engines(fd);
                write_regs(fd, ctx[v], e, flags, values[v]);
 
                regs[v][0] = read_regs(fd, ctx[v], e, flags);
@@ -854,6 +874,7 @@ static unsigned int __has_context_isolation(int fd)
 igt_main
 {
        unsigned int has_context_isolation = 0;
+       const struct intel_execution_engine2 *e;
        int fd = -1;
 
        igt_fixture {
@@ -871,10 +892,12 @@ igt_main
                igt_warn_on_f(gen > LAST_KNOWN_GEN,
                              "GEN not recognized! Test needs to be updated to 
run.\n");
                igt_skip_on(gen > LAST_KNOWN_GEN);
+
+               /* Context 0 is created on device open. */
+               gem_context_set_all_engines(fd, 0);
        }
 
-       for (const struct intel_execution_engine2 *e = intel_execution_engines2;
-            e->name; e++) {
+       __for_each_physical_engine(fd, e) {
                igt_subtest_group {
                        igt_fixture {
                                igt_require(has_context_isolation & (1 << 
e->class));
-- 
2.25.0

_______________________________________________
Intel-gfx mailing list
[email protected]
https://lists.freedesktop.org/mailman/listinfo/intel-gfx

Reply via email to