Skip to Main content Skip to Navigation
Conference papers

A Messy State of the Union: Taming the Composite State Machines of TLS

Abstract : Implementations of the Transport Layer Security (TLS) protocol must handle a variety of protocol versions and extensions, authentication modes, and key exchange methods. Confusingly, each combination may prescribe a different message sequence between the client and the server. We address the problem of designing a robust composite state machine that correctly multiplexes between these different protocol modes. We systematically test popular open-source TLS implementations for state machine bugs and discover several critical security vulnerabilities that have lain hidden in these libraries for years, and have now finally been patched due to our disclosures. Several of these vulnerabilities, including the recently publicized FREAK flaw, enable a network attacker to break into TLS connections between authenticated clients and servers. We argue that state machine bugs stem from incorrect compositions of individually correct state machines. We present the first verified implementation of a composite TLS state machine in C that can be embedded into OpenSSL and accounts for all its supported ciphersuites. Our attacks expose the need for the formal verifica- tion of core components in cryptographic protocol libraries; our implementation demonstrates that such mechanized proofs are within reach, even for mainstream TLS implementations.
Document type :
Conference papers
Complete list of metadata

Cited literature [36 references]  Display  Hide  Download
Contributor : Bruno Blanchet Connect in order to contact the contributor
Submitted on : Monday, April 4, 2016 - 6:23:12 PM
Last modification on : Friday, February 4, 2022 - 3:10:30 AM
Long-term archiving on: : Monday, November 14, 2016 - 4:06:46 PM


Files produced by the author(s)


  • HAL Id : hal-01114250, version 1



Benjamin Beurdouche, Karthikeyan Bhargavan, Antoine Delignat-Lavaud, Cédric Fournet, Markulf Kohlweiss, et al.. A Messy State of the Union: Taming the Composite State Machines of TLS. IEEE Symposium on Security & Privacy 2015, May 2015, San Jose, United States. ⟨hal-01114250⟩



Record views


Files downloads