|
|
debe55 |
From 05fb8ceb229d76ae32bd18e707b3682c8302490c Mon Sep 17 00:00:00 2001
|
|
|
debe55 |
From: Jeremy Barton <jbarton@microsoft.com>
|
|
|
debe55 |
Date: Tue, 13 Jul 2021 01:38:33 -0700
|
|
|
debe55 |
Subject: [PATCH 11/11] Adjust crypto shim for functions renamed for OSSL3
|
|
|
debe55 |
beta1
|
|
|
debe55 |
|
|
|
debe55 |
---
|
|
|
debe55 |
.../opensslshim.h | 15 +++++++++------
|
|
|
debe55 |
.../osslcompat_30.h | 3 +++
|
|
|
debe55 |
.../System.Security.Cryptography.Native/pal_evp.c | 2 +-
|
|
|
debe55 |
.../pal_evp_pkey.c | 2 +-
|
|
|
debe55 |
4 files changed, 14 insertions(+), 8 deletions(-)
|
|
|
debe55 |
|
|
|
debe55 |
diff --git a/src/Native/Unix/System.Security.Cryptography.Native/opensslshim.h b/src/Native/Unix/System.Security.Cryptography.Native/opensslshim.h
|
|
|
debe55 |
index c11285e7dd..b3386d381f 100644
|
|
|
debe55 |
--- a/src/Native/Unix/System.Security.Cryptography.Native/opensslshim.h
|
|
|
debe55 |
+++ b/src/Native/Unix/System.Security.Cryptography.Native/opensslshim.h
|
|
|
debe55 |
@@ -292,7 +292,7 @@ void SSL_get0_alpn_selected(const SSL* ssl, const unsigned char** protocol, unsi
|
|
|
debe55 |
REQUIRED_FUNCTION(EVP_md5) \
|
|
|
debe55 |
RENAMED_FUNCTION(EVP_MD_CTX_free, EVP_MD_CTX_destroy) \
|
|
|
debe55 |
RENAMED_FUNCTION(EVP_MD_CTX_new, EVP_MD_CTX_create) \
|
|
|
debe55 |
- REQUIRED_FUNCTION(EVP_MD_size) \
|
|
|
debe55 |
+ RENAMED_FUNCTION(EVP_MD_get_size, EVP_MD_size) \
|
|
|
debe55 |
REQUIRED_FUNCTION(EVP_PKEY_CTX_ctrl) \
|
|
|
debe55 |
REQUIRED_FUNCTION(EVP_PKEY_CTX_free) \
|
|
|
debe55 |
REQUIRED_FUNCTION(EVP_PKEY_CTX_get0_pkey) \
|
|
|
debe55 |
@@ -303,13 +303,14 @@ void SSL_get0_alpn_selected(const SSL* ssl, const unsigned char** protocol, unsi
|
|
|
debe55 |
FALLBACK_FUNCTION(EVP_PKEY_CTX_set_rsa_padding) \
|
|
|
debe55 |
FALLBACK_FUNCTION(EVP_PKEY_CTX_set_rsa_pss_saltlen) \
|
|
|
debe55 |
FALLBACK_FUNCTION(EVP_PKEY_CTX_set_signature_md) \
|
|
|
debe55 |
- REQUIRED_FUNCTION(EVP_PKEY_base_id) \
|
|
|
debe55 |
REQUIRED_FUNCTION(EVP_PKEY_decrypt) \
|
|
|
debe55 |
REQUIRED_FUNCTION(EVP_PKEY_decrypt_init) \
|
|
|
debe55 |
REQUIRED_FUNCTION(EVP_PKEY_derive_set_peer) \
|
|
|
debe55 |
REQUIRED_FUNCTION(EVP_PKEY_derive_init) \
|
|
|
debe55 |
REQUIRED_FUNCTION(EVP_PKEY_derive) \
|
|
|
debe55 |
REQUIRED_FUNCTION(EVP_PKEY_free) \
|
|
|
debe55 |
+ RENAMED_FUNCTION(EVP_PKEY_get_base_id, EVP_PKEY_base_id) \
|
|
|
debe55 |
+ RENAMED_FUNCTION(EVP_PKEY_get_size, EVP_PKEY_size) \
|
|
|
debe55 |
FALLBACK_FUNCTION(EVP_PKEY_get0_RSA) \
|
|
|
debe55 |
REQUIRED_FUNCTION(EVP_PKEY_get1_DSA) \
|
|
|
debe55 |
REQUIRED_FUNCTION(EVP_PKEY_get1_EC_KEY) \
|
|
|
debe55 |
@@ -322,7 +323,6 @@ void SSL_get0_alpn_selected(const SSL* ssl, const unsigned char** protocol, unsi
|
|
|
debe55 |
REQUIRED_FUNCTION(EVP_PKEY_set1_RSA) \
|
|
|
debe55 |
REQUIRED_FUNCTION(EVP_PKEY_sign) \
|
|
|
debe55 |
REQUIRED_FUNCTION(EVP_PKEY_sign_init) \
|
|
|
debe55 |
- REQUIRED_FUNCTION(EVP_PKEY_size) \
|
|
|
debe55 |
FALLBACK_FUNCTION(EVP_PKEY_up_ref) \
|
|
|
debe55 |
REQUIRED_FUNCTION(EVP_rc2_cbc) \
|
|
|
debe55 |
REQUIRED_FUNCTION(EVP_rc2_ecb) \
|
|
|
debe55 |
@@ -699,7 +699,7 @@ FOR_ALL_OPENSSL_FUNCTIONS
|
|
|
debe55 |
#define EVP_md5 EVP_md5_ptr
|
|
|
debe55 |
#define EVP_MD_CTX_free EVP_MD_CTX_free_ptr
|
|
|
debe55 |
#define EVP_MD_CTX_new EVP_MD_CTX_new_ptr
|
|
|
debe55 |
-#define EVP_MD_size EVP_MD_size_ptr
|
|
|
debe55 |
+#define EVP_MD_get_size EVP_MD_get_size_ptr
|
|
|
debe55 |
#define EVP_PKEY_CTX_ctrl EVP_PKEY_CTX_ctrl_ptr
|
|
|
debe55 |
#define EVP_PKEY_CTX_free EVP_PKEY_CTX_free_ptr
|
|
|
debe55 |
#define EVP_PKEY_CTX_get0_pkey EVP_PKEY_CTX_get0_pkey_ptr
|
|
|
debe55 |
@@ -710,13 +710,14 @@ FOR_ALL_OPENSSL_FUNCTIONS
|
|
|
debe55 |
#define EVP_PKEY_CTX_set_rsa_padding EVP_PKEY_CTX_set_rsa_padding_ptr
|
|
|
debe55 |
#define EVP_PKEY_CTX_set_rsa_pss_saltlen EVP_PKEY_CTX_set_rsa_pss_saltlen_ptr
|
|
|
debe55 |
#define EVP_PKEY_CTX_set_signature_md EVP_PKEY_CTX_set_signature_md_ptr
|
|
|
debe55 |
-#define EVP_PKEY_base_id EVP_PKEY_base_id_ptr
|
|
|
debe55 |
#define EVP_PKEY_decrypt_init EVP_PKEY_decrypt_init_ptr
|
|
|
debe55 |
#define EVP_PKEY_decrypt EVP_PKEY_decrypt_ptr
|
|
|
debe55 |
#define EVP_PKEY_derive_set_peer EVP_PKEY_derive_set_peer_ptr
|
|
|
debe55 |
#define EVP_PKEY_derive_init EVP_PKEY_derive_init_ptr
|
|
|
debe55 |
#define EVP_PKEY_derive EVP_PKEY_derive_ptr
|
|
|
debe55 |
#define EVP_PKEY_free EVP_PKEY_free_ptr
|
|
|
debe55 |
+#define EVP_PKEY_get_base_id EVP_PKEY_get_base_id_ptr
|
|
|
debe55 |
+#define EVP_PKEY_get_size EVP_PKEY_get_size_ptr
|
|
|
debe55 |
#define EVP_PKEY_get0_RSA EVP_PKEY_get0_RSA_ptr
|
|
|
debe55 |
#define EVP_PKEY_get1_DSA EVP_PKEY_get1_DSA_ptr
|
|
|
debe55 |
#define EVP_PKEY_get1_EC_KEY EVP_PKEY_get1_EC_KEY_ptr
|
|
|
debe55 |
@@ -729,7 +730,6 @@ FOR_ALL_OPENSSL_FUNCTIONS
|
|
|
debe55 |
#define EVP_PKEY_set1_RSA EVP_PKEY_set1_RSA_ptr
|
|
|
debe55 |
#define EVP_PKEY_sign_init EVP_PKEY_sign_init_ptr
|
|
|
debe55 |
#define EVP_PKEY_sign EVP_PKEY_sign_ptr
|
|
|
debe55 |
-#define EVP_PKEY_size EVP_PKEY_size_ptr
|
|
|
debe55 |
#define EVP_PKEY_up_ref EVP_PKEY_up_ref_ptr
|
|
|
debe55 |
#define EVP_rc2_cbc EVP_rc2_cbc_ptr
|
|
|
debe55 |
#define EVP_rc2_ecb EVP_rc2_ecb_ptr
|
|
|
debe55 |
@@ -1006,6 +1006,9 @@ FOR_ALL_OPENSSL_FUNCTIONS
|
|
|
debe55 |
#if OPENSSL_VERSION_NUMBER < OPENSSL_VERSION_3_0_RTM
|
|
|
debe55 |
|
|
|
debe55 |
// Undo renames for renamed-in-3.0
|
|
|
debe55 |
+#define EVP_MD_get_size EVP_MD_size
|
|
|
debe55 |
+#define EVP_PKEY_get_base_id EVP_PKEY_base_id
|
|
|
debe55 |
+#define EVP_PKEY_get_size EVP_PKEY_size
|
|
|
debe55 |
#define SSL_get1_peer_certificate SSL_get_peer_certificate
|
|
|
debe55 |
|
|
|
debe55 |
#endif
|
|
|
debe55 |
diff --git a/src/Native/Unix/System.Security.Cryptography.Native/osslcompat_30.h b/src/Native/Unix/System.Security.Cryptography.Native/osslcompat_30.h
|
|
|
debe55 |
index bb529df51e..dba69f1382 100644
|
|
|
debe55 |
--- a/src/Native/Unix/System.Security.Cryptography.Native/osslcompat_30.h
|
|
|
debe55 |
+++ b/src/Native/Unix/System.Security.Cryptography.Native/osslcompat_30.h
|
|
|
debe55 |
@@ -19,10 +19,13 @@ void ERR_new(void);
|
|
|
debe55 |
void ERR_set_debug(const char *file, int line, const char *func);
|
|
|
debe55 |
void ERR_set_error(int lib, int reason, const char *fmt, ...);
|
|
|
debe55 |
int EVP_CIPHER_CTX_get_original_iv(EVP_CIPHER_CTX *ctx, void *buf, size_t len);
|
|
|
debe55 |
+int EVP_MD_get_size(const EVP_MD* md);
|
|
|
debe55 |
int EVP_PKEY_CTX_set_rsa_keygen_bits(EVP_PKEY_CTX* ctx, int bits);
|
|
|
debe55 |
int EVP_PKEY_CTX_set_rsa_oaep_md(EVP_PKEY_CTX* ctx, const EVP_MD* md);
|
|
|
debe55 |
int EVP_PKEY_CTX_set_rsa_padding(EVP_PKEY_CTX* ctx, int pad_mode);
|
|
|
debe55 |
int EVP_PKEY_CTX_set_rsa_pss_saltlen(EVP_PKEY_CTX* ctx, int saltlen);
|
|
|
debe55 |
int EVP_PKEY_CTX_set_signature_md(EVP_PKEY_CTX* ctx, const EVP_MD* md);
|
|
|
debe55 |
+int EVP_PKEY_get_base_id(const EVP_PKEY* pkey);
|
|
|
debe55 |
+int EVP_PKEY_get_size(const EVP_PKEY* pkey);
|
|
|
debe55 |
OSSL_PROVIDER* OSSL_PROVIDER_try_load(OSSL_LIB_CTX* , const char* name, int retain_fallbacks);
|
|
|
debe55 |
X509* SSL_get1_peer_certificate(const SSL* ssl);
|
|
|
debe55 |
diff --git a/src/Native/Unix/System.Security.Cryptography.Native/pal_evp.c b/src/Native/Unix/System.Security.Cryptography.Native/pal_evp.c
|
|
|
debe55 |
index 9665ffe3fa..5ec3c63122 100644
|
|
|
debe55 |
--- a/src/Native/Unix/System.Security.Cryptography.Native/pal_evp.c
|
|
|
debe55 |
+++ b/src/Native/Unix/System.Security.Cryptography.Native/pal_evp.c
|
|
|
debe55 |
@@ -59,7 +59,7 @@ int32_t CryptoNative_EvpDigestFinalEx(EVP_MD_CTX* ctx, uint8_t* md, uint32_t* s)
|
|
|
debe55 |
|
|
|
debe55 |
int32_t CryptoNative_EvpMdSize(const EVP_MD* md)
|
|
|
debe55 |
{
|
|
|
debe55 |
- return EVP_MD_size(md);
|
|
|
debe55 |
+ return EVP_MD_get_size(md);
|
|
|
debe55 |
}
|
|
|
debe55 |
|
|
|
debe55 |
const EVP_MD* CryptoNative_EvpMd5()
|
|
|
debe55 |
diff --git a/src/Native/Unix/System.Security.Cryptography.Native/pal_evp_pkey.c b/src/Native/Unix/System.Security.Cryptography.Native/pal_evp_pkey.c
|
|
|
debe55 |
index f232b382ea..67410bc4e8 100644
|
|
|
debe55 |
--- a/src/Native/Unix/System.Security.Cryptography.Native/pal_evp_pkey.c
|
|
|
debe55 |
+++ b/src/Native/Unix/System.Security.Cryptography.Native/pal_evp_pkey.c
|
|
|
debe55 |
@@ -21,7 +21,7 @@ void CryptoNative_EvpPkeyDestroy(EVP_PKEY* pkey)
|
|
|
debe55 |
int32_t CryptoNative_EvpPKeySize(EVP_PKEY* pkey)
|
|
|
debe55 |
{
|
|
|
debe55 |
assert(pkey != NULL);
|
|
|
debe55 |
- return EVP_PKEY_size(pkey);
|
|
|
debe55 |
+ return EVP_PKEY_get_size(pkey);
|
|
|
debe55 |
}
|
|
|
debe55 |
|
|
|
debe55 |
int32_t CryptoNative_UpRefEvpPkey(EVP_PKEY* pkey)
|
|
|
debe55 |
--
|
|
|
debe55 |
2.31.1
|
|
|
debe55 |
|