summaryrefslogtreecommitdiff
path: root/src/lib/libssl/tls13_lib.c (unfollow)
Commit message (Collapse)AuthorFilesLines
2025-08-11Add RCS tags.jsing11-0/+22
2025-08-11Resync s2n-bignum primitives for amd64 with upstream.jsing11-115/+113
This amounts to whitespace changes and label renaming.
2025-08-10Clean up and move define to correct place.beck2-5/+3
ok tb@
2025-08-09Add missing make dependency as the oclo binary depends onanton1-1/+3
ocloexec_verify. Take the easy route and ensure all binaries are built before the regress make target.
2025-08-06sync CA certificates from newer mozilla list, ok tb@sthen1-339/+1
https://raw.githubusercontent.com/mozilla-firefox/firefox/refs/heads/release/security/nss/lib/ckfw/builtins/certdata.txt SHA256 (certdata.txt) = 579f336ace2e5717b8ecc06002ce0cce96f70623d188e1999c34b0f77696d3e9 Removals: - /C=IE/O=Baltimore/OU=CyberTrust/CN=Baltimore CyberTrust Root - /C=GB/ST=Greater Manchester/L=Salford/O=Comodo CA Limited/CN=AAA Certificate Services - /O=Entrust.net/OU=www.entrust.net/CPS_2048 incorp. by ref. (limits liab.)/OU=(c) 1999 Entrust.net Limited/CN=Entrust.net Certification Authority (2048) - /C=BE/O=GlobalSign nv-sa/OU=Root CA/CN=GlobalSign Root CA - /C=US/O=Starfield Technologies, Inc./OU=Starfield Class 2 Certification Authority - /C=US/O=The Go Daddy Group, Inc./OU=Go Daddy Class 2 Certification Authority - /C=US/OU=www.xrampsecurity.com/O=XRamp Security Services Inc/CN=XRamp Global Certification Authority Addition: + /C=PL/O=Unizeto Technologies S.A./OU=Certum Certification Authority/CN=Certum Trusted Network CA 2
2025-08-05Speed up bn_{mod,sqr}_mul_words() for specific inputs.jsing1-3/+25
Use bn_{mul,sqr}_comba{4,6,8}() and bn_montgomery_reduce_words() for specific input sizes. This is significantly faster than using bn_montgomery_multiply_words(). ok tb@
2025-08-05Provide bn_sqr_comba6().jsing2-2/+48
This allows for fast squaring of a 6 word array. ok tb@
2025-08-05Provide bn_mul_comba6().jsing2-2/+63
This allows for fast multiplication of two 6 word arrays. ok tb@
2025-08-05Mark the inputs to bn_mul_comba{4,8}() as const.jsing3-9/+9
This makes it consistent with bn_sqr_comba{4,8}() and simplifies an upcoming change. ok tb@
2025-08-04Sort NAME, RETURN VALUES, ERRORS, and STANDARDS in the same order as SYNOPSIS.schwarze1-16/+16
Sort HISTORY chronologically. No text change.
2025-08-04link illumos oclo test to the treetb1-2/+2
2025-08-04Implement the POSIX-2024 close-on-fork flag, but modified to beguenther2-9/+10
reset on exec as preserving it across exec is not necessary for its original purpose and has security and usability concerns. Many thanks to Ricardo Branco (rbranco (at) suse.de) who did an independent implementation, caught that /dev/fd/* needed to be handled, and provided a port of the illumos test suite. Thanks to tb@ for assistance with that. ok deraadt@
2025-08-04replace the flockfile backend with a per FILE recursive mutex.dlg1-1/+7
the flockfile implementation in thread/rthread_file.c used an external lock, and associated it with the relevant FILE * as needed. this isn't great for a lot of reasons, complexity being the big one, but the straw that broke the camels back is that it uses a single spinlock to coordinate all of this, which in turn generates a lot of sched_yield syscalls. this avoids all the code complexity and the spinlock by just embedding a small __rctmx in every FILE. tested by and ok tb@ jca@ ok claudio@
2025-08-03Implement constant time EC scalar multiplication.jsing1-16/+103
Replace simplistic non-constant time scalar multiplication with a constant time version. This is actually faster since we compute multiples of the point, then double four times and add once. The multiple to add is selected conditionally, ensuring that the access patterns remain the same regardless of value. Inspired by Go's scalar multiplication code. ok tb@
2025-08-03Remove duplicate computation for b3.jsing1-5/+1
2025-08-03Add prototype for EC_GFp_homogeneous_projective_method().jsing1-1/+2
2025-08-03Avoid signed overflow in BN_MONT_CTX_set()tb1-2/+3
ri is an int, so the check relied on signed overflow (UB). It's not really reachable, but shrug. reported by smatch via jsg ok beck jsing kenjiro
2025-08-03Avoid signed overflow in BN_mul()tb1-3/+4
Reported by smatch via jsg. ok beck jsing kenjiro
2025-08-03Provide benchmarks for EC arithmetic.jsing2-1/+212
This provides benchmarking for EC_POINT_add(), EC_POINT_dbl() and EC_POINT_mul()'s scalar * generator path.
2025-08-02Provide bn_mod_sqr_words() and call it from ec_field_element_sqr().jsing3-4/+20
For now this still calls bn_montgomery_multiply_words(), however it can be optimised further in the future.
2025-08-02Copy EC_FIELD_MODULUS/EC_FIELD_ELEMENTs when copying groups and points.jsing1-1/+9
ok tb@
2025-08-02Provide constant time conditional selection between EC_FIELD_ELEMENTs.jsing2-2/+17
Provide a ec_field_element_select() function that allows for constant time conditional selection between two EC_FIELD_ELEMENTs. This will become a building block for constant time point multiplication. ok tb@
2025-08-02Provide harness to run illumos's oclo tests from libc regresstb3-0/+32
This depends on the illumos-os-tests port I just imported and can be linked to the build once guenther lands the close-on-fork diff. Adapted from an initial diff by Ricardo Branco
2025-08-02hash_test: remove variable name from prototype and fix a casttb1-3/+3
2025-07-31Rework PKCS7_simple_smimecap()tb2-27/+36
This is nearly identical to CMS_add_simple_smimecap(). We can reuse its doc comment mutatis mutandis and use the same construction. Maybe this wants deduplicating. Maybe not. ok kenjiro
2025-07-31Rework PKCS7_add1_attrib_digest()tb1-12/+18
There's nothing really wrong here (at least when compared to the rest of this file an hour or so ago), but we can make this look somewhat more like code. That there's no bug here is not really related to the fact that it's an add1 function, not an add0 one. In fact, it's kind of surprising that the author had an uncharacteristic moment of lucidity and remembered to free the last argument passed to PKCS7_add_signed_attribute() on failure. ok kenjiro
2025-07-31Rewrite PKCS7_get_smimecap() to use d2i_X509_ALGORS()tb1-6/+9
Since we finally found a use for i2d_X509_ALGORS(), make use of its sibling here. This avoids some ridiculous contortions in not quite peak muppet code (obviously this was a first test run for the grand finale in CMS). ok kenjiro
2025-07-31Plug leaks due to misuse of PKCS7_add_signed_attribute()tb2-26/+52
set0/add0 functions that can fail are the worst. Without fail this trips up both users and authors (by and large these are two identical groups consisting of a single person), resulting in leaks and double frees. In today's episode of spelunking in the gruesome gore provided by the PKCS#7 and Time-Stamp protocol "implementations", we fix a couple of leaks in PKCS7_add_attrib_smimecap() and ESS_add_signing_cert(). We do so by recalling that there is i2d_X509_ALGORS(), so we might as well put it to use instead of inlining it poorly (aka, without error checking). Normalize said error checking and ensure ownership is handled correctly in the usual single-exit idiom. ESS_add_signing_cert() can also make use of proper i2d handling, so it's simpler and correct and in the end looks pretty much the same as PKCS7_add_attrib_smimecap(). ok kenjiro
2025-07-29curve25519.c: zap trailing whitespace introduced in previoustb1-2/+2
2025-07-28PKCS7_add0_attrib_signing_time: tweak commenttb1-2/+2
2025-07-27Below STANDARDS, reference the two most relevant sections of RFC 5652.schwarze1-1/+5
Given that RFC 5652 does not override the earlier (and simpler) standards but instead strives to remain compatible, referencing both the original and the latest versions seems helpful. OK tb@
2025-07-27openssl certhash: add digest param to certhash_directoryjoshua1-13/+9
This will allow us to call certhash_directory with other digests as required to implement the openssl rehash command, which uses SHA1 or MD5. ok jsing tb
2025-07-27Remove DES_UNROLL from opensslconf.h.jsing13-156/+0
This is no longer used in the DES code. ok tb@
2025-07-27Rework DES encryption/decryption loops.jsing2-124/+31
Use a slightly unrolled loop, which gets us half way between DES_UNROLL and no DES_UNROLL. While we're not terribly concerned by DES performance, this gets us a small gain on aarch64 and a small loss on arm. But above all, we end up with simpler code. ok tb@
2025-07-27Inline cms_add1_signingTime() in its only consumertb1-31/+9
Why have seven lines if you can have 30... tweak/ok kenjiro
2025-07-27Update PKCS7_add0_attrib_signing_time() docstb1-3/+3
Document the change of behavor from pk7_attr.c r1.17: the time is now validated to be in correct RFC 5280 time format. ok kenjiro
2025-07-27Fix PKCS7_add0_attrib_signing_time()tb1-5/+24
If the caller passes in NULL, helpfully a new ASN1_TIME is allocated with X509_gmtime_adj() and leaked if PKCS7_add0_attrib_signing_time() fails afterward. Fix this. Also don't blindly set the signing time to a UTCTime. Validate the usual RFC 5280 format before setting it, as that's what RFC 5652, section 11.3 mandates. ok kenjiro
2025-07-27Fix incorrect ownership handling in add_attribute()tb1-34/+42
This little gem has a number of issues. On failure, the caller can't know whether ownership of value was taken or not, so to avoid a double free, the only option is to leak value on failure. As X509_ATTRIBUTE_create() takes ownership on success, this call must be the last one that can fail. This way ownership is only taken on success. Next, if X509_ATTRIBUTE_create() fails in the case that the input stack already contains an attribute of type nid, that attr is freed and the caller freeing the stack with pop_free() will double free. So, rework this in a few ways. Make this transactional, so we don't fail with a modified *in_sk, so work with a local sk as usual. Then walk the stack and see if we have an attribute with the appropriate nid already. If not, make sure there's room to place the new attribute. Create the new attribute, free the old attribute if necessary and replace it with the new one. Finally assign the local sk to *in_sk and return success. On error unwind all we did. The behavior now matches OpenSSL 3's new behavior, except that we don't leave an empty stack around on error. ok kenjiro
2025-07-25Retire interop tests with OpenSSL 3.3 and 3.4tb9-141/+11
2025-07-23Remove BN_LLONG defines/undefs from opensslconf.h.jsing13-65/+0
These have been ineffective since r1.19 of bn.h, when BN_LLONG/BN_ULLONG defines/undefs were added based on _LP64. ok tb@
2025-07-23regress/libcrypto/x509/bettertls: switch to eopenssl35tb1-4/+4
2025-07-23regress/libcrypto/ec: switch to openssl35tb1-4/+4
2025-07-23ec_asn1_test: fix includestb1-1/+5
2025-07-23ectest: fix includestb1-6/+3
2025-07-23c2sp: unhook openssl 3.3 and 3.4tb1-2/+2
2025-07-22Remove unused function pointer from struct aead_aes_gcm_ctx.jsing1-2/+1
2025-07-22Remove remaining block128_f casts from EVP AES.jsing2-5/+8
Use aes_encrypt_block128() instead of AES_encrypt(), avoiding risky casts.
2025-07-22Remove crypto_cpu_caps_ia32()jsing6-30/+6
There are no more consumers of crypto_cpu_caps_ia32(), so remove it. ok bcook@ joshua@ tb@
2025-07-22Move AES-NI for ECB out of EVP.jsing6-87/+58
Make aes_ecb_encrypt_internal() replaceable and provide machine dependent versions for amd64 and i386, which dispatch to AES-NI if appropriate. Remove the AES-NI specific EVP methods for ECB. This removes the last of the machine dependent code from EVP AES. ok bcook@ joshua@ tb@
2025-07-21Move AES-NI from EVP to AES for CCM mode.jsing7-112/+145
The mode implementation for CCM has two variants - one takes the block function, while the other takes a "ccm64" function. The latter is expected to handle the lower 64 bits of the IV/counter but only for 16 byte blocks. The AES-NI implementation for CCM currently uses the second variant. Provide aes_ccm64_encrypt_internal() as a function that can be replaced on a machine dependent basis, along with an aes_ccm64_encrypt_generic() function that provides the default implementation and can be used as a fallback. Wire up the AES-NI version for amd64 and i386, change EVP's aes_ccm_cipher() to use CRYPTO_ctr128_{en,de}crypt_ccm64() with aes_ccm64_encrypt_internal()) and remove the various AES-NI specific EVP_CIPHER methods for CCM. ok tb@