diff options
| author | Caleb Garrett <[email protected]> | 2024-02-05 14:36:02 -0500 |
|---|---|---|
| committer | Caleb Garrett <[email protected]> | 2024-02-05 14:36:02 -0500 |
| commit | 079bb7b4901b3fa6787c2ca5d8c022de3533ad8c (patch) | |
| tree | 0766b7afa75a2d69f26a35f96404b5a9ddb63153 /tests | |
| parent | e1f6f4b31d3c8e4b892b6277fe1f53a85d0f456c (diff) | |
Added STM32 hash test.
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/stm32/Cargo.toml | 23 | ||||
| -rw-r--r-- | tests/stm32/src/bin/hash.rs | 66 | ||||
| -rw-r--r-- | tests/stm32/src/common.rs | 7 |
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" | |||
| 15 | stm32f767zi = ["embassy-stm32/stm32f767zi", "chrono", "not-gpdma", "eth", "rng"] | 15 | stm32f767zi = ["embassy-stm32/stm32f767zi", "chrono", "not-gpdma", "eth", "rng"] |
| 16 | stm32g071rb = ["embassy-stm32/stm32g071rb", "cm0", "not-gpdma", "dac"] | 16 | stm32g071rb = ["embassy-stm32/stm32g071rb", "cm0", "not-gpdma", "dac"] |
| 17 | stm32g491re = ["embassy-stm32/stm32g491re", "chrono", "stop", "not-gpdma", "rng", "fdcan"] | 17 | stm32g491re = ["embassy-stm32/stm32g491re", "chrono", "stop", "not-gpdma", "rng", "fdcan"] |
| 18 | stm32h563zi = ["embassy-stm32/stm32h563zi", "chrono", "eth", "rng"] | 18 | stm32h563zi = ["embassy-stm32/stm32h563zi", "chrono", "eth", "rng", "hash"] |
| 19 | stm32h753zi = ["embassy-stm32/stm32h753zi", "chrono", "not-gpdma", "eth", "rng", "fdcan"] | 19 | stm32h753zi = ["embassy-stm32/stm32h753zi", "chrono", "not-gpdma", "eth", "rng", "fdcan", "hash"] |
| 20 | stm32h755zi = ["embassy-stm32/stm32h755zi-cm7", "chrono", "not-gpdma", "eth", "dac", "rng", "fdcan"] | 20 | stm32h755zi = ["embassy-stm32/stm32h755zi-cm7", "chrono", "not-gpdma", "eth", "dac", "rng", "fdcan", "hash"] |
| 21 | stm32h7a3zi = ["embassy-stm32/stm32h7a3zi", "not-gpdma", "rng", "fdcan"] | 21 | stm32h7a3zi = ["embassy-stm32/stm32h7a3zi", "not-gpdma", "rng", "fdcan"] |
| 22 | stm32l073rz = ["embassy-stm32/stm32l073rz", "cm0", "not-gpdma", "rng"] | 22 | stm32l073rz = ["embassy-stm32/stm32l073rz", "cm0", "not-gpdma", "rng"] |
| 23 | stm32l152re = ["embassy-stm32/stm32l152re", "chrono", "not-gpdma"] | 23 | stm32l152re = ["embassy-stm32/stm32l152re", "chrono", "not-gpdma"] |
| 24 | stm32l496zg = ["embassy-stm32/stm32l496zg", "not-gpdma", "rng"] | 24 | stm32l496zg = ["embassy-stm32/stm32l496zg", "not-gpdma", "rng"] |
| 25 | stm32l4a6zg = ["embassy-stm32/stm32l4a6zg", "chrono", "not-gpdma", "rng"] | 25 | stm32l4a6zg = ["embassy-stm32/stm32l4a6zg", "chrono", "not-gpdma", "rng", "hash"] |
| 26 | stm32l4r5zi = ["embassy-stm32/stm32l4r5zi", "chrono", "not-gpdma", "rng"] | 26 | stm32l4r5zi = ["embassy-stm32/stm32l4r5zi", "chrono", "not-gpdma", "rng"] |
| 27 | stm32l552ze = ["embassy-stm32/stm32l552ze", "not-gpdma", "rng"] | 27 | stm32l552ze = ["embassy-stm32/stm32l552ze", "not-gpdma", "rng", "hash"] |
| 28 | stm32u585ai = ["embassy-stm32/stm32u585ai", "chrono", "rng"] | 28 | stm32u585ai = ["embassy-stm32/stm32u585ai", "chrono", "rng", "hash"] |
| 29 | stm32u5a5zj = ["embassy-stm32/stm32u5a5zj", "chrono", "rng"] | 29 | stm32u5a5zj = ["embassy-stm32/stm32u5a5zj", "chrono", "rng", "hash"] |
| 30 | stm32wb55rg = ["embassy-stm32/stm32wb55rg", "chrono", "not-gpdma", "ble", "mac" , "rng"] | 30 | stm32wb55rg = ["embassy-stm32/stm32wb55rg", "chrono", "not-gpdma", "ble", "mac" , "rng"] |
| 31 | stm32wba52cg = ["embassy-stm32/stm32wba52cg", "chrono", "rng"] | 31 | stm32wba52cg = ["embassy-stm32/stm32wba52cg", "chrono", "rng", "hash"] |
| 32 | stm32wl55jc = ["embassy-stm32/stm32wl55jc-cm4", "not-gpdma", "rng", "chrono"] | 32 | stm32wl55jc = ["embassy-stm32/stm32wl55jc-cm4", "not-gpdma", "rng", "chrono"] |
| 33 | 33 | ||
| 34 | hash = [] | ||
| 34 | eth = ["embassy-executor/task-arena-size-16384"] | 35 | eth = ["embassy-executor/task-arena-size-16384"] |
| 35 | rng = [] | 36 | rng = [] |
| 36 | sdmmc = [] | 37 | sdmmc = [] |
| @@ -74,6 +75,7 @@ static_cell = "2" | |||
| 74 | portable-atomic = { version = "1.5", features = [] } | 75 | portable-atomic = { version = "1.5", features = [] } |
| 75 | 76 | ||
| 76 | chrono = { version = "^0.4", default-features = false, optional = true} | 77 | chrono = { version = "^0.4", default-features = false, optional = true} |
| 78 | sha2 = { 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" | |||
| 108 | required-features = [] | 110 | required-features = [] |
| 109 | 111 | ||
| 110 | [[bin]] | 112 | [[bin]] |
| 113 | name = "hash" | ||
| 114 | path = "src/bin/hash.rs" | ||
| 115 | required-features = [ "hash",] | ||
| 116 | |||
| 117 | [[bin]] | ||
| 111 | name = "rng" | 118 | name = "rng" |
| 112 | path = "src/bin/rng.rs" | 119 | path = "src/bin/rng.rs" |
| 113 | required-features = [ "rng",] | 120 | required-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"] | ||
| 6 | mod common; | ||
| 7 | use common::*; | ||
| 8 | use embassy_executor::Spawner; | ||
| 9 | use embassy_stm32::hash::*; | ||
| 10 | use embassy_stm32::{bind_interrupts, peripherals, hash}; | ||
| 11 | use sha2::{Digest, Sha224, Sha256}; | ||
| 12 | use {defmt_rtt as _, panic_probe as _}; | ||
| 13 | |||
| 14 | bind_interrupts!(struct Irqs { | ||
| 15 | HASH_RNG => hash::InterruptHandler<peripherals::HASH>; | ||
| 16 | }); | ||
| 17 | |||
| 18 | #[embassy_executor::main] | ||
| 19 | async 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"))] |
| 130 | define_peris!( | 130 | define_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")] |
| 143 | define_peris!( | 144 | define_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")] |
| 149 | define_peris!( | 151 | define_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")] |
| 155 | define_peris!( | 158 | define_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")] |
| 173 | define_peris!( | 177 | define_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")] |
| 198 | define_peris!( | 203 | define_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")] |
| 228 | define_peris!( | 234 | define_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>;}, |
