summaryrefslogtreecommitdiff
path: root/src/lib/libc/stdlib/labs.c (unfollow)
Commit message (Collapse)AuthorFilesLines
2017-01-24unifdef OPENSSL_NO_BIO - we do not support this in any form.jsing1-15/+1
ok beck@
2017-01-24Introduce ticket support. To enable them it is enough to set a positiveclaudio6-14/+251
lifetime with tls_config_set_session_lifetime(). This enables tickets and uses an internal automatic rekeying mode for the ticket keys. If multiple processes are involved the following functions can be used to make tickets work accross all instances: - tls_config_set_session_id() sets the session identifier - tls_config_add_ticket_key() adds an encryption and authentication key For now only the last 4 keys added will be used (unless they are too old). If tls_config_add_ticket_key() is used the caller must ensure to add new keys regularly. It is best to do this 4 times per session lifetime (which is also the ticket key lifetime). Since tickets break PFS it is best to minimize the session lifetime according to needs. With a lot of help, input and OK beck@, jsing@
2017-01-24ssl_cert_free() checks for NULL itself.jsing1-10/+5
2017-01-24Remove a "free up if allocated" comment that exists before code that freesjsing1-2/+1
things if they are allocated. ok captainobvious@
2017-01-24sk_SSL_CIPHER_free() checks for NULL so do not bother doing the same fromjsing4-27/+16
the callers.
2017-01-24ssl_sess_cert_free() checks for NULL, so do not bother doing it at thejsing2-6/+8
call sites.
2017-01-24There is no point in zeroing fields that exist within a struct that isjsing1-3/+1
about to be explicit_bzero'd and freed.
2017-01-24Add missing documentation for tls_config_set_verify_depthclaudio1-1/+5
Done together with jsing@
2017-01-24Shuffle the deck chairs to bring them back in order.claudio1-9/+9
2017-01-24tls_config_add_keypair_mem is the function to add additional keypairs andclaudio1-5/+5
ocsp_staple functions set the OCSP response they don't add them (which implies you can call them multiple times). Discussed with jsing@ beck@
2017-01-23move default_passwd_cb and default_passwd_cb_userdata back intobeck4-30/+35
the ssl_ctx from internal - these are used directly by python and openvpn and a few other things - we have the set accessors but the get accessors were added in 1.1 and these roll their own caveat OPENSSL_VERSION chickenpluckery
2017-01-23Move options and mode from SSL_CTX and SSL to internal, since these can bejsing12-66/+70
set and cleared via existing functions.
2017-01-23Split most of SSL_METHOD out into an internal variant, which is opaque.jsing23-303/+378
Discussed with beck@
2017-01-23hook malloc_general to the testsotto1-2/+2
2017-01-23test malloc/realloc/free with some flag combo'sotto2-0/+122
2017-01-23Remove ssl_ctrl, ssl_ctx_ctrl, ssl_callback_ctrl and ssl_ctx_callback_ctrljsing8-76/+14
from SSL_METHOD, replacing usage with direct calls to the appropriate functions. ok beck@
2017-01-23send state and rstate from ssl_st into internal. There are accessorsbeck16-295/+296
so these should not be diddled with directly ok jsing@
2017-01-23move back read_hash and enc_read_ctx into ssl_st. wpa_supplicant andbeck8-52/+57
other perversions touches them sickly and unnaturally.
2017-01-23Fix regress to handle movement of ssl structures to internalbeck1-2/+4
2017-01-23Move a large part of ssl_st into internal, so we can see what squeals.beck22-888/+892
ok jsing@
2017-01-23Move ex_data, next and prev from SSL_SESSION to internal.jsing3-31/+32
ok beck@
2017-01-23Move most of the fields in SSL_CTX to internal - the ones that remain arejsing11-202/+209
known to be in use. ok beck@
2017-01-23move the callbacks from ssl_st to internalbeck19-230/+237
ok jsing@
2017-01-23Move callback function pointers and argument pointers from SSL_CTX tojsing16-200/+210
internal. ok beck@
2017-01-23Move not_resumable and sess_cert from SSL_SESSION to internal.jsing7-47/+50
ok beck@
2017-01-23Remove heartbeat related fields from the SSL_CTX, which are unusedjsing1-9/+1
(thankfully).
2017-01-23Move the stats struct from SSL_CTX to internal.jsing10-65/+64
ok beck@
2017-01-22Move most of the SSL3_STATE fields to internal - the ones that remain arejsing18-681/+690
known to be used by ports. ok beck@
2017-01-22Disable session cache and tickets by default.claudio1-1/+5
OK beck@ jsing@
2017-01-22Update the TLS ALPN unit tests to work with internal/opaque data.jsing2-13/+11
2017-01-22Move most of DTLS1_STATE to internal.beck11-273/+272
ok jsing@
2017-01-22Move ALPN and NPN fields from SSL/SSL_CTX to internal.jsing7-125/+129
ok beck@
2017-01-22Move internal parts of ssl_session_st to internalbeck4-40/+40
ok jsing@
2017-01-22Move recently added min_version/max_version from SSL and SSL_CTX to theirjsing2-10/+6
opaque structs.
2017-01-22Wrap long lines.jsing1-4/+7
2017-01-22Bump majors for libssl and libtls following the translucent struct change.jsing2-2/+2
Further changes to the publically visible structs will ride this bump.
2017-01-22Convert publically visible structs to translucent structs.jsing8-29/+111
This change adds an internal opaque struct for each of the significant publically visible structs. The opaque struct is then allocated and attached to the publically visible struct when the appropriate *_new() function is called, then cleared and freed as necessary. This will allow for changes to be made to the internals of libssl, without requiring a major bump each time the publically visible structs are modified. ok beck@
2017-01-22Clean up ssl3_new() - in particular, we do not need to zero fields thatjsing1-11/+4
are within a struct that was just allocated via calloc. ok beck@
2017-01-22There is no point in setting struct fields to zero, when you've alreadyjsing1-5/+2
zeroed the entire struct via memset. ok beck@
2017-01-21use BN_div_nonct where it is safe to do so.beck1-2/+2
ok guenther@
2017-01-21Add ct and nonct versions of BN_mod_inverse for internal usebeck13-36/+67
ok jsing@
2017-01-21Split out BN_div and BN_mod into ct and nonct versions for Internal use.beck17-58/+92
ok jsing@
2017-01-21Make explicit _ct and _nonct versions of bn_mod_exp funcitons thatbeck19-47/+249
matter for constant time, and make the public interface only used external to the library. This moves us to a model where the important things are constant time versions unless you ask for them not to be, rather than the opposite. I'll continue with this method by method. Add regress tests for same. ok jsing@
2017-01-21whitespacederaadt2-5/+5
2017-01-211. When shrinking a chunk allocation, compare the size of the currentotto1-46/+87
allocation to the size of the new allocation (instead of the requested size). 2. Previously realloc takes the easy way and always reallocates if C is active. This commit fixes by carefully updating the recorded requested size in all cases, and writing the canary bytes in the proper location after reallocating. 3. Introduce defines to test if MALLOC_MOVE should be done and to compute the new value.
2017-01-21Specify minimum and maximum protocol version for each method. This isjsing6-6/+36
currently unused, but will be in the near future. ok beck@
2017-01-21Place {DECLARE,IMPLEMENT}_OBJ_BSEARCH{_GLOBAL,}_CMP_FN macros undefjsing1-1/+5
LIBRESSL_INTERNAL.
2017-01-21Expand DECLARE_OBJ_BSEARCH_CMP_FN and IMPLEMENT_OBJ_BSEARCH_CMP_FN macros.jsing6-28/+168
No change to generated assembly excluding line numbers.
2017-01-21/usr/bin/unifdef -D MONT_MUL_MOD -D MONT_EXP_WORD -D RECP_MUL_MOD -m bn_exp.cbeck1-23/+2
with some style cleanup after. no binary change ok jsing@
2017-01-21Expand DECLARE_OBJ_BSEARCH_CMP_FN and IMPLEMENT_OBJ_BSEARCH_CMP_FN macros.jsing2-8/+38
No change to generated assembly excluding line numbers.