[crypto/ec] Ladder tweaks
authorBilly Brumley <bbrumley@gmail.com>
Sat, 28 Mar 2020 18:35:43 +0000 (20:35 +0200)
committerNicola Tuveri <nic.tuv@gmail.com>
Wed, 1 Apr 2020 16:03:06 +0000 (19:03 +0300)
commitd0771a9fdb93bdff992a079f596829139b8b12c0
tree2f389fe3613e1adaf403be6a4f91ee37837628c4
parent3c61ea367179ebaca8b448367b08c460c9d07120
[crypto/ec] Ladder tweaks

- Convert to affine coords on ladder entry. This lets us use more efficient
  ladder step formulae.

- Convert to affine coords on ladder exit. This prevents the current code
  awkwardness where conversion happens twice during serialization: first to
  fetch the buffer size, then again to fetch the coords.

- Instead of projectively blinding the input point, blind both accumulators
  independently.

(cherry picked from commit a4a93bbfb0e679eaa249f77c7c4e7e823ca870ef)

Reviewed-by: Nicola Tuveri <nic.tuv@gmail.com>
Reviewed-by: Bernd Edlinger <bernd.edlinger@hotmail.de>
(Merged from https://github.com/openssl/openssl/pull/11435)
crypto/ec/ec_mult.c
crypto/ec/ecp_smpl.c