ngtcp2 is a C implementation of the IETF QUIC protocol. In versions prior to 1.22.1, ngtcp2_qlog_parameters_set_transport_params() serializes peer transport parameters into a fixed 1024-byte stack buffer without bounds checking. When qlog is enabled, a remote peer can send sufficiently large transport parameters during the QUIC handshake to cause writes beyond the buffer boundary, resulting in a stack buffer overflow. This affects deployments that enable the qlog callback and process untrusted peer transport parameters. This issue has been fixed in version 1.22.1. If developers are unable to immediately upgrade, they can disable the qlog on client.
| Vendor | Product | Versions |
|---|---|---|
| ngtcp2 | ngtcp2 | < 1.22.1 |
Updated description with detailed technical information, added affected versions <= 1.22.0, changed severity to HIGH, updated CVSS estimate to 7.5, and added CWE-787.
Updated severity to CRITICAL, marked as actively exploited, and provided fixed version 1.22.1.
Initial creation