]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/amdkfd: fix list_del corruption in kfd_criu_resume_svm
authorMario Limonciello <mario.limonciello@amd.com>
Sat, 13 Jun 2026 02:22:04 +0000 (21:22 -0500)
committerAlex Deucher <alexander.deucher@amd.com>
Wed, 17 Jun 2026 22:19:37 +0000 (18:19 -0400)
The cleanup tail of kfd_criu_resume_svm() walks
svms->criu_svm_metadata_list and kfree()s each struct criu_svm_metadata
without removing it from the list. The list head is left pointing at
freed kmalloc-96 objects.

A second AMDKFD_IOC_CRIU_OP from the same process re-enters: list_empty()
reads the dangling ->next (use-after-free), the loop walks freed entries,
and each is kfree()'d again (double-free). This is reachable by an
unprivileged render-group user via /dev/kfd with no capabilities required.

Add list_del() before the kfree() so the list is properly emptied. The
list_for_each_entry_safe() iterator already caches the next pointer, so
unlinking during the walk is safe.

Fixes: 2a909ae71871 ("drm/amdkfd: CRIU resume shared virtual memory ranges")
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
Signed-off-by: Mario Limonciello <mario.limonciello@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
(cherry picked from commit 6322d278a298e2c1430b9d2697743d3a04b788b1)

drivers/gpu/drm/amd/amdkfd/kfd_svm.c

index d64d104783d403da33afbbe9acf44c813a016d86..5a56d86b3ecf86cf6af1986b86f6576f16229a38 100644 (file)
@@ -4115,6 +4115,7 @@ exit:
        list_for_each_entry_safe(criu_svm_md, next, &svms->criu_svm_metadata_list, list) {
                pr_debug("freeing criu_svm_md[]\n\tstart: 0x%llx\n",
                                                criu_svm_md->data.start_addr);
+               list_del(&criu_svm_md->list);
                kfree(criu_svm_md);
        }