[ < ] | [ > ] | [ << ] | [ Up ] | [ >> ] | [Top] | [Contents] | [Index] | [ ? ] |
12.2 TLS Handshake Protocol
The GnuTLS handshake protocol is implemented as a state machine that waits for input or returns immediately when the non-blocking transport layer functions are used. The main idea is shown in the following figure.
data:image/s3,"s3://crabby-images/42e33/42e33c9dc06e4410b46c54bc6fadc228f77ead37" alt="gnutls-handshake-state"
Also the way the input is processed varies per ciphersuite. Several
implementations of the internal handlers are available and
gnutls_handshake only multiplexes the input to the appropriate
handler. For example a PSK ciphersuite has a different
implementation of the process_client_key_exchange
than a
certificate ciphersuite.
data:image/s3,"s3://crabby-images/6cb10/6cb10bf91c6b1b67aa3f7fb33637e9fef09cd627" alt="gnutls-handshake-sequence"