drm/i915/gt: Include reset failures in the trace
The GT and engine reset failures are completely invisible when looking at a trace for a bug, but are vital to understanding the incomplete flow. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Reviewed-by: Mika Kuoppala <mika.kuoppala@linux.intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20201204151234.19729-3-chris@chris-wilson.co.uk
This commit is contained in:
parent
d997e240ce
commit
cb56a07d2f
@ -231,7 +231,7 @@ static int g4x_do_reset(struct intel_gt *gt,
|
|||||||
GRDOM_MEDIA | GRDOM_RESET_ENABLE);
|
GRDOM_MEDIA | GRDOM_RESET_ENABLE);
|
||||||
ret = wait_for_atomic(g4x_reset_complete(pdev), 50);
|
ret = wait_for_atomic(g4x_reset_complete(pdev), 50);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
drm_dbg(>->i915->drm, "Wait for media reset failed\n");
|
GT_TRACE(gt, "Wait for media reset failed\n");
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -239,7 +239,7 @@ static int g4x_do_reset(struct intel_gt *gt,
|
|||||||
GRDOM_RENDER | GRDOM_RESET_ENABLE);
|
GRDOM_RENDER | GRDOM_RESET_ENABLE);
|
||||||
ret = wait_for_atomic(g4x_reset_complete(pdev), 50);
|
ret = wait_for_atomic(g4x_reset_complete(pdev), 50);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
drm_dbg(>->i915->drm, "Wait for render reset failed\n");
|
GT_TRACE(gt, "Wait for render reset failed\n");
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -265,7 +265,7 @@ static int ilk_do_reset(struct intel_gt *gt, intel_engine_mask_t engine_mask,
|
|||||||
5000, 0,
|
5000, 0,
|
||||||
NULL);
|
NULL);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
drm_dbg(>->i915->drm, "Wait for render reset failed\n");
|
GT_TRACE(gt, "Wait for render reset failed\n");
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -276,7 +276,7 @@ static int ilk_do_reset(struct intel_gt *gt, intel_engine_mask_t engine_mask,
|
|||||||
5000, 0,
|
5000, 0,
|
||||||
NULL);
|
NULL);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
drm_dbg(>->i915->drm, "Wait for media reset failed\n");
|
GT_TRACE(gt, "Wait for media reset failed\n");
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -305,9 +305,9 @@ static int gen6_hw_domain_reset(struct intel_gt *gt, u32 hw_domain_mask)
|
|||||||
500, 0,
|
500, 0,
|
||||||
NULL);
|
NULL);
|
||||||
if (err)
|
if (err)
|
||||||
drm_dbg(>->i915->drm,
|
GT_TRACE(gt,
|
||||||
"Wait for 0x%08x engines reset failed\n",
|
"Wait for 0x%08x engines reset failed\n",
|
||||||
hw_domain_mask);
|
hw_domain_mask);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
@ -407,8 +407,7 @@ static int gen11_lock_sfc(struct intel_engine_cs *engine, u32 *hw_mask)
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (ret) {
|
if (ret) {
|
||||||
drm_dbg(&engine->i915->drm,
|
ENGINE_TRACE(engine, "Wait for SFC forced lock ack failed\n");
|
||||||
"Wait for SFC forced lock ack failed\n");
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1148,8 +1147,7 @@ int intel_engine_reset(struct intel_engine_cs *engine, const char *msg)
|
|||||||
ret = intel_guc_reset_engine(&engine->gt->uc.guc, engine);
|
ret = intel_guc_reset_engine(&engine->gt->uc.guc, engine);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
/* If we fail here, we expect to fallback to a global reset */
|
/* If we fail here, we expect to fallback to a global reset */
|
||||||
drm_dbg(>->i915->drm, "%sFailed to reset %s, ret=%d\n",
|
ENGINE_TRACE(engine, "Failed to reset, err: %d\n", ret);
|
||||||
uses_guc ? "GuC " : "", engine->name, ret);
|
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1186,7 +1184,7 @@ static void intel_gt_reset_global(struct intel_gt *gt,
|
|||||||
|
|
||||||
kobject_uevent_env(kobj, KOBJ_CHANGE, error_event);
|
kobject_uevent_env(kobj, KOBJ_CHANGE, error_event);
|
||||||
|
|
||||||
drm_dbg(>->i915->drm, "resetting chip, engines=%x\n", engine_mask);
|
GT_TRACE(gt, "resetting chip, engines=%x\n", engine_mask);
|
||||||
kobject_uevent_env(kobj, KOBJ_CHANGE, reset_event);
|
kobject_uevent_env(kobj, KOBJ_CHANGE, reset_event);
|
||||||
|
|
||||||
/* Use a watchdog to ensure that our reset completes */
|
/* Use a watchdog to ensure that our reset completes */
|
||||||
|
Loading…
Reference in New Issue
Block a user