aboutsummaryrefslogtreecommitdiff
path: root/tests/stm32/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 /tests/stm32/src
parente8c998aad882d766988ac2c0cb0c357c600b28c1 (diff)
parent7bf044278e8c85b5ea6dbe3de6b3cdea884c995a (diff)
Merge pull request #2528 from caleb-garrett/hash
STM32 Hash Accelerator
Diffstat (limited to 'tests/stm32/src')
-rw-r--r--tests/stm32/src/bin/hash.rs78
1 files changed, 78 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..cfcf3d976
--- /dev/null
+++ b/tests/stm32/src/bin/hash.rs
@@ -0,0 +1,78 @@
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::dma::NoDma;
10use embassy_stm32::hash::*;
11use embassy_stm32::{bind_interrupts, hash, peripherals};
12use sha2::{Digest, Sha224, Sha256};
13use {defmt_rtt as _, panic_probe as _};
14
15#[cfg(any(feature = "stm32l4a6zg", feature = "stm32h755zi", feature = "stm32h753zi"))]
16bind_interrupts!(struct Irqs {
17 HASH_RNG => hash::InterruptHandler<peripherals::HASH>;
18});
19
20#[cfg(any(
21 feature = "stm32wba52cg",
22 feature = "stm32l552ze",
23 feature = "stm32h563zi",
24 feature = "stm32u5a5zj",
25 feature = "stm32u585ai"
26))]
27bind_interrupts!(struct Irqs {
28 HASH => hash::InterruptHandler<peripherals::HASH>;
29});
30
31#[embassy_executor::main]
32async fn main(_spawner: Spawner) {
33 let p: embassy_stm32::Peripherals = embassy_stm32::init(config());
34 let mut hw_hasher = Hash::new(p.HASH, NoDma, Irqs);
35
36 let test_1: &[u8] = b"as;dfhaslfhas;oifvnasd;nifvnhasd;nifvhndlkfghsd;nvfnahssdfgsdafgsasdfasdfasdfasdfasdfghjklmnbvcalskdjghalskdjgfbaslkdjfgbalskdjgbalskdjbdfhsdfhsfghsfghfgh";
37 let test_2: &[u8] = b"fdhalksdjfhlasdjkfhalskdjfhgal;skdjfgalskdhfjgalskdjfglafgadfgdfgdafgaadsfgfgdfgadrgsyfthxfgjfhklhjkfgukhulkvhlvhukgfhfsrghzdhxyfufynufyuszeradrtydyytserr";
38 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";
39
40 // Start an SHA-256 digest.
41 let mut sha256context = hw_hasher.start(Algorithm::SHA256, DataType::Width8);
42 hw_hasher.update_blocking(&mut sha256context, test_1);
43
44 // Interrupt the SHA-256 digest to compute an SHA-224 digest.
45 let mut sha224context = hw_hasher.start(Algorithm::SHA224, DataType::Width8);
46 hw_hasher.update_blocking(&mut sha224context, test_3);
47 let mut sha224_digest_buffer: [u8; 28] = [0; 28];
48 let _ = hw_hasher.finish_blocking(sha224context, &mut sha224_digest_buffer);
49
50 // Finish the SHA-256 digest.
51 hw_hasher.update_blocking(&mut sha256context, test_2);
52 let mut sha256_digest_buffer: [u8; 32] = [0; 32];
53 let _ = hw_hasher.finish_blocking(sha256context, &mut sha256_digest_buffer);
54
55 // Compute the SHA-256 digest in software.
56 let mut sw_sha256_hasher = Sha256::new();
57 sw_sha256_hasher.update(test_1);
58 sw_sha256_hasher.update(test_2);
59 let sw_sha256_digest = sw_sha256_hasher.finalize();
60
61 //Compute the SHA-224 digest in software.
62 let mut sw_sha224_hasher = Sha224::new();
63 sw_sha224_hasher.update(test_3);
64 let sw_sha224_digest = sw_sha224_hasher.finalize();
65
66 // Compare the SHA-256 digests.
67 info!("Hardware SHA-256 Digest: {:?}", sha256_digest_buffer);
68 info!("Software SHA-256 Digest: {:?}", sw_sha256_digest[..]);
69 defmt::assert!(sha256_digest_buffer == sw_sha256_digest[..]);
70
71 // Compare the SHA-224 digests.
72 info!("Hardware SHA-256 Digest: {:?}", sha224_digest_buffer);
73 info!("Software SHA-256 Digest: {:?}", sw_sha224_digest[..]);
74 defmt::assert!(sha224_digest_buffer == sw_sha224_digest[..]);
75
76 info!("Test OK");
77 cortex_m::asm::bkpt();
78}