comparison libtomcrypt/src/pk/ecc/ltc_ecc_mulmod_timing.c @ 1733:d529a52b2f7c coverity coverity

merge coverity from main
author Matt Johnston <matt@ucc.asn.au>
date Fri, 26 Jun 2020 21:07:34 +0800
parents 1ff2a1034c52
children
comparison
equal deleted inserted replaced
1643:b59623a64678 1733:d529a52b2f7c
15 #include "tomcrypt.h" 15 #include "tomcrypt.h"
16 16
17 /** 17 /**
18 @file ltc_ecc_mulmod_timing.c 18 @file ltc_ecc_mulmod_timing.c
19 ECC Crypto, Tom St Denis 19 ECC Crypto, Tom St Denis
20 */ 20 */
21 21
22 #ifdef LTC_MECC 22 #ifdef LTC_MECC
23 23
24 #ifdef LTC_ECC_TIMING_RESISTANT 24 #ifdef LTC_ECC_TIMING_RESISTANT
25 25
57 mp_clear(mu); 57 mp_clear(mu);
58 mp_montgomery_free(mp); 58 mp_montgomery_free(mp);
59 return err; 59 return err;
60 } 60 }
61 61
62 /* alloc ram for window temps */ 62 /* alloc ram for window temps */
63 for (i = 0; i < 3; i++) { 63 for (i = 0; i < 3; i++) {
64 M[i] = ltc_ecc_new_point(); 64 M[i] = ltc_ecc_new_point();
65 if (M[i] == NULL) { 65 if (M[i] == NULL) {
66 for (j = 0; j < i; j++) { 66 for (j = 0; j < i; j++) {
67 ltc_ecc_del_point(M[j]); 67 ltc_ecc_del_point(M[j]);
68 } 68 }
69 mp_clear(mu); 69 mp_clear(mu);
70 mp_montgomery_free(mp); 70 mp_montgomery_free(mp);
71 return CRYPT_MEM; 71 return CRYPT_MEM;
72 } 72 }
73 } 73 }
74 74
75 /* make a copy of G incase R==G */ 75 /* make a copy of G incase R==G */
76 tG = ltc_ecc_new_point(); 76 tG = ltc_ecc_new_point();
77 if (tG == NULL) { err = CRYPT_MEM; goto done; } 77 if (tG == NULL) { err = CRYPT_MEM; goto done; }
78 78
80 if ((err = mp_mulmod(G->x, mu, modulus, tG->x)) != CRYPT_OK) { goto done; } 80 if ((err = mp_mulmod(G->x, mu, modulus, tG->x)) != CRYPT_OK) { goto done; }
81 if ((err = mp_mulmod(G->y, mu, modulus, tG->y)) != CRYPT_OK) { goto done; } 81 if ((err = mp_mulmod(G->y, mu, modulus, tG->y)) != CRYPT_OK) { goto done; }
82 if ((err = mp_mulmod(G->z, mu, modulus, tG->z)) != CRYPT_OK) { goto done; } 82 if ((err = mp_mulmod(G->z, mu, modulus, tG->z)) != CRYPT_OK) { goto done; }
83 mp_clear(mu); 83 mp_clear(mu);
84 mu = NULL; 84 mu = NULL;
85 85
86 /* calc the M tab */ 86 /* calc the M tab */
87 /* M[0] == G */ 87 /* M[0] == G */
88 if ((err = mp_copy(tG->x, M[0]->x)) != CRYPT_OK) { goto done; } 88 if ((err = mp_copy(tG->x, M[0]->x)) != CRYPT_OK) { goto done; }
89 if ((err = mp_copy(tG->y, M[0]->y)) != CRYPT_OK) { goto done; } 89 if ((err = mp_copy(tG->y, M[0]->y)) != CRYPT_OK) { goto done; }
90 if ((err = mp_copy(tG->z, M[0]->z)) != CRYPT_OK) { goto done; } 90 if ((err = mp_copy(tG->z, M[0]->z)) != CRYPT_OK) { goto done; }