diff options
| author | Dario Nieuwenhuis <[email protected]> | 2024-02-13 01:36:11 +0100 |
|---|---|---|
| committer | GitHub <[email protected]> | 2024-02-13 01:36:11 +0100 |
| commit | 8c82d1bcbcb8b04f18e9fd2a2d388a316bc50b49 (patch) | |
| tree | 3ef1dcdc7f98476e3febbd1515b1cc7221d1c9b7 /tests/stm32/src | |
| parent | e8c998aad882d766988ac2c0cb0c357c600b28c1 (diff) | |
| parent | 7bf044278e8c85b5ea6dbe3de6b3cdea884c995a (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.rs | 78 |
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"] | ||
| 6 | mod common; | ||
| 7 | use common::*; | ||
| 8 | use embassy_executor::Spawner; | ||
| 9 | use embassy_stm32::dma::NoDma; | ||
| 10 | use embassy_stm32::hash::*; | ||
| 11 | use embassy_stm32::{bind_interrupts, hash, peripherals}; | ||
| 12 | use sha2::{Digest, Sha224, Sha256}; | ||
| 13 | use {defmt_rtt as _, panic_probe as _}; | ||
| 14 | |||
| 15 | #[cfg(any(feature = "stm32l4a6zg", feature = "stm32h755zi", feature = "stm32h753zi"))] | ||
| 16 | bind_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 | ))] | ||
| 27 | bind_interrupts!(struct Irqs { | ||
| 28 | HASH => hash::InterruptHandler<peripherals::HASH>; | ||
| 29 | }); | ||
| 30 | |||
| 31 | #[embassy_executor::main] | ||
| 32 | async 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 | } | ||
