summaryrefslogtreecommitdiff
path: root/src/lib/libc/stdlib/hcreate.c (unfollow)
Commit message (Collapse)AuthorFilesLines
2023-09-19Fix some NULL/0 misspellings in SSL_CTX_new()tb1-5/+5
2023-09-18aesni_ctr32_encrypt_blocks() is called indirectly from C code, so itderaadt1-0/+1
needs endbr64 ok kettenis tb
2023-09-18remove tls_reset(3) from the NAME, SYNOPSIS, and HISTORY sectionsschwarze1-10/+5
because it is documented in the separate tls_client(3) manual page
2023-09-18PEM_def_callback(3) does not truncate its argument but merely the copy,schwarze1-15/+21
plus a few wording improvements
2023-09-18Rewrite RSA_get_ex_new_index(3) and CRYPTO_set_ex_data(3) from scratch.schwarze2-462/+753
The defects of the old pages were too numerous to list in full but included vagueness, gaps, misleading statements, bad ordering, and duplication. Use my Copyright since none of the text we inherited from OpenSSL remains. Without doing a thorough review, tb@ thinks he likes the new pages after quickly reading through both of them.
2023-09-13replace the outdated statement that everything uses SHA-1schwarze1-5/+33
by a table showing the supported algorithms
2023-09-13Document the special meaning of NID_undef in this context.schwarze1-4/+13
From Matt Caswell <matt at openssl dot org> via OpenSSL commit 1212818e (Sep 11, 2018) from the OpenSSL 1.1 branch, which is still under a free license. Wording slightly tweaked by me.
2023-09-13Various improvements:schwarze1-15/+63
* Document the ASN1_PKEY_CTRL_DEFAULT_MD_NID control operation. * Mention that EVP_PKEY_asn1_new(3) sets ASN1_PKEY_DYNAMIC. * Fix the description of EVP_PKEY_asn1_copy(3), which was totally wrong. * Warn about the crazy ASN1_PKEY_DYNAMIC handling in EVP_PKEY_asn1_free(3). * Be more precise about EVP_PKEY_asn1_new(3) RETURN VALUES.
2023-09-13document the EVP_PKEY_ASN1_METHOD flagsschwarze1-5/+51
ASN1_PKEY_ALIAS, ASN1_PKEY_DYNAMIC, and ASN1_PKEY_SIGPARAM_NULL
2023-09-13minor markup fixes: add one missing .Dv and one missing .Vt macroschwarze1-4/+8
2023-09-13document the EVP_PKEY_CTRL_MD and EVP_PKEY_CTRL_GET_MD command constantsschwarze1-4/+35
2023-09-12fix typoschwarze1-2/+2
2023-09-12document the four EVP_PKEY_OP_TYPE_* mask constantsschwarze1-4/+23
2023-09-12document sizes for ED25519 and X25519,schwarze1-6/+19
including the constants ED25519_KEYLEN and X25519_KEYLEN
2023-09-12document the constant EVP_CHACHAPOLY_TLS_TAG_LENschwarze2-3/+9
2023-09-12Document EVP_AEAD_DEFAULT_TAG_LENGTH and EVP_AEAD_MAX_TAG_LENGTH,schwarze1-5/+20
making some adjacent wordings slightly more precise.
2023-09-12fix the vague and misleading description of the EVP_MD_FLAG_* constantsschwarze1-22/+72
2023-09-11Small cleanups in cms_sd_asn1_ctrl():tb1-6/+6
Compare explicitly against NULL and use ret instead of i.
2023-09-11Rewrite CMS_SignerInfo_{sign,verify}()tb1-61/+55
Convert to using one-shot signing and verification. This is simpler than doing Init/Update/Final and necessary for Ed25519 support (RFC 8419). Use a single exit idiom, don't reuse the same buffer for decoding and signing and simplify a few other things. ok jsing
2023-09-11spellingjsg1-3/+3
2023-09-11Back out superfluous initializationjob1-5/+4
requested by jsing@
2023-09-10Make EVP_PKEY_get1_$TYPE a wrapper of EVP_PKEY_get0_$TYPEtb1-22/+29
Avoids a bit of code duplication and reduces the probability of a fix being applied to only one of get0 and get1 (which happend in p_lib.c r1.35). ok jsing
2023-09-10EVP_CipherInit(): use EVP_CIPHER_CTX_cleanup()tb1-3/+3
Before EVP_CIPHER_CTX was opaque, callers could pass an uninitialized ctx into EVP_CipherInit() and calling EVP_CIPHER_CTX_cleanup() on such a ctx would end in tears. The only way to initialize a ctx is by way of EVP_CIPHER_CTX_new(), on which we can call EVP_CIPHER_CTX_cleanup() and avoid silly leaks on ctx reuse. This also allows some simplifications in the documentation. There are more changes of this kind that should be done all over libcrypto. They will be tackled in subsequent commits. "makes a lot of sense" schwarze ok jsing
2023-09-10Mention EVP_PKEY_encrypt_old(3) and EVP_PKEY_decrypt_old(3) becauseschwarze1-7/+87
some software still calls them. Put them here because despite the function and header names, they are really specific to RSA. Besides, this avoids a distraction in the more important EVP_PKEY_encrypt(3) and EVP_PKEY_decrypt(3) manual pages.
2023-09-10Briefly mention SSLeay_add_all_algorithms(3) becauseschwarze1-6/+18
surprisingly large numbers of software packages still call it. Mark the unused aliases OPENSSL_add_all_algorithms_conf(3), OPENSSL_add_all_algorithms_noconf(3), SSLeay_add_all_ciphers(3), and SSLeay_add_all_digests(3) as intentionally undicumented.
2023-09-10Document the deprecated functions EVP_set_pw_prompt(3) andschwarze1-71/+86
EVP_get_pw_prompt(3) because some software out there still uses them. While here, also improve the description of EVP_read_pw_string(3). Delete documentation for des_read_pw(3) and des_read_pw_string(3). They couldn't be used in LibreSSL since at least 2016 because they were never in Symbols.list, and in 2022, jsing@ also removed them from <openssl/ui_compat.h>. Delete the misleading AUTHORS section. Richard Levitte did not write the original implementation of these functions, and the compatibility wrapper around the UI_process(3) API that he did write is not notable enough to be mentioned so prominently.
2023-09-10Mark EVP_ENCODE_LENGTH() and EVP_DECODE_LENGTH() as intentionallyschwarze1-2/+6
undocumented because they do not describe properties of the Base64 encoding but add arbitrary constant lengths, hence being implementation details of BIO_f_base64(3). Besides, they are practically unused outside evp/bio_b64.c.
2023-09-10fix Xr punctuationjsg1-3/+3
2023-09-10spellingjsg2-6/+6
2023-09-09new manual page EVP_PKEY_CTX_get_operation(3),schwarze4-5/+127
also documenting EVP_PKEY_CTX_get0_pkey(3)
2023-09-09document EVP_PKEY_CTX_get_data(3) and EVP_PKEY_CTX_set_data(3)schwarze1-6/+58
2023-09-09Document EVP_PKEY_CTX_set0_keygen_info(3).schwarze1-10/+59
While here, also add the missing RETURN VALUES entries for EVP_PKEY_gen_cb(3), EVP_PKEY_CTX_get_cb(3), and EVP_PKEY_CTX_get_keygen_info(3).
2023-09-09Document EVP_PKEY_CTX_get0_peerkey(3).schwarze1-19/+97
While here, also make the descriptions of the other functions more precise.
2023-09-09Print waring message when not allocated memory in putleakinfo().asou1-2/+20
ok otto.
2023-09-08Mark EVP_PKEY_save_parameters() as intentionally undocumentedschwarze1-2/+6
because nothing uses it according to codesearch.debian.net and it only affects X509_PUBKEY_set(3) for DSA and GOST2001 keys, resulting in incomplete output without the public key parameters.
2023-09-07Below RETURN VALUES,schwarze1-10/+12
* mention that EVP_MD_CTX_md(3) also returns NULL if no message digest is configured yet; and * omplete the list of functions returning const EVP_MD *, also making the wording more precise. Delete EVP_MAX_MD_SIZE from the NAME, SYNOPSIS, and HISTORY sections because we do not usually document preprocessor macro constants in this way. There is nothing special about this constant justifying an exception.
2023-09-07add the missing entries for EVP_MD_CTX_pkey_ctx(3) and EVP_MD_CTX_md_data(3)schwarze1-1/+7
to the RETURN VALUES section
2023-09-07document EVP_MD_nid(3) and EVP_MD_name(3)schwarze1-4/+41
2023-09-07improve the descriptions of most functionsschwarze1-30/+45
2023-09-07Split two new manual pages EVP_MD_nid(3) and EVP_MD_CTX_ctrl(3)schwarze5-315/+501
out of the large EVP_DigestInit(3). No text change.
2023-09-06Mark EVP_CIPHER_set_asn1_iv() and EVP_CIPHER_get_asn1_iv() as intentionallyschwarze1-2/+7
undocumented because they are unused outside libcrypto according to codesearch.debian.net and should probably not be public: they seem hardly useful even for implementing custom EVP_CIPHER algorithms. tb@ came to similar conclusions regarding these two functions.
2023-09-06Initialize afi & safi to zerojob1-4/+5
OK tb@
2023-09-06Avoid use-of-uninitialized in i2r_IPAddrBlocks()tb1-1/+8
Reported by Viktor Szakats in https://github.com/libressl/portable/issues/910 ok job
2023-09-06Correct the RETURN VALUES of OBJ_add_object(3).schwarze1-6/+33
The text was misleading before and after the improvement in obj_dat.c rev. 1.61. The way i'm fixing the documentation here takes that improvement into account. Also add a CAVEATS section about adding incomplete objects.
2023-09-05add a BUGS section warning about the creation of incomplete objectsschwarze1-3/+22
2023-09-05Improve error handling in OBJ_add_object()tb1-13/+7
There is no need for a helper function to obfuscate lh_ADDED_OBJ_new(). Just call the real thing directly. Adding an object with a NID of NID_undef basically amounts to disabling a built-in OID. It does so in an incoherent fashion and the caller can't easily tell success from failure of the operation. Arguably the result is a corrupted objects table. Let's not allow adding such an object in an attempt at keeping things slightly more coherent. Issue noted and initial diff by schwarze while writing documentation ok schwarze
2023-09-05document EVP_CIPHER_name(3)schwarze1-2/+32
2023-09-05add the missing .Dv macros to the list of flagsschwarze1-13/+13
2023-09-05improve the descriptions of almost all flags,schwarze1-40/+101
in particular saying which API functions each flag affects
2023-09-05Partial rewrite:schwarze1-140/+231
* Integrate the leftovers of the former NOTES section into the main text, resulting in a more logical order of information. * Make many descriptions more precise and tweak many wordings. For example, the description of OBJ_cmp(3) was totally misleading. Add a CAVEATS section explaining the scary ownership contracts of the functions returning ASN1_OBJECT pointers. Move the discussion of NID_undef to the BUGS section because the statement "objects which are not in the table have the NID value NID_undef" was misleading in more than one way. Considering that an API as fundamental as this one contains such a gigantic amount of quirks and traps and gaps makes me shudder.