drm/i915: Print caller when tainting for CI
authorMichał Winiarski <michal.winiarski@intel.com>
Mon, 6 Jul 2020 14:41:06 +0000 (16:41 +0200)
committerChris Wilson <chris@chris-wilson.co.uk>
Mon, 6 Jul 2020 18:21:07 +0000 (19:21 +0100)
We can add taint from multiple places, printing the caller allows us to
have a better overview of what exactly caused us to do the tainting.

v2: Tweak format and print the device (Chris)
v3: Move things around (Chris)

Suggested-by: Michal Wajdeczko <michal.wajdeczko@intel.com>
Signed-off-by: Michał Winiarski <michal.winiarski@intel.com>
Cc: Chris Wilson <chris@chris-wilson.co.uk>
Cc: Michal Wajdeczko <michal.wajdeczko@intel.com>
Cc: Petri Latvala <petri.latvala@intel.com>
Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk>
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Link: https://patchwork.freedesktop.org/patch/msgid/20200706144107.204821-2-michal@hardline.pl
drivers/gpu/drm/i915/gt/intel_reset.c
drivers/gpu/drm/i915/gt/selftest_rc6.c
drivers/gpu/drm/i915/i915_gem.h
drivers/gpu/drm/i915/i915_utils.c
drivers/gpu/drm/i915/i915_utils.h
drivers/gpu/drm/i915/intel_uncore.c

index 6f94b6479a2f6b736e4436bae61c60bb9da2bbd4..121bf39a6f3e2aee32a6f8f44077f66fa3f086df 100644 (file)
@@ -930,7 +930,7 @@ static bool __intel_gt_unset_wedged(struct intel_gt *gt)
                 * Warn CI about the unrecoverable wedged condition.
                 * Time for a reboot.
                 */
-               add_taint_for_CI(TAINT_WARN);
+               add_taint_for_CI(gt->i915, TAINT_WARN);
                return false;
        }
 
@@ -1097,7 +1097,7 @@ taint:
         * rather than continue on into oblivion. For everyone else,
         * the system should still plod along, but they have been warned!
         */
-       add_taint_for_CI(TAINT_WARN);
+       add_taint_for_CI(gt->i915, TAINT_WARN);
 error:
        __intel_gt_set_wedged(gt);
        goto finish;
@@ -1362,7 +1362,7 @@ void intel_gt_set_wedged_on_init(struct intel_gt *gt)
        set_bit(I915_WEDGED_ON_INIT, &gt->reset.flags);
 
        /* Wedged on init is non-recoverable */
-       add_taint_for_CI(TAINT_WARN);
+       add_taint_for_CI(gt->i915, TAINT_WARN);
 }
 
 void intel_gt_set_wedged_on_fini(struct intel_gt *gt)
index 3c8434846fa15af6d3dac59bcf3164646352d474..64ef5ee5decf261c6c49076ff33be1dc58f5b2f8 100644 (file)
@@ -233,7 +233,7 @@ int live_rc6_ctx_wa(void *arg)
                            i915_reset_engine_count(error, engine)) {
                                pr_err("%s: GPU reset required\n",
                                       engine->name);
-                               add_taint_for_CI(TAINT_WARN);
+                               add_taint_for_CI(gt->i915, TAINT_WARN);
                                err = -EIO;
                                goto out;
                        }
index 1753c84d6c0d37ca65b5d8750d135bac5dc11595..f333e88a2b6ed531cbc2300beb134a5ed14168ac 100644 (file)
@@ -72,7 +72,7 @@ struct drm_i915_private;
        trace_printk(__VA_ARGS__);                                      \
 } while (0)
 #define GEM_TRACE_DUMP() \
-       do { ftrace_dump(DUMP_ALL); add_taint_for_CI(TAINT_WARN); } while (0)
+       do { ftrace_dump(DUMP_ALL); __add_taint_for_CI(TAINT_WARN); } while (0)
 #define GEM_TRACE_DUMP_ON(expr) \
        do { if (expr) GEM_TRACE_DUMP(); } while (0)
 #else
index f42a9e9a0b4fbac9525b6bdc990c93c771713a27..01a3d3c941bfe552fee4abebe12812ee6d09de42 100644 (file)
@@ -49,6 +49,13 @@ __i915_printk(struct drm_i915_private *dev_priv, const char *level,
        }
 }
 
+void add_taint_for_CI(struct drm_i915_private *i915, unsigned int taint)
+{
+       __i915_printk(i915, KERN_NOTICE, "CI tainted:%#x by %pS\n",
+                     taint, (void *)_RET_IP_);
+       __add_taint_for_CI(taint);
+}
+
 #if IS_ENABLED(CONFIG_DRM_I915_DEBUG)
 static unsigned int i915_probe_fail_count;
 
index 03a73d2bd50db3d8a393d1297f42fa4b41021d77..b1c5955a52e13650e3b857ebe1fe739edda0d5c3 100644 (file)
@@ -436,7 +436,8 @@ static inline const char *enableddisabled(bool v)
        return v ? "enabled" : "disabled";
 }
 
-static inline void add_taint_for_CI(unsigned int taint)
+void add_taint_for_CI(struct drm_i915_private *i915, unsigned int taint);
+static inline void __add_taint_for_CI(unsigned int taint)
 {
        /*
         * The system is "ok", just about surviving for the user, but
index 592364aed2da04b251eb72cc0ebf46228cadb156..8e2c073da1aa6b32df8e9a75848fd8726ac77a6f 100644 (file)
@@ -142,7 +142,7 @@ fw_domain_wait_ack_clear(const struct intel_uncore_forcewake_domain *d)
        if (wait_ack_clear(d, FORCEWAKE_KERNEL)) {
                DRM_ERROR("%s: timed out waiting for forcewake ack to clear.\n",
                          intel_uncore_forcewake_domain_to_str(d->id));
-               add_taint_for_CI(TAINT_WARN); /* CI now unreliable */
+               add_taint_for_CI(d->uncore->i915, TAINT_WARN); /* CI now unreliable */
        }
 }
 
@@ -219,7 +219,7 @@ fw_domain_wait_ack_set(const struct intel_uncore_forcewake_domain *d)
        if (wait_ack_set(d, FORCEWAKE_KERNEL)) {
                DRM_ERROR("%s: timed out waiting for forcewake ack request.\n",
                          intel_uncore_forcewake_domain_to_str(d->id));
-               add_taint_for_CI(TAINT_WARN); /* CI now unreliable */
+               add_taint_for_CI(d->uncore->i915, TAINT_WARN); /* CI now unreliable */
        }
 }