From fbd69f9b486775c2269abbd0d8263fcdc807649d Mon Sep 17 00:00:00 2001 From: Sean Parkinson Date: Thu, 30 May 2024 09:59:59 +1000 Subject: [PATCH] ECC: when multiplying by zero, set z to 1 Make sure zero times a point is infinity but z is 1 as it is assumed later on. --- wolfcrypt/src/ecc.c | 2 +- wolfcrypt/test/test.c | 4 ++++ 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/wolfcrypt/src/ecc.c b/wolfcrypt/src/ecc.c index ea9cedd532..ee1e7b7dbb 100644 --- a/wolfcrypt/src/ecc.c +++ b/wolfcrypt/src/ecc.c @@ -4061,7 +4061,7 @@ int wc_ecc_mulmod(const mp_int* k, ecc_point *G, ecc_point *R, mp_int* a, if ((k != NULL) && (R != NULL) && (mp_iszero(k))) { mp_zero(R->x); mp_zero(R->y); - mp_zero(R->z); + mp_set(R->z, 1); return MP_OKAY; } return wc_ecc_mulmod_ex(k, G, R, a, modulus, map, NULL); diff --git a/wolfcrypt/test/test.c b/wolfcrypt/test/test.c index 0fd362b301..10b9f37bf9 100644 --- a/wolfcrypt/test/test.c +++ b/wolfcrypt/test/test.c @@ -31085,6 +31085,10 @@ static wc_test_ret_t ecc_mulmod_test(ecc_key* key1) ret = WC_TEST_RET_ENC_EC(ret); goto done; } + if (mp_cmp_d(key3->pubkey.z, 1) != MP_EQ) { + ret = WC_TEST_RET_ENC_EC(ret); + goto done; + } #endif done: