CVE-2025-38434
Published: Jul 25, 2025
Modified: May 11, 2026
Description
In the Linux kernel, the following vulnerability has been resolved: Revert "riscv: Define TASK_SIZE_MAX for __access_ok()" This reverts commit ad5643cf2f69 ("riscv: Define TASK_SIZE_MAX for __access_ok()"). This commit changes TASK_SIZE_MAX to be LONG_MAX to optimize access_ok(), because the previous TASK_SIZE_MAX (default to TASK_SIZE) requires some computation. The reasoning was that all user addresses are less than LONG_MAX, and all kernel addresses are greater than LONG_MAX. Therefore access_ok() can filter kernel addresses. Addresses between TASK_SIZE and LONG_MAX are not valid user addresses, but access_ok() let them pass. That was thought to be okay, because they are not valid addresses at hardware level. Unfortunately, one case is missed: get_user_pages_fast() happily accepts addresses between TASK_SIZE and LONG_MAX. futex(), for instance, uses get_user_pages_fast(). This causes the problem reported by Robert [1]. Therefore, revert this commit. TASK_SIZE_MAX is changed to the default: TASK_SIZE. This unfortunately reduces performance, because TASK_SIZE is more expensive to compute compared to LONG_MAX. But correctness first, we can think about optimization later, if required.
| Vendor | Product | Versions |
|---|---|---|
Linux | Linux | affected ad5643cf2f699989daa85d909403febd6712fccb - < fe30c30bf3bb68d4a4d8c7c814769857b5c973e6affected ad5643cf2f699989daa85d909403febd6712fccb - < f8b1898748dfeb4f9b67b6a6d661f354b9de3523affected ad5643cf2f699989daa85d909403febd6712fccb - < 890ba5be6335dbbbc99af14ea007befb5f83f174 |
Linux | Linux | affected 6.10unaffected 0 - < 6.10unaffected 6.12.36 - <= 6.12.*unaffected 6.15.5 - <= 6.15.*unaffected 6.16 - <= * |
Security Training
Train your team to recognize and prevent security threats with our comprehensive security awareness program.
Start TrainingVulnerability Scanning
Discover vulnerabilities in your applications and infrastructure before attackers do.
Scan Now