aboutsummaryrefslogtreecommitdiffstats
path: root/crypto/rsa
diff options
context:
space:
mode:
authorBodo Möller <bodo@openssl.org>2000-12-18 09:00:48 +0000
committerBodo Möller <bodo@openssl.org>2000-12-18 09:00:48 +0000
commitf640ee90c39c5496fc2ec212b869c7cc221bc76e (patch)
treeea801a4892687f5829e30763a6df1fa86f847b9b /crypto/rsa
parent09f4278d25815300f6b8a490e83a4da5bae0f847 (diff)
downloadopenssl-f640ee90c39c5496fc2ec212b869c7cc221bc76e.tar.gz
Obtain lock CRYPTO_LOCK_RSA before creating BN_MONT_CTX
structures and setting rsa->_method_mod_{n,p,q}. Submitted by: "Reddie, Steven" <Steven.Reddie@ca.com>
Diffstat (limited to 'crypto/rsa')
-rw-r--r--crypto/rsa/rsa_eay.c82
1 files changed, 70 insertions, 12 deletions
diff --git a/crypto/rsa/rsa_eay.c b/crypto/rsa/rsa_eay.c
index 37baaacfc7..e675d0a7b8 100644
--- a/crypto/rsa/rsa_eay.c
+++ b/crypto/rsa/rsa_eay.c
@@ -141,9 +141,24 @@ static int RSA_eay_public_encrypt(int flen, const unsigned char *from,
if ((rsa->_method_mod_n == NULL) && (rsa->flags & RSA_FLAG_CACHE_PUBLIC))
{
- if ((rsa->_method_mod_n=BN_MONT_CTX_new()) != NULL)
- if (!BN_MONT_CTX_set(rsa->_method_mod_n,rsa->n,ctx))
- goto err;
+ CRYPTO_w_lock(CRYPTO_LOCK_RSA);
+ if (rsa->_method_mod_n == NULL)
+ {
+ BN_MONT_CTX* bn_mont_ctx;
+ if ((bn_mont_ctx=BN_MONT_CTX_new()) == NULL)
+ {
+ CRYPTO_w_unlock(CRYPTO_LOCK_RSA);
+ goto err;
+ }
+ if (!BN_MONT_CTX_set(bn_mont_ctx,rsa->n,ctx))
+ {
+ BN_MONT_CTX_free(bn_mont_ctx);
+ CRYPTO_w_unlock(CRYPTO_LOCK_RSA);
+ goto err;
+ }
+ rsa->_method_mod_n = bn_mont_ctx;
+ }
+ CRYPTO_w_unlock(CRYPTO_LOCK_RSA);
}
if (!meth->bn_mod_exp(&ret,&f,rsa->e,rsa->n,ctx,
@@ -378,9 +393,24 @@ static int RSA_eay_public_decrypt(int flen, const unsigned char *from,
/* do the decrypt */
if ((rsa->_method_mod_n == NULL) && (rsa->flags & RSA_FLAG_CACHE_PUBLIC))
{
- if ((rsa->_method_mod_n=BN_MONT_CTX_new()) != NULL)
- if (!BN_MONT_CTX_set(rsa->_method_mod_n,rsa->n,ctx))
- goto err;
+ CRYPTO_w_lock(CRYPTO_LOCK_RSA);
+ if (rsa->_method_mod_n == NULL)
+ {
+ BN_MONT_CTX* bn_mont_ctx;
+ if ((bn_mont_ctx=BN_MONT_CTX_new()) == NULL)
+ {
+ CRYPTO_w_unlock(CRYPTO_LOCK_RSA);
+ goto err;
+ }
+ if (!BN_MONT_CTX_set(bn_mont_ctx,rsa->n,ctx))
+ {
+ BN_MONT_CTX_free(bn_mont_ctx);
+ CRYPTO_w_unlock(CRYPTO_LOCK_RSA);
+ goto err;
+ }
+ rsa->_method_mod_n = bn_mont_ctx;
+ }
+ CRYPTO_w_unlock(CRYPTO_LOCK_RSA);
}
if (!meth->bn_mod_exp(&ret,&f,rsa->e,rsa->n,ctx,
@@ -432,17 +462,45 @@ static int RSA_eay_mod_exp(BIGNUM *r0, const BIGNUM *I, RSA *rsa)
{
if (rsa->_method_mod_p == NULL)
{
- if ((rsa->_method_mod_p=BN_MONT_CTX_new()) != NULL)
- if (!BN_MONT_CTX_set(rsa->_method_mod_p,rsa->p,
- ctx))
+ CRYPTO_w_lock(CRYPTO_LOCK_RSA);
+ if (rsa->_method_mod_p == NULL)
+ {
+ BN_MONT_CTX* bn_mont_ctx;
+ if ((bn_mont_ctx=BN_MONT_CTX_new()) == NULL)
+ {
+ CRYPTO_w_unlock(CRYPTO_LOCK_RSA);
+ goto err;
+ }
+ if (!BN_MONT_CTX_set(bn_mont_ctx,rsa->p,ctx))
+ {
+ BN_MONT_CTX_free(bn_mont_ctx);
+ CRYPTO_w_unlock(CRYPTO_LOCK_RSA);
goto err;
+ }
+ rsa->_method_mod_p = bn_mont_ctx;
+ }
+ CRYPTO_w_unlock(CRYPTO_LOCK_RSA);
}
if (rsa->_method_mod_q == NULL)
{
- if ((rsa->_method_mod_q=BN_MONT_CTX_new()) != NULL)
- if (!BN_MONT_CTX_set(rsa->_method_mod_q,rsa->q,
- ctx))
+ CRYPTO_w_lock(CRYPTO_LOCK_RSA);
+ if (rsa->_method_mod_q == NULL)
+ {
+ BN_MONT_CTX* bn_mont_ctx;
+ if ((bn_mont_ctx=BN_MONT_CTX_new()) == NULL)
+ {
+ CRYPTO_w_unlock(CRYPTO_LOCK_RSA);
+ goto err;
+ }
+ if (!BN_MONT_CTX_set(bn_mont_ctx,rsa->q,ctx))
+ {
+ BN_MONT_CTX_free(bn_mont_ctx);
+ CRYPTO_w_unlock(CRYPTO_LOCK_RSA);
goto err;
+ }
+ rsa->_method_mod_q = bn_mont_ctx;
+ }
+ CRYPTO_w_unlock(CRYPTO_LOCK_RSA);
}
}