aboutsummaryrefslogtreecommitdiff
path: root/examples/stm32f7/src
diff options
context:
space:
mode:
authorDario Nieuwenhuis <[email protected]>2024-02-13 01:36:11 +0100
committerGitHub <[email protected]>2024-02-13 01:36:11 +0100
commit8c82d1bcbcb8b04f18e9fd2a2d388a316bc50b49 (patch)
tree3ef1dcdc7f98476e3febbd1515b1cc7221d1c9b7 /examples/stm32f7/src
parente8c998aad882d766988ac2c0cb0c357c600b28c1 (diff)
parent7bf044278e8c85b5ea6dbe3de6b3cdea884c995a (diff)
Merge pull request #2528 from caleb-garrett/hash
STM32 Hash Accelerator
Diffstat (limited to 'examples/stm32f7/src')
-rw-r--r--examples/stm32f7/src/bin/eth.rs2
-rw-r--r--examples/stm32f7/src/bin/hash.rs56
2 files changed, 57 insertions, 1 deletions
diff --git a/examples/stm32f7/src/bin/eth.rs b/examples/stm32f7/src/bin/eth.rs
index 5bff48197..9a608e909 100644
--- a/examples/stm32f7/src/bin/eth.rs
+++ b/examples/stm32f7/src/bin/eth.rs
@@ -19,7 +19,7 @@ use {defmt_rtt as _, panic_probe as _};
19 19
20bind_interrupts!(struct Irqs { 20bind_interrupts!(struct Irqs {
21 ETH => eth::InterruptHandler; 21 ETH => eth::InterruptHandler;
22 RNG => rng::InterruptHandler<peripherals::RNG>; 22 HASH_RNG => rng::InterruptHandler<peripherals::RNG>;
23}); 23});
24 24
25type Device = Ethernet<'static, ETH, GenericSMI>; 25type Device = Ethernet<'static, ETH, GenericSMI>;
diff --git a/examples/stm32f7/src/bin/hash.rs b/examples/stm32f7/src/bin/hash.rs
new file mode 100644
index 000000000..96e50f84b
--- /dev/null
+++ b/examples/stm32f7/src/bin/hash.rs
@@ -0,0 +1,56 @@
1#![no_std]
2#![no_main]
3
4use defmt::info;
5use embassy_executor::Spawner;
6use embassy_stm32::hash::*;
7use embassy_stm32::{bind_interrupts, hash, peripherals, Config};
8use embassy_time::Instant;
9use sha2::{Digest, Sha256};
10use {defmt_rtt as _, panic_probe as _};
11
12bind_interrupts!(struct Irqs {
13 HASH_RNG => hash::InterruptHandler<peripherals::HASH>;
14});
15
16#[embassy_executor::main]
17async fn main(_spawner: Spawner) -> ! {
18 let config = Config::default();
19 let p = embassy_stm32::init(config);
20
21 let test_1: &[u8] = b"as;dfhaslfhas;oifvnasd;nifvnhasd;nifvhndlkfghsd;nvfnahssdfgsdafgsasdfasdfasdfasdfasdfghjklmnbvcalskdjghalskdjgfbaslkdjfgbalskdjgbalskdjbdfhsdfhsfghsfghfgh";
22 let test_2: &[u8] = b"fdhalksdjfhlasdjkfhalskdjfhgal;skdjfgalskdhfjgalskdjfglafgadfgdfgdafgaadsfgfgdfgadrgsyfthxfgjfhklhjkfgukhulkvhlvhukgfhfsrghzdhxyfufynufyuszeradrtydyytserr";
23
24 let mut hw_hasher = Hash::new(p.HASH, p.DMA2_CH7, Irqs);
25
26 let hw_start_time = Instant::now();
27
28 // Compute a digest in hardware.
29 let mut context = hw_hasher.start(Algorithm::SHA256, DataType::Width8);
30 hw_hasher.update(&mut context, test_1).await;
31 hw_hasher.update(&mut context, test_2).await;
32 let mut hw_digest: [u8; 32] = [0; 32];
33 hw_hasher.finish(context, &mut hw_digest).await;
34
35 let hw_end_time = Instant::now();
36 let hw_execution_time = hw_end_time - hw_start_time;
37
38 let sw_start_time = Instant::now();
39
40 // Compute a digest in software.
41 let mut sw_hasher = Sha256::new();
42 sw_hasher.update(test_1);
43 sw_hasher.update(test_2);
44 let sw_digest = sw_hasher.finalize();
45
46 let sw_end_time = Instant::now();
47 let sw_execution_time = sw_end_time - sw_start_time;
48
49 info!("Hardware Digest: {:?}", hw_digest);
50 info!("Software Digest: {:?}", sw_digest[..]);
51 info!("Hardware Execution Time: {:?}", hw_execution_time);
52 info!("Software Execution Time: {:?}", sw_execution_time);
53 assert_eq!(hw_digest, sw_digest[..]);
54
55 loop {}
56}