secp256k1_gej_add_ge does the wrong thing with points P, Q with P_y = -Q_y but P≠-Q #257

issue apoelstra openend this issue on June 16, 2015
  1. apoelstra commented at 2:45 pm on June 16, 2015: contributor

    It is possible, by using the value β from the endomorphism optimization, to obtain two points P = x : y : z and Q = βx : -y : z which are both on the curve. If you attempt to add these points using secp256k1_gej_add_ge, it incorrectly returns infinity, since it sees that the z-coordinates match and the y-coordinates are negative.

    Specifically, it computes the value M = Y_1 * Z_2^3 + Y_2 * Z_1^3, and sets the returned z-coordinate to 2 * M * z_1z_2, and of course M will be zero for these two points. So it is not a simple matter of fixing how the infinity flag is set, the algebra actually does not compute the complete group law. This is derived in the paper “Eric Brier and Marc Joye, Weierstrass Elliptic Curves and Side-Channel Attacks” in Proposition 1, which explicitly assumes that the points P and Q don’t happen.

    The current secp256k1 API does not use this function except in one place, secp256k1_ecmult_gen, where it is impossible to get such an input to the function, so right now this bug is harmless. However https://github.com/bitcoin/secp256k1/pull/252 exposes it more directly, since when the endomorphism optimization is turned on roughly half of all scalars produce a bad pair P, Q in the wNAF ladder.

  2. sipa commented at 2:59 pm on June 16, 2015: contributor
    No other choice than to replace the function with one that computes (infinity, 2*P, P+Q) independently, and uses a conditional copy to return one of them.
  3. apoelstra commented at 3:03 pm on June 16, 2015: contributor
    Do you have an algebraic reason to believe there is no unified formula, or just that you are not aware of one?
  4. sipa commented at 3:04 pm on June 16, 2015: contributor
    I am not aware of one.
  5. apoelstra commented at 3:19 pm on June 17, 2015: contributor

    I have a borderline coherent algebraic reason that we can’t find a unified formula: we want to calculate λ (the point-addition λ, not the one from the endomorphism optimization) in such a way that λ = f(y1, y2)/g(x1, x2) when x1 ≠ x2, but λ = h(x1, x2)/i(y1, y2) otherwise. That is, we are trying to unify these two equations, one of which is an x-function over a y-function and the other of which is the opposite.

    Any unification scheme is therefore going to need to swap x and y somehow. The Brier/Joye paper uses the curve equation y^2 = x^3 + 7 to do this, and AFAICT this is the only way they could, since this is the only relationship we have between x and y.

    However, with the offending pairs (x, y) and (βx, -y) we see that y^2 = (±y)^2 and x^3 = (βx)^3; that is, the curve equation is totally unable to distinguish these points. So since the original formula λ = (y1 - y2)/(x1 - x2) broke down for the pairs (x, y) and (x, y), no manipulation by means of the curve equation can get us a formula that never breaks down.

    This isn’t a very solid argument, but I think it indicates that @sipa is right and we’ll have to find a way to use two equations and then cmov the final result in place. (Maybe there is an earlier point in the algebra that we can do this to avoid too much wasted work?) I might offer my calc students some cash for unifying the formula, but I can’t justify spending any more of my own time on it.

  6. sipa cross-referenced this on Jun 22, 2015 from issue Correct secp256k1_gej_add_ge by sipa
  7. apoelstra referenced this in commit 61f927e23c on Jun 23, 2015
  8. sipa referenced this in commit 171149d69b on Jun 23, 2015
  9. apoelstra referenced this in commit 617c9299e7 on Jun 23, 2015
  10. apoelstra cross-referenced this on Jun 24, 2015 from issue Correct `secp256k1_gej_add_ge` with 3% performance hit on signing by apoelstra
  11. apoelstra referenced this in commit 88fbe8f109 on Jun 24, 2015
  12. apoelstra referenced this in commit fc5aee4ef0 on Jun 25, 2015
  13. apoelstra referenced this in commit e227671639 on Jun 25, 2015
  14. apoelstra referenced this in commit 8c5d5f7b5b on Jun 29, 2015
  15. sipa closed this on Jun 29, 2015

  16. sipa referenced this in commit 17f7148606 on Jun 29, 2015


apoelstra sipa


github-metadata-mirror

This is a metadata mirror of the GitHub repository bitcoin-core/secp256k1. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2025-01-23 22:15 UTC

This site is hosted by @0xB10C
More mirrored repositories can be found on mirror.b10c.me