提交 cbce8c46 编写于 作者: A Andy Polyakov

bn/bn_exp.c: harmonize.

上级 3d7bf77f
...@@ -128,9 +128,11 @@ ...@@ -128,9 +128,11 @@
# include <alloca.h> # include <alloca.h>
#endif #endif
#undef SPARC_T4_MONT
#if defined(OPENSSL_BN_ASM_MONT) && (defined(__sparc__) || defined(__sparc)) #if defined(OPENSSL_BN_ASM_MONT) && (defined(__sparc__) || defined(__sparc))
# include "sparc_arch.h" # include "sparc_arch.h"
extern unsigned int OPENSSL_sparcv9cap_P[]; extern unsigned int OPENSSL_sparcv9cap_P[];
# define SPARC_T4_MONT
#endif #endif
/* maximum precomputation table size for *variable* sliding windows */ /* maximum precomputation table size for *variable* sliding windows */
...@@ -476,14 +478,18 @@ int BN_mod_exp_mont(BIGNUM *rr, const BIGNUM *a, const BIGNUM *p, ...@@ -476,14 +478,18 @@ int BN_mod_exp_mont(BIGNUM *rr, const BIGNUM *a, const BIGNUM *p,
wend=0; /* The bottom bit of the window */ wend=0; /* The bottom bit of the window */
#if 1 /* by Shay Gueron's suggestion */ #if 1 /* by Shay Gueron's suggestion */
j = mont->N.top; /* borrow j */ j = m->top; /* borrow j */
if (bn_wexpand(r,j) == NULL) goto err; if (m->d[j-1] & (((BN_ULONG)1)<<(BN_BITS2-1)))
r->d[0] = (0-m->d[0])&BN_MASK2; /* 2^(top*BN_BITS2) - m */ {
for(i=1;i<j;i++) r->d[i] = (~m->d[i])&BN_MASK2; if (bn_wexpand(r,j) == NULL) goto err;
r->top = j; /* 2^(top*BN_BITS2) - m */
#else r->d[0] = (0-m->d[0])&BN_MASK2;
if (!BN_to_montgomery(r,BN_value_one(),mont,ctx)) goto err; for(i=1;i<j;i++) r->d[i] = (~m->d[i])&BN_MASK2;
r->top = j;
}
else
#endif #endif
if (!BN_to_montgomery(r,BN_value_one(),mont,ctx)) goto err;
for (;;) for (;;)
{ {
if (BN_is_bit_set(p,wstart) == 0) if (BN_is_bit_set(p,wstart) == 0)
...@@ -535,7 +541,7 @@ int BN_mod_exp_mont(BIGNUM *rr, const BIGNUM *a, const BIGNUM *p, ...@@ -535,7 +541,7 @@ int BN_mod_exp_mont(BIGNUM *rr, const BIGNUM *a, const BIGNUM *p,
start=0; start=0;
if (wstart < 0) break; if (wstart < 0) break;
} }
#if defined(OPENSSL_BN_ASM_MONT) && (defined(__sparc__) || defined(__sparc)) #if defined(SPARC_T4_MONT)
if (OPENSSL_sparcv9cap_P[0]&(SPARCV9_VIS3|SPARCV9_PREFER_FPU)) if (OPENSSL_sparcv9cap_P[0]&(SPARCV9_VIS3|SPARCV9_PREFER_FPU))
{ {
j = mont->N.top; /* borrow j */ j = mont->N.top; /* borrow j */
...@@ -555,7 +561,7 @@ err: ...@@ -555,7 +561,7 @@ err:
return(ret); return(ret);
} }
#if defined(OPENSSL_BN_ASM_MONT) && (defined(__sparc__) || defined(__sparc)) #if defined(SPARC_T4_MONT)
static BN_ULONG bn_get_bits(const BIGNUM *a, int bitpos) static BN_ULONG bn_get_bits(const BIGNUM *a, int bitpos)
{ {
BN_ULONG ret=0; BN_ULONG ret=0;
...@@ -636,7 +642,7 @@ int BN_mod_exp_mont_consttime(BIGNUM *rr, const BIGNUM *a, const BIGNUM *p, ...@@ -636,7 +642,7 @@ int BN_mod_exp_mont_consttime(BIGNUM *rr, const BIGNUM *a, const BIGNUM *p,
int powerbufLen = 0; int powerbufLen = 0;
unsigned char *powerbuf=NULL; unsigned char *powerbuf=NULL;
BIGNUM tmp, am; BIGNUM tmp, am;
#if defined(OPENSSL_BN_ASM_MONT) && (defined(__sparc__) || defined(__sparc)) #if defined(SPARC_T4_MONT)
unsigned int t4=0; unsigned int t4=0;
#endif #endif
...@@ -673,7 +679,7 @@ int BN_mod_exp_mont_consttime(BIGNUM *rr, const BIGNUM *a, const BIGNUM *p, ...@@ -673,7 +679,7 @@ int BN_mod_exp_mont_consttime(BIGNUM *rr, const BIGNUM *a, const BIGNUM *p,
/* Get the window size to use with size of p. */ /* Get the window size to use with size of p. */
window = BN_window_bits_for_ctime_exponent_size(bits); window = BN_window_bits_for_ctime_exponent_size(bits);
#if defined(OPENSSL_BN_ASM_MONT) && (defined(__sparc__) || defined(__sparc)) #if defined(SPARC_T4_MONT)
if (window>=5 && (top&15)==0 && top<=64 && if (window>=5 && (top&15)==0 && top<=64 &&
(OPENSSL_sparcv9cap_P[1]&(CFR_MONTMUL|CFR_MONTSQR))== (OPENSSL_sparcv9cap_P[1]&(CFR_MONTMUL|CFR_MONTSQR))==
(CFR_MONTMUL|CFR_MONTSQR) && (CFR_MONTMUL|CFR_MONTSQR) &&
...@@ -718,13 +724,16 @@ int BN_mod_exp_mont_consttime(BIGNUM *rr, const BIGNUM *a, const BIGNUM *p, ...@@ -718,13 +724,16 @@ int BN_mod_exp_mont_consttime(BIGNUM *rr, const BIGNUM *a, const BIGNUM *p,
/* prepare a^0 in Montgomery domain */ /* prepare a^0 in Montgomery domain */
#if 1 /* by Shay Gueron's suggestion */ #if 1 /* by Shay Gueron's suggestion */
tmp.d[0] = (0-m->d[0])&BN_MASK2; /* 2^(top*BN_BITS2) - m */ if (m->d[top-1] & (((BN_ULONG)1)<<(BN_BITS2-1)))
for (i=1;i<top;i++) {
tmp.d[i] = (~m->d[i])&BN_MASK2; /* 2^(top*BN_BITS2) - m */
tmp.top = top; tmp.d[0] = (0-m->d[0])&BN_MASK2;
#else for (i=1;i<top;i++) tmp.d[i] = (~m->d[i])&BN_MASK2;
if (!BN_to_montgomery(&tmp,BN_value_one(),mont,ctx)) goto err; tmp.top = top;
}
else
#endif #endif
if (!BN_to_montgomery(&tmp,BN_value_one(),mont,ctx)) goto err;
/* prepare a^1 in Montgomery domain */ /* prepare a^1 in Montgomery domain */
if (a->neg || BN_ucmp(a,m) >= 0) if (a->neg || BN_ucmp(a,m) >= 0)
...@@ -734,7 +743,7 @@ int BN_mod_exp_mont_consttime(BIGNUM *rr, const BIGNUM *a, const BIGNUM *p, ...@@ -734,7 +743,7 @@ int BN_mod_exp_mont_consttime(BIGNUM *rr, const BIGNUM *a, const BIGNUM *p,
} }
else if (!BN_to_montgomery(&am,a,mont,ctx)) goto err; else if (!BN_to_montgomery(&am,a,mont,ctx)) goto err;
#if defined(OPENSSL_BN_ASM_MONT) && (defined(__sparc__) || defined(__sparc)) #if defined(SPARC_T4_MONT)
if (t4) if (t4)
{ {
typedef int (*bn_pwr5_mont_f)(BN_ULONG *tp,const BN_ULONG *np, typedef int (*bn_pwr5_mont_f)(BN_ULONG *tp,const BN_ULONG *np,
...@@ -992,7 +1001,7 @@ int BN_mod_exp_mont_consttime(BIGNUM *rr, const BIGNUM *a, const BIGNUM *p, ...@@ -992,7 +1001,7 @@ int BN_mod_exp_mont_consttime(BIGNUM *rr, const BIGNUM *a, const BIGNUM *p,
} }
/* Convert the final result from montgomery to standard format */ /* Convert the final result from montgomery to standard format */
#if defined(OPENSSL_BN_ASM_MONT) && (defined(__sparc__) || defined(__sparc)) #if defined(SPARC_T4_MONT)
if (OPENSSL_sparcv9cap_P[0]&(SPARCV9_VIS3|SPARCV9_PREFER_FPU)) if (OPENSSL_sparcv9cap_P[0]&(SPARCV9_VIS3|SPARCV9_PREFER_FPU))
{ {
am.d[0] = 1; /* borrow am */ am.d[0] = 1; /* borrow am */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册