#big-integer #integer #precision #const-generics #bignum #arbitrary

no-std crypto-bigint

Pure Rust implementation of a big integer library which has been designed from the ground-up for use in cryptographic applications. Provides constant-time, no_std-friendly implementations of modern formulas using const generics.

43 releases

0.6.0-pre.12 Jan 17, 2024
0.6.0-pre.7 Dec 29, 2023
0.6.0-pre.0 Nov 28, 2023
0.5.2 Apr 26, 2023
0.2.2 Jun 27, 2021

#1408 in Cryptography

Download history 448003/week @ 2024-01-03 452902/week @ 2024-01-10 522610/week @ 2024-01-17 519554/week @ 2024-01-24 534803/week @ 2024-01-31 494953/week @ 2024-02-07 497462/week @ 2024-02-14 520734/week @ 2024-02-21 532428/week @ 2024-02-28 555591/week @ 2024-03-06 551610/week @ 2024-03-13 551803/week @ 2024-03-20 508299/week @ 2024-03-27 585598/week @ 2024-04-03 561386/week @ 2024-04-10 482742/week @ 2024-04-17

2,240,412 downloads per month
Used in 2,716 crates (44 directly)

Apache-2.0 OR MIT

615KB
15K SLoC

RustCrypto: Cryptographic Big Integers

crate Docs Build Status Apache2/MIT licensed Rust Version Project Chat

Pure Rust implementation of a big integer library which has been designed from the ground-up for use in cryptographic applications.

Provides constant-time, no_std-friendly implementations of modern formulas using const generics.

Documentation

Goals

  • Supports no_std-friendly const generic stack-allocated big integers.
  • Constant-time by default. Variable-time functions are explicitly marked as such.
  • Leverage what is possible today with const generics on stable rust.
  • Support const fn as much as possible, including decoding big integers from bytes/hex and performing arithmetic operations on them, with the goal of being able to compute values at compile-time.

Security Notes

This crate has been audited by NCC Group with no significant findings. We would like to thank Entropy for funding the audit.

All functions contained in the crate are designed to execute in constant time unless explicitly specified otherwise (via a *_vartime name suffix).

This library is not suitable for use on processors with a variable-time multiplication operation (e.g. short circuit on multiply-by-zero / multiply-by-one, such as certain 32-bit PowerPC CPUs and some non-ARM microcontrollers).

Minimum Supported Rust Version

This crate requires Rust 1.73 at a minimum.

We may change the MSRV in the future, but it will be accompanied by a minor version bump.

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

~130–640KB
~13K SLoC