9.3 KiB
9.3 KiB
Changelog
Entries are listed in reverse chronological order per undeprecated major series.
4.x series
4.1.3
- Security: Fix timing leak in Scalar subtraction on u32, u64, fiat_u32, and fiat_u64 backends
- Fix assorted new warnings and lints from rustc and clippy
4.1.2
- Fix nightly SIMD build
4.1.1
- Mark
constants::BASEPOINT_ORDERdeprecated from pub API - Add implementation for
PrimeFieldBits, behind thegroup-bitsfeature flag.
4.1.0
- Add arbitrary integer multiplication with
MontgomeryPoint::mul_bits_be - Add implementations of the
ffandgrouptraits, behind thegroupfeature flag - Adapt to new types introduced in
fiat-crypto0.2 infiatbackend - Fix
no_stdforfiatbackend - Mark
Scalar::clamp_integeras#[must_use] - Various documentation fixes
4.0.0
Breaking changes
- Update the MSRV from 1.41 to 1.60
- Provide SemVer policy
- Make
digestan optional feature - Make
rand_corean optional feature - Remove
stdfeature flag - Remove
nightlyfeature flag - Automatic serial backend selection between
u32andu64over the defaultu32 - Backend
simdis now automatically selected overserialwhen a supported CPU is detected - Backend override is now via cfg(curve25519_dalek_backend) over additive features
- Provide override to select
u32oru64backend via cfg(curve25519_dalek_bits) - Replace methods
Scalar::{zero, one}with constantsScalar::{ZERO, ONE} - Deprecate
EdwardsPoint::hash_from_bytesand rename itEdwardsPoint::nonspec_map_to_curve - Require including a new trait,
use curve25519_dalek::traits::BasepointTablewhenever usingEdwardsBasepointTableorRistrettoBasepointTable Scalar::from_canonical_bytesnow returnsCtOptionScalar::is_canonicalnow returnsChoice- Remove
Scalar::from_bytes_clampedandScalar::reduce - Deprecate and feature-gate
Scalar::from_bitsbehindlegacy_compatibility
Other changes
- Add
EdwardsPoint::{mul_base, mul_base_clamped},MontgomeryPoint::{mul_base, mul_base_clamped}, andBasepointTable::mul_base_clamped - Add
precomputed-tablesfeature - Update Maintenance Policies for SemVer
- Migrate documentation to docs.rs hosted
- Fix backend documentation generation
- Fix panic when
Ristretto::double_and_compress_batchreceives the identity point - Remove
byteorderdependency - Update the
criteriondependency to 0.4.0 - Include README.md into crate Documentation
- Update the
rand_coredependency version and theranddev-dependency version. - Relax the
zeroizedependency to^1 - Update the edition from 2015 to 2021
3.x series
3.2.0
- Add support for getting the identity element for the Montgomery form of curve25519, which is useful in certain protocols for checking contributory behaviour in derivation of shared secrets.
3.1.2
- Revert a commit which mistakenly removed support for
zeroizetraits for some point types, as well as elligator2 support for Edwards points.
3.1.1
- Fix documentation builds on nightly due to syntax changes to
#![cfg_attr(feature = "nightly", doc = include_str!("../README.md"))].
3.1.0
- Add support for the Elligator2 encoding for Edwards points.
- Add two optional formally-verified field arithmetic backends which use the Fiat Crypto project's Rust code, which is generated from proofs of functional correctness checked by the Coq theorem proving system.
- Add support for additional sizes of precomputed tables for basepoint scalar multiplication.
- Fix an unused import.
- Add support for using the
zeroizetraits with all point types. Note that points are not automatically zeroized on Drop, but that consumers ofcurve25519-dalekshould call these methods manually when needed.
3.0.3
- Fix documentation builds on nightly due to syntax changes to
#![cfg_attr(feature = "nightly", doc = include_str!("../README.md"))].
3.0.2
- Multiple documentation typo fixes.
- Fixes to make using
alloc+no_stdpossible for stable Rust.
3.0.1
- Update the optional
packed-simddependency to rely on a newer, maintained version of thepacked-simd-2crate.
3.0.0
Breaking changes
- Update the
digestdependency to0.9. This requires a major version because thedigesttraits are part of the public API, but there are otherwise no changes to the API.
2.x series
2.1.3
- Fix documentation builds on nightly due to syntax changes to
#![fg_attr(feature = "nightly", doc = include_str!("../README.md"))].
2.1.2
- Multiple documentation typo fixes.
- Fix
allocfeature working with stable rust.
2.1.1
- Update the optional
packed-simddependency to rely on a newer, maintained version of thepacked-simd-2crate.
2.1.0
- Make
Scalar::from_bitsaconst fn, allowing its use inconstcontexts.
2.0.0
The only significant change is the data model change to the serde feature;
besides the rand_core version bump, there are no other user-visible changes.
Breaking changes
- Fix a data modeling error in the
serdefeature pointed out by Trevor Perrin which caused points and scalars to be serialized with length fields rather than as fixed-size 32-byte arrays. This is a breaking change, but it fixes compatibility withserde-jsonand ensures that theserde-bincodeencoding matches the conventional encoding for X/Ed25519. - Update
rand_coreto0.5, allowing use with newrandversions.
Other changes
- Switch from
clear_on_droptozeroize(by Tony Arcieri). - Require
subtle = ^2.2.1and remove the note advising nightly Rust, which is no longer required as of that version ofsubtle. See thesubtlechangelog for more details. - Update
README.mdfor2.xseries. - Remove the
build.rshack which loaded the entire crate into its ownbuild.rsto generate constants, and keep the constants in the source code.
1.x series
1.2.6
- Fixes to make using alloc+no_std possible for stable Rust.
1.2.5
- Update the optional
packed-simddependency to rely on a newer, maintained version of thepacked-simd-2crate.
1.2.4
- Specify a semver bound for
clear_on_droprather than an exact version, addressing an issue where changes to inline assembly in rustc preventedclear_on_dropfrom working without an update.
1.2.3
- Fix an issue identified by a Quarkslab audit (and Jack Grigg), where manually
constructing unreduced
Scalarvalues, as needed for X/Ed25519, and then performing scalar/scalar arithmetic could compute incorrect results. - Switch to upstream Rust intrinsics for the IFMA backend now that they exist in Rust and don't need to be defined locally.
- Ensure that the NAF computation works correctly, even for parameters never used elsewhere in the codebase.
- Minor refactoring to EdwardsPoint decompression.
- Fix broken links in documentation.
- Fix compilation on nightly broken due to changes to the
#[doc(include)]path root (not quite correctly done in 1.2.2).
1.2.2
- Fix a typo in an internal doc-comment.
- Add the "crypto" tag to crate metadata.
- Fix compilation on nightly broken due to changes to the
#[doc(include)]path root.
1.2.1
- Fix a bug in bucket index calculations in the Pippenger multiscalar algorithm for very large input sizes.
- Add a more extensive randomized multiscalar multiplication consistency check to the test suite to prevent regressions.
- Ensure that that multiscalar and NAF computations work correctly on extremal
Scalarvalues constructed viafrom_bits.
1.2.0
- New multiscalar multiplication algorithm with better performance for large problem sizes. The backend algorithm is selected transparently using the size hints of the input iterators, so no changes are required for client crates to start using it.
- Equality of Edwards points is now checked in projective coordinates.
- Serde can now be used with
no_std.
1.1.4
- Fix typos in documentation comments.
- Remove unnecessary
Defaultbound onScalar::from_hash.
1.1.3
- Reverts the change in 1.1.0 to allow owned and borrowed RNGs, which caused a breakage due to a subtle interaction with ownership rules. (The
RngCorechange is retained).
1.1.2
- Disabled KaTeX on
docs.rspending proper support upstream.
1.1.1
- Fixed an issue related to
#[cfg(rustdoc)]which prevented documenting multiple backends.
1.1.0
- Adds support for precomputation for multiscalar multiplication.
- Restructures the internal source tree into
serialandvectorbackends (no change to external API). - Adds a new IFMA backend which sets speed records.
- The
avx2_backendfeature is now an alias for thesimd_backendfeature, which autoselects an appropriate vector backend (currently AVX2 or IFMA). - Replaces the
randdependency withrand_core. - Generalizes trait bounds on
RistrettoPoint::random()andScalar::random()to allow owned and borrowed RNGs and to allowRngCoreinstead ofRng.
1.0.3
- Adds
ConstantTimeEqimplementation for compressed points.
1.0.2
- Fixes a typo in the naming of variables in Ristretto formulas (no change to functionality).
1.0.1
- Depends on the stable
2.0version ofsubtleinstead of2.0.0-pre.0.
1.0.0
Initial stable release. Yanked due to a dependency mistake (see above).