bn/bn_exp.c: harmonize.
This commit is contained in:
parent
3d7bf77f61
commit
cbce8c4644
@ -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,
|
|||||||
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 (m->d[j-1] & (((BN_ULONG)1)<<(BN_BITS2-1)))
|
||||||
|
{
|
||||||
if (bn_wexpand(r,j) == NULL) goto err;
|
if (bn_wexpand(r,j) == NULL) goto err;
|
||||||
r->d[0] = (0-m->d[0])&BN_MASK2; /* 2^(top*BN_BITS2) - m */
|
/* 2^(top*BN_BITS2) - m */
|
||||||
|
r->d[0] = (0-m->d[0])&BN_MASK2;
|
||||||
for(i=1;i<j;i++) r->d[i] = (~m->d[i])&BN_MASK2;
|
for(i=1;i<j;i++) r->d[i] = (~m->d[i])&BN_MASK2;
|
||||||
r->top = j;
|
r->top = j;
|
||||||
#else
|
}
|
||||||
if (!BN_to_montgomery(r,BN_value_one(),mont,ctx)) goto err;
|
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,
|
|||||||
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:
|
|||||||
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,
|
|||||||
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,
|
|||||||
|
|
||||||
/* 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,
|
|||||||
|
|
||||||
/* 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.d[0] = (0-m->d[0])&BN_MASK2;
|
||||||
|
for (i=1;i<top;i++) tmp.d[i] = (~m->d[i])&BN_MASK2;
|
||||||
tmp.top = top;
|
tmp.top = top;
|
||||||
#else
|
}
|
||||||
if (!BN_to_montgomery(&tmp,BN_value_one(),mont,ctx)) goto err;
|
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,
|
|||||||
}
|
}
|
||||||
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,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* 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 */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user