]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
drm/i915/tgl: Extend Wa_1408615072 to tgl
authorMatt Roper <matthew.d.roper@intel.com>
Tue, 24 Dec 2019 01:20:26 +0000 (17:20 -0800)
committerMatt Roper <matthew.d.roper@intel.com>
Fri, 27 Dec 2019 18:46:39 +0000 (10:46 -0800)
Although the workaround number and description are the same, the vsunit
clock gate disable bit has moved to a new register and location on
gen12.

Bspec: 52890
Bspec: 52758
Cc: stable@kernel.vger.org
Cc: Lucas De Marchi <lucas.demarchi@intel.com>
Cc: Radhakrishna Sripada <radhakrishna.sripada@intel.com>
Signed-off-by: Matt Roper <matthew.d.roper@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20191224012026.3157766-4-matthew.d.roper@intel.com
Reviewed-by: Lucas De Marchi <lucas.demarchi@intel.com>
drivers/gpu/drm/i915/i915_reg.h
drivers/gpu/drm/i915/intel_pm.c

index 968a43f7cd98ff4f2982726c71889b9cb0fb2a84..030a3f3e69afe8d8c4693aca2017ca6303a175f1 100644 (file)
@@ -4181,6 +4181,9 @@ enum {
 #define   HSUNIT_CLKGATE_DIS           REG_BIT(8)
 #define   VSUNIT_CLKGATE_DIS           REG_BIT(3)
 
+#define UNSLICE_UNIT_LEVEL_CLKGATE2    _MMIO(0x94e4)
+#define   VSUNIT_CLKGATE_DIS_TGL       REG_BIT(19)
+
 #define INF_UNIT_LEVEL_CLKGATE         _MMIO(0x9560)
 #define   CGPSF_CLKGATE_DIS            (1 << 3)
 
index cbd83ece73063dee1f7225b1c0db7ead6cfb6b3b..58db5a7d27ecabd175e4afa8b025a2dd0291ffe2 100644 (file)
@@ -6605,6 +6605,10 @@ static void tgl_init_clock_gating(struct drm_i915_private *dev_priv)
        u32 vd_pg_enable = 0;
        unsigned int i;
 
+       /* Wa_1408615072:tgl */
+       intel_uncore_rmw(&dev_priv->uncore, UNSLICE_UNIT_LEVEL_CLKGATE2,
+                        0, VSUNIT_CLKGATE_DIS_TGL);
+
        /* This is not a WA. Enable VD HCP & MFX_ENC powergate */
        for (i = 0; i < I915_MAX_VCS; i++) {
                if (HAS_ENGINE(dev_priv, _VCS(i)))