#blake2s #并行处理 #blake2sp

no-std blake2s_simd

一个带有动态 SIMD 的纯 Rust BLAKE2s 实现

14 个版本 (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.5.5 2019 年 7 月 22 日

#14 in 并发

Download history 63644/week @ 2024-04-28 67195/week @ 2024-05-05 90764/week @ 2024-05-12 79920/week @ 2024-05-19 100828/week @ 2024-05-26 107005/week @ 2024-06-02 78266/week @ 2024-06-09 80331/week @ 2024-06-16 84419/week @ 2024-06-23 71780/week @ 2024-06-30 100143/week @ 2024-07-07 108840/week @ 2024-07-14 115583/week @ 2024-07-21 118555/week @ 2024-07-28 99199/week @ 2024-08-04 133110/week @ 2024-08-11

473,467 每月下载量
用于 264 个 Crates (29 直接)

MIT 许可证

150KB
3K SLoC

blake2s_simd GitHub crates.io Actions Status

BLAKE2s 和 BLAKE2sp 哈希函数的实现。另见 blake2b_simd

此 crate 包括

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

示例

use blake2s_simd::{blake2s, Params};

let expected = "08d6cad88075de8f192db097573d0e829411cd91eb6ec65e8fc16c017edfdb74";
let hash = blake2s(b"foo");
assert_eq!(expected, &hash.to_hex());

let hash = Params::new()
    .hash_length(16)
    .key(b"Squeamish Ossifrage")
    .personal(b"Shaftoe")
    .to_state()
    .update(b"foo")
    .update(b"bar")
    .update(b"baz")
    .finalize();
assert_eq!("28325512782cbf5019424fa65da9a6c7", &hash.to_hex());

依赖项

~100KB