Coverage Report

Created: 2023-03-20 06:28

/src/dropbear/libtommath/bn_mp_mod.c
Line
Count
Source (jump to first uncovered line)
1
#include "tommath_private.h"
2
#ifdef BN_MP_MOD_C
3
/* LibTomMath, multiple-precision integer library -- Tom St Denis */
4
/* SPDX-License-Identifier: Unlicense */
5
6
/* c = a mod b, 0 <= c < b if b > 0, b < c <= 0 if b < 0 */
7
mp_err mp_mod(const mp_int *a, const mp_int *b, mp_int *c)
8
2.25k
{
9
2.25k
   mp_int  t;
10
2.25k
   mp_err  err;
11
12
2.25k
   if ((err = mp_init_size(&t, b->used)) != MP_OKAY) {
13
0
      return err;
14
0
   }
15
16
2.25k
   if ((err = mp_div(a, b, NULL, &t)) != MP_OKAY) {
17
0
      goto LBL_ERR;
18
0
   }
19
20
2.25k
   if (MP_IS_ZERO(&t) || (t.sign == b->sign)) {
21
2.09k
      err = MP_OKAY;
22
2.09k
      mp_exch(&t, c);
23
2.09k
   } else {
24
163
      err = mp_add(b, &t, c);
25
163
   }
26
27
2.25k
LBL_ERR:
28
2.25k
   mp_clear(&t);
29
2.25k
   return err;
30
2.25k
}
31
#endif