CoverCrypt

Implementation of the CoverCrypt algorithm.

Building and testing

The crate is separated in 3 main modules:

To build the core only, run

bash cargo build --release

To build the Cosmian interfaces without FFI, pass the interfaces feature flag, i.e. bash cargo build --release --features interfaces

To build everything, including the FFI, pass the ffi feature flag, or use --all-features i.e. bash cargo build --release --all-features

The latter will build a shared library and one can verify that the FFI symbols are present using (linux) bash objdump -T target/release/libcover_crypt.so

The code contains numerous tests that you can run using

bash cargo test --release --all-features

Building the library for a different glibc

Go to the build directory for an example on hw to build for GLIBC 2.17

Building for Pyo3

bash maturin develop --cargo-extra-args="--release --features python

Benchmarks

Benchmarking is using Criterion library.

Run all benchmarks:

bash cargo bench --features ffi

note: unfortunately, we cannot automatically tell Criterion to run benchmarks with ffi feature activated, we need to specify it.

Run only non-FFI benchmarks:

console cargo bench

Flamegraph

To generate a Flamegraph on Criterion's benchmark:

console cargo flamegraph --bench benches --features ffi -- --bench