#authenticated-encryption #aead #encryption

no-std aegis

AEGIS authenticated ciphers (AEGIS-128, AEGIS-256, AEGIS-128X, AEGIS-256X)

36 releases

new 0.8.0 Dec 11, 2024
0.6.13 Nov 14, 2024
0.6.6 Jun 10, 2024
0.6.2 Nov 30, 2023
0.2.2 Oct 20, 2021

#1111 in Cryptography

Download history 22/week @ 2024-08-23 34/week @ 2024-08-30 71/week @ 2024-09-06 40/week @ 2024-09-13 227/week @ 2024-09-20 78/week @ 2024-09-27 38/week @ 2024-10-04 34/week @ 2024-10-11 312/week @ 2024-10-18 281/week @ 2024-10-25 267/week @ 2024-11-01 175/week @ 2024-11-08 101/week @ 2024-11-15 62/week @ 2024-11-22 306/week @ 2024-11-29 295/week @ 2024-12-06

881 downloads per month
Used in 3 crates

MIT license

1MB
9K SLoC

C 4.5K SLoC // 0.0% comments Rust 3K SLoC Zig 1.5K SLoC // 0.0% comments

Contains (static library, 145KB) wasm-libs/libaegis.a

AEGIS for Rust

This is a Rust implementation of AEGIS.

AEGIS is a new family of authenticated encryption algorithms, offering high security and exceptional performance on modern desktop, server, and mobile CPUs.

API documentation

Cargo flags

  • std: allow dynamic allocations. This is the default.

  • pure-rust: don't use the cc crate to take advantage of the implementations from libaegis. Setting this flag will substantially degrade performance, and parallel variants will not be available.

  • rustcrypto-traits-06: add traits from rust-crypto/aead version 0.6. Alternative interfaces are available in the compat namespace.

Benchmarks

AEGIS is very fast on CPUs with parallel execution pipelines and AES support.

Benchmarks can be reproduced using export CC="clang -O3 -march=native" and the cargo bench or cargo-zigbuild bench commands.

For performance, clang is recommended over gcc.

Encryption (16 KB)

AEGIS benchmark results

Authentication (64 KB)

AEGIS-MAC benchmark results

Mobile benchmarks

AEGIS mobile benchmark results

Dependencies