Commit cbce8c46 authored by Andy Polyakov's avatar Andy Polyakov
Browse files

bn/bn_exp.c: harmonize.

parent 3d7bf77f
Loading
Loading
Loading
Loading
+28 −19
Original line number Diff line number Diff line
@@ -128,9 +128,11 @@
# include <alloca.h>
#endif

#undef SPARC_T4_MONT
#if defined(OPENSSL_BN_ASM_MONT) && (defined(__sparc__) || defined(__sparc))
# include "sparc_arch.h"
extern unsigned int OPENSSL_sparcv9cap_P[];
# define SPARC_T4_MONT
#endif

/* 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 */

#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;
	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;
		r->top = j;
#else
	if (!BN_to_montgomery(r,BN_value_one(),mont,ctx)) goto err;
		}
	else
#endif
	if (!BN_to_montgomery(r,BN_value_one(),mont,ctx)) goto err;
	for (;;)
		{
		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;
		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))
		{
		j = mont->N.top;	/* borrow j */
@@ -555,7 +561,7 @@ err:
	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)
	{
	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;
	unsigned char *powerbuf=NULL;
	BIGNUM tmp, am;
#if defined(OPENSSL_BN_ASM_MONT) && (defined(__sparc__) || defined(__sparc))
#if defined(SPARC_T4_MONT)
	unsigned int t4=0;
#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. */
	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 &&
	    (OPENSSL_sparcv9cap_P[1]&(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 */
#if 1	/* by Shay Gueron's suggestion */
	tmp.d[0] = (0-m->d[0])&BN_MASK2;	/* 2^(top*BN_BITS2) - m */
	for (i=1;i<top;i++)
		tmp.d[i] = (~m->d[i])&BN_MASK2;
	if (m->d[top-1] & (((BN_ULONG)1)<<(BN_BITS2-1)))
		{
		/* 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;
#else
 	if (!BN_to_montgomery(&tmp,BN_value_one(),mont,ctx))	goto err;
		}
	else
#endif
 	if (!BN_to_montgomery(&tmp,BN_value_one(),mont,ctx))	goto err;

	/* prepare a^1 in Montgomery domain */
	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;

#if defined(OPENSSL_BN_ASM_MONT) && (defined(__sparc__) || defined(__sparc))
#if defined(SPARC_T4_MONT)
    if (t4)
	{
	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 */
#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))
		{
		am.d[0] = 1;	/* borrow am */