CVE-2025-40288
Severity CVSS v4.0:
Pending analysis
Type:
Unavailable / Other
Publication date:
06/12/2025
Last modified:
06/12/2025
Description
In the Linux kernel, the following vulnerability has been resolved:<br />
<br />
drm/amdgpu: Fix NULL pointer dereference in VRAM logic for APU devices<br />
<br />
Previously, APU platforms (and other scenarios with uninitialized VRAM managers)<br />
triggered a NULL pointer dereference in `ttm_resource_manager_usage()`. The root<br />
cause is not that the `struct ttm_resource_manager *man` pointer itself is NULL,<br />
but that `man->bdev` (the backing device pointer within the manager) remains<br />
uninitialized (NULL) on APUs—since APUs lack dedicated VRAM and do not fully<br />
set up VRAM manager structures. When `ttm_resource_manager_usage()` attempts to<br />
acquire `man->bdev->lru_lock`, it dereferences the NULL `man->bdev`, leading to<br />
a kernel OOPS.<br />
<br />
1. **amdgpu_cs.c**: Extend the existing bandwidth control check in<br />
`amdgpu_cs_get_threshold_for_moves()` to include a check for<br />
`ttm_resource_manager_used()`. If the manager is not used (uninitialized<br />
`bdev`), return 0 for migration thresholds immediately—skipping VRAM-specific<br />
logic that would trigger the NULL dereference.<br />
<br />
2. **amdgpu_kms.c**: Update the `AMDGPU_INFO_VRAM_USAGE` ioctl and memory info<br />
reporting to use a conditional: if the manager is used, return the real VRAM<br />
usage; otherwise, return 0. This avoids accessing `man->bdev` when it is<br />
NULL.<br />
<br />
3. **amdgpu_virt.c**: Modify the vf2pf (virtual function to physical function)<br />
data write path. Use `ttm_resource_manager_used()` to check validity: if the<br />
manager is usable, calculate `fb_usage` from VRAM usage; otherwise, set<br />
`fb_usage` to 0 (APUs have no discrete framebuffer to report).<br />
<br />
This approach is more robust than APU-specific checks because it:<br />
- Works for all scenarios where the VRAM manager is uninitialized (not just APUs),<br />
- Aligns with TTM&#39;s design by using its native helper function,<br />
- Preserves correct behavior for discrete GPUs (which have fully initialized<br />
`man->bdev` and pass the `ttm_resource_manager_used()` check).<br />
<br />
v4: use ttm_resource_manager_used(&adev->mman.vram_mgr.manager) instead of checking the adev->gmc.is_app_apu flag (Christian)
Impact
References to Advisories, Solutions, and Tools
- https://git.kernel.org/stable/c/070bdce18fb12a49eb9c421e57df17d2ad29bf5f
- https://git.kernel.org/stable/c/1243e396148a65bb6c42a2b70fe43e50c16c494f
- https://git.kernel.org/stable/c/43aa61c18a3a45042b098b7a1186ffb29364002c
- https://git.kernel.org/stable/c/883f309add55060233bf11c1ea6947140372920f
- https://git.kernel.org/stable/c/e70113b741ba253886cd71dbadfe3ea444bb2f5c



