EVP_CipherInit basically is the same EVP_CipherInit_ex except that it
in some instances it resets/inits the ctx parameter first. We already
call EVP_CIPHER_CTX_reset to reset/init the ctx before. Also ensure that
EVP_CipherInit_Ex gets the cipher to actually be able to initialise the
context.
OpenSSL 1.0.2:
https://github.com/openssl/openssl/blob/OpenSSL_1_0_2-stable/crypto/evp/evp_enc.c#L94
EVP_CipherInit calls first EVP_CIPHER_CTX_init and then EVP_CipherInit_ex
Our openssl_compat.h has
for these older OpenSSL versions
OpenSSL 3.0:
https://github.com/openssl/openssl/blob/openssl-3.2/crypto/evp/evp_enc.c#L450
basically the same as 1.0.2. Just that method names have been changed.
Change-Id: I911e25949a8647b567fd4178683534d4404ab469
Signed-off-by: Arne Schwabe <arne@rfc2549.org>
Acked-by: Gert Doering <gert@greenie.muc.de>
Message-Id: <20240402134909.6340-1-gert@greenie.muc.de>
URL: https://www.mail-archive.com/openvpn-devel@lists.sourceforge.net/msg28523.html
Signed-off-by: Gert Doering <gert@greenie.muc.de>
| ... | ... |
@@ -846,11 +846,7 @@ cipher_ctx_init(EVP_CIPHER_CTX *ctx, const uint8_t *key, |
| 846 | 846 |
evp_cipher_type *kt = cipher_get(ciphername); |
| 847 | 847 |
|
| 848 | 848 |
EVP_CIPHER_CTX_reset(ctx); |
| 849 |
- if (!EVP_CipherInit(ctx, kt, NULL, NULL, enc)) |
|
| 850 |
- {
|
|
| 851 |
- crypto_msg(M_FATAL, "EVP cipher init #1"); |
|
| 852 |
- } |
|
| 853 |
- if (!EVP_CipherInit_ex(ctx, NULL, NULL, key, NULL, enc)) |
|
| 849 |
+ if (!EVP_CipherInit_ex(ctx, kt, NULL, key, NULL, enc)) |
|
| 854 | 850 |
{
|
| 855 | 851 |
crypto_msg(M_FATAL, "EVP cipher init #2"); |
| 856 | 852 |
} |