Coverage Report

Created: 2025-07-18 06:54

/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
214k
{
9
214k
   mp_int  t;
10
214k
   mp_err  err;
11
12
214k
   if ((err = mp_init_size(&t, b->used)) != MP_OKAY) {
13
0
      return err;
14
0
   }
15
16
214k
   if ((err = mp_div(a, b, NULL, &t)) != MP_OKAY) {
17
0
      goto LBL_ERR;
18
0
   }
19
20
214k
   if (MP_IS_ZERO(&t) || (t.sign == b->sign)) {
21
214k
      err = MP_OKAY;
22
214k
      mp_exch(&t, c);
23
214k
   } else {
24
433
      err = mp_add(b, &t, c);
25
433
   }
26
27
214k
LBL_ERR:
28
214k
   mp_clear(&t);
29
214k
   return err;
30
214k
}
31
#endif