#blake2b #blake2 #blake2bp

no-std blake2b_simd

一个使用动态 SIMD 的纯 Rust BLAKE2b 实现

26 个版本 (3 个稳定版本)

1.0.2 2023 年 9 月 10 日
1.0.1 2023 年 2 月 9 日
1.0.0 2021 年 11 月 19 日
0.5.11 2020 年 11 月 2 日
0.4.1 2018 年 10 月 26 日

#5 in 硬件支持

Download history 140582/week @ 2024-04-20 128718/week @ 2024-04-27 128211/week @ 2024-05-04 154527/week @ 2024-05-11 180039/week @ 2024-05-18 182383/week @ 2024-05-25 183553/week @ 2024-06-01 156604/week @ 2024-06-08 154860/week @ 2024-06-15 165122/week @ 2024-06-22 134270/week @ 2024-06-29 151097/week @ 2024-07-06 176787/week @ 2024-07-13 178290/week @ 2024-07-20 175643/week @ 2024-07-27 164733/week @ 2024-08-03

726,392 每月下载量
用于 1,279 个Crates (114 个直接使用)

MIT 许可协议

145KB
3K SLoC

blake2b_simd GitHub crates.io Actions Status

BLAKE2b 和 BLAKE2bp 哈希函数的实现。另请参阅 blake2s_simd

此 crate 包括

  • 100% 稳定的 Rust。
  • 基于 Samuel Neves 的 blake2-avx2 的 SIMD 实现。这些实现非常快。有关基准测试,请参阅 README 中的性能部分
  • 适用于其他平台的可移植、安全实现。
  • 动态 CPU 功能检测。默认情况下,二进制文件包括多个实现,并在运行时选择处理器支持的最快的实现。
  • 包括来自 BLAKE2 规范 的所有功能,如可调整长度、密钥和树哈希的关联数据。
  • no_std 支持。默认启用 std Cargo 功能,用于 CPU 功能检测和实现 std::io::Write
  • 支持并行计算多个 BLAKE2b 哈希,匹配 BLAKE2bp 的效率。请参阅 many 模块。

示例

use blake2b_simd::{blake2b, Params};

let expected = "ca002330e69d3e6b84a46a56a6533fd79d51d97a3bb7cad6c2ff43b354185d6d\
                c1e723fb3db4ae0737e120378424c714bb982d9dc5bbd7a0ab318240ddd18f8d";
let hash = blake2b(b"foo");
assert_eq!(expected, &hash.to_hex());

let hash = Params::new()
    .hash_length(16)
    .key(b"The Magic Words are Squeamish Ossifrage")
    .personal(b"L. P. Waterhouse")
    .to_state()
    .update(b"foo")
    .update(b"bar")
    .update(b"baz")
    .finalize();
assert_eq!("ee8ff4e9be887297cf79348dc35dab56", &hash.to_hex());

依赖关系

~98KB