#blake2s #simd #dynamic #hash #pure #platform #default

no-std blake2s_const

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

2个不稳定版本

0.8.0 2024年7月5日
0.7.0 2024年7月5日

#73性能分析

Download history 8833/week @ 2024-07-06 756/week @ 2024-07-13 10924/week @ 2024-07-20 14195/week @ 2024-07-27 8279/week @ 2024-08-03 8467/week @ 2024-08-10

41,878 每月下载量
用于 bellman_ce

MIT 许可证

150KB
3.5K SLoC

blake2s_simd GitHub crates.io 构建状态

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());

依赖项

~105KB