Jessica Yu 3c1500
From 6c76a93c453643e11a1063906c7c39168dd8d163 Mon Sep 17 00:00:00 2001
Jessica Yu 3c1500
From: Chris Wilson <chris@chris-wilson.co.uk>
Jessica Yu 3c1500
Date: Mon, 9 Sep 2019 12:00:08 +0100
Jessica Yu 3c1500
Subject: drm/i915: Perform GGTT restore much earlier during resume
Jessica Yu 3c1500
Git-commit: 6c76a93c453643e11a1063906c7c39168dd8d163
Jessica Yu 3c1500
Patch-mainline: v5.4-rc3
Jessica Yu 3c1500
References: bsc#1152489
Jessica Yu 3c1500
Jessica Yu 3c1500
As soon as we re-enable the various functions within the HW, they may go
Jessica Yu 3c1500
off and read data via a GGTT offset. Hence, if we have not yet restored
Jessica Yu 3c1500
the GGTT PTE before then, they may read and even *write* random locations
Jessica Yu 3c1500
in memory.
Jessica Yu 3c1500
Jessica Yu 3c1500
Detected by DMAR faults during resume.
Jessica Yu 3c1500
Jessica Yu 3c1500
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Jessica Yu 3c1500
Cc: Mika Kuoppala <mika.kuoppala@linux.intel.com>
Jessica Yu 3c1500
Cc: Martin Peres <martin.peres@linux.intel.com>
Jessica Yu 3c1500
Cc: Joonas Lahtinen <joonas.lahtinen@linux.intel.com>
Jessica Yu 3c1500
Cc: stable@vger.kernel.org
Jessica Yu 3c1500
Reviewed-by: Mika Kuoppala <mika.kuoppala@linux.intel.com>
Jessica Yu 3c1500
Link: https://patchwork.freedesktop.org/patch/msgid/20190909110011.8958-4-chris@chris-wilson.co.uk
Jessica Yu 3c1500
(cherry picked from commit cec5ca08e36fd18d2939b98055346b3b06f56c6c)
Jessica Yu 3c1500
Signed-off-by: Rodrigo Vivi <rodrigo.vivi@intel.com>
Jessica Yu 3c1500
Acked-by: Thomas Zimmermann <tzimmermann@suse.de>
Jessica Yu 3c1500
---
Jessica Yu 3c1500
 drivers/gpu/drm/i915/gem/i915_gem_pm.c    | 3 ---
Jessica Yu 3c1500
 drivers/gpu/drm/i915/i915_drv.c           | 5 +++++
Jessica Yu 3c1500
 drivers/gpu/drm/i915/selftests/i915_gem.c | 6 ++++++
Jessica Yu 3c1500
 3 files changed, 11 insertions(+), 3 deletions(-)
Jessica Yu 3c1500
Jessica Yu 3c1500
diff --git a/drivers/gpu/drm/i915/gem/i915_gem_pm.c b/drivers/gpu/drm/i915/gem/i915_gem_pm.c
Jessica Yu 3c1500
index 92e53c25424c..ad2a63dbcac2 100644
Jessica Yu 3c1500
--- a/drivers/gpu/drm/i915/gem/i915_gem_pm.c
Jessica Yu 3c1500
+++ b/drivers/gpu/drm/i915/gem/i915_gem_pm.c
Jessica Yu 3c1500
@@ -241,9 +241,6 @@ void i915_gem_resume(struct drm_i915_private *i915)
Jessica Yu 3c1500
 	mutex_lock(&i915->drm.struct_mutex);
Jessica Yu 3c1500
 	intel_uncore_forcewake_get(&i915->uncore, FORCEWAKE_ALL);
Jessica Yu 3c1500
 
Jessica Yu 3c1500
-	i915_gem_restore_gtt_mappings(i915);
Jessica Yu 3c1500
-	i915_gem_restore_fences(i915);
Jessica Yu 3c1500
-
Jessica Yu 3c1500
 	if (i915_gem_init_hw(i915))
Jessica Yu 3c1500
 		goto err_wedged;
Jessica Yu 3c1500
 
Jessica Yu 3c1500
diff --git a/drivers/gpu/drm/i915/i915_drv.c b/drivers/gpu/drm/i915/i915_drv.c
Jessica Yu 3c1500
index 020696726f9e..bb6f86c7067a 100644
Jessica Yu 3c1500
--- a/drivers/gpu/drm/i915/i915_drv.c
Jessica Yu 3c1500
+++ b/drivers/gpu/drm/i915/i915_drv.c
Jessica Yu 3c1500
@@ -1924,6 +1924,11 @@ static int i915_drm_resume(struct drm_device *dev)
Jessica Yu 3c1500
 	if (ret)
Jessica Yu 3c1500
 		DRM_ERROR("failed to re-enable GGTT\n");
Jessica Yu 3c1500
 
Jessica Yu 3c1500
+	mutex_lock(&dev_priv->drm.struct_mutex);
Jessica Yu 3c1500
+	i915_gem_restore_gtt_mappings(dev_priv);
Jessica Yu 3c1500
+	i915_gem_restore_fences(dev_priv);
Jessica Yu 3c1500
+	mutex_unlock(&dev_priv->drm.struct_mutex);
Jessica Yu 3c1500
+
Jessica Yu 3c1500
 	intel_csr_ucode_resume(dev_priv);
Jessica Yu 3c1500
 
Jessica Yu 3c1500
 	i915_restore_state(dev_priv);
Jessica Yu 3c1500
diff --git a/drivers/gpu/drm/i915/selftests/i915_gem.c b/drivers/gpu/drm/i915/selftests/i915_gem.c
Jessica Yu 3c1500
index bb6dd54a6ff3..37593831b539 100644
Jessica Yu 3c1500
--- a/drivers/gpu/drm/i915/selftests/i915_gem.c
Jessica Yu 3c1500
+++ b/drivers/gpu/drm/i915/selftests/i915_gem.c
Jessica Yu 3c1500
@@ -118,6 +118,12 @@ static void pm_resume(struct drm_i915_private *i915)
Jessica Yu 3c1500
 	with_intel_runtime_pm(&i915->runtime_pm, wakeref) {
Jessica Yu 3c1500
 		intel_gt_sanitize(&i915->gt, false);
Jessica Yu 3c1500
 		i915_gem_sanitize(i915);
Jessica Yu 3c1500
+
Jessica Yu 3c1500
+		mutex_lock(&i915->drm.struct_mutex);
Jessica Yu 3c1500
+		i915_gem_restore_gtt_mappings(i915);
Jessica Yu 3c1500
+		i915_gem_restore_fences(i915);
Jessica Yu 3c1500
+		mutex_unlock(&i915->drm.struct_mutex);
Jessica Yu 3c1500
+
Jessica Yu 3c1500
 		i915_gem_resume(i915);
Jessica Yu 3c1500
 	}
Jessica Yu 3c1500
 }
Jessica Yu 3c1500
-- 
Jessica Yu 3c1500
2.28.0
Jessica Yu 3c1500