Skip to content
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

core/crypto: Even more improvments #3288

Merged
merged 14 commits into from
Apr 10, 2024

Conversation

Yawning
Copy link
Contributor

@Yawning Yawning commented Mar 17, 2024

  • Test rand_bytes on all supported platforms
  • Cleanups of the existing fiat derived code
  • Ed25519
    • Scalar field
    • Edwards25519 group
      • Faster scalar-basepoint multiply (defered, a lot of extra complexity)
      • Strauss-Shamir double scalar mult
    • EdDSA
      • RFC Test cases
      • speccheck test cases
  • ristretto255

Performance isn't amazing, clocking in at ~58 us keygen/sign, and ~60(+5) us verify. But as I made a conscious decision to tradeoff performance for "easy to implement, understand, and audit", this is more than acceptable. For reference, an implementation that pulls out all the stops does sign/keygen in ~18 us, and verify in ~37 us on my system, when the assembly is disabled.

The low hanging fruit for future improvement would be to add the comb based scalar-basepoint multiply, since that can also accelerate X25519 keygen. Improving the verify performance would require using the lattice decompose-then-multiply, which is incredibly complicated, and the existing implementation is ballpark competitive with others since the difference between a 4-bit fixed window, vs 5-bit sliding window isn't massive.

@Yawning Yawning force-pushed the feature/even-moar-crypto branch 8 times, most recently from ef47b1e to 3b1b3e9 Compare March 25, 2024 23:47
@Yawning Yawning force-pushed the feature/even-moar-crypto branch 14 times, most recently from 30a7e54 to 2d9a0dc Compare April 4, 2024 11:58
@Yawning Yawning force-pushed the feature/even-moar-crypto branch 8 times, most recently from 2dfc905 to c7aa5a6 Compare April 7, 2024 17:52
@Yawning Yawning force-pushed the feature/even-moar-crypto branch from c7aa5a6 to 26996e2 Compare April 8, 2024 05:26
@Yawning Yawning force-pushed the feature/even-moar-crypto branch 5 times, most recently from 962db2e to f22e1d1 Compare April 9, 2024 05:05
@Yawning Yawning marked this pull request as ready for review April 9, 2024 05:20
@Yawning Yawning force-pushed the feature/even-moar-crypto branch from f22e1d1 to fa1d681 Compare April 9, 2024 05:38
@Kelimion Kelimion merged commit 2ba2bc1 into odin-lang:master Apr 10, 2024
4 checks passed
@Yawning Yawning deleted the feature/even-moar-crypto branch April 10, 2024 13:22
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.

2 participants