Line data Source code
1 : #include "tommath_private.h" 2 : #ifdef BN_MP_CMP_MAG_C 3 : /* LibTomMath, multiple-precision integer library -- Tom St Denis */ 4 : /* SPDX-License-Identifier: Unlicense */ 5 : 6 : /* compare maginitude of two ints (unsigned) */ 7 2047490 : mp_ord mp_cmp_mag(const mp_int *a, const mp_int *b) 8 : { 9 119673 : int n; 10 119673 : const mp_digit *tmpa, *tmpb; 11 : 12 : /* compare based on # of non-zero digits */ 13 2047490 : if (a->used > b->used) { 14 20882 : return MP_GT; 15 : } 16 : 17 2025036 : if (a->used < b->used) { 18 40960 : return MP_LT; 19 : } 20 : 21 : /* alias for a */ 22 1983448 : tmpa = a->dp + (a->used - 1); 23 : 24 : /* alias for b */ 25 1983448 : tmpb = b->dp + (a->used - 1); 26 : 27 : /* compare based on digits */ 28 2161823 : for (n = 0; n < a->used; ++n, --tmpa, --tmpb) { 29 2161462 : if (*tmpa > *tmpb) { 30 677617 : return MP_GT; 31 : } 32 : 33 1435651 : if (*tmpa < *tmpb) { 34 1188018 : return MP_LT; 35 : } 36 : } 37 340 : return MP_EQ; 38 : } 39 : #endif