libtommath/mp_shrink.c

23 lines
632 B
C
Raw Normal View History

#include "tommath_private.h"
#ifdef MP_SHRINK_C
2019-04-07 13:29:11 +00:00
/* LibTomMath, multiple-precision integer library -- Tom St Denis */
/* SPDX-License-Identifier: Unlicense */
2003-02-28 16:08:34 +00:00
/* shrink a bignum */
mp_err mp_shrink(mp_int *a)
2003-02-28 16:08:34 +00:00
{
int alloc = MP_MAX(MP_MIN_PREC, a->used);
if (a->alloc != alloc) {
2019-10-29 17:41:25 +00:00
mp_digit *dp = (mp_digit *) MP_REALLOC(a->dp,
(size_t)a->alloc * sizeof(mp_digit),
(size_t)alloc * sizeof(mp_digit));
if (dp == NULL) {
2017-08-30 17:13:53 +00:00
return MP_MEM;
}
2019-10-29 17:41:25 +00:00
a->dp = dp;
a->alloc = alloc;
2017-08-30 17:13:53 +00:00
}
return MP_OKAY;
2003-02-28 16:08:34 +00:00
}
2004-10-29 22:07:18 +00:00
#endif