summaryrefslogtreecommitdiff
path: root/src/lib/libc/stdlib/merge.c (unfollow)
Commit message (Collapse)AuthorFilesLines
2023-04-11Clean up unused BIGNUM.jsing1-4/+1
2023-04-11Document the RETURN VALUES of BIO_method_type(3) and BIO_method_name(3)schwarze14-28/+160
for the various BIO types.
2023-04-11Recommit jsing's r1.27 - portable is readytb1-23/+4
Use htobe64() instead of testing BYTE_ORDER and then handrolling htobe64(). Thanks to tobhe for providing most of the fix via openiked-portable
2023-04-11While all the BIO_TYPE_* constants are part of the API, most of theirschwarze1-32/+77
values are only part of the ABI and not of the API, so delete them from the SYNOPSIS: application programmers must not rely on the specific values. Instead of listing the specific values, properly describe the meaning of all these constants. However, the values of BIO_TYPE_NONE and BIO_TYPE_START are hard-coded into the API and application programmers need to be aware of their values, so those remain in the SYNOPSIS.
2023-04-11Back out r1.27 using htobe64() - apparently some OS don't have it.tb1-4/+23
ok jsing
2023-04-11Consolidate sha1 into a single file.jsing3-91/+23
2023-04-11Simplify handling of big vs little endian.jsing1-40/+5
Rather than sprinkling BYTE_ORDER checks throughout the implementation, always define PULL64 - on big endian platforms it just becomes a no-op. ok tb@
2023-04-11Use htobe64() instead of testing BYTE_ORDER and then handrolling htobe64().jsing1-23/+4
ok tb@
2023-04-11Omit sha512_block_data_order() prototype when assembly is not being used.jsing1-4/+3
In the case that the pure C implementation of SHA512 is being used, the prototype is unnecessary as the function is declared static and exists in dependency order. Simply omit the prototype rather than using #ifndef to toggle the static prefix. ok tb@
2023-04-11Remove less than useful implementation notes.jsing1-36/+1
ok tb@
2023-04-11bn_mod_sqrt: remove no longer necessary complications due to thetb1-15/+5
non-deterministic nature of the old implementation.
2023-04-11Add a new implementation of BN_mod_sqrt()tb3-411/+728
This is a reimplementation from scratch of the Tonelli-Shanks algorithm based on Henri Cohen "A Course in Computational Algebraic Number Theory", Springer GTM 138, section 1.5.1. It is API compatible with the previous implementation, so no documentation change is required. Contrary to the old implementation, this does not have any infinite loops and has various additional sanity checks to prevent misbehavior in case the input modulus is not a prime. It contains extensive comments and the individual parts of the algorithm are split into digestible chunks instead of having one huge function. One difference of note is that it BN_mod_sqrt() now always returns the smaller of the two possible answers. In other words, while its core is non-deterministic, its answer is not. ok jsing
2023-04-11Correct benchmark result computation on 32 bit platforms.jsing2-4/+4
2023-04-10Some more cleanup in bn_to_stringtb1-12/+8
2023-04-10Drop BN_NO_DEPRECATED dance from bn_testtb1-7/+1
2023-04-10Provide benchmarks for BN_copy()jsing2-1/+184
2023-04-10Fix indentation of structs and unions in x509v3.htb1-87/+87
No change according to diff -w
2023-04-10Make bn_to_string() statictb1-3/+3
This function is no longer used directly by regress, so it can now be local to this file.
2023-04-10bn_to_string no longer needs to be linked staticallytb1-2/+1
2023-04-10Rework the bn_to_string() to use public APItb1-73/+213
We can use the undocumented functions {i2s,s2i}_ASN1_INTEGER(3) to exercise bn_to_string(). This way we use public API and remove the need of linking statically.
2023-04-09Move a few functions out of OPENSSL_NO_DEPRECATEDtb8-29/+19
Geoff Thorpe added OPENSSL_NO_DEPRECATED nearly two decades ago. The hope was that at some point some functions can be dropped. Most of the functions marked deprecated are actually unused nowadays but unfortunately some of them are still used in the ecosystem. Move them out of OPENSSL_NO_DEPRECATED so we can define it without breaking the consumers in the next bump. ERR_remove_state() is still used by a dozen or so ports. This isn't a big deal since it is just a stupid wrapper for the not quite as deprecated ERR_remove_thread_state(). It's not worth patching these ports. Annoyingly, {DH,DSA}_generate_parameters() and RSA_generate_key() are still used. They "make use" of the old-style BN_GENCB callback, which is therefore more difficult to remove - in case you don't know know: that's the thing responsible for printing pretty '.', '+' and '*' when you generate keys. Most annoyingly, DH_generate_parameters() was added to rust-openssl in 2020 for "advanced DH support". This is very unfortunate since cargo bundles a rust-openssl and updates it only every few years or so. As a consequence we're going to be stuck with this nonsense for a good while. ok beck jsing
2023-04-09Remove some doubled empty linestb1-7/+1
2023-04-09Remove X9.31 support from openssl(1)tb2-18/+7
The X9.31 standard has long been retired and deprecated and libcrypto will drop support for it soon. This prepares userland. ok jsing
2023-04-09Drop X9.31 support from libtlstb2-7/+2
The TLS signer isn't exposed in public API (we should finally fix it...) and it supports X9.31, a standard that has been retired and deprecated for a very long time. libcrypto will stop supporting it soon, this step is needed to prepare userland. ok jsing
2023-04-09Minor code cleanuptb1-42/+31
Unwrap a few awkwardly wrapped lines, drop redundant parentheses and add empty lines after some variable declarations. No change in the generated assembly.
2023-04-09Provide and use sha{224,384}_{update,final} functions.jsing1-28/+54
Improve readability and consistency by providing and using functions named for the specific hash, rather than reusing the sha256/sha512 update and final functions. No functional change. ok tb@
2023-04-09Rename SHA functions to have sha{1,224,256,384,512}_ prefix.jsing1-31/+31
Also remove some unnecessary parentheses. No functional change. ok tb@
2023-04-09fix double wordsjsg1-3/+3
2023-04-08bn_test: two minor style tweakstb1-6/+3
2023-04-07bn_mont: fix typo in comment divisable -> divisibletb1-2/+2
2023-04-07bn_test: rename rc into ret as per usualtb1-91/+91
2023-04-07bn_test: pass BN_CTX into all functionstb1-364/+297
There is a BN_CTX at program scope. Pass it into all test functions. This simplifies memory management at the end of the functions quite a bit.
2023-04-07bn_test: drop a few braces that are now unnecessarytb1-33/+17
2023-04-07bn_test: move rc initialization to its own linetb1-9/+17
2023-04-07bn_test: keep the error stack cleantb1-1/+13
Make message() print and clear the error stack. This way we can know what test errored. To make this work also clear the error stack after a handful of xfail tests.
2023-04-07bn_test: use bn_copy() instead of BN_free/BN_duptb1-3/+2
This is not only simpler but also required by an upcoming change.
2023-04-07bn_test: a few early return would leak. goto err insteadtb1-5/+5
2023-04-07bn_test: rand_neg() is not only one of the most stupidly named functionstb1-2/+2
in the entire code base it also has a few parentheses too many
2023-04-07bn_test: handle rc consistentlytb1-111/+134
Various test functions had bugs due to the fact that the return code would be set to 1 at the top so that each error would have to set rc = 0. This is silly. Fail closed instead by setting rc = 0 at the top and only flipping to 1 before the err label
2023-04-07bn_test: inline the only use of lst[]tb1-14/+12
lst[] can be converted from a bit string to a hex string. Use BN_hex2bn() isntead of BN_bin2bn(). Handle this inside test_lshift() rather than doing artistic ownership dances.
2023-04-07Improve some test failure reportingtb1-5/+12
2023-04-07Ignore ten getter and setter control macros related to proxy BIOs.schwarze1-0/+6
Those are not useful because such a BIO type neither exists in LibreSSL nor in OpenSSL 1.1.1. Not adding the deprecation notice to some manual page because there is no manual page that is even vaguely related.
2023-04-07Two minor tweaks that are useful for processing bio.h, among other headers:schwarze1-1/+2
* ignore lines defining "__bounded__()" * ignore whitespace between "#" and "include"
2023-04-07Mark BIO_CB_return(), BIO_cb_pre(), and BIO_cb_post() as intentionallyschwarze1-2/+7
undocumented because they are unused according to codesearch.debian.net and would cause nothing but obfuscation if they were used.
2023-04-06Document the effects that BIO_set_info_callback(3), BIO_callback_ctrl(3),schwarze1-3/+54
BIO_get_info_callback(3), and BIO_info_cb(3) have on connect BIOs.
2023-04-06Properly document BIO_set_info_callback(3) and BIO_get_info_callback(3)schwarze1-8/+96
which where mentioned below SYNOPSIS and HISTORY but not described. Also document the command constant BIO_CTRL_SET_CALLBACK and the deprecated function type name bio_info_cb(3). Mention that callbacks installed using BIO_set_callback_ex(3) and BIO_set_callback(3) can tamper with *all* the return values.
2023-04-06Use RCS tag instead of an incorrect path.tb1-1/+1
2023-04-06Move a comment to the proper placetb1-6/+5
2023-04-06wycheproof: fix copy-paste error in previoustb1-2/+2
2023-04-06wycheproof: use EVP_MD instead of importing "hash"tb1-70/+52