aboutsummaryrefslogtreecommitdiff
path: root/tests
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
parente1f6f4b31d3c8e4b892b6277fe1f53a85d0f456c (diff)
Added STM32 hash test.
Diffstat (limited to 'tests')
-rw-r--r--tests/stm32/Cargo.toml23
-rw-r--r--tests/stm32/src/bin/hash.rs66
-rw-r--r--tests/stm32/src/common.rs7
3 files changed, 88 insertions, 8 deletions
diff --git a/tests/stm32/Cargo.toml b/tests/stm32/Cargo.toml
index cb1bd9a50..d02f1a253 100644
--- a/tests/stm32/Cargo.toml
+++ b/tests/stm32/Cargo.toml
@@ -15,22 +15,23 @@ stm32f446re = ["embassy-stm32/stm32f446re", "chrono", "stop", "can", "not-gpdma"
15stm32f767zi = ["embassy-stm32/stm32f767zi", "chrono", "not-gpdma", "eth", "rng"] 15stm32f767zi = ["embassy-stm32/stm32f767zi", "chrono", "not-gpdma", "eth", "rng"]
16stm32g071rb = ["embassy-stm32/stm32g071rb", "cm0", "not-gpdma", "dac"] 16stm32g071rb = ["embassy-stm32/stm32g071rb", "cm0", "not-gpdma", "dac"]
17stm32g491re = ["embassy-stm32/stm32g491re", "chrono", "stop", "not-gpdma", "rng", "fdcan"] 17stm32g491re = ["embassy-stm32/stm32g491re", "chrono", "stop", "not-gpdma", "rng", "fdcan"]
18stm32h563zi = ["embassy-stm32/stm32h563zi", "chrono", "eth", "rng"] 18stm32h563zi = ["embassy-stm32/stm32h563zi", "chrono", "eth", "rng", "hash"]
19stm32h753zi = ["embassy-stm32/stm32h753zi", "chrono", "not-gpdma", "eth", "rng", "fdcan"] 19stm32h753zi = ["embassy-stm32/stm32h753zi", "chrono", "not-gpdma", "eth", "rng", "fdcan", "hash"]
20stm32h755zi = ["embassy-stm32/stm32h755zi-cm7", "chrono", "not-gpdma", "eth", "dac", "rng", "fdcan"] 20stm32h755zi = ["embassy-stm32/stm32h755zi-cm7", "chrono", "not-gpdma", "eth", "dac", "rng", "fdcan", "hash"]
21stm32h7a3zi = ["embassy-stm32/stm32h7a3zi", "not-gpdma", "rng", "fdcan"] 21stm32h7a3zi = ["embassy-stm32/stm32h7a3zi", "not-gpdma", "rng", "fdcan"]
22stm32l073rz = ["embassy-stm32/stm32l073rz", "cm0", "not-gpdma", "rng"] 22stm32l073rz = ["embassy-stm32/stm32l073rz", "cm0", "not-gpdma", "rng"]
23stm32l152re = ["embassy-stm32/stm32l152re", "chrono", "not-gpdma"] 23stm32l152re = ["embassy-stm32/stm32l152re", "chrono", "not-gpdma"]
24stm32l496zg = ["embassy-stm32/stm32l496zg", "not-gpdma", "rng"] 24stm32l496zg = ["embassy-stm32/stm32l496zg", "not-gpdma", "rng"]
25stm32l4a6zg = ["embassy-stm32/stm32l4a6zg", "chrono", "not-gpdma", "rng"] 25stm32l4a6zg = ["embassy-stm32/stm32l4a6zg", "chrono", "not-gpdma", "rng", "hash"]
26stm32l4r5zi = ["embassy-stm32/stm32l4r5zi", "chrono", "not-gpdma", "rng"] 26stm32l4r5zi = ["embassy-stm32/stm32l4r5zi", "chrono", "not-gpdma", "rng"]
27stm32l552ze = ["embassy-stm32/stm32l552ze", "not-gpdma", "rng"] 27stm32l552ze = ["embassy-stm32/stm32l552ze", "not-gpdma", "rng", "hash"]
28stm32u585ai = ["embassy-stm32/stm32u585ai", "chrono", "rng"] 28stm32u585ai = ["embassy-stm32/stm32u585ai", "chrono", "rng", "hash"]
29stm32u5a5zj = ["embassy-stm32/stm32u5a5zj", "chrono", "rng"] 29stm32u5a5zj = ["embassy-stm32/stm32u5a5zj", "chrono", "rng", "hash"]
30stm32wb55rg = ["embassy-stm32/stm32wb55rg", "chrono", "not-gpdma", "ble", "mac" , "rng"] 30stm32wb55rg = ["embassy-stm32/stm32wb55rg", "chrono", "not-gpdma", "ble", "mac" , "rng"]
31stm32wba52cg = ["embassy-stm32/stm32wba52cg", "chrono", "rng"] 31stm32wba52cg = ["embassy-stm32/stm32wba52cg", "chrono", "rng", "hash"]
32stm32wl55jc = ["embassy-stm32/stm32wl55jc-cm4", "not-gpdma", "rng", "chrono"] 32stm32wl55jc = ["embassy-stm32/stm32wl55jc-cm4", "not-gpdma", "rng", "chrono"]
33 33
34hash = []
34eth = ["embassy-executor/task-arena-size-16384"] 35eth = ["embassy-executor/task-arena-size-16384"]
35rng = [] 36rng = []
36sdmmc = [] 37sdmmc = []
@@ -74,6 +75,7 @@ static_cell = "2"
74portable-atomic = { version = "1.5", features = [] } 75portable-atomic = { version = "1.5", features = [] }
75 76
76chrono = { version = "^0.4", default-features = false, optional = true} 77chrono = { version = "^0.4", default-features = false, optional = true}
78sha2 = { version = "0.10.8", default-features = false }
77 79
78# BEGIN TESTS 80# BEGIN TESTS
79# Generated by gen_test.py. DO NOT EDIT. 81# Generated by gen_test.py. DO NOT EDIT.
@@ -108,6 +110,11 @@ path = "src/bin/gpio.rs"
108required-features = [] 110required-features = []
109 111
110[[bin]] 112[[bin]]
113name = "hash"
114path = "src/bin/hash.rs"
115required-features = [ "hash",]
116
117[[bin]]
111name = "rng" 118name = "rng"
112path = "src/bin/rng.rs" 119path = "src/bin/rng.rs"
113required-features = [ "rng",] 120required-features = [ "rng",]
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}
diff --git a/tests/stm32/src/common.rs b/tests/stm32/src/common.rs
index fefe72c86..7e7915b2e 100644
--- a/tests/stm32/src/common.rs
+++ b/tests/stm32/src/common.rs
@@ -128,6 +128,7 @@ define_peris!(
128); 128);
129#[cfg(any(feature = "stm32h755zi", feature = "stm32h753zi"))] 129#[cfg(any(feature = "stm32h755zi", feature = "stm32h753zi"))]
130define_peris!( 130define_peris!(
131 HASH_DMA = DMA1_CH0,
131 UART = USART1, UART_TX = PB6, UART_RX = PB7, UART_TX_DMA = DMA1_CH0, UART_RX_DMA = DMA1_CH1, 132 UART = USART1, UART_TX = PB6, UART_RX = PB7, UART_TX_DMA = DMA1_CH0, UART_RX_DMA = DMA1_CH1,
132 SPI = SPI1, SPI_SCK = PA5, SPI_MOSI = PB5, SPI_MISO = PA6, SPI_TX_DMA = DMA1_CH0, SPI_RX_DMA = DMA1_CH1, 133 SPI = SPI1, SPI_SCK = PA5, SPI_MOSI = PB5, SPI_MISO = PA6, SPI_TX_DMA = DMA1_CH0, SPI_RX_DMA = DMA1_CH1,
133 ADC = ADC1, DAC = DAC1, DAC_PIN = PA4, 134 ADC = ADC1, DAC = DAC1, DAC_PIN = PA4,
@@ -141,18 +142,21 @@ define_peris!(
141); 142);
142#[cfg(feature = "stm32u585ai")] 143#[cfg(feature = "stm32u585ai")]
143define_peris!( 144define_peris!(
145 HASH_DMA = GPDMA1_CH0,
144 UART = USART3, UART_TX = PD8, UART_RX = PD9, UART_TX_DMA = GPDMA1_CH0, UART_RX_DMA = GPDMA1_CH1, 146 UART = USART3, UART_TX = PD8, UART_RX = PD9, UART_TX_DMA = GPDMA1_CH0, UART_RX_DMA = GPDMA1_CH1,
145 SPI = SPI1, SPI_SCK = PE13, SPI_MOSI = PE15, SPI_MISO = PE14, SPI_TX_DMA = GPDMA1_CH0, SPI_RX_DMA = GPDMA1_CH1, 147 SPI = SPI1, SPI_SCK = PE13, SPI_MOSI = PE15, SPI_MISO = PE14, SPI_TX_DMA = GPDMA1_CH0, SPI_RX_DMA = GPDMA1_CH1,
146 @irq UART = {USART3 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::USART3>;}, 148 @irq UART = {USART3 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::USART3>;},
147); 149);
148#[cfg(feature = "stm32u5a5zj")] 150#[cfg(feature = "stm32u5a5zj")]
149define_peris!( 151define_peris!(
152 HASH_DMA = GPDMA1_CH0,
150 UART = LPUART1, UART_TX = PG7, UART_RX = PG8, UART_TX_DMA = GPDMA1_CH0, UART_RX_DMA = GPDMA1_CH1, 153 UART = LPUART1, UART_TX = PG7, UART_RX = PG8, UART_TX_DMA = GPDMA1_CH0, UART_RX_DMA = GPDMA1_CH1,
151 SPI = SPI1, SPI_SCK = PA5, SPI_MOSI = PA7, SPI_MISO = PA6, SPI_TX_DMA = GPDMA1_CH0, SPI_RX_DMA = GPDMA1_CH1, 154 SPI = SPI1, SPI_SCK = PA5, SPI_MOSI = PA7, SPI_MISO = PA6, SPI_TX_DMA = GPDMA1_CH0, SPI_RX_DMA = GPDMA1_CH1,
152 @irq UART = {LPUART1 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::LPUART1>;}, 155 @irq UART = {LPUART1 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::LPUART1>;},
153); 156);
154#[cfg(feature = "stm32h563zi")] 157#[cfg(feature = "stm32h563zi")]
155define_peris!( 158define_peris!(
159 HASH_DMA = GPDMA1_CH0,
156 UART = LPUART1, UART_TX = PB6, UART_RX = PB7, UART_TX_DMA = GPDMA1_CH0, UART_RX_DMA = GPDMA1_CH1, 160 UART = LPUART1, UART_TX = PB6, UART_RX = PB7, UART_TX_DMA = GPDMA1_CH0, UART_RX_DMA = GPDMA1_CH1,
157 SPI = SPI4, SPI_SCK = PE12, SPI_MOSI = PE14, SPI_MISO = PE13, SPI_TX_DMA = GPDMA1_CH0, SPI_RX_DMA = GPDMA1_CH1, 161 SPI = SPI4, SPI_SCK = PE12, SPI_MOSI = PE14, SPI_MISO = PE13, SPI_TX_DMA = GPDMA1_CH0, SPI_RX_DMA = GPDMA1_CH1,
158 @irq UART = {LPUART1 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::LPUART1>;}, 162 @irq UART = {LPUART1 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::LPUART1>;},
@@ -171,6 +175,7 @@ define_peris!(
171); 175);
172#[cfg(feature = "stm32l4a6zg")] 176#[cfg(feature = "stm32l4a6zg")]
173define_peris!( 177define_peris!(
178 HASH_DMA = DMA2_CH7,
174 UART = USART3, UART_TX = PD8, UART_RX = PD9, UART_TX_DMA = DMA1_CH2, UART_RX_DMA = DMA1_CH3, 179 UART = USART3, UART_TX = PD8, UART_RX = PD9, UART_TX_DMA = DMA1_CH2, UART_RX_DMA = DMA1_CH3,
175 SPI = SPI1, SPI_SCK = PA5, SPI_MOSI = PA7, SPI_MISO = PA6, SPI_TX_DMA = DMA1_CH3, SPI_RX_DMA = DMA1_CH2, 180 SPI = SPI1, SPI_SCK = PA5, SPI_MOSI = PA7, SPI_MISO = PA6, SPI_TX_DMA = DMA1_CH3, SPI_RX_DMA = DMA1_CH2,
176 @irq UART = {USART3 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::USART3>;}, 181 @irq UART = {USART3 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::USART3>;},
@@ -196,6 +201,7 @@ define_peris!(
196); 201);
197#[cfg(feature = "stm32l552ze")] 202#[cfg(feature = "stm32l552ze")]
198define_peris!( 203define_peris!(
204 HASH_DMA = DMA1_CH0,
199 UART = USART3, UART_TX = PD8, UART_RX = PD9, UART_TX_DMA = DMA1_CH1, UART_RX_DMA = DMA1_CH2, 205 UART = USART3, UART_TX = PD8, UART_RX = PD9, UART_TX_DMA = DMA1_CH1, UART_RX_DMA = DMA1_CH2,
200 SPI = SPI1, SPI_SCK = PA5, SPI_MOSI = PA7, SPI_MISO = PA6, SPI_TX_DMA = DMA1_CH1, SPI_RX_DMA = DMA1_CH2, 206 SPI = SPI1, SPI_SCK = PA5, SPI_MOSI = PA7, SPI_MISO = PA6, SPI_TX_DMA = DMA1_CH1, SPI_RX_DMA = DMA1_CH2,
201 @irq UART = {USART3 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::USART3>;}, 207 @irq UART = {USART3 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::USART3>;},
@@ -226,6 +232,7 @@ define_peris!(
226); 232);
227#[cfg(feature = "stm32wba52cg")] 233#[cfg(feature = "stm32wba52cg")]
228define_peris!( 234define_peris!(
235 HASH_DMA = GPDMA1_CH0,
229 UART = LPUART1, UART_TX = PB5, UART_RX = PA10, UART_TX_DMA = GPDMA1_CH0, UART_RX_DMA = GPDMA1_CH1, 236 UART = LPUART1, UART_TX = PB5, UART_RX = PA10, UART_TX_DMA = GPDMA1_CH0, UART_RX_DMA = GPDMA1_CH1,
230 SPI = SPI1, SPI_SCK = PB4, SPI_MOSI = PA15, SPI_MISO = PB3, SPI_TX_DMA = GPDMA1_CH0, SPI_RX_DMA = GPDMA1_CH1, 237 SPI = SPI1, SPI_SCK = PB4, SPI_MOSI = PA15, SPI_MISO = PB3, SPI_TX_DMA = GPDMA1_CH0, SPI_RX_DMA = GPDMA1_CH1,
231 @irq UART = {LPUART1 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::LPUART1>;}, 238 @irq UART = {LPUART1 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::LPUART1>;},