Blame SOURCES/corefx-openssl-0001-Use-EVP_PKEY-for-RSA-key-generation.patch

debe55
From 2b6b45878b1be4d77eec34ab5bc80b626995a8c5 Mon Sep 17 00:00:00 2001
debe55
From: Jeremy Barton <jbarton@microsoft.com>
debe55
Date: Fri, 19 Mar 2021 15:05:41 -0700
debe55
Subject: [PATCH 01/11] Use EVP_PKEY for RSA key generation
debe55
debe55
---
debe55
 .../Interop.EvpPkey.Rsa.cs                    | 16 ++++++++
debe55
 .../Interop.Rsa.cs                            |  3 --
debe55
 .../Security/Cryptography/RSAOpenSsl.cs       | 37 ++++---------------
debe55
 .../apibridge.c                               |  8 ++++
debe55
 .../apibridge.h                               |  1 +
debe55
 .../opensslshim.h                             | 23 ++++++++++++
debe55
 .../pal_evp_pkey_rsa.c                        | 29 +++++++++++++++
debe55
 .../pal_evp_pkey_rsa.h                        |  5 +++
debe55
 .../pal_rsa.c                                 |  5 ---
debe55
 .../pal_rsa.h                                 |  7 ----
debe55
 ...em.Security.Cryptography.Algorithms.csproj |  3 ++
debe55
 11 files changed, 93 insertions(+), 44 deletions(-)
