[PATCH 6/6] eng wa verify
Tvrtko Ursulin
tvrtko.ursulin at linux.intel.com
Wed Nov 28 09:10:34 UTC 2018
From: Tvrtko Ursulin <tvrtko.ursulin at intel.com>
Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin at intel.com>
---
drivers/gpu/drm/i915/i915_drv.c | 1 +
drivers/gpu/drm/i915/i915_gem.c | 3 +++
drivers/gpu/drm/i915/intel_workarounds.c | 31 ++++++++++++++++++++++++
drivers/gpu/drm/i915/intel_workarounds.h | 2 ++
4 files changed, 37 insertions(+)
diff --git a/drivers/gpu/drm/i915/i915_drv.c b/drivers/gpu/drm/i915/i915_drv.c
index 3bd08c5c3869..ac687fa124a4 100644
--- a/drivers/gpu/drm/i915/i915_drv.c
+++ b/drivers/gpu/drm/i915/i915_drv.c
@@ -2382,6 +2382,7 @@ int i915_reset_engine(struct intel_engine_cs *engine, const char *msg)
i915_gem_reset_finish_engine(engine);
intel_gt_workarounds_verify(engine->i915, engine->name);
+ i915_engine_workarounds_verify(engine, "reset");
return ret;
}
diff --git a/drivers/gpu/drm/i915/i915_gem.c b/drivers/gpu/drm/i915/i915_gem.c
index 5e9eaaa652c6..edc9550faef4 100644
--- a/drivers/gpu/drm/i915/i915_gem.c
+++ b/drivers/gpu/drm/i915/i915_gem.c
@@ -169,6 +169,9 @@ static u32 __i915_gem_park(struct drm_i915_private *i915)
i915_pmu_gt_parked(i915);
i915_vma_parked(i915);
+ intel_gt_workarounds_verify(i915, "idle");
+ i915_engine_workarounds_verify(i915->engine[RCS], "idle");
+
i915->gt.awake = false;
if (INTEL_GEN(i915) >= 6)
diff --git a/drivers/gpu/drm/i915/intel_workarounds.c b/drivers/gpu/drm/i915/intel_workarounds.c
index 0d3c582f8eea..a23324948916 100644
--- a/drivers/gpu/drm/i915/intel_workarounds.c
+++ b/drivers/gpu/drm/i915/intel_workarounds.c
@@ -1331,6 +1331,37 @@ printk(">wa_%s: type=%u reg=%x mask=%x val=%x ---> %x\n",
engine->wa_engine.count, engine->name);
}
+void i915_engine_workarounds_verify(struct intel_engine_cs *engine,
+ const char *from)
+{
+ struct drm_i915_private *dev_priv = engine->i915;
+ struct i915_engine_wa *reg;
+ unsigned int i;
+
+ if (!engine->wa_engine.count)
+ return;
+
+ for (i = 0, reg = engine->wa_engine.regs;
+ i < engine->wa_engine.count;
+ i++, reg++) {
+ u32 val = I915_READ(reg->reg);
+
+ switch (reg->type) {
+ case I915_WA_MASKED:
+ wa_verify_bits(reg->reg, val, 0xffff, reg->val,
+ from, __func__, false);
+ break;
+ case I915_WA_MASK_AND_OR:
+ wa_verify_bits(reg->reg, val, reg->mask, reg->val,
+ from, __func__,
+ reg->mask ? true : false);
+ break;
+ default:
+ MISSING_CASE(reg->type);
+ };
+ }
+}
+
#if IS_ENABLED(CONFIG_DRM_I915_SELFTEST)
#include "selftests/intel_workarounds.c"
#endif
diff --git a/drivers/gpu/drm/i915/intel_workarounds.h b/drivers/gpu/drm/i915/intel_workarounds.h
index 19e1d5422c6e..95ebb4f1863f 100644
--- a/drivers/gpu/drm/i915/intel_workarounds.h
+++ b/drivers/gpu/drm/i915/intel_workarounds.h
@@ -36,5 +36,7 @@ void intel_whitelist_workarounds_apply(struct intel_engine_cs *engine);
void i915_engine_workarounds_init(struct intel_engine_cs *engine);
void i915_engine_workarounds_apply(struct intel_engine_cs *engine);
+void i915_engine_workarounds_verify(struct intel_engine_cs *engine,
+ const char *from);
#endif
--
2.19.1
More information about the Intel-gfx-trybot
mailing list