aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChris Wilson <chris@chris-wilson.co.uk>2017-01-05 10:30:21 -0500
committerChris Wilson <chris@chris-wilson.co.uk>2017-01-05 10:34:42 -0500
commitf3b8f9126a9f3312636780fe83b923f3f63137fb (patch)
tree07355ec211c6ab312a90db556f5893656b890c50
parent56f6e0a7e7b09adb553339f9075696e918b96587 (diff)
drm/i915/execlists: Reorder execlists register enabling
Empirically we restart following a GPU reset more successfully if we call lrc_init_hws() (which contains a posting read) last. (The failure mode that was observed was that breadcrumb writes into the HWS from the recovered requests went astray leading to the context-switch maintaining forward progress, but the requests not being retired/completed.) For clarity, lrc_init_hws() is inlined (and the unused function then removed). Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Cc: Tvrtko Ursulin <tvrtko.ursulin@intel.com> Cc: Mika Kuoppala <mika.kuoppala@intel.com> Reviewed-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com> Link: http://patchwork.freedesktop.org/patch/msgid/20170105153023.30575-3-chris@chris-wilson.co.uk
-rw-r--r--drivers/gpu/drm/i915/intel_lrc.c18
1 files changed, 4 insertions, 14 deletions
diff --git a/drivers/gpu/drm/i915/intel_lrc.c b/drivers/gpu/drm/i915/intel_lrc.c
index 51ecb395551b..a9eefb171170 100644
--- a/drivers/gpu/drm/i915/intel_lrc.c
+++ b/drivers/gpu/drm/i915/intel_lrc.c
@@ -1335,15 +1335,6 @@ out:
1335 return ret; 1335 return ret;
1336} 1336}
1337 1337
1338static void lrc_init_hws(struct intel_engine_cs *engine)
1339{
1340 struct drm_i915_private *dev_priv = engine->i915;
1341
1342 I915_WRITE(RING_HWS_PGA(engine->mmio_base),
1343 engine->status_page.ggtt_offset);
1344 POSTING_READ(RING_HWS_PGA(engine->mmio_base));
1345}
1346
1347static int gen8_init_common_ring(struct intel_engine_cs *engine) 1338static int gen8_init_common_ring(struct intel_engine_cs *engine)
1348{ 1339{
1349 struct drm_i915_private *dev_priv = engine->i915; 1340 struct drm_i915_private *dev_priv = engine->i915;
@@ -1353,20 +1344,19 @@ static int gen8_init_common_ring(struct intel_engine_cs *engine)
1353 if (ret) 1344 if (ret)
1354 return ret; 1345 return ret;
1355 1346
1356 lrc_init_hws(engine);
1357
1358 intel_engine_reset_breadcrumbs(engine); 1347 intel_engine_reset_breadcrumbs(engine);
1348 intel_engine_init_hangcheck(engine);
1359 1349
1360 I915_WRITE(RING_HWSTAM(engine->mmio_base), 0xffffffff); 1350 I915_WRITE(RING_HWSTAM(engine->mmio_base), 0xffffffff);
1361
1362 I915_WRITE(RING_MODE_GEN7(engine), 1351 I915_WRITE(RING_MODE_GEN7(engine),
1363 _MASKED_BIT_DISABLE(GFX_REPLAY_MODE) | 1352 _MASKED_BIT_DISABLE(GFX_REPLAY_MODE) |
1364 _MASKED_BIT_ENABLE(GFX_RUN_LIST_ENABLE)); 1353 _MASKED_BIT_ENABLE(GFX_RUN_LIST_ENABLE));
1354 I915_WRITE(RING_HWS_PGA(engine->mmio_base),
1355 engine->status_page.ggtt_offset);
1356 POSTING_READ(RING_HWS_PGA(engine->mmio_base));
1365 1357
1366 DRM_DEBUG_DRIVER("Execlists enabled for %s\n", engine->name); 1358 DRM_DEBUG_DRIVER("Execlists enabled for %s\n", engine->name);
1367 1359
1368 intel_engine_init_hangcheck(engine);
1369
1370 /* After a GPU reset, we may have requests to replay */ 1360 /* After a GPU reset, we may have requests to replay */
1371 if (!execlists_elsp_idle(engine)) { 1361 if (!execlists_elsp_idle(engine)) {
1372 engine->execlist_port[0].count = 0; 1362 engine->execlist_port[0].count = 0;