debe55
debe55
diff --git a/src/Common/src/Interop/Unix/System.Security.Cryptography.Native/Interop.EvpPkey.Rsa.cs b/src/Common/src/Interop/Unix/System.Security.Cryptography.Native/Interop.EvpPkey.Rsa.cs
debe55
index 1f61a826a9..c28522784b 100644
debe55
--- a/src/Common/src/Interop/Unix/System.Security.Cryptography.Native/Interop.EvpPkey.Rsa.cs
debe55
+++ b/src/Common/src/Interop/Unix/System.Security.Cryptography.Native/Interop.EvpPkey.Rsa.cs
debe55
@@ -10,6 +10,22 @@ internal static partial class Interop
debe55
 {
debe55
     internal static partial class Crypto
debe55
     {
debe55
+        [DllImport(Libraries.CryptoNative, EntryPoint = "CryptoNative_RsaGenerateKey")]
debe55
+        private static extern SafeEvpPKeyHandle CryptoNative_RsaGenerateKey(int keySize);
debe55
+
debe55
+        internal static SafeEvpPKeyHandle RsaGenerateKey(int keySize)
debe55
+        {
debe55
+            SafeEvpPKeyHandle pkey = CryptoNative_RsaGenerateKey(keySize);
debe55
+
debe55
+            if (pkey.IsInvalid)
debe55
+            {
debe55
+                pkey.Dispose();
debe55
+                throw CreateOpenSslCryptographicException();
debe55
+            }
debe55
+
debe55
+            return pkey;
debe55
+        }
debe55
+
debe55
         [DllImport(Libraries.CryptoNative, EntryPoint = "CryptoNative_EvpPkeyGetRsa")]
debe55
         internal static extern SafeRsaHandle EvpPkeyGetRsa(SafeEvpPKeyHandle pkey);
debe55
 
debe55
diff --git a/src/Common/src/Interop/Unix/System.Security.Cryptography.Native/Interop.Rsa.cs b/src/Common/src/Interop/Unix/System.Security.Cryptography.Native/Interop.Rsa.cs
debe55
index a7b85ae011..a05f020ada 100644
debe55
--- a/src/Common/src/Interop/Unix/System.Security.Cryptography.Native/Interop.Rsa.cs
debe55
+++ b/src/Common/src/Interop/Unix/System.Security.Cryptography.Native/Interop.Rsa.cs
debe55
@@ -89,9 +89,6 @@ internal static partial class Crypto
debe55
         [DllImport(Libraries.CryptoNative, EntryPoint = "CryptoNative_RsaSize")]
debe55
         internal static extern int RsaSize(SafeRsaHandle rsa);
debe55
 
debe55
-        [DllImport(Libraries.CryptoNative, EntryPoint = "CryptoNative_RsaGenerateKeyEx")]
debe55
-        internal static extern int RsaGenerateKeyEx(SafeRsaHandle rsa, int bits, SafeBignumHandle e);
debe55
-
debe55
         internal static bool RsaSign(int type, ReadOnlySpan<byte> m, int m_len, Span<byte> sigret, out int siglen, SafeRsaHandle rsa) =>
debe55
             RsaSign(type, ref MemoryMarshal.GetReference(m), m_len, ref MemoryMarshal.GetReference(sigret), out siglen, rsa);
debe55
 
debe55
diff --git a/src/Common/src/System/Security/Cryptography/RSAOpenSsl.cs b/src/Common/src/System/Security/Cryptography/RSAOpenSsl.cs
debe55
index 6741d28bba..4d4a8414b3 100644
debe55
--- a/src/Common/src/System/Security/Cryptography/RSAOpenSsl.cs
debe55
+++ b/src/Common/src/System/Security/Cryptography/RSAOpenSsl.cs
debe55
@@ -25,9 +25,6 @@ public sealed partial class RSAOpenSsl : RSA
debe55
     {
debe55
         private const int BitsPerByte = 8;
debe55
 
debe55
-        // 65537 (0x10001) in big-endian form
debe55
-        private static readonly byte[] s_defaultExponent = { 0x01, 0x00, 0x01 };
debe55
-
debe55
         private Lazy<SafeRsaHandle> _key;
debe55
 
debe55
         public RSAOpenSsl()
debe55
@@ -585,36 +582,18 @@ private static void CheckBoolReturn(int returnValue)
debe55
 
debe55
         private SafeRsaHandle GenerateKey()
debe55
         {
debe55
-            SafeRsaHandle key = Interop.Crypto.RsaCreate();
debe55
-            bool generated = false;
debe55
-
debe55
-            Interop.Crypto.CheckValidOpenSslHandle(key);
debe55
-
debe55
-            try
debe55
+            using (SafeEvpPKeyHandle pkey = Interop.Crypto.RsaGenerateKey(KeySize))
debe55
             {
debe55
-                using (SafeBignumHandle exponent = Interop.Crypto.CreateBignum(s_defaultExponent))
debe55
-                {
debe55
-                    // The documentation for RSA_generate_key_ex does not say that it returns only
debe55
-                    // 0 or 1, so the call marshals it back as a full Int32 and checks for a value
debe55
-                    // of 1 explicitly.
debe55
-                    int response = Interop.Crypto.RsaGenerateKeyEx(
debe55
-                        key,
debe55
-                        KeySize,
debe55
-                        exponent);
debe55
-
debe55
-                    CheckBoolReturn(response);
debe55
-                    generated = true;
debe55
-                }
debe55
-            }
debe55
-            finally
debe55
-            {
debe55
-                if (!generated)
debe55
+                SafeRsaHandle rsa = Interop.Crypto.EvpPkeyGetRsa(pkey);
debe55
+
debe55
+                if (rsa.IsInvalid)
debe55
                 {
debe55
-                    key.Dispose();
debe55
+                    rsa.Dispose();
debe55
+                    throw Interop.Crypto.CreateOpenSslCryptographicException();
debe55
                 }
debe55
-            }
debe55
 
debe55
-            return key;
debe55
+                return rsa;
debe55
+            }
debe55
         }
debe55
 
debe55
         protected override byte[] HashData(byte[] data, int offset, int count, HashAlgorithmName hashAlgorithm) =>
debe55
diff --git a/src/Native/Unix/System.Security.Cryptography.Native/apibridge.c b/src/Native/Unix/System.Security.Cryptography.Native/apibridge.c
debe55
index 167de7fd8e..def7198deb 100644
debe55
--- a/src/Native/Unix/System.Security.Cryptography.Native/apibridge.c
debe55
+++ b/src/Native/Unix/System.Security.Cryptography.Native/apibridge.c
debe55
@@ -728,4 +728,12 @@ void local_SSL_CTX_set_security_level(SSL_CTX* ctx, int32_t level)
debe55
     (void)ctx;
debe55
     (void)level;
debe55
 }
debe55
+
debe55
+int32_t local_RSA_pkey_ctx_ctrl(EVP_PKEY_CTX* ctx, int32_t optype, int32_t cmd, int32_t p1, void* p2)
debe55
+{
debe55
+    // On OpenSSL 1.0.2 there aren't two different identifiers for RSA,
debe55
+    // so just pass the request on th EVP_PKEY_CTX_ctrl with the only identifier defined.
debe55
+    return EVP_PKEY_CTX_ctrl(ctx, EVP_PKEY_RSA, optype, cmd, p1, p2);
debe55
+}
debe55
+
debe55
 #endif
debe55
diff --git a/src/Native/Unix/System.Security.Cryptography.Native/apibridge.h b/src/Native/Unix/System.Security.Cryptography.Native/apibridge.h
debe55
index 5f62864b24..b58611ae73 100644
debe55
--- a/src/Native/Unix/System.Security.Cryptography.Native/apibridge.h
debe55
+++ b/src/Native/Unix/System.Security.Cryptography.Native/apibridge.h
debe55
@@ -26,6 +26,7 @@ int32_t local_RSA_meth_get_flags(const RSA_METHOD* meth);
debe55
 int32_t local_RSA_set0_crt_params(RSA* rsa, BIGNUM* dmp1, BIGNUM* dmq1, BIGNUM* iqmp);
debe55
 int32_t local_RSA_set0_factors(RSA* rsa, BIGNUM* p, BIGNUM* q);
debe55
 int32_t local_RSA_set0_key(RSA* rsa, BIGNUM* n, BIGNUM* e, BIGNUM* d);
debe55
+int32_t local_RSA_pkey_ctx_ctrl(EVP_PKEY_CTX* ctx, int32_t optype, int32_t cmd, int32_t p1, void* p2);
debe55
 int32_t local_SSL_is_init_finished(const SSL* ssl);
debe55
 unsigned long local_SSL_CTX_set_options(SSL_CTX* ctx, unsigned long options);
debe55
 void local_SSL_CTX_set_security_level(SSL_CTX* ctx, int32_t level);
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 ed3994926d..dff6091e9e 100644
debe55
--- a/src/Native/Unix/System.Security.Cryptography.Native/opensslshim.h
debe55
+++ b/src/Native/Unix/System.Security.Cryptography.Native/opensslshim.h
debe55
@@ -145,6 +145,7 @@ void RSA_get0_factors(const RSA* rsa, const BIGNUM** p, const BIGNUM** q);
debe55
 void RSA_get0_key(const RSA* rsa, const BIGNUM** n, const BIGNUM** e, const BIGNUM** d);
debe55
 int32_t RSA_meth_get_flags(const RSA_METHOD* meth);
debe55
 const RSA_METHOD* RSA_PKCS1_OpenSSL(void);
debe55
+int32_t RSA_pkey_ctx_ctrl(EVP_PKEY_CTX* ctx, int32_t optype, int32_t cmd, int32_t p1, void* p2);
debe55
 int32_t RSA_set0_crt_params(RSA* rsa, BIGNUM* dmp1, BIGNUM* dmq1, BIGNUM* iqmp);
debe55
 int32_t RSA_set0_factors(RSA* rsa, BIGNUM* p, BIGNUM* q);
debe55
 int32_t RSA_set0_key(RSA* rsa, BIGNUM* n, BIGNUM* e, BIGNUM* d);
debe55
@@ -170,6 +171,13 @@ const X509_ALGOR* X509_get0_tbs_sigalg(const X509* x509);
debe55
 X509_PUBKEY* X509_get_X509_PUBKEY(const X509* x509);
debe55
 int32_t X509_get_version(const X509* x509);
debe55
 int32_t X509_up_ref(X509* x509);
debe55
+
debe55
+// Redefine EVP_PKEY_CTX_set_rsa operations to use (local_)RSA_pkey_ctx_ctrl so the path is the same
debe55
+// for 1.0-built on 1.1 as on 1.1-built on 1.1.
debe55
+#undef EVP_PKEY_CTX_set_rsa_keygen_bits
debe55
+#define EVP_PKEY_CTX_set_rsa_keygen_bits(ctx, bits) \
debe55
+    RSA_pkey_ctx_ctrl(ctx, EVP_PKEY_OP_KEYGEN, EVP_PKEY_CTRL_RSA_KEYGEN_BITS, bits, NULL)
debe55
+
debe55
 #endif
debe55
 
debe55
 #if OPENSSL_VERSION_NUMBER < OPENSSL_VERSION_1_0_2_RTM
debe55
@@ -341,8 +349,12 @@ void SSL_get0_alpn_selected(const SSL* ssl, const unsigned char** protocol, unsi
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
+    REQUIRED_FUNCTION(EVP_PKEY_CTX_ctrl) \
debe55
     REQUIRED_FUNCTION(EVP_PKEY_CTX_free) \
debe55
+    REQUIRED_FUNCTION(EVP_PKEY_CTX_get0_pkey) \
debe55
     REQUIRED_FUNCTION(EVP_PKEY_CTX_new) \
debe55
+    REQUIRED_FUNCTION(EVP_PKEY_CTX_new_id) \
debe55
+    REQUIRED_FUNCTION(EVP_PKEY_base_id) \
debe55
     REQUIRED_FUNCTION(EVP_PKEY_derive_set_peer) \
debe55
     REQUIRED_FUNCTION(EVP_PKEY_derive_init) \
debe55
     REQUIRED_FUNCTION(EVP_PKEY_derive) \
debe55
@@ -350,6 +362,8 @@ void SSL_get0_alpn_selected(const SSL* ssl, const unsigned char** protocol, unsi
debe55
     REQUIRED_FUNCTION(EVP_PKEY_get1_DSA) \
debe55
     REQUIRED_FUNCTION(EVP_PKEY_get1_EC_KEY) \
debe55
     REQUIRED_FUNCTION(EVP_PKEY_get1_RSA) \
debe55
+    REQUIRED_FUNCTION(EVP_PKEY_keygen) \
debe55
+    REQUIRED_FUNCTION(EVP_PKEY_keygen_init) \
debe55
     REQUIRED_FUNCTION(EVP_PKEY_new) \
debe55
     REQUIRED_FUNCTION(EVP_PKEY_set1_DSA) \
debe55
     REQUIRED_FUNCTION(EVP_PKEY_set1_EC_KEY) \
debe55
@@ -432,6 +446,7 @@ void SSL_get0_alpn_selected(const SSL* ssl, const unsigned char** protocol, unsi
debe55
     FALLBACK_FUNCTION(RSA_get0_key) \
debe55
     FALLBACK_FUNCTION(RSA_meth_get_flags) \
debe55
     REQUIRED_FUNCTION(RSA_new) \
debe55
+    FALLBACK_FUNCTION(RSA_pkey_ctx_ctrl) \
debe55
     RENAMED_FUNCTION(RSA_PKCS1_OpenSSL, RSA_PKCS1_SSLeay) \
debe55
     REQUIRED_FUNCTION(RSA_private_decrypt) \
debe55
     REQUIRED_FUNCTION(RSA_private_encrypt) \
debe55
@@ -727,8 +742,12 @@ FOR_ALL_OPENSSL_FUNCTIONS
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_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
 #define EVP_PKEY_CTX_new EVP_PKEY_CTX_new_ptr
debe55
+#define EVP_PKEY_CTX_new_id EVP_PKEY_CTX_new_id_ptr
debe55
+#define EVP_PKEY_base_id EVP_PKEY_base_id_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
@@ -736,6 +755,8 @@ FOR_ALL_OPENSSL_FUNCTIONS
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
 #define EVP_PKEY_get1_RSA EVP_PKEY_get1_RSA_ptr
debe55
+#define EVP_PKEY_keygen EVP_PKEY_keygen_ptr
debe55
+#define EVP_PKEY_keygen_init EVP_PKEY_keygen_init_ptr
debe55
 #define EVP_PKEY_new EVP_PKEY_new_ptr
debe55
 #define EVP_PKEY_set1_DSA EVP_PKEY_set1_DSA_ptr
debe55
 #define EVP_PKEY_set1_EC_KEY EVP_PKEY_set1_EC_KEY_ptr
debe55
@@ -818,6 +839,7 @@ FOR_ALL_OPENSSL_FUNCTIONS
debe55
 #define RSA_get_method RSA_get_method_ptr
debe55
 #define RSA_meth_get_flags RSA_meth_get_flags_ptr
debe55
 #define RSA_new RSA_new_ptr
debe55
+#define RSA_pkey_ctx_ctrl RSA_pkey_ctx_ctrl_ptr
debe55
 #define RSA_PKCS1_OpenSSL RSA_PKCS1_OpenSSL_ptr
debe55
 #define RSA_private_decrypt RSA_private_decrypt_ptr
debe55
 #define RSA_private_encrypt RSA_private_encrypt_ptr
debe55
@@ -1026,6 +1048,7 @@ FOR_ALL_OPENSSL_FUNCTIONS
debe55
 #define RSA_set0_crt_params local_RSA_set0_crt_params
debe55
 #define RSA_set0_factors local_RSA_set0_factors
debe55
 #define RSA_set0_key local_RSA_set0_key
debe55
+#define RSA_pkey_ctx_ctrl local_RSA_pkey_ctx_ctrl
debe55
 #define SSL_CTX_set_security_level local_SSL_CTX_set_security_level
debe55
 #define SSL_is_init_finished local_SSL_is_init_finished
debe55
 #define X509_CRL_get0_nextUpdate local_X509_CRL_get0_nextUpdate
debe55
diff --git a/src/Native/Unix/System.Security.Cryptography.Native/pal_evp_pkey_rsa.c b/src/Native/Unix/System.Security.Cryptography.Native/pal_evp_pkey_rsa.c
debe55
index e8d961dbd2..29f9238ce9 100644
debe55
--- a/src/Native/Unix/System.Security.Cryptography.Native/pal_evp_pkey_rsa.c
debe55
+++ b/src/Native/Unix/System.Security.Cryptography.Native/pal_evp_pkey_rsa.c
debe55
@@ -4,6 +4,35 @@
debe55
 
debe55
 #include "pal_evp_pkey_rsa.h"
debe55
 
debe55
+EVP_PKEY* CryptoNative_RsaGenerateKey(int keySize)
debe55
+{
debe55
+    EVP_PKEY_CTX* ctx = EVP_PKEY_CTX_new_id(EVP_PKEY_RSA, NULL);
debe55
+
debe55
+    if (ctx == NULL)
debe55
+    {
debe55
+        return NULL;
debe55
+    }
debe55
+
debe55
+    EVP_PKEY* pkey = NULL;
debe55
+    EVP_PKEY* ret = NULL;
debe55
+
debe55
+    if (EVP_PKEY_keygen_init(ctx) == 1 &&
debe55
+        EVP_PKEY_CTX_set_rsa_keygen_bits(ctx, keySize) == 1 &&
debe55
+        EVP_PKEY_keygen(ctx, &pkey) == 1)
debe55
+    {
debe55
+        ret = pkey;
debe55
+        pkey = NULL;
debe55
+    }
debe55
+
debe55
+    if (pkey != NULL)
debe55
+    {
debe55
+        EVP_PKEY_free(pkey);
debe55
+    }
debe55
+
debe55
+    EVP_PKEY_CTX_free(ctx);
debe55
+    return ret;
debe55
+}
debe55
+
debe55
 RSA* CryptoNative_EvpPkeyGetRsa(EVP_PKEY* pkey)
debe55
 {
debe55
     return EVP_PKEY_get1_RSA(pkey);
debe55
diff --git a/src/Native/Unix/System.Security.Cryptography.Native/pal_evp_pkey_rsa.h b/src/Native/Unix/System.Security.Cryptography.Native/pal_evp_pkey_rsa.h
debe55
index d8ff369670..1fda149414 100644
debe55
--- a/src/Native/Unix/System.Security.Cryptography.Native/pal_evp_pkey_rsa.h
debe55
+++ b/src/Native/Unix/System.Security.Cryptography.Native/pal_evp_pkey_rsa.h
debe55
@@ -6,6 +6,11 @@
debe55
 #include "pal_compiler.h"
debe55
 #include "opensslshim.h"
debe55
 
debe55
+/*
debe55
+Creates an RSA key of the requested size.
debe55
+*/
debe55
+DLLEXPORT EVP_PKEY* CryptoNative_RsaGenerateKey(int32_t keySize);
debe55
+
debe55
 /*
debe55
 Shims the EVP_PKEY_get1_RSA method.
debe55
 
debe55
diff --git a/src/Native/Unix/System.Security.Cryptography.Native/pal_rsa.c b/src/Native/Unix/System.Security.Cryptography.Native/pal_rsa.c
debe55
index f764815a04..080027de0e 100644
debe55
--- a/src/Native/Unix/System.Security.Cryptography.Native/pal_rsa.c
debe55
+++ b/src/Native/Unix/System.Security.Cryptography.Native/pal_rsa.c
debe55
@@ -143,11 +143,6 @@ int32_t CryptoNative_RsaSize(RSA* rsa)
debe55
     return RSA_size(rsa);
debe55
 }
debe55
 
debe55
-int32_t CryptoNative_RsaGenerateKeyEx(RSA* rsa, int32_t bits, BIGNUM* e)
debe55
-{
debe55
-    return RSA_generate_key_ex(rsa, bits, e, NULL);
debe55
-}
debe55
-
debe55
 int32_t
debe55
 CryptoNative_RsaSign(int32_t type, const uint8_t* m, int32_t mlen, uint8_t* sigret, int32_t* siglen, RSA* rsa)
debe55
 {
debe55
diff --git a/src/Native/Unix/System.Security.Cryptography.Native/pal_rsa.h b/src/Native/Unix/System.Security.Cryptography.Native/pal_rsa.h
debe55
index b85fed627f..1c0bc2df47 100644
debe55
--- a/src/Native/Unix/System.Security.Cryptography.Native/pal_rsa.h
debe55
+++ b/src/Native/Unix/System.Security.Cryptography.Native/pal_rsa.h
debe55
@@ -86,13 +86,6 @@ Returns the RSA modulus size in bytes.
debe55
 */
debe55
 DLLEXPORT int32_t CryptoNative_RsaSize(RSA* rsa);
debe55
 
debe55
-/*
debe55
-Shims the RSA_generate_key_ex method.
debe55
-
debe55
-Returns 1 upon success, otherwise 0.
debe55
-*/
debe55
-DLLEXPORT int32_t CryptoNative_RsaGenerateKeyEx(RSA* rsa, int32_t bits, BIGNUM* e);
debe55
-
debe55
 /*
debe55
 Shims the RSA_sign method.
debe55
 
debe55
diff --git a/src/System.Security.Cryptography.Algorithms/src/System.Security.Cryptography.Algorithms.csproj b/src/System.Security.Cryptography.Algorithms/src/System.Security.Cryptography.Algorithms.csproj
debe55
index fa63b6e2fe..6ad2b78e01 100644
debe55
--- a/src/System.Security.Cryptography.Algorithms/src/System.Security.Cryptography.Algorithms.csproj
debe55
+++ b/src/System.Security.Cryptography.Algorithms/src/System.Security.Cryptography.Algorithms.csproj
debe55
@@ -507,6 +507,9 @@
debe55
     <Compile Include="$(CommonPath)\Interop\Unix\System.Security.Cryptography.Native\Interop.EvpPkey.Ecdh.cs">
debe55
       <Link>Common\Interop\Unix\System.Security.Cryptography.Native\Interop.EvpPkey.Ecdh.cs</Link>
debe55
     </Compile>
debe55
+    <Compile Include="$(CommonPath)\Interop\Unix\System.Security.Cryptography.Native\Interop.EvpPkey.Rsa.cs">
debe55
+      <Link>Common\Interop\Unix\System.Security.Cryptography.Native\Interop.EvpPkey.Rsa.cs</Link>
debe55
+    </Compile>
debe55
     <Compile Include="$(CommonPath)\Interop\Unix\System.Security.Cryptography.Native\Interop.EVP.cs">
debe55
       <Link>Common\Interop\Unix\System.Security.Cryptography.Native\Interop.EVP.cs</Link>
debe55
     </Compile>
debe55
-- 
debe55
2.31.1
debe55