Commit 114e8043 authored by Stefan Berger's avatar Stefan Berger Committed by Herbert Xu

crypto: ecc - Add special case for NIST P521 in ecc_point_mult

In ecc_point_mult use the number of bits of the NIST P521 curve + 2. The
change is required specifically for NIST P521 to pass mathematical tests
on the public key.
Tested-by: default avatarLukas Wunner <lukas@wunner.de>
Reviewed-by: default avatarJarkko Sakkinen <jarkko@kernel.org>
Signed-off-by: default avatarStefan Berger <stefanb@linux.ibm.com>
Signed-off-by: default avatarHerbert Xu <herbert@gondor.apana.org.au>
parent e7fb0627
...@@ -1320,7 +1320,10 @@ static void ecc_point_mult(struct ecc_point *result, ...@@ -1320,7 +1320,10 @@ static void ecc_point_mult(struct ecc_point *result,
carry = vli_add(sk[0], scalar, curve->n, ndigits); carry = vli_add(sk[0], scalar, curve->n, ndigits);
vli_add(sk[1], sk[0], curve->n, ndigits); vli_add(sk[1], sk[0], curve->n, ndigits);
scalar = sk[!carry]; scalar = sk[!carry];
num_bits = sizeof(u64) * ndigits * 8 + 1; if (curve->nbits == 521) /* NIST P521 */
num_bits = curve->nbits + 2;
else
num_bits = sizeof(u64) * ndigits * 8 + 1;
vli_set(rx[1], point->x, ndigits); vli_set(rx[1], point->x, ndigits);
vli_set(ry[1], point->y, ndigits); vli_set(ry[1], point->y, ndigits);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment