#stream-cipher #xchacha20 #random #chacha8 #chacha12

no-std chacha20

The ChaCha20 stream cipher (RFC 8439) implemented in pure Rust using traits from the RustCrypto cipher crate, with optional architecture-specific hardware acceleration (AVX2, SSE2). Additionally provides the ChaCha8, ChaCha12, XChaCha20, XChaCha12 and XChaCha8 stream ciphers, and also optional rand_core-compatible RNGs based on those ciphers.

22 releases

0.10.0-pre.2 Oct 7, 2024
0.10.0-pre.1 Jul 27, 2024
0.9.1 Apr 1, 2023
0.9.0 Feb 21, 2022
0.0.0 Oct 6, 2016

#1717 in Cryptography

Download history 235488/week @ 2024-10-04 235750/week @ 2024-10-11 252394/week @ 2024-10-18 232521/week @ 2024-10-25 221880/week @ 2024-11-01 241204/week @ 2024-11-08 264339/week @ 2024-11-15 227825/week @ 2024-11-22 254751/week @ 2024-11-29 278525/week @ 2024-12-06 270706/week @ 2024-12-13 120832/week @ 2024-12-20 114407/week @ 2024-12-27 229701/week @ 2025-01-03 291470/week @ 2025-01-10 217696/week @ 2025-01-17

866,425 downloads per month
Used in 1,432 crates (108 directly)

Apache-2.0 OR MIT

98KB
2K SLoC

RustCrypto: ChaCha20

Crate Docs Apache2/MIT licensed Rust Version Project Chat Build Status HAZMAT

Pure Rust implementation of the ChaCha20 Stream Cipher.

Documentation

About

ChaCha20 is a stream cipher which is designed to support high-performance software implementations.

It improves upon the previous Salsa20 stream cipher with increased per-round diffusion at no cost to performance.

This crate also contains an implementation of XChaCha20: a variant of ChaCha20 with an extended 192-bit (24-byte) nonce, gated under the chacha20 Cargo feature (on-by-default).

Implementations

This crate contains the following implementations of ChaCha20, all of which work on stable Rust with the following RUSTFLAGS:

  • x86 / x86_64
    • avx2: (~1.4cpb) -Ctarget-cpu=haswell -Ctarget-feature=+avx2
    • sse2: (~2.5cpb) -Ctarget-feature=+sse2 (on by default on x86 CPUs)
  • aarch64
    • neon (~2-3x faster than soft) requires Rust 1.61+ and the neon feature enabled
  • Portable
    • soft: (~5 cpb on x86/x86_64)

NOTE: cpb = cycles per byte (smaller is better)

Security

⚠️ Warning: Hazmat!

This crate does not ensure ciphertexts are authentic (i.e. by using a MAC to verify ciphertext integrity), which can lead to serious vulnerabilities if used incorrectly!

To avoid this, use an AEAD mode based on ChaCha20, i.e. ChaCha20Poly1305. See the RustCrypto/AEADs repository for more information.

USE AT YOUR OWN RISK!

Notes

This crate has received one security audit by NCC Group, with no significant findings. We would like to thank MobileCoin for funding the audit.

All implementations contained in the crate (along with the underlying ChaCha20 stream cipher itself) are designed to execute in constant time.

Minimum Supported Rust Version

Rust 1.65 or higher.

Minimum supported Rust version can be changed in the future, but it will be done with a minor version bump.

SemVer Policy

  • All on-by-default features of this library are covered by SemVer
  • MSRV is considered exempt from SemVer as noted above

License

Licensed under either of:

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~0.3–0.8MB
~17K SLoC