blake2s_simd 1.0.2

a pure Rust BLAKE2s implementation with dynamic SIMD
Documentation
# blake2s_simd [![GitHub]https://img.shields.io/github/tag/oconnor663/blake2_simd.svg?label=GitHub]https://github.com/oconnor663/blake2_simd [![crates.io]https://img.shields.io/crates/v/blake2s_simd.svg]https://crates.io/crates/blake2s_simd [![Actions Status]https://github.com/oconnor663/blake2_simd/workflows/tests/badge.svg]https://github.com/oconnor663/blake2_simd/actions

An implementation of the BLAKE2s and BLAKE2sp hash functions. See also
[`blake2b_simd`](../blake2b).

This crate includes:

- 100% stable Rust.
- SIMD implementations based on Samuel Neves' [`blake2-avx2`]https://github.com/sneves/blake2-avx2.
  These are very fast. For benchmarks, see [the Performance section of the
  README](https://github.com/oconnor663/blake2_simd#performance).
- Portable, safe implementations for other platforms.
- Dynamic CPU feature detection. Binaries include multiple implementations by default and
  choose the fastest one the processor supports at runtime.
- All the features from the [the BLAKE2 spec]https://blake2.net/blake2.pdf, like adjustable
  length, keying, and associated data for tree hashing.
- `no_std` support. The `std` Cargo feature is on by default, for CPU feature detection and
  for implementing `std::io::Write`.
- Support for computing multiple BLAKE2s hashes in parallel, matching the efficiency of
  BLAKE2sp. See the [`many`]many/index.html module.

# Example

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