2024-01-31 21:21:36 -05:00
|
|
|
#![no_std]
|
|
|
|
#![no_main]
|
|
|
|
|
|
|
|
use defmt::info;
|
|
|
|
use embassy_executor::Spawner;
|
|
|
|
use embassy_stm32::Config;
|
2024-02-03 16:10:00 -05:00
|
|
|
use embassy_time::Instant;
|
2024-01-31 21:21:36 -05:00
|
|
|
use {defmt_rtt as _, panic_probe as _};
|
|
|
|
|
|
|
|
use embassy_stm32::hash::*;
|
|
|
|
use sha2::{Digest, Sha256};
|
|
|
|
|
|
|
|
#[embassy_executor::main]
|
|
|
|
async fn main(_spawner: Spawner) -> ! {
|
|
|
|
let config = Config::default();
|
|
|
|
let p = embassy_stm32::init(config);
|
|
|
|
|
2024-02-03 16:10:00 -05:00
|
|
|
let test_1: &[u8] = b"as;dfhaslfhas;oifvnasd;nifvnhasd;nifvhndlkfghsd;nvfnahssdfgsdafgsasdfasdfasdfasdfasdfghjklmnbvcalskdjghalskdjgfbaslkdjfgbalskdjgbalskdjbdfhsdfhsfghsfghfgh";
|
|
|
|
let test_2: &[u8] = b"fdhalksdjfhlasdjkfhalskdjfhgal;skdjfgalskdhfjgalskdjfglafgadfgdfgdafgaadsfgfgdfgadrgsyfthxfgjfhklhjkfgukhulkvhlvhukgfhfsrghzdhxyfufynufyuszeradrtydyytserr";
|
|
|
|
|
|
|
|
let mut hw_hasher = Hash::new(p.HASH, p.DMA2_CH7);
|
|
|
|
|
2024-01-31 21:21:36 -05:00
|
|
|
let hw_start_time = Instant::now();
|
|
|
|
|
|
|
|
// Compute a digest in hardware.
|
2024-02-03 16:10:00 -05:00
|
|
|
let mut context = hw_hasher.start(Algorithm::SHA256, DataType::Width8).await;
|
|
|
|
hw_hasher.update(&mut context, test_1).await;
|
|
|
|
hw_hasher.update(&mut context, test_2).await;
|
2024-01-31 21:21:36 -05:00
|
|
|
let mut buffer: [u8; 32] = [0; 32];
|
2024-02-03 16:10:00 -05:00
|
|
|
let hw_digest = hw_hasher.finish(context, &mut buffer).await;
|
2024-01-31 21:21:36 -05:00
|
|
|
|
|
|
|
let hw_end_time = Instant::now();
|
|
|
|
let hw_execution_time = hw_end_time - hw_start_time;
|
|
|
|
|
|
|
|
let sw_start_time = Instant::now();
|
|
|
|
|
|
|
|
// Compute a digest in software.
|
|
|
|
let mut sw_hasher = Sha256::new();
|
2024-02-03 16:10:00 -05:00
|
|
|
sw_hasher.update(test_1);
|
|
|
|
sw_hasher.update(test_2);
|
2024-01-31 21:21:36 -05:00
|
|
|
let sw_digest = sw_hasher.finalize();
|
|
|
|
|
|
|
|
let sw_end_time = Instant::now();
|
|
|
|
let sw_execution_time = sw_end_time - sw_start_time;
|
|
|
|
|
|
|
|
info!("Hardware Digest: {:?}", hw_digest);
|
|
|
|
info!("Software Digest: {:?}", sw_digest[..]);
|
|
|
|
info!("Hardware Execution Time: {:?}", hw_execution_time);
|
|
|
|
info!("Software Execution Time: {:?}", sw_execution_time);
|
|
|
|
assert_eq!(*hw_digest, sw_digest[..]);
|
|
|
|
|
|
|
|
loop {}
|
|
|
|
}
|