summaryrefslogtreecommitdiff
path: root/src/lib/libcrypto/buffer/buffer.c
diff options
context:
space:
mode:
authortb <>2024-01-13 10:57:08 +0000
committertb <>2024-01-13 10:57:08 +0000
commitd36667012f7e01108077f5f9fdd8db6f47f068e4 (patch)
tree0fd48c87176036b6c3e261429aa318870888df67 /src/lib/libcrypto/buffer/buffer.c
parent65a07541b919135a5a39abd6d2d7f93ed3332df4 (diff)
downloadopenbsd-d36667012f7e01108077f5f9fdd8db6f47f068e4.tar.gz
openbsd-d36667012f7e01108077f5f9fdd8db6f47f068e4.tar.bz2
openbsd-d36667012f7e01108077f5f9fdd8db6f47f068e4.zip
Add a table of cipher names, ciphers and aliases
This arranges the data provided by dynamic library initialization in a static table and will help avoid gross code with missing error checking and other defects on every use of the library. This table isn't pretty due to various naming inconsistecies accumulated over the decades. It will significantly simplify the implementation of API such as EVP_get_cipherbyname() and EVP_CIPHER_do_all(). All the table does is map strings to ciphers, typically used on the openssl(1) command line or in code it's the mechanism that underlies the map from NID_chacha20 to the data returned by EVP_chacha20(). It's of course more complicated because it just had to be stupid. This is one of the places where the use of bsearch() is justified. The price to pay for the simplification is that adding custom aliases and custom ciphers to this table will no longer be supported. It is one significant user of the LHASH madness. That's just another piece of the awful "toolkit aspect"-guided misdesign that contributes to making this codebase so terrible. A corresponding table for the digests will be added in the next commit. ok jsing
Diffstat (limited to 'src/lib/libcrypto/buffer/buffer.c')
0 files changed, 0 insertions, 0 deletions