]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
drm/i915/fbc: fix the implementation of wa_18038517565
authorVinod Govindapillai <vinod.govindapillai@intel.com>
Tue, 29 Jul 2025 12:46:48 +0000 (15:46 +0300)
committerTvrtko Ursulin <tursulin@ursulin.net>
Tue, 12 Aug 2025 08:05:07 +0000 (09:05 +0100)
As per the wa_18038517565, we need to disable FBC compressor
clock gating before enabling FBC and enable after disabling
FBC. Placing the enabling of clock gating in the fbc deactivate
function can make the above wa logic go wrong in case of
frontbuffer rendering FBC mechanism. FBC deactivate can get
called during fb invalidate and then the corresponding FBC
activate can get called without properly disabling the clock
gating and can result in compression stalled. So move the
enable clock gating at the end of one FBC session after FBC
is completely disabled for a pipe.

Bspec: 74212, 72197, 69741, 65555
Fixes: 010363c46189 ("drm/i915/display: implement wa_18038517565")
Signed-off-by: Vinod Govindapillai <vinod.govindapillai@intel.com>
Reviewed-by: Jouni Högander <jouni.hogander@intel.com>
Link: https://lore.kernel.org/r/20250729124648.288497-1-vinod.govindapillai@intel.com
(cherry picked from commit 82dde0407ab126f8413fd6c51429e5057ced5ba2)
Signed-off-by: Tvrtko Ursulin <tursulin@ursulin.net>
drivers/gpu/drm/i915/display/intel_fbc.c

index 6e26cb4c57243ec3d384b35f9aa4a901356e4228..685ac98bd001a79fd52ec02ceedee399505b1389 100644 (file)
@@ -552,10 +552,6 @@ static void ilk_fbc_deactivate(struct intel_fbc *fbc)
        if (dpfc_ctl & DPFC_CTL_EN) {
                dpfc_ctl &= ~DPFC_CTL_EN;
                intel_de_write(display, ILK_DPFC_CONTROL(fbc->id), dpfc_ctl);
-
-               /* wa_18038517565 Enable DPFC clock gating after FBC disable */
-               if (display->platform.dg2 || DISPLAY_VER(display) >= 14)
-                       fbc_compressor_clkgate_disable_wa(fbc, false);
        }
 }
 
@@ -1710,6 +1706,10 @@ static void __intel_fbc_disable(struct intel_fbc *fbc)
 
        __intel_fbc_cleanup_cfb(fbc);
 
+       /* wa_18038517565 Enable DPFC clock gating after FBC disable */
+       if (display->platform.dg2 || DISPLAY_VER(display) >= 14)
+               fbc_compressor_clkgate_disable_wa(fbc, false);
+
        fbc->state.plane = NULL;
        fbc->flip_pending = false;
        fbc->busy_bits = 0;