Description
In the Linux kernel, the following vulnerability has been resolved: drm/sched: Fix potential double free in drm_sched_job_add_resv_dependencies When adding dependencies with drm_sched_job_add_dependency(), that function consumes the fence reference both on success and failure, so in the latter case the dma_fence_put() on the error path (xarray failed to expand) is a double free. Interestingly this bug appears to have been present ever since commit ebd5f74255b9 ("drm/sched: Add dependency tracking"), since the code back then looked like this: drm_sched_job_add_implicit_dependencies(): ... for (i = 0; i < fence_count; i++) { ret = drm_sched_job_add_dependency(job, fences[i]); if (ret) break; } for (; i < fence_count; i++) dma_fence_put(fences[i]); Which means for the failing 'i' the dma_fence_put was already a double free. Possibly there were no users at that time, or the test cases were insufficient to hit it. The bug was then only noticed and fixed after commit 9c2ba265352a ("drm/scheduler: use new iterator in drm_sched_job_add_implicit_dependencies v2") landed, with its fixup of commit 4eaf02d6076c ("drm/scheduler: fix drm_sched_job_add_implicit_dependencies"). At that point it was a slightly different flavour of a double free, which commit 963d0b356935 ("drm/scheduler: fix drm_sched_job_add_implicit_dependencies harder") noticed and attempted to fix. But it only moved the double free from happening inside the drm_sched_job_add_dependency(), when releasing the reference not yet obtained, to the caller, when releasing the reference already released by the former in the failure case. As such it is not easy to identify the right target for the fixes tag so lets keep it simple and just continue the chain. While fixing we also improve the comment and explain the reason for taking the reference and not dropping it.
Product status
963d0b3569354230f6e2c36a286ef270a8901878 (git) before 4c38a63ae12ecc9370a7678077bde2d61aa80e9c
963d0b3569354230f6e2c36a286ef270a8901878 (git) before 57239762aa90ad768dac055021f27705dae73344
963d0b3569354230f6e2c36a286ef270a8901878 (git) before e5e3eb2aff92994ee81ce633f1c4e73bd4b87e11
963d0b3569354230f6e2c36a286ef270a8901878 (git) before fdfb47e85af1e11ec822c82739dde2dd8dff5115
963d0b3569354230f6e2c36a286ef270a8901878 (git) before 5801e65206b065b0b2af032f7f1eef222aa2fd83
5.16
Any version before 5.16
6.1.158 (semver)
6.6.114 (semver)
6.12.55 (semver)
6.17.5 (semver)
6.18-rc2 (original_commit_for_fix)
References
git.kernel.org/...c/4c38a63ae12ecc9370a7678077bde2d61aa80e9c
git.kernel.org/...c/57239762aa90ad768dac055021f27705dae73344
git.kernel.org/...c/e5e3eb2aff92994ee81ce633f1c4e73bd4b87e11
git.kernel.org/...c/fdfb47e85af1e11ec822c82739dde2dd8dff5115
git.kernel.org/...c/5801e65206b065b0b2af032f7f1eef222aa2fd83