Frederik Wedel-Heinen bf5269e995 Continue processing cookieless client hellos for dtls1.3 | 1 year ago | |
---|---|---|
.. | ||
README.md | 3 years ago | |
extensions.c | 6 months ago | |
extensions_clnt.c | 6 months ago | |
extensions_cust.c | 1 year ago | |
extensions_srvr.c | 6 months ago | |
statem.c | 7 months ago | |
statem_clnt.c | 6 months ago | |
statem_dtls.c | 7 months ago | |
statem_lib.c | 6 months ago | |
statem_local.h | 1 year ago | |
statem_srvr.c | 6 months ago |
This file provides some guidance on the thinking behind the design of the state machine code to aid future maintenance.
The state machine code replaces an older state machine present in OpenSSL versions 1.0.2 and below. The new state machine has the following objectives:
The message flow state machine is divided into a reading sub-state machine and a writing sub-state machine. See the source comments in statem.c for a more detailed description of the various states and transitions possible.
Conceptually the state machine component is designed as follows:
libssl
|
-------------------------|-----statem.h------------------------------------
|
_______V____________________
| |
| statem.c |
| |
| Core state machine code |
|____________________________|
statem_local.h ^ ^
_________| |_______
| |
_____________|____________ _____________|____________
| | | |
| statem_clnt.c | | statem_srvr.c |
| | | |
| TLS/DTLS client specific | | TLS/DTLS server specific |
| state machine code | | state machine code |
|__________________________| |__________________________|
| |_______________|__ |
| ________________| | |
| | | |
____________V_______V________ ________V______V_______________
| | | |
| statem_lib.c | | statem_dtls.c |
| | | |
| Non core functions common | | Non core functions common to |
| to both servers and clients | | both DTLS servers and clients |
|_____________________________| |_______________________________|