]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
drm/etnaviv: fix flush sequence logic
authorTomeu Vizoso <tomeu@tomeuvizoso.net>
Tue, 21 Oct 2025 09:37:23 +0000 (11:37 +0200)
committerLucas Stach <l.stach@pengutronix.de>
Mon, 27 Oct 2025 21:47:09 +0000 (22:47 +0100)
The current logic uses the flush sequence from the current address
space. This is harmless when deducing the flush requirements for the
current submit, as either the incoming address space is the same one
as the currently active one or we switch context, in which case the
flush is unconditional.

However, this sequence is also stored as the current flush sequence
of the GPU. If we switch context the stored flush sequence will no
longer belong to the currently active address space. This incoherency
can then cause missed flushes, resulting in translation errors.

Fixes: 27b67278e007 ("drm/etnaviv: rework MMU handling")
Signed-off-by: Tomeu Vizoso <tomeu@tomeuvizoso.net>
Signed-off-by: Lucas Stach <l.stach@pengutronix.de>
Reviewed-by: Christian Gmeiner <cgmeiner@igalia.com>
Link: https://lore.kernel.org/r/20251021093723.3887980-1-l.stach@pengutronix.de
drivers/gpu/drm/etnaviv/etnaviv_buffer.c

index b13a17276d07cdb4266425d0f6ab8f2c2afc6a22..88385dc3b30d851c40ea60f59291e5db220fce40 100644 (file)
@@ -347,7 +347,7 @@ void etnaviv_buffer_queue(struct etnaviv_gpu *gpu, u32 exec_state,
        u32 link_target, link_dwords;
        bool switch_context = gpu->exec_state != exec_state;
        bool switch_mmu_context = gpu->mmu_context != mmu_context;
-       unsigned int new_flush_seq = READ_ONCE(gpu->mmu_context->flush_seq);
+       unsigned int new_flush_seq = READ_ONCE(mmu_context->flush_seq);
        bool need_flush = switch_mmu_context || gpu->flush_seq != new_flush_seq;
        bool has_blt = !!(gpu->identity.minor_features5 &
                          chipMinorFeatures5_BLT_ENGINE);