Coverage Report

Created: 2025-08-26 06:44

/src/dropbear/libtommath/bn_mp_cmp_d.c
Line
Count
Source
1
#include "tommath_private.h"
2
#ifdef BN_MP_CMP_D_C
3
/* LibTomMath, multiple-precision integer library -- Tom St Denis */
4
/* SPDX-License-Identifier: Unlicense */
5
6
/* compare a digit */
7
mp_ord mp_cmp_d(const mp_int *a, mp_digit b)
8
14.2M
{
9
   /* compare based on sign */
10
14.2M
   if (a->sign == MP_NEG) {
11
6.61M
      return MP_LT;
12
6.61M
   }
13
14
   /* compare based on magnitude */
15
7.59M
   if (a->used > 1) {
16
7.56M
      return MP_GT;
17
7.56M
   }
18
19
   /* compare the only digit of a to b */
20
28.2k
   if (a->dp[0] > b) {
21
8.12k
      return MP_GT;
22
20.0k
   } else if (a->dp[0] < b) {
23
31
      return MP_LT;
24
20.0k
   } else {
25
20.0k
      return MP_EQ;
26
20.0k
   }
27
28.2k
}
28
#endif