]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/amdgpu: Skip emit de meta data on gfx11 with rs64 enabled
authorYifan Zha <Yifan.Zha@amd.com>
Fri, 14 Nov 2025 09:48:58 +0000 (17:48 +0800)
committerAlex Deucher <alexander.deucher@amd.com>
Wed, 19 Nov 2025 22:34:15 +0000 (17:34 -0500)
[Why]
Accoreding to CP updated to RS64 on gfx11,
WRITE_DATA with PREEMPTION_META_MEMORY(dst_sel=8) is illegal for CP FW.
That packet is used for MCBP on F32 based system.
So it would lead to incorrect GRBM write and FW is not handling that
extra case correctly.

[How]
With gfx11 rs64 enabled, skip emit de meta data.

Signed-off-by: Yifan Zha <Yifan.Zha@amd.com>
Acked-by: Alex Deucher <alexander.deucher@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/gfx_v11_0.c

index 02d7cfae22bde9a9f1a6e813151b80da33388811..8a2ee2de390f3f7ba39b613ae95dce0418c7937c 100644 (file)
@@ -5874,9 +5874,9 @@ static void gfx_v11_0_ring_emit_ib_gfx(struct amdgpu_ring *ring,
                if (flags & AMDGPU_IB_PREEMPTED)
                        control |= INDIRECT_BUFFER_PRE_RESUME(1);
 
-               if (vmid)
+               if (vmid && !ring->adev->gfx.rs64_enable)
                        gfx_v11_0_ring_emit_de_meta(ring,
-                                   (!amdgpu_sriov_vf(ring->adev) && flags & AMDGPU_IB_PREEMPTED) ? true : false);
+                               !amdgpu_sriov_vf(ring->adev) && (flags & AMDGPU_IB_PREEMPTED));
        }
 
        amdgpu_ring_write(ring, header);