drm/i915/display: Warn if the FBC is still writing to stolen on removal
authorChris Wilson <chris@chris-wilson.co.uk>
Sun, 3 May 2020 18:00:34 +0000 (19:00 +0100)
committerChris Wilson <chris@chris-wilson.co.uk>
Mon, 4 May 2020 16:11:51 +0000 (17:11 +0100)
If the FBC is still writing into stolen, it will overwrite any future
users of that stolen region. Check before release, just to ease any
concerns -- we can remove it again later if it is barking up the wrong
tree.

References: https://gitlab.freedesktop.org/drm/intel/-/issues/1635
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20200503180034.20010-1-chris@chris-wilson.co.uk
drivers/gpu/drm/i915/display/intel_fbc.c

index 7194f9bc62c537dd991c1681644137d8a22740e2..1c26673acb2dd8bd603c427a1eddae38b86761e6 100644 (file)
@@ -540,6 +540,9 @@ static void __intel_fbc_cleanup_cfb(struct drm_i915_private *dev_priv)
 {
        struct intel_fbc *fbc = &dev_priv->fbc;
 
+       if (WARN_ON(intel_fbc_hw_is_active(dev_priv)))
+               return;
+
        if (!drm_mm_node_allocated(&fbc->compressed_fb))
                return;