aboutsummaryrefslogtreecommitdiff
path: root/tests/stm32/src/bin
diff options
context:
space:
mode:
authorCaleb Garrett <[email protected]>2024-02-05 14:36:02 -0500
committerCaleb Garrett <[email protected]>2024-02-05 14:36:02 -0500
commit079bb7b4901b3fa6787c2ca5d8c022de3533ad8c (patch)
tree0766b7afa75a2d69f26a35f96404b5a9ddb63153 /tests/stm32/src/bin
parente1f6f4b31d3c8e4b892b6277fe1f53a85d0f456c (diff)
Added STM32 hash test.
Diffstat (limited to 'tests/stm32/src/bin')
-rw-r--r--tests/stm32/src/bin/hash.rs66
1 files changed, 66 insertions, 0 deletions
diff --git a/tests/stm32/src/bin/hash.rs b/tests/stm32/src/bin/hash.rs
new file mode 100644
index 000000000..60a60b0f1
--- /dev/null
+++ b/tests/stm32/src/bin/hash.rs
@@ -0,0 +1,66 @@
1// required-features: hash
2#![no_std]
3#![no_main]
4
5#[path = "../common.rs"]
6mod common;
7use common::*;
8use embassy_executor::Spawner;
9use embassy_stm32::hash::*;
10use embassy_stm32::{bind_interrupts, peripherals, hash};
11use sha2::{Digest, Sha224, Sha256};
12use {defmt_rtt as _, panic_probe as _};
13
14bind_interrupts!(struct Irqs {
15 HASH_RNG => hash::InterruptHandler<peripherals::HASH>;
16});
17
18#[embassy_executor::main]
19async fn main(_spawner: Spawner) {
20 let p: embassy_stm32::Peripherals = embassy_stm32::init(config());
21 let dma = peri!(p, HASH_DMA);
22 let mut hw_hasher = Hash::new(p.HASH, dma);
23
24 let test_1: &[u8] = b"as;dfhaslfhas;oifvnasd;nifvnhasd;nifvhndlkfghsd;nvfnahssdfgsdafgsasdfasdfasdfasdfasdfghjklmnbvcalskdjghalskdjgfbaslkdjfgbalskdjgbalskdjbdfhsdfhsfghsfghfgh";
25 let test_2: &[u8] = b"fdhalksdjfhlasdjkfhalskdjfhgal;skdjfgalskdhfjgalskdjfglafgadfgdfgdafgaadsfgfgdfgadrgsyfthxfgjfhklhjkfgukhulkvhlvhukgfhfsrghzdhxyfufynufyuszeradrtydyytserr";
26 let test_3: &[u8] = b"a.ewtkluGWEBR.KAJRBTA,RMNRBG,FDMGB.kger.tkasjrbt.akrjtba.krjtba.ktmyna,nmbvtyliasd;gdrtba,sfvs.kgjzshd.gkbsr.tksejb.SDkfBSE.gkfgb>ESkfbSE>gkJSBESE>kbSE>fk";
27
28 // Start an SHA-256 digest.
29 let mut sha256context = hw_hasher.start(Algorithm::SHA256, DataType::Width8).await;
30 hw_hasher.update(&mut sha256context, test_1).await;
31
32 // Interrupt the SHA-256 digest to compute an SHA-224 digest.
33 let mut sha224context = hw_hasher.start(Algorithm::SHA224, DataType::Width8).await;
34 hw_hasher.update(&mut sha224context, test_3).await;
35 let mut sha224_digest_buffer: [u8; 64] = [0; 64];
36 let sha224_digest = hw_hasher.finish(sha224context, &mut sha224_digest_buffer).await;
37
38 // Finish the SHA-256 digest.
39 hw_hasher.update(&mut sha256context, test_2).await;
40 let mut sha_256_digest_buffer: [u8; 64] = [0; 64];
41 let sha256_digest = hw_hasher.finish(sha256context, &mut sha_256_digest_buffer).await;
42
43 // Compute the SHA-256 digest in software.
44 let mut sw_sha256_hasher = Sha256::new();
45 sw_sha256_hasher.update(test_1);
46 sw_sha256_hasher.update(test_2);
47 let sw_sha256_digest = sw_sha256_hasher.finalize();
48
49 //Compute the SHA-224 digest in software.
50 let mut sw_sha224_hasher = Sha224::new();
51 sw_sha224_hasher.update(test_3);
52 let sw_sha224_digest = sw_sha224_hasher.finalize();
53
54 // Compare the SHA-256 digests.
55 info!("Hardware SHA-256 Digest: {:?}", sha256_digest);
56 info!("Software SHA-256 Digest: {:?}", sw_sha256_digest[..]);
57 defmt::assert!(*sha256_digest == sw_sha256_digest[..]);
58
59 // Compare the SHA-224 digests.
60 info!("Hardware SHA-256 Digest: {:?}", sha224_digest);
61 info!("Software SHA-256 Digest: {:?}", sw_sha224_digest[..]);
62 defmt::assert!(*sha224_digest == sw_sha224_digest[..]);
63
64 info!("Test OK");
65 cortex_m::asm::bkpt();
66}