CVE-2025-68793
Gravedad:
Pendiente de análisis
Tipo:
No Disponible / Otro tipo
Fecha de publicación:
13/01/2026
Última modificación:
13/01/2026
Descripción
*** Pendiente de traducción *** In the Linux kernel, the following vulnerability has been resolved:<br />
<br />
drm/amdgpu: fix a job->pasid access race in gpu recovery<br />
<br />
Avoid a possible UAF in GPU recovery due to a race between<br />
the sched timeout callback and the tdr work queue.<br />
<br />
The gpu recovery function calls drm_sched_stop() and<br />
later drm_sched_start(). drm_sched_start() restarts<br />
the tdr queue which will eventually free the job. If<br />
the tdr queue frees the job before time out callback<br />
completes, the job will be freed and we&#39;ll get a UAF<br />
when accessing the pasid. Cache it early to avoid the<br />
UAF.<br />
<br />
Example KASAN trace:<br />
[ 493.058141] BUG: KASAN: slab-use-after-free in amdgpu_device_gpu_recover+0x968/0x990 [amdgpu]<br />
[ 493.067530] Read of size 4 at addr ffff88b0ce3f794c by task kworker/u128:1/323<br />
[ 493.074892]<br />
[ 493.076485] CPU: 9 UID: 0 PID: 323 Comm: kworker/u128:1 Tainted: G E 6.16.0-1289896.2.zuul.bf4f11df81c1410bbe901c4373305a31 #1 PREEMPT(voluntary)<br />
[ 493.076493] Tainted: [E]=UNSIGNED_MODULE<br />
[ 493.076495] Hardware name: TYAN B8021G88V2HR-2T/S8021GM2NR-2T, BIOS V1.03.B10 04/01/2019<br />
[ 493.076500] Workqueue: amdgpu-reset-dev drm_sched_job_timedout [gpu_sched]<br />
[ 493.076512] Call Trace:<br />
[ 493.076515] <br />
[ 493.076518] dump_stack_lvl+0x64/0x80<br />
[ 493.076529] print_report+0xce/0x630<br />
[ 493.076536] ? _raw_spin_lock_irqsave+0x86/0xd0<br />
[ 493.076541] ? __pfx__raw_spin_lock_irqsave+0x10/0x10<br />
[ 493.076545] ? amdgpu_device_gpu_recover+0x968/0x990 [amdgpu]<br />
[ 493.077253] kasan_report+0xb8/0xf0<br />
[ 493.077258] ? amdgpu_device_gpu_recover+0x968/0x990 [amdgpu]<br />
[ 493.077965] amdgpu_device_gpu_recover+0x968/0x990 [amdgpu]<br />
[ 493.078672] ? __pfx_amdgpu_device_gpu_recover+0x10/0x10 [amdgpu]<br />
[ 493.079378] ? amdgpu_coredump+0x1fd/0x4c0 [amdgpu]<br />
[ 493.080111] amdgpu_job_timedout+0x642/0x1400 [amdgpu]<br />
[ 493.080903] ? pick_task_fair+0x24e/0x330<br />
[ 493.080910] ? __pfx_amdgpu_job_timedout+0x10/0x10 [amdgpu]<br />
[ 493.081702] ? _raw_spin_lock+0x75/0xc0<br />
[ 493.081708] ? __pfx__raw_spin_lock+0x10/0x10<br />
[ 493.081712] drm_sched_job_timedout+0x1b0/0x4b0 [gpu_sched]<br />
[ 493.081721] ? __pfx__raw_spin_lock_irq+0x10/0x10<br />
[ 493.081725] process_one_work+0x679/0xff0<br />
[ 493.081732] worker_thread+0x6ce/0xfd0<br />
[ 493.081736] ? __pfx_worker_thread+0x10/0x10<br />
[ 493.081739] kthread+0x376/0x730<br />
[ 493.081744] ? __pfx_kthread+0x10/0x10<br />
[ 493.081748] ? __pfx__raw_spin_lock_irq+0x10/0x10<br />
[ 493.081751] ? __pfx_kthread+0x10/0x10<br />
[ 493.081755] ret_from_fork+0x247/0x330<br />
[ 493.081761] ? __pfx_kthread+0x10/0x10<br />
[ 493.081764] ret_from_fork_asm+0x1a/0x30<br />
[ 493.081771] <br />
<br />
(cherry picked from commit 20880a3fd5dd7bca1a079534cf6596bda92e107d)



