rand_aes 0.6.1

AES based pseudo-random number generator
Documentation
//! Test that verify that the software backend and the hardware backends produce the same random numbers for a given seed.

use crate::constants::{AES128_KEY_SIZE, AES256_KEY_SIZE, AES_BLOCK_SIZE};

#[cfg(any(target_arch = "x86_64", target_arch = "x86"))]
use crate::backend::x86::{
    Aes128Ctr128 as Aes128Ctr128Hardware, Aes128Ctr64 as Aes128Ctr64Hardware,
    Aes256Ctr128 as Aes256Ctr128Hardware, Aes256Ctr64 as Aes256Ctr64Hardware,
};

#[cfg(all(target_arch = "riscv64", feature = "experimental_riscv"))]
use crate::backend::riscv64::{
    Aes128Ctr128 as Aes128Ctr128Hardware, Aes128Ctr64 as Aes128Ctr64Hardware,
    Aes256Ctr128 as Aes256Ctr128Hardware, Aes256Ctr64 as Aes256Ctr64Hardware,
};

#[cfg(target_arch = "aarch64")]
use crate::backend::aarch64::{
    Aes128Ctr128 as Aes128Ctr128Hardware, Aes128Ctr64 as Aes128Ctr64Hardware,
    Aes256Ctr128 as Aes256Ctr128Hardware, Aes256Ctr64 as Aes256Ctr64Hardware,
};

use crate::backend::soft::{
    Aes128Ctr128 as Aes128Ctr128Software, Aes128Ctr64 as Aes128Ctr64Software,
    Aes256Ctr128 as Aes256Ctr128Software, Aes256Ctr64 as Aes256Ctr64Software,
};

/// Runs the verification testsuite. Will panic once it finds an error.
///
/// This function is unsafe, since we don't properly gate the function behind compiletime or
/// runtime based checks if the hardware based AES features are available. This function is not
/// supposed to be used by the user and is behind an internal feature flag.   
#[doc(hidden)]
pub unsafe fn run_verification() {
    println!("Verifying Aes128Ctr64");
    for i in 0..u8::MAX {
        for j in 0..u8::MAX {
            verify_aes128_ctr64([i; AES128_KEY_SIZE], [j; AES_BLOCK_SIZE]);
        }
    }
    println!("Finished Aes128Ctr64");

    println!("Verifying Aes128Ctr128");
    for i in 0..u8::MAX {
        for j in 0..u8::MAX {
            verify_aes128_ctr128([i; AES128_KEY_SIZE], [j; AES_BLOCK_SIZE]);
        }
    }
    println!("Finished Aes128Ctr128");

    println!("Verifying Aes256Ctr64");
    for i in 0..u8::MAX {
        for j in 0..u8::MAX {
            verify_aes256_ctr64([i; AES256_KEY_SIZE], [j; AES_BLOCK_SIZE]);
        }
    }
    println!("Finished Aes256Ctr64");

    println!("Verifying Aes256Ctr128");
    for i in 0..u8::MAX {
        for j in 0..u8::MAX {
            verify_aes256_ctr128([i; AES256_KEY_SIZE], [j; AES_BLOCK_SIZE]);
        }
    }
    println!("Finished Aes256Ctr128");
}

fn verify_aes128_ctr64(key: [u8; AES128_KEY_SIZE], iv: [u8; AES_BLOCK_SIZE]) {
    let mut ctr = [0u8; 8];
    let mut nonce = [0u8; 8];
    ctr.copy_from_slice(&iv[0..8]);
    nonce.copy_from_slice(&iv[8..16]);

    let mut software = Aes128Ctr64Software::from_seed_impl(key, nonce, ctr);
    let hardware = unsafe { Aes128Ctr64Hardware::from_seed_impl(key, nonce, ctr) };

    for _ in 0..u8::MAX {
        assert_eq!(software.next_impl().to_le_bytes(), unsafe {
            hardware.next_impl().to_le_bytes()
        });
    }
}

fn verify_aes128_ctr128(key: [u8; AES128_KEY_SIZE], iv: [u8; AES_BLOCK_SIZE]) {
    let mut software = Aes128Ctr128Software::from_seed_impl(key, iv);
    let hardware = unsafe { Aes128Ctr128Hardware::from_seed_impl(key, iv) };

    for _ in 0..u8::MAX {
        assert_eq!(software.next_impl().to_le_bytes(), unsafe {
            hardware.next_impl().to_le_bytes()
        });
    }
}

fn verify_aes256_ctr64(key: [u8; AES256_KEY_SIZE], iv: [u8; AES_BLOCK_SIZE]) {
    let mut ctr = [0u8; 8];
    let mut nonce = [0u8; 8];
    ctr.copy_from_slice(&iv[0..8]);
    nonce.copy_from_slice(&iv[8..16]);

    let mut software = Aes256Ctr64Software::from_seed_impl(key, nonce, ctr);
    let hardware = unsafe { Aes256Ctr64Hardware::from_seed_impl(key, nonce, ctr) };

    for _ in 0..u8::MAX {
        assert_eq!(software.next_impl().to_le_bytes(), unsafe {
            hardware.next_impl().to_le_bytes()
        });
    }
}

fn verify_aes256_ctr128(key: [u8; AES256_KEY_SIZE], iv: [u8; AES_BLOCK_SIZE]) {
    let mut software = Aes256Ctr128Software::from_seed_impl(key, iv);
    let hardware = unsafe { Aes256Ctr128Hardware::from_seed_impl(key, iv) };

    for _ in 0..u8::MAX {
        assert_eq!(software.next_impl().to_le_bytes(), unsafe {
            hardware.next_impl().to_le_bytes()
        });
    }
}