Skip to content

Conversation

@tarcieri
Copy link
Member

...and remove masking_scalar.

This API allows the inversion masking process to be handled outside of the ECDSA implementation itself (potentially generically in a way that can work across elliptic curves).

...and remove masking scalar.

This API allows the inversion masking process to be handled outside of
the ECDSA implementation itself (potentially generically in a way that
can work across elliptic curves).
@tarcieri tarcieri requested a review from nickray July 28, 2020 17:05
@codecov-commenter
Copy link

Codecov Report

Merging #107 into master will not change coverage.
The diff coverage is n/a.

Impacted file tree graph

@@           Coverage Diff           @@
##           master     #107   +/-   ##
=======================================
  Coverage   53.59%   53.59%           
=======================================
  Files           3        3           
  Lines         181      181           
=======================================
  Hits           97       97           
  Misses         84       84           

Continue to review full report at Codecov.

Legend - Click here to learn more
Δ = absolute <relative> (impact), ø = not affected, ? = missing data
Powered by Codecov. Last update 12b96e3...98e2563. Read the comment docs.

@tarcieri tarcieri merged commit 58eccf8 into master Jul 28, 2020
@tarcieri tarcieri deleted the ecdsa/generic-ephemeral-scalar branch July 28, 2020 17:47
tarcieri added a commit to RustCrypto/elliptic-curves that referenced this pull request Jul 28, 2020
Updates both crates with the `SignPrimitive` changes from
RustCrypto/signatures#107.

These changes removed the `masking_scalar` from the trait, and replaced
it with trait bounds that make it possible to substitute a blinded
scalar.

In the `p256` crate (which is the only one that presently implements a
variable-time inversion) the `masking_scalar` is replaced with a
`BlindedScalar` type that implements the previous blinded inversion.

The implementation it uses (including `Scalar::invert_vartime`) could
potentially be made generic and extracted into the `elliptic-curve`
crate, allowing it to be used with any curve which implements the
arithmetic primitives used in the blinded inversion implementation.
However, for now, this PR leaves it in `p256`, and therefore at least
has feature parity with the old implementation.
tarcieri added a commit to RustCrypto/elliptic-curves that referenced this pull request Jul 28, 2020
Updates both crates with the `SignPrimitive` changes from
RustCrypto/signatures#107.

These changes removed the `masking_scalar` from the trait, and replaced
it with trait bounds that make it possible to substitute a blinded
scalar.

In the `p256` crate (which is the only one that presently implements a
variable-time inversion) the `masking_scalar` is replaced with a
`BlindedScalar` type that implements the previous blinded inversion.

The implementation it uses (including `Scalar::invert_vartime`) could
potentially be made generic and extracted into the `elliptic-curve`
crate, allowing it to be used with any curve which implements the
arithmetic primitives used in the blinded inversion implementation.
However, for now, this PR leaves it in `p256`, and therefore at least
has feature parity with the old implementation.
tarcieri added a commit to RustCrypto/elliptic-curves that referenced this pull request Jul 28, 2020
Updates both crates with the `SignPrimitive` changes from
RustCrypto/signatures#107.

These changes removed the `masking_scalar` from the trait, and replaced
it with trait bounds that make it possible to substitute a blinded
scalar.

In the `p256` crate (which is the only one that presently implements a
variable-time inversion) the `masking_scalar` is replaced with a
`BlindedScalar` type that implements the previous blinded inversion.

The implementation it uses (including `Scalar::invert_vartime`) could
potentially be made generic and extracted into the `elliptic-curve`
crate, allowing it to be used with any curve which implements the
arithmetic primitives used in the blinded inversion implementation.
However, for now, this PR leaves it in `p256`, and therefore at least
has feature parity with the old implementation.
tarcieri added a commit to RustCrypto/elliptic-curves that referenced this pull request Jul 28, 2020
Updates both crates with the `SignPrimitive` changes from
RustCrypto/signatures#107.

These changes removed the `masking_scalar` from the trait, and replaced
it with trait bounds that make it possible to substitute a blinded
scalar.

In the `p256` crate (which is the only one that presently implements a
variable-time inversion) the `masking_scalar` is replaced with a
`BlindedScalar` type that implements the previous blinded inversion.

The implementation it uses (including `Scalar::invert_vartime`) could
potentially be made generic and extracted into the `elliptic-curve`
crate, allowing it to be used with any curve which implements the
arithmetic primitives used in the blinded inversion implementation.
However, for now, this PR leaves it in `p256`, and therefore at least
has feature parity with the old implementation.
@tarcieri tarcieri mentioned this pull request Aug 11, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants