Line data Source code
1 : #include "tommath_private.h" 2 : #ifdef BN_MP_COPY_C 3 : /* LibTomMath, multiple-precision integer library -- Tom St Denis */ 4 : /* SPDX-License-Identifier: Unlicense */ 5 : 6 : /* copy, b = a */ 7 295541 : mp_err mp_copy(const mp_int *a, mp_int *b) 8 : { 9 8492 : int n; 10 8492 : mp_digit *tmpa, *tmpb; 11 8492 : mp_err err; 12 : 13 : /* if dst == src do nothing */ 14 295541 : if (a == b) { 15 282065 : return MP_OKAY; 16 : } 17 : 18 : /* grow dest */ 19 5218 : if (b->alloc < a->used) { 20 405 : if ((err = mp_grow(b, a->used)) != MP_OKAY) { 21 0 : return err; 22 : } 23 : } 24 : 25 : /* zero b and copy the parameters over */ 26 : /* pointer aliases */ 27 : 28 : /* source */ 29 5218 : tmpa = a->dp; 30 : 31 : /* destination */ 32 5218 : tmpb = b->dp; 33 : 34 : /* copy all the digits */ 35 351413 : for (n = 0; n < a->used; n++) { 36 346195 : *tmpb++ = *tmpa++; 37 : } 38 : 39 : /* clear high digits */ 40 5218 : MP_ZERO_DIGITS(tmpb, b->used - n); 41 : 42 : /* copy used count and sign */ 43 5218 : b->used = a->used; 44 5218 : b->sign = a->sign; 45 5218 : return MP_OKAY; 46 : } 47 : #endif