Логотип exploitDog
Консоль
Логотип exploitDog

exploitDog

github логотип

GHSA-9fvj-xqr2-xwg8

Опубликовано: 29 авг. 2025
Источник: github
Github: Прошло ревью
CVSS3: 7.5

Описание

gnark affected by denial of service when computing scalar multiplication using fake-GLV algorithm

Impact

For optimizing the scalar multiplication algorithm in circuit for some curves, gnark uses fake-GLV algorithm in case the curve doesn't support true-GLV. For this to work, we need to compute the scalar decomposition using the Half GCD method in gnark-crypto. However, for some of the inputs the algorithm didn't converge quickly enough.

In case the prover accepts untrusted witness, it could lead to denial of service as the prover gets stuck in a very slowly converging loop.

Thanks to @feltroidprime for reporting the issue and proposing a fix.

Patches

The issue has been patched in gnark-crypto commit https://github.com/Consensys/gnark-crypto/commit/56600883e0e9f9b159e9c7000b94e76185ec3d0d. The dependency update is implemented in gnark commit https://github.com/Consensys/gnark/commit/68be6cede36e387ab760725beabd3c96cc94e6dc.

Workarounds

This update doesn't require recompiling the circuits as the issue is in the hint function. The users can update the gnark-crypto dependency to the fixed version.

References

Пакеты

Наименование

github.com/consensys/gnark

go
Затронутые версииВерсия исправления

= 0.12.0

0.13.0

EPSS

Процентиль: 43%
0.00207
Низкий

7.5 High

CVSS3

Дефекты

CWE-400

Связанные уязвимости

CVSS3: 7.5
nvd
5 месяцев назад

gnark is a zero-knowledge proof system framework. In version 0.12.0, there is a potential denial of service vulnerability when computing scalar multiplication is using the fake-GLV algorithm. This is because the algorithm didn't converge quickly enough for some of the inputs. This issue has been patched in version 0.13.0.

EPSS

Процентиль: 43%
0.00207
Низкий

7.5 High

CVSS3

Дефекты

CWE-400