Skip to content
/ librscrc Public

Crc checksum implemented in rust

License

Apache-2.0, MIT licenses found

Licenses found

Apache-2.0
LICENSE-APACHE
MIT
LICENSE-MIT
Notifications You must be signed in to change notification settings

psvri/librscrc

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

29 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

librscrc

CircleCI librscrc docs

Librscrc is a collection of crc32 algorithms with support for various approaches like simd and table based lookup and custom polynomial implemented in rust.

Simd is currently supported on the following architectures

  • x86
  • x86_64
  • aarch64

Unsafe code is used for calls to intrinsics. These can be opted out by setting default-features = false in Cargo.toml, there by disabling simd and hardware crc intrinsics support.

Performance

Your mileage may vary based on the hardware used. This section is meant to only give a comparison of various approaches.

  • Nightly compiler is required to use hardware crc instructions on aarch64 with feature flag "nightly" enable.
  • Simd and hardware instructions are used if the required cpu features are detected at run time. In case it's not found, it falls back to lookup based approach.
  • Simd approach is based on the paper published by intel
Algorithm(crc32c) x86_64(throughput) aarch64(throughput)
naive 249.97 MiB/s 221.81 MiB/s
lookup 3.6584 GiB/s 2.2660 GiB/s
hardware crc 10.483 GiB/s 21.026 GiB/s
simd 25.479 GiB/s 18.079 GiB/s

About

Crc checksum implemented in rust

Resources

License

Apache-2.0, MIT licenses found

Licenses found

Apache-2.0
LICENSE-APACHE
MIT
LICENSE-MIT

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages