]> git.itanic.dy.fi Git - linux-stable/commitdiff
drm/i915/display: Add workaround 22014263786
authorJosé Roberto de Souza <jose.souza@intel.com>
Tue, 19 Apr 2022 18:27:52 +0000 (11:27 -0700)
committerJosé Roberto de Souza <jose.souza@intel.com>
Wed, 20 Apr 2022 16:39:31 +0000 (09:39 -0700)
This workaround fixes screen flickers with FBC.

BSpec: 33450
BSpec: 52890
BSpec: 54369
BSpec: 66624
Reviewed-by: Matt Roper <matthew.d.roper@intel.com>
Cc: Matt Roper <matthew.d.roper@intel.com>
Signed-off-by: José Roberto de Souza <jose.souza@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20220419182753.364237-1-jose.souza@intel.com
drivers/gpu/drm/i915/display/intel_fbc.c
drivers/gpu/drm/i915/i915_reg.h

index 670835318a1f12ab149ab8d01270907b7a4b6570..b7bdb0739744ad8a30198481a7fda814a367bea1 100644 (file)
@@ -811,6 +811,14 @@ static void intel_fbc_program_cfb(struct intel_fbc *fbc)
        fbc->funcs->program_cfb(fbc);
 }
 
+static void intel_fbc_program_workarounds(struct intel_fbc *fbc)
+{
+       /* Wa_22014263786:icl,jsl,tgl,dg1,rkl,adls,dg2,adlp */
+       if (DISPLAY_VER(fbc->i915) >= 11)
+               intel_de_rmw(fbc->i915, ILK_DPFC_CHICKEN(fbc->id), 0,
+                            DPFC_CHICKEN_FORCE_SLB_INVALIDATION);
+}
+
 static void __intel_fbc_cleanup_cfb(struct intel_fbc *fbc)
 {
        struct drm_i915_private *i915 = fbc->i915;
@@ -1462,6 +1470,7 @@ static void __intel_fbc_enable(struct intel_atomic_state *state,
 
        intel_fbc_update_state(state, crtc, plane);
 
+       intel_fbc_program_workarounds(fbc);
        intel_fbc_program_cfb(fbc);
 }
 
index 5f1f38684d6561bd5a8e1910a71b639a2bd25313..aa0062d07269150f20267032a3441ccf644dc193 100644 (file)
 #define   DPFC_HT_MODIFY                       REG_BIT(31) /* pre-ivb */
 #define   DPFC_NUKE_ON_ANY_MODIFICATION                REG_BIT(23) /* bdw+ */
 #define   DPFC_CHICKEN_COMP_DUMMY_PIXEL                REG_BIT(14) /* glk+ */
+#define   DPFC_CHICKEN_FORCE_SLB_INVALIDATION  REG_BIT(13) /* icl+ */
 #define   DPFC_DISABLE_DUMMY0                  REG_BIT(8) /* ivb+ */
 
 #define GLK_FBC_STRIDE(fbc_id) _MMIO_PIPE((fbc_id), 0x43228, 0x43268)