summaryrefslogtreecommitdiffstats
path: root/libtommath/bn_mp_sqr.c
blob: 460d8ab4e562fd3dd5a809fb276009ee5216cc49 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
#include <tommath.h>
#ifdef BN_MP_SQR_C
/* LibTomMath, multiple-precision integer library -- Tom St Denis
 *
 * LibTomMath is a library that provides multiple-precision
 * integer arithmetic as well as number theoretic functionality.
 *
 * The library was designed directly after the MPI library by
 * Michael Fromberger but has been written from scratch with
 * additional optimizations in place.
 *
 * The library is free for all purposes without any express
 * guarantee it works.
 *
 * Tom St Denis, tomstdenis@gmail.com, http://libtom.org
 */

/* computes b = a*a */
int mp_sqr(mp_int * a, mp_int * b)
{
	int res;

#ifdef BN_MP_TOOM_SQR_C
	/* use Toom-Cook? */
	if (a->used >= TOOM_SQR_CUTOFF) {
		res = mp_toom_sqr(a, b);
		/* Karatsuba? */
	} else
#endif
#ifdef BN_MP_KARATSUBA_SQR_C
	if (a->used >= KARATSUBA_SQR_CUTOFF) {
		res = mp_karatsuba_sqr(a, b);
	} else
#endif
	{
#ifdef BN_FAST_S_MP_SQR_C
		/* can we use the fast comba multiplier? */
		if ((a->used * 2 + 1) < MP_WARRAY &&
		    a->used <
		    (1 << (sizeof(mp_word) * CHAR_BIT - 2 * DIGIT_BIT - 1))) {
			res = fast_s_mp_sqr(a, b);
		} else
#endif
#ifdef BN_S_MP_SQR_C
			res = s_mp_sqr(a, b);
#else
			res = MP_VAL;
#endif
	}
	b->sign = MP_ZPOS;
	return res;
}
#endif

/* $Source: /cvs/libtom/libtommath/bn_mp_sqr.c,v $ */
/* $Revision: 1.4 $ */
/* $Date: 2006/12/28 01:25:13 $ */