Home

Description

In the Linux kernel, the following vulnerability has been resolved: lib/crypto: arm64/poly1305: Fix register corruption in no-SIMD contexts Restore the SIMD usability check that was removed by commit a59e5468a921 ("crypto: arm64/poly1305 - Add block-only interface"). This safety check is cheap and is well worth eliminating a footgun. While the Poly1305 functions should not be called when SIMD registers are unusable, if they are anyway, they should just do the right thing instead of corrupting random tasks' registers and/or computing incorrect MACs. Fixing this is also needed for poly1305_kunit to pass. Just use may_use_simd() instead of the original crypto_simd_usable(), since poly1305_kunit won't rely on crypto_simd_disabled_for_test.

PUBLISHED Reserved 2025-04-16 | Published 2025-09-15 | Updated 2025-09-29 | Assigner Linux

Product status

Default status
unaffected

a59e5468a921937cb7317892779c67046ad9f5cc (git) before ef74efa598b7bbc5c24509f7f56af2806f81c339
affected

a59e5468a921937cb7317892779c67046ad9f5cc (git) before eec76ea5a7213c48529a46eed1b343e5cee3aaab
affected

Default status
affected

6.16
affected

Any version before 6.16
unaffected

6.16.4 (semver)
unaffected

6.17 (original_commit_for_fix)
unaffected

References

git.kernel.org/...c/ef74efa598b7bbc5c24509f7f56af2806f81c339

git.kernel.org/...c/eec76ea5a7213c48529a46eed1b343e5cee3aaab

cve.org (CVE-2025-39804)

nvd.nist.gov (CVE-2025-39804)

Download JSON