summaryrefslogtreecommitdiffstats
path: root/libtommath/bn_mp_shrink.c
diff options
context:
space:
mode:
authordkf <donal.k.fellows@manchester.ac.uk>2011-03-14 14:23:22 (GMT)
committerdkf <donal.k.fellows@manchester.ac.uk>2011-03-14 14:23:22 (GMT)
commitaf01fe0b35a0b2afccffd2b93104778f54eb3f5b (patch)
tree36b3156067a6b9a0dc5de12048675aa0b7802bc9 /libtommath/bn_mp_shrink.c
parent8f3d2ff6163cce22d1c9b8c00a0051a9164fed0d (diff)
downloadtcl-af01fe0b35a0b2afccffd2b93104778f54eb3f5b.zip
tcl-af01fe0b35a0b2afccffd2b93104778f54eb3f5b.tar.gz
tcl-af01fe0b35a0b2afccffd2b93104778f54eb3f5b.tar.bz2
Apply non-comment changes to take our fork of libtommath up to tracking 0.42.0 libtommath_merge_0_42_0
from 0.39.
Diffstat (limited to 'libtommath/bn_mp_shrink.c')
-rw-r--r--libtommath/bn_mp_shrink.c11
1 files changed, 8 insertions, 3 deletions
diff --git a/libtommath/bn_mp_shrink.c b/libtommath/bn_mp_shrink.c
index 482ca48..bfdf93a 100644
--- a/libtommath/bn_mp_shrink.c
+++ b/libtommath/bn_mp_shrink.c
@@ -19,12 +19,17 @@
int mp_shrink (mp_int * a)
{
mp_digit *tmp;
- if (a->alloc != a->used && a->used > 0) {
- if ((tmp = OPT_CAST(mp_digit) XREALLOC (a->dp, sizeof (mp_digit) * a->used)) == NULL) {
+ int used = 1;
+
+ if(a->used > 0)
+ used = a->used;
+
+ if (a->alloc != used) {
+ if ((tmp = OPT_CAST(mp_digit) XREALLOC (a->dp, sizeof (mp_digit) * used)) == NULL) {
return MP_MEM;
}
a->dp = tmp;
- a->alloc = a->used;
+ a->alloc = used;
}
return MP_OKAY;
}