Frederik Wedel-Heinen f08be09651 Avoid a memcpy in dtls_get_reassembled_message() | před 8 měsíci | |
---|---|---|
.. | ||
README.md | před 3 roky | |
extensions.c | před 11 měsíci | |
extensions_clnt.c | před 1 rokem | |
extensions_cust.c | před 11 měsíci | |
extensions_srvr.c | před 10 měsíci | |
statem.c | před 2 roky | |
statem_clnt.c | před 9 měsíci | |
statem_dtls.c | před 8 měsíci | |
statem_lib.c | před 9 měsíci | |
statem_local.h | před 1 rokem | |
statem_srvr.c | před 9 měsíci |
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 |
|_____________________________| |_______________________________|