summaryrefslogtreecommitdiffstats
path: root/libtommath/bn_mp_reduce_setup.c
diff options
context:
space:
mode:
authorkennykb <kennykb@noemail.net>2005-01-19 22:41:25 (GMT)
committerkennykb <kennykb@noemail.net>2005-01-19 22:41:25 (GMT)
commitb3ce7426a67ecb023356a28d94171635385dc616 (patch)
tree47f8ad0d7291237c7f9af988c5e05275ed9286ee /libtommath/bn_mp_reduce_setup.c
parentccd3f20006ac278b5ded38d34df7f6d6e5b6b886 (diff)
downloadtcl-b3ce7426a67ecb023356a28d94171635385dc616.zip
tcl-b3ce7426a67ecb023356a28d94171635385dc616.tar.gz
tcl-b3ce7426a67ecb023356a28d94171635385dc616.tar.bz2
Import of libtommath 0.33
FossilOrigin-Name: bd185c2b4e79e51a5759271085f1702fafff39a3
Diffstat (limited to 'libtommath/bn_mp_reduce_setup.c')
-rw-r--r--libtommath/bn_mp_reduce_setup.c30
1 files changed, 30 insertions, 0 deletions
diff --git a/libtommath/bn_mp_reduce_setup.c b/libtommath/bn_mp_reduce_setup.c
new file mode 100644
index 0000000..99f158a
--- /dev/null
+++ b/libtommath/bn_mp_reduce_setup.c
@@ -0,0 +1,30 @@
+#include <tommath.h>
+#ifdef BN_MP_REDUCE_SETUP_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@iahu.ca, http://math.libtomcrypt.org
+ */
+
+/* pre-calculate the value required for Barrett reduction
+ * For a given modulus "b" it calulates the value required in "a"
+ */
+int mp_reduce_setup (mp_int * a, mp_int * b)
+{
+ int res;
+
+ if ((res = mp_2expt (a, b->used * 2 * DIGIT_BIT)) != MP_OKAY) {
+ return res;
+ }
+ return mp_div (a, b, a, NULL);
+}
+#endif