summaryrefslogtreecommitdiff
path: root/src/lib/libcrypto/dsa/dsa_key.c (unfollow)
Commit message (Collapse)AuthorFilesLines
2022-12-08bio chain test: minor readability tweakstb1-5/+6
2022-12-08bio chain test: rename a few variables for consistencytb1-29/+29
2022-12-08bio chain test: decouple lengths of test chainstb1-59/+89
Add helpers to create and destroy a linear chain of BIOs. Provide two defines for the two lengths of the test chains and make them distinct to rule out coincidences. As a bonus, the code becomes simpler.
2022-12-08bio chain test: refactor link_chains_at()tb1-198/+109
Add helper that validate the chains. This deduplicates a lot of code and makes the heart of the test much easier to read.
2022-12-08bio chain test: lose some do_{,bio_} prefixestb1-12/+12
2022-12-08Split biotest into its three logical partstb4-458/+512
Some parts of this test rely on unportable behavior, so cannot run in portable. This way we can run more tests for portable which is helpful for analysis tools, better coverage, etc.
2022-12-08biotest: Tweak long comment a bittb1-11/+13
2022-12-08Fix copy-paste error that left a paragraph ending in a commatb1-3/+3
2022-12-08Add BIO_push() and BIO_set_next() regress coveragetb1-1/+367
This tests for the behavior changes in bio_lib.c r1.40 and r1.41 and makes sure that BIO_push() and BIO_set_next() act on two chains in the expected and now documented way.
2022-12-08bn_mod_exp test: drop extra parentheses for readabilitytb1-4/+4
2022-12-07Improve the implementation of BIO_push(3) such that it changes nothingschwarze2-6/+39
and reports failure if a call would result in a cycle. The algorithm used was originally suggested by jsing@. Feedback and OK tb@.
2022-12-07Add references to the BIO_{push,pop}(3) exampletb1-3/+8
The reader may not know what digest BIOs, Base64 BIOs and file BIOs are and the relevant function names are non-obvious, hence it's not entirely trivial to find the manuals where they are explained. With these references a reader should be able to turn the example into actual code. ok schwarze
2022-12-07Fix example stringtb1-4/+4
If you want to Base64-encode "Hello World\n" using a BIO, you had better pass "Hello World\n" into it, not something slightly different... While we're touching this, we might as well write it the way K&R did...
2022-12-06Zap extra spacetb1-3/+3
2022-12-06Major rewrite for accuracy and clarity, and document BIO_set_next(3).schwarze1-37/+148
Feedback and OK tb@.
2022-12-06Add a few missing headers and drop a few unused onestb7-20/+20
In bn_test.c include bn_local.h instead of using copy-pasted prototypes.
2022-12-06Make sure BIO_push(3) always preserves all invariants of the prev_bioschwarze1-3/+10
and next_bio fields of all BIO objects in all affected chains, no matter what the arguments are. In particular, if the second argument (the one to be appended) is not at the beginning of its chain, properly detach the beginning of its chain before appending. We have weak indications that this bug might affect real-world code. For example, in FreeRDP, file libfreerdp/crypto/tls.c, function bio_rdp_tls_ctrl(), case BIO_C_SET_SSL, BIO_push(3) is definitely called with a second argument that is *not* at the beginning of its chain. Admittedly, that code is hard to fathom, but it does appear to result in a bogus prev_bio pointer without this patch. The practical impact of this bug in this and other software remains unknown; the consequences might possibly escalate up to use-after-free issues if BIO_pop(3) is afterwards called on corrupted BIO objects. OK tb@
2022-12-06Improve the poorly designed BIO_set_next(3) API to always preserve allschwarze1-3/+18
invariants of the prev_bio and next_bio fields of all BIO objects in all involved chains, no matter which arguments this function is called with. Both real-world uses of this function (in libssl and freerdp) have been audited to make sure this makes nothing worse. We believe libssl behaves correctly before and after the patch (mostly because the second argument is NULL there), and we believe the code in freerdp behaves incorrectly before and after the patch, leaving a prev_bio pointer in place that is becoming bogus, only in a different object before and after the patch. But after the patch, that bogus pointer is due to a separate bug in BIO_push(3), which we are planning to fix afterwards. Joint work with and OK tb@.
2022-12-06arithmethic -> arithmeticjsg1-3/+3
2022-12-05Unbreak rust-openssl-tests on sparc64tb1-8/+4
For the test compilation using the CC crate, base clang is good enough, so we don't need to pull in another heavy dependency just for this test.
2022-12-05bn_mod_exp.c doesn't need <string.h>tb1-2/+1
2022-12-04userspace: remove vestigial '?' cases from top-level getopt(3) loopscheloha2-4/+2
getopt(3) returns '?' when it encounters a flag not present in the in the optstring or if a flag is missing its option argument. We can handle this case with the "default" failure case with no loss of legibility. Hence, remove all the redundant "case '?':" lines. Prompted by dlg@. With help from dlg@ and millert@. Link: https://marc.info/?l=openbsd-tech&m=167011979726449&w=2 ok naddy@ millert@ dlg@
2022-12-04zap weird spaces $EDITOR added in previoustb1-2/+2
2022-12-03skip rust-openssl-tests on sparc64tb1-3/+17
The issue is likely that the build is trying to compile some generated C code with the prehistoric gcc from base, so add a tentative workaround for that. Since I don't currently have access to a sparc64 box where I could validate this easily and check if the workaround is enough, let's not waste lots of cycles on this.
2022-12-03Clean up makefiletb1-8/+6
2022-12-03biotest needs bio_local.h nowtb1-6/+7
Should have been part of the previous commit
2022-12-03Test BIO_{push,pop}() along a linear chaintb1-1/+135
2022-12-03More cleanuptb1-11/+8
Drop unnecessary loading of error strings, fix error path and consistently print to stdout.
2022-12-03Refactor and fix bn_mod_exp testtb1-80/+86
The amount of copy-paste in this test led to a few bugs and it was hard to spot them since things were done in random order. Use a different approach: compute the result of a^b (mod m) according to BN_mod_exp_simple(), then compare the results of all the other *_mod_exp* functions to that. Reuse the test structure from bn_mod_exp_zero.c to loop over the list of functions. This way we test more functions and don't forget to check some crucial bits.
2022-12-03Add missing checks for BN_mod_exp_{non,}ct()tb1-6/+8
Someone added a few more functions to test, but forgot to check their results, so if they would not do the expected thing that would only be noticed if one of the already tested functions would break.
2022-12-03Fix some ancient silliness with a random bytetb1-8/+5
For nearly 25 years this test has attempted to generate random numbers of bit length between 192 and 319 bits. Unfortunately, it used an unsigned char so instead of generating numbers in the interval [-64..63] and add them to 256, it used numbers in the intervals [0..63] and [192..255]...
2022-12-02Drop 'perhaps a little', plus grammar and spelling nitstb1-5/+5
BIO_push() and BIO_pop() are misnamed. No need to gently and politely suggest that their 'names [...] are perhaps a little misleading'.
2022-12-02Revert bio_prev removaltb2-2/+12
As schwarze points out, you can pop any BIO in a chain, not just the first one (bonus points for a great name for this API). The internal doubly linked was used to fix up the BIO chain bio was part of when you BIO_pop() a bio that wasn't in the first position, which is explicitly allowed in our documentation and implied by OpenSSL's.
2022-12-02bn_mod_exp.c: printing to stdout needs no BIOtb1-17/+9
2022-12-02bn_mod_exp: we have a BN_CTX available...tb1-19/+15
Use BN_CTX_get() instead of BN_new()/BN_free().
2022-12-02Check BN_rand() and BN_mod() return valuestb1-6/+11
CID 430848 CID 430849
2022-12-02Link new bn_mod_exp_zero test to buildtb1-1/+3
2022-12-02Rewrite the tests that various modular exponentiation functionstb2-148/+189
compute a^0 = 0 (mod 1) for all a from scratch.
2022-12-02libcrypto/bn: switch back to manual regress targetstb1-3/+8
The previous change had the undesired side effect of running the super verbose run-regress-bn_test.
2022-12-02regres/libssl/unit: simplify Makefiletb1-20/+10
2022-12-02Use regress framework rather than handrolling ittb1-12/+1
2022-12-02Use the default targets from bsd.regress.mk as far as possibletb1-9/+4
2022-12-02Let bsd.regress.mk take care of running teststb1-8/+1
2022-12-02bn_add_sub: no need for a BIO to print to stderrtb1-21/+13
2022-12-01Unhook exptb1-2/+1
2022-12-01Fix typo, move one .PHONY target nearer to the target itselftb1-4/+3
2022-12-01zap extra blank linetb1-2/+1
2022-12-01Check that the bn_isqrt -C output isn't changedtb2-1/+43
bn_isqrt -C generates code included in lib/libcrypto/lib/bn_isqrt.c. The regress tests already ensure that the content of the tables don't change. Ensure further that the code generation doesn't get out of sync.
2022-12-01Update reference to table generationtb1-2/+2
2022-12-01regress/libcrypto: merge exp/ into bn/tb3-11/+4
Move exp/exptest.c to bn/bn_mod_exp.c. This is a BN test that mostly tests a variety of BN_mod_exp*() API behavior and correctness. Commit stolen from jsing