]> git.baikalelectronics.ru Git - kernel.git/commitdiff
drm/i915: Add Wa_1604278689:icl,ehl
authorMatt Roper <matthew.d.roper@intel.com>
Wed, 11 Mar 2020 16:22:57 +0000 (09:22 -0700)
committerMatt Roper <matthew.d.roper@intel.com>
Fri, 13 Mar 2020 16:01:44 +0000 (09:01 -0700)
The bspec description for this workaround tells us to program
0xFFFF_FFFF into both FBC_RT_BASE_ADDR_REGISTER_* registers, but we've
previously found that this leads to failures in CI.  Our suspicion is
that the failures are caused by this valid turning on the "address valid
bit" even though we're intentionally supplying an invalid address.
Experimentation has shown that setting all bits _except_ for the
RT_VALID bit seems to avoid these failures.

v2:
 - Mask off the RT_VALID bit.  Experimentation with CI trybot indicates
   that this is necessary to avoid reset failures on BCS.

v3:
 - Program RT_BASE before RT_BASE_UPPER so that the valid bit is turned
   off by the first write.  (Chris)

Bspec: 11388
Bspec: 33451
Signed-off-by: Matt Roper <matthew.d.roper@intel.com>
Cc: Chris Wilson <chris@chris-wilson.co.uk>
Link: https://patchwork.freedesktop.org/patch/msgid/20200311162300.1838847-4-matthew.d.roper@intel.com
Reviewed-by: José Roberto de Souza <jose.souza@intel.com>
drivers/gpu/drm/i915/gt/intel_workarounds.c
drivers/gpu/drm/i915/i915_reg.h

index 3e352e2a5b79fbf0ba91cb39e1626d4faf569d1c..3bbd892942798d6701d98199db3c1d71c1db8cf8 100644 (file)
@@ -575,6 +575,12 @@ static void icl_ctx_workarounds_init(struct intel_engine_cs *engine,
        /* allow headerless messages for preemptible GPGPU context */
        WA_SET_BIT_MASKED(GEN10_SAMPLER_MODE,
                          GEN11_SAMPLER_ENABLE_HEADLESS_MSG);
+
+       /* Wa_1604278689:icl,ehl */
+       wa_write(wal, IVB_FBC_RT_BASE, 0xFFFFFFFF & ~ILK_FBC_RT_VALID);
+       wa_write_masked_or(wal, IVB_FBC_RT_BASE_UPPER,
+                          0, /* write-only register; skip validation */
+                          0xFFFFFFFF);
 }
 
 static void tgl_ctx_workarounds_init(struct intel_engine_cs *engine,
index ee4a75ac9186d8ff18cddc913d83b603e3fb8bd9..b6b52b735120d1e0ba660ce1a9bbfdc28d868220 100644 (file)
@@ -3285,6 +3285,7 @@ static inline bool i915_mmio_reg_valid(i915_reg_t reg)
 
 /* Framebuffer compression for Ivybridge */
 #define IVB_FBC_RT_BASE                        _MMIO(0x7020)
+#define IVB_FBC_RT_BASE_UPPER          _MMIO(0x7024)
 
 #define IPS_CTL                _MMIO(0x43408)
 #define   IPS_ENABLE   (1 << 31)