HarborGuard / CVE
Back to search
HIGHCVE-2026-31566Published Modified CNA Linux

CVE-2026-31566: drm/amdgpu: Fix fence put before wait in amdgpu_amdkfd_submit_ib

In the Linux kernel, the following vulnerability has been resolved: drm/amdgpu: Fix fence put before wait in amdgpu_amdkfd_submit_ib amdgpu_amdkfd_submit_ib() submits a GPU job and gets a fence from amdgpu_ib_schedule(). This fence is used to wait for job completion. Currently, the code drops the fence reference using dma_fence_put() before calling dma_fence_wait(). If dma_fence_put() releases the last reference, the fence may be freed before dma_fence_wait() is called. This can lead to a use-after-free. Fix this by waiting on the fence first and releasing the reference only after dma_fence_wait() completes. Fixes the below: drivers/gpu/drm/amd/amdgpu/amdgpu_amdkfd.c:697 amdgpu_amdkfd_submit_ib() warn: passing freed memory 'f' (line 696) (cherry picked from commit 8b9e5259adc385b61a6590a13b82ae0ac2bd3482)

Metrics

CVSS v3.1
7.8
Severity
HIGH
Fixed in
0
Affected Products
2

Fix available

0138e42be35ff2ce6572ae744de851ea286cf3c6939820864eacd886f1a6f817414fb8f9ea3e9a2b442d248726a0837640452b71c5a202ca3d35239ec6.1.1686.6.1316.12.806.18.216.19.117.07150850146ebfa4ca998f653f264b8df6f7f85bebc7760c107dc08ef3e231d72c492e67b0a86848be23602eb0779760544314ed3905fa6a89a4e4070
Affected packages
  • Linux / Linux
    < bc7760c107dc08ef3e231d72c492e67b0a86848b (from 9ae55f030dc523fc4dc6069557e4a887ea815453) · < e23602eb0779760544314ed3905fa6a89a4e4070 (from 9ae55f030dc523fc4dc6069557e4a887ea815453) · < 138e42be35ff2ce6572ae744de851ea286cf3c69 (from 9ae55f030dc523fc4dc6069557e4a887ea815453) · < 39820864eacd886f1a6f817414fb8f9ea3e9a2b4 (from 9ae55f030dc523fc4dc6069557e4a887ea815453) · < 42d248726a0837640452b71c5a202ca3d35239ec (from 9ae55f030dc523fc4dc6069557e4a887ea815453) · < 7150850146ebfa4ca998f653f264b8df6f7f85be (from 9ae55f030dc523fc4dc6069557e4a887ea815453)
  • Linux / Linux
    6.0
    Fixed in 0, 6.1.168, 6.6.131, 6.12.80, 6.18.21, 6.19.11, 7.0
CVSS Vector
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H