drm/i915: Update workarounds selftest for read only regs
authorRobert M. Fosha <robert.m.fosha@intel.com>
Tue, 18 Jun 2019 01:01:08 +0000 (18:01 -0700)
committerTvrtko Ursulin <tvrtko.ursulin@intel.com>
Tue, 18 Jun 2019 16:29:56 +0000 (17:29 +0100)
Updates the live_workarounds selftest to handle whitelisted
registers that are flagged as read only.

Signed-off-by: Robert M. Fosha <robert.m.fosha@intel.com>
Signed-off-by: John Harrison <John.C.Harrison@Intel.com>
Reviewed-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20190618010108.27499-5-John.C.Harrison@Intel.com
drivers/gpu/drm/i915/gt/selftest_workarounds.c

index 91449d5157f61ee971ca908287072d799ac01f0c..5f2011f3a4a4683cb2bf8924a4c30be1f71f5722 100644 (file)
@@ -402,6 +402,29 @@ static bool wo_register(struct intel_engine_cs *engine, u32 reg)
        return false;
 }
 
+static bool ro_register(u32 reg)
+{
+       if (reg & RING_FORCE_TO_NONPRIV_RD)
+               return true;
+
+       return false;
+}
+
+static int whitelist_writable_count(struct intel_engine_cs *engine)
+{
+       int count = engine->whitelist.count;
+       int i;
+
+       for (i = 0; i < engine->whitelist.count; i++) {
+               u32 reg = i915_mmio_reg_offset(engine->whitelist.list[i].reg);
+
+               if (ro_register(reg))
+                       count--;
+       }
+
+       return count;
+}
+
 static int check_dirty_whitelist(struct i915_gem_context *ctx,
                                 struct intel_engine_cs *engine)
 {
@@ -457,6 +480,9 @@ static int check_dirty_whitelist(struct i915_gem_context *ctx,
                if (wo_register(engine, reg))
                        continue;
 
+               if (ro_register(reg))
+                       continue;
+
                srm = MI_STORE_REGISTER_MEM;
                lrm = MI_LOAD_REGISTER_MEM;
                if (INTEL_GEN(ctx->i915) >= 8)
@@ -728,9 +754,13 @@ static int read_whitelisted_registers(struct i915_gem_context *ctx,
 
        for (i = 0; i < engine->whitelist.count; i++) {
                u64 offset = results->node.start + sizeof(u32) * i;
+               u32 reg = i915_mmio_reg_offset(engine->whitelist.list[i].reg);
+
+               /* Clear RD only and WR only flags */
+               reg &= ~(RING_FORCE_TO_NONPRIV_RD | RING_FORCE_TO_NONPRIV_WR);
 
                *cs++ = srm;
-               *cs++ = i915_mmio_reg_offset(engine->whitelist.list[i].reg);
+               *cs++ = reg;
                *cs++ = lower_32_bits(offset);
                *cs++ = upper_32_bits(offset);
        }
@@ -763,9 +793,14 @@ static int scrub_whitelisted_registers(struct i915_gem_context *ctx,
                goto err_batch;
        }
 
-       *cs++ = MI_LOAD_REGISTER_IMM(engine->whitelist.count);
+       *cs++ = MI_LOAD_REGISTER_IMM(whitelist_writable_count(engine));
        for (i = 0; i < engine->whitelist.count; i++) {
-               *cs++ = i915_mmio_reg_offset(engine->whitelist.list[i].reg);
+               u32 reg = i915_mmio_reg_offset(engine->whitelist.list[i].reg);
+
+               if (ro_register(reg))
+                       continue;
+
+               *cs++ = reg;
                *cs++ = 0xffffffff;
        }
        *cs++ = MI_BATCH_BUFFER_END;
@@ -950,7 +985,7 @@ static int live_isolated_whitelist(void *arg)
        }
 
        for_each_engine(engine, i915, id) {
-               if (!engine->whitelist.count)
+               if (!whitelist_writable_count(engine))
                        continue;
 
                /* Read default values */