summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJosé Roberto de Souza <jose.souza@intel.com>2022-06-29 16:47:21 +0300
committerJosé Roberto de Souza <jose.souza@intel.com>2022-06-30 16:55:30 +0300
commit87a7d5350c67aca513dc0a80f696d5583430d594 (patch)
tree54745a917976afe5d85b896c08a033c311096507
parent0f36d074aeb51a20508a65861d1518dbc231a1fc (diff)
downloadlinux-87a7d5350c67aca513dc0a80f696d5583430d594.tar.xz
drm/i915: Drain freed object after suspend display
Display is turned off by i915_drm_suspend() during the suspend procedure, removing the last reference of some gem objects that were used by display. The issue is that those objects are only actually freed when mm.free_work executed and that can happen very late in the suspend process causing issues. So here draining all freed objects released by display fixing suspend issues. Signed-off-by: José Roberto de Souza <jose.souza@intel.com> Reviewed-by: Matt Atwood <matthew.s.atwood@intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20220629134721.48375-1-jose.souza@intel.com
-rw-r--r--drivers/gpu/drm/i915/i915_driver.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/gpu/drm/i915/i915_driver.c b/drivers/gpu/drm/i915/i915_driver.c
index 2bd45e51d3b0..a67f20710978 100644
--- a/drivers/gpu/drm/i915/i915_driver.c
+++ b/drivers/gpu/drm/i915/i915_driver.c
@@ -1163,6 +1163,8 @@ static int i915_drm_suspend(struct drm_device *dev)
enable_rpm_wakeref_asserts(&dev_priv->runtime_pm);
+ i915_gem_drain_freed_objects(dev_priv);
+
return 0;
}