RSA_eay_private_encrypt,
RSA_eay_private_decrypt,
RSA_eay_mod_exp,
- BN_mod_exp_mont,
+ BN_mod_exp_mont, /* XXX probably we should not use Montgomery if e == 3 */
RSA_eay_init,
RSA_eay_finish,
0,
NULL,
};
-RSA_METHOD *RSA_PKCS1_SSLeay(void)
+const RSA_METHOD *RSA_PKCS1_SSLeay(void)
{
return(&rsa_pkcs1_eay_meth);
}
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,
/* 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,
{
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);
}
}