- x86 SSE implementation now provably can't panic
HighwayHasher
debug representation now exhaustive- Removed all
unsafe
Wasm SIMD implementation at no cost
This release contains only performance optimizations:
PortableHash
throughput increases by 10-15% for all inputHighwayHasher
throughput increases by 20-60% for inputs under 1KB- All hashing implementations received size efficiency improvements
v1.0 is a re-release of v0.8.1 with the following changes that should have no observable effect
- Update to 2021 edition
- Simplify buffer filling logic
- Annotate hashing constructors with
#[must_use]
- A small performance increase, mainly for the portable implementation (other hashers may benefited as well), by eliminating all emitted panics
- Minor pedantic clippy lints applied
- The
HighwayBuilder
type has been removed in favor of the former aliasHighwayHasher
- Add Neon SIMD implementation for aarch64 targets which enabled throughput improvements of over 4x. The downside with this implementation is that all aarch64 environments are assumed to support NEON SIMD. Thus, aarch64 environments without NEON SIMD are not supported.
- Minimum supported rust version updated to 1.59 for aarch64 targets
- Update minimum supported rust to 1.54
- Add Wasm SIMD implementation for 3x performance gain. See readme for caveats and how to opt-in
no_std
builds will use a SIMD implementation when opted in at compile time
Allow for forwards compatibility with later rust compilers due to changes in some AVX2 usage
Extremely minor update that removes the last vestiges of unsafe
from the portable implementation -- without sacrificing performance. No changes in behavior.
Fix hash calculation on big endian platforms. This regression was introduced in v0.5.0 and all users are advised to upgrade.
No code changes -- just some docs updates and this crate is now tagged with the hasher
keyword.
no_std
compatible when default cargo features are disabled. To get SIMD implementations, one will need to call theforce_new
constructors explicitly.- All highway hash implementations now implement the
Hasher
andWrite
trait - Make
HighwayHasher
an alias toHighwayBuilder
and recommend the use ofHighwayHasher
in documentation
- 60% throughput increase to the portable highway hash implementation
- Highway-rs is now dependency free!
- Use rust 2018 edition
- Breaking change: hashes take an owned
Key
instead of a reference. This is not only better API design, but it could also lead to marginal better performance as the hash implementations would clone the reference regardless. Unfortunately, it is a breaking change, but one should only need to remove an ampersand.
Allow the use of highway hash in standard rust collections
use std::collections::HashMap;
use highway::{HighwayBuildHasher, Key};
let mut map =
HashMap::with_hasher(HighwayBuildHasher::new(Key([
0xcbf29ce484222325,
0xc3a5c85c97cb3127,
0xb492b66fbe98f273,
0x9ae16a3b2f90404f,
])));
map.insert(1, 2);
assert_eq!(map.get(&1), Some(&2));
Or if utilizing a key is not important, one can use the default
use std::collections::HashMap;
use std::hash::BuildHasherDefault;
use highway::HighwayHasher;
let mut map =
HashMap::with_hasher(BuildHasherDefault::<HighwayHasher>::default());
map.insert(1, 2);
assert_eq!(map.get(&1), Some(&2));
- Added clone implementations to many structures
- impl Default for HighwayBuilder
- Change 128bit hash return type from u128 to [u64; 2] to match the return type from the reference implementation
- Change 256bit hash return type from (u128, u128) to [u64; 4] to match the return type from the reference implementation
You can use the following code to migrate the current return types to the old ones.
fn u64_to_u128(data: &[u64]) -> u128 {
u128::from(data[0]) + (u128::from(data[1]) << 64)
}
fn u64_to_u256(data: &[u64]) -> (u128, u128) {
(u64_to_u128(data), u64_to_u128(&data[2..]))
}
- Fix: debug arithmetic overflow panic in portable hash
- Remove
SseHash::finalize64
as part of public API (accidentally included)
- Fix: AVX enabled hash could segfault on unaligned loads of user input.
- Fix: SIMD enabled hash functions would return the improper response when not compiled with either an explicit
target-cpu=native
or iftarget-feature=+avx2
was omitted
- Initial Release