← back
CVE-2025-29779

Post-Quantum Secure Feldman's Verifiable Secret Sharing has Inadequate Fault Injection Countermeasures in `secure_redundant_execution`

CVSS 5.4 MEDIUMEPSS 0.2%CWE-1240CWE-1279
In short

A Python library for secret sharing has weak protections against fault injection attacks, where an attacker with physical access to hardware could exploit the system to steal secret values or trick it into accepting fake data. The library tries to defend against this by running code multiple times, but Python's design makes this defense ineffective.

Technical detail

The `secure_redundant_execution` function lacks true execution isolation, uses non-constant-time comparison, and implements timing-based randomization that provides inadequate protection against targeted fault injection attacks. An attacker with physical access can exploit timing side-channels, bypass redundancy checks, extract secret polynomial coefficients during VSS operations, or manipulate commitment verification to accept fraudulent commitments, compromising the cryptographic guarantees of the scheme.

Summary generated and translated by AI from the official description.
Post-Quantum Secure Feldman's Verifiable Secret Sharing provides a Python implementation of Feldman's Verifiable Secret Sharing (VSS) scheme. In versions 0.8.0b2 and prior, the `secure_redundant_execution` function in feldman_vss.py attempts to mitigate fault injection attacks by executing a function multiple times and comparing results. However, several critical weaknesses exist. Python's execution environment cannot guarantee true isolation between redundant executions, the constant-time comparison implementation in Python is subject to timing variations, the randomized execution order and timing provide insufficient protection against sophisticated fault attacks, and the error handling may leak timing information about partial execution results. These limitations make the protection ineffective against targeted fault injection attacks, especially from attackers with physical access to the hardware. A successful fault injection attack could allow an attacker to bypass the redundancy check mechanisms, extract secret polynomial coefficients during share generation or verification, force the acceptance of invalid shares during verification, and/or manipulate the commitment verification process to accept fraudulent commitments. This undermines the core security guarantees of the Verifiable Secret Sharing scheme. As of time of publication, no patched versions of Post-Quantum Secure Feldman's Verifiable Secret Sharing exist, but other mitigations are available. Long-term remediation requires reimplementing the security-critical functions in a lower-level language like Rust. Short-term mitigations include deploying the software in environments with physical security controls, increasing the redundancy count (from 5 to a higher number) by modifying the source code, adding external verification of cryptographic operations when possible, considering using hardware security modules (HSMs) for key operations.
CVSS:4.0/AV:P/AC:H/AT:P/PR:N/UI:N/VC:H/VI:H/VA:H/SC:N/SI:N/SA:N

Want to know if your infrastructure is exposed to this?

Talk to TrueHacking →