Vulnerability description

Use of Default Cryptographic Key vulnerability in Erlang/OTP ssl (DTLS server) allows predictable DTLS cookie computation during the startup window, enabling source address verification bypass.

On DTLS server startup, dtls_server_connection:initial_hello/3 initializes previous_cookie_secret to the empty binary (<<>>) instead of a random value. Because HMAC with an empty key is deterministic, anyone who observes the plaintext ClientHello can compute dtls_handshake:cookie(<<>>, IP, Port, Hello) and forge a valid DTLS cookie before the first rotation of the cookie secret. The DTLS cookie (RFC 6347 §4.2.1) is a denial-of-service mitigation that prevents spoofed source IPs from forcing the server to allocate state and perform expensive cryptographic operations; it is not an authentication mechanism. During the window from server startup until the first secret rotation (0 to 15 seconds), an attacker who can observe the plaintext ClientHello can bypass the source address verification, enabling DTLS handshake amplification with spoofed source addresses.

This vulnerability is associated with program file lib/ssl/src/dtls_server_connection.erl and program routine dtls_server_connection:initial_hello/3.

This issue affects OTP from OTP 20.0 before 29.0.3, 28.5.0.3 and 27.3.4.14 corresponding to ssl from 8.2 before 11.7.3, 11.6.0.3 and 11.2.12.10.

Affected

pkg:otp/ssl

Module Source File Routine
dtls_server_connection src/dtls_server_connection.erl dtls_server_connection:initial_hello/3
Status Type Version Changes / Fixed in
affected otp 8.2
  • unaffected at 11.7.3
  • unaffected at 11.6.0.3
  • unaffected at 11.2.12.10

pkg:github/erlang/otp

Module Source File Routine
dtls_server_connection lib/ssl/src/dtls_server_connection.erl dtls_server_connection:initial_hello/3
Status Type Version Changes / Fixed in
affected otp 20.0
affected git e594aad2f8 < 888e3bcd72

References

Credits

  • Finder: Lukas Backström
  • Remediation developer: Ingela Anderton Andin
  • Remediation reviewer: Dan Gudmundsson

CVE record as JSON:  GET /cves/CVE-2026-54887.json
OSV record as JSON:  GET /osv/EEF-CVE-2026-54887.json