-
Notifications
You must be signed in to change notification settings - Fork 110
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Code duplication between reddsa
and redjubjub
#6341
Comments
This comment was marked as outdated.
This comment was marked as outdated.
As of |
Nitpick: the duplicate implementation was removed in 0.6. |
The description of the issue says:
I think this statement contains an off-by-one error. The correct number of zero digits should be |
digs out Guide to ECC You're correct! |
Sorry, I should have added the full definition right away so others don't have to search for it. I only realized that now. |
@upbqdn can you please add a size for this issue? |
Done. |
Details
The
redjubjub
crate implements the RedDSA signature scheme over the Jubjub curve.The
reddsa
crate mostly subsumes that task and provides RedDSA support for both the Jubjub and Pallas curves; the migration of the code fromredjubjub
toreddsa
, and itsgeneralization to unify support over distinct elliptic curves, are currently in an incomplete state, resulting in some code duplication. Thus, there are currently (at least) three mostly identical implementations of the multiplication of a curve point by a scalar with the w-NAF method, in redjubjub/src/scalar_mul.rs, reddsa/src/scalar_mul.rs, and reddsa/src/orchard.rs. In all three cases, the input scalar is converted to a w-NAF representation over exactly 256 digits:
https://github.com/ZcashFoundation/redjubjub/blob/e19279f70f3999627b4076386848d1956b18560e/src/scalar_mul.rs#L66-L70
https://github.com/ZcashFoundation/reddsa/blob/507dcdf695bbc7eccd5d6b8e3c0d62625a45e4e9/src/scalar_mul.rs#L73-L77
https://github.com/ZcashFoundation/reddsa/blob/507dcdf695bbc7eccd5d6b8e3c0d62625a45e4e9/src/orchard.rs#L90-L94
The w-NAF representation converts an input value
x
into signed digits, using a window widthw
(expressed in bits), with the following characteristics:w
digits of value zero.x
such that 0 ≤ x < 2n + 2n-w.The
non_adjacent_form()
function requires that the window widthw
lies between 2 and 8.The use of 256 digits is then slightly wasteful for the Jubjub and Pallas curves, where scalars are lower than the prime (sub)group order of interest:
Since the number of iterations in the multiplication loop is exactly equal to the number of digits, and each iteration includes at least a curve point doubling, then some of these doublings are wasted (they will repeatedly double the initial value of the accumulator point, i.e. the curve identity point). On the other hand, if the
non_adjacent_form()
andoptional_multiscalar_mul()
functions are turned into generic functions that handle arbitrary curves whose scalars fit on 32 bytes, then 256 digits are not enough: a curve whose order is greater than 2255 +2247 (e.g. secp256k1, or NIST’s P-256) may need up to 257 digits for its scalars in w-NAF representation.The text was updated successfully, but these errors were encountered: