Skip to content

PQClean has a correctness error in HQC decapsulation

High severity GitHub Reviewed Published Dec 11, 2024 in PQClean/PQClean • Updated Dec 11, 2024

Package

cargo pqcrypto-hqc (Rust)

Affected versions

< 0.2.1

Patched versions

0.2.1

Description

Impact

A correctness error has been identified in the reference implementation of the HQC key encapsulation mechanism. Due to an indexing error, part of the secret key is incorrectly treated as non-secret data. This results in an incorrect shared secret value being returned when the decapsulation function is called with a malformed ciphertext.

No concrete attack exploiting the error has been identified at this point. However, the error involves mishandling of the secret key, and in principle this presents a security vulnerability.

Patches

PQClean does not have a release process, as it is a collection of implementations. If you obtained a HQC implementation from PQClean, please update to a version that includes the fixes proposed in PQClean/PQClean#578.

Please also refer to our security policy.

Workarounds

Manually patching is always possible

Further details

In the 2023/04/30 version of the HQC specification and reference implementation, an extra field (sigma) was added to the secret key structure to enable implicit rejection of malformed ciphertexts. The logic to retrieve the public key from the secret key in the decapsulation function was not updated accordingly. As a result, sigma is treated as part of the public key. Later in the decapsulation call, a incorrectly constructed comparison check allows this error to go through undetected. Due to how these two bugs interfere with each other, the decapsulation function never uses sigma to perform implicit rejection; instead, it accepts malformed ciphertexts and returns shared secrets based on their decryptions.

References

This issue was first reported in OQS GHSA-gpf4-vrrw-r8v7. The vulnerability was identified by Célian Glénaz and Dahmun Goudarzi (Quarkslab).

References

@thomwiggers thomwiggers published to PQClean/PQClean Dec 11, 2024
Published to the GitHub Advisory Database Dec 11, 2024
Reviewed Dec 11, 2024
Last updated Dec 11, 2024

Severity

High

CVE ID

No known CVE

GHSA ID

GHSA-753p-wrj5-g8fj

Source code

Credits

Loading Checking history
See something to contribute? Suggest improvements for this vulnerability.