diff options
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/stm32/Cargo.toml | 2 | ||||
| -rw-r--r-- | tests/stm32/src/bin/hash.rs | 30 | ||||
| -rw-r--r-- | tests/stm32/src/common.rs | 7 |
3 files changed, 16 insertions, 23 deletions
diff --git a/tests/stm32/Cargo.toml b/tests/stm32/Cargo.toml index d02f1a253..fc4420687 100644 --- a/tests/stm32/Cargo.toml +++ b/tests/stm32/Cargo.toml | |||
| @@ -26,7 +26,7 @@ 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", "hash"] | 27 | stm32l552ze = ["embassy-stm32/stm32l552ze", "not-gpdma", "rng", "hash"] |
| 28 | stm32u585ai = ["embassy-stm32/stm32u585ai", "chrono", "rng", "hash"] | 28 | stm32u585ai = ["embassy-stm32/stm32u585ai", "chrono", "rng", "hash"] |
| 29 | stm32u5a5zj = ["embassy-stm32/stm32u5a5zj", "chrono", "rng", "hash"] | 29 | stm32u5a5zj = ["embassy-stm32/stm32u5a5zj", "chrono", "rng"] |
| 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", "hash"] | 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"] |
diff --git a/tests/stm32/src/bin/hash.rs b/tests/stm32/src/bin/hash.rs index 2867115dc..cfcf3d976 100644 --- a/tests/stm32/src/bin/hash.rs +++ b/tests/stm32/src/bin/hash.rs | |||
| @@ -6,6 +6,7 @@ | |||
| 6 | mod common; | 6 | mod common; |
| 7 | use common::*; | 7 | use common::*; |
| 8 | use embassy_executor::Spawner; | 8 | use embassy_executor::Spawner; |
| 9 | use embassy_stm32::dma::NoDma; | ||
| 9 | use embassy_stm32::hash::*; | 10 | use embassy_stm32::hash::*; |
| 10 | use embassy_stm32::{bind_interrupts, hash, peripherals}; | 11 | use embassy_stm32::{bind_interrupts, hash, peripherals}; |
| 11 | use sha2::{Digest, Sha224, Sha256}; | 12 | use sha2::{Digest, Sha224, Sha256}; |
| @@ -30,27 +31,26 @@ bind_interrupts!(struct Irqs { | |||
| 30 | #[embassy_executor::main] | 31 | #[embassy_executor::main] |
| 31 | async fn main(_spawner: Spawner) { | 32 | async fn main(_spawner: Spawner) { |
| 32 | let p: embassy_stm32::Peripherals = embassy_stm32::init(config()); | 33 | let p: embassy_stm32::Peripherals = embassy_stm32::init(config()); |
| 33 | let dma = peri!(p, HASH_DMA); | 34 | let mut hw_hasher = Hash::new(p.HASH, NoDma, Irqs); |
| 34 | let mut hw_hasher = Hash::new(p.HASH, dma); | ||
| 35 | 35 | ||
| 36 | let test_1: &[u8] = b"as;dfhaslfhas;oifvnasd;nifvnhasd;nifvhndlkfghsd;nvfnahssdfgsdafgsasdfasdfasdfasdfasdfghjklmnbvcalskdjghalskdjgfbaslkdjfgbalskdjgbalskdjbdfhsdfhsfghsfghfgh"; | 36 | let test_1: &[u8] = b"as;dfhaslfhas;oifvnasd;nifvnhasd;nifvhndlkfghsd;nvfnahssdfgsdafgsasdfasdfasdfasdfasdfghjklmnbvcalskdjghalskdjgfbaslkdjfgbalskdjgbalskdjbdfhsdfhsfghsfghfgh"; |
| 37 | let test_2: &[u8] = b"fdhalksdjfhlasdjkfhalskdjfhgal;skdjfgalskdhfjgalskdjfglafgadfgdfgdafgaadsfgfgdfgadrgsyfthxfgjfhklhjkfgukhulkvhlvhukgfhfsrghzdhxyfufynufyuszeradrtydyytserr"; | 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"; | 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 | 39 | ||
| 40 | // Start an SHA-256 digest. | 40 | // Start an SHA-256 digest. |
| 41 | let mut sha256context = hw_hasher.start(Algorithm::SHA256, DataType::Width8).await; | 41 | let mut sha256context = hw_hasher.start(Algorithm::SHA256, DataType::Width8); |
| 42 | hw_hasher.update(&mut sha256context, test_1).await; | 42 | hw_hasher.update_blocking(&mut sha256context, test_1); |
| 43 | 43 | ||
| 44 | // Interrupt the SHA-256 digest to compute an SHA-224 digest. | 44 | // Interrupt the SHA-256 digest to compute an SHA-224 digest. |
| 45 | let mut sha224context = hw_hasher.start(Algorithm::SHA224, DataType::Width8).await; | 45 | let mut sha224context = hw_hasher.start(Algorithm::SHA224, DataType::Width8); |
| 46 | hw_hasher.update(&mut sha224context, test_3).await; | 46 | hw_hasher.update_blocking(&mut sha224context, test_3); |
| 47 | let mut sha224_digest_buffer: [u8; 64] = [0; 64]; | 47 | let mut sha224_digest_buffer: [u8; 28] = [0; 28]; |
| 48 | let sha224_digest = hw_hasher.finish(sha224context, &mut sha224_digest_buffer).await; | 48 | let _ = hw_hasher.finish_blocking(sha224context, &mut sha224_digest_buffer); |
| 49 | 49 | ||
| 50 | // Finish the SHA-256 digest. | 50 | // Finish the SHA-256 digest. |
| 51 | hw_hasher.update(&mut sha256context, test_2).await; | 51 | hw_hasher.update_blocking(&mut sha256context, test_2); |
| 52 | let mut sha_256_digest_buffer: [u8; 64] = [0; 64]; | 52 | let mut sha256_digest_buffer: [u8; 32] = [0; 32]; |
| 53 | let sha256_digest = hw_hasher.finish(sha256context, &mut sha_256_digest_buffer).await; | 53 | let _ = hw_hasher.finish_blocking(sha256context, &mut sha256_digest_buffer); |
| 54 | 54 | ||
| 55 | // Compute the SHA-256 digest in software. | 55 | // Compute the SHA-256 digest in software. |
| 56 | let mut sw_sha256_hasher = Sha256::new(); | 56 | let mut sw_sha256_hasher = Sha256::new(); |
| @@ -64,14 +64,14 @@ async fn main(_spawner: Spawner) { | |||
| 64 | let sw_sha224_digest = sw_sha224_hasher.finalize(); | 64 | let sw_sha224_digest = sw_sha224_hasher.finalize(); |
| 65 | 65 | ||
| 66 | // Compare the SHA-256 digests. | 66 | // Compare the SHA-256 digests. |
| 67 | info!("Hardware SHA-256 Digest: {:?}", sha256_digest); | 67 | info!("Hardware SHA-256 Digest: {:?}", sha256_digest_buffer); |
| 68 | info!("Software SHA-256 Digest: {:?}", sw_sha256_digest[..]); | 68 | info!("Software SHA-256 Digest: {:?}", sw_sha256_digest[..]); |
| 69 | defmt::assert!(*sha256_digest == sw_sha256_digest[..]); | 69 | defmt::assert!(sha256_digest_buffer == sw_sha256_digest[..]); |
| 70 | 70 | ||
| 71 | // Compare the SHA-224 digests. | 71 | // Compare the SHA-224 digests. |
| 72 | info!("Hardware SHA-256 Digest: {:?}", sha224_digest); | 72 | info!("Hardware SHA-256 Digest: {:?}", sha224_digest_buffer); |
| 73 | info!("Software SHA-256 Digest: {:?}", sw_sha224_digest[..]); | 73 | info!("Software SHA-256 Digest: {:?}", sw_sha224_digest[..]); |
| 74 | defmt::assert!(*sha224_digest == sw_sha224_digest[..]); | 74 | defmt::assert!(sha224_digest_buffer == sw_sha224_digest[..]); |
| 75 | 75 | ||
| 76 | info!("Test OK"); | 76 | info!("Test OK"); |
| 77 | cortex_m::asm::bkpt(); | 77 | cortex_m::asm::bkpt(); |
diff --git a/tests/stm32/src/common.rs b/tests/stm32/src/common.rs index 14d5b6d7b..fefe72c86 100644 --- a/tests/stm32/src/common.rs +++ b/tests/stm32/src/common.rs | |||
| @@ -128,7 +128,6 @@ 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, | ||
| 132 | UART = USART1, UART_TX = PB6, UART_RX = PB7, UART_TX_DMA = DMA1_CH0, UART_RX_DMA = DMA1_CH1, | 131 | UART = USART1, UART_TX = PB6, UART_RX = PB7, UART_TX_DMA = DMA1_CH0, UART_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, | 132 | SPI = SPI1, SPI_SCK = PA5, SPI_MOSI = PB5, SPI_MISO = PA6, SPI_TX_DMA = DMA1_CH0, SPI_RX_DMA = DMA1_CH1, |
| 134 | ADC = ADC1, DAC = DAC1, DAC_PIN = PA4, | 133 | ADC = ADC1, DAC = DAC1, DAC_PIN = PA4, |
| @@ -142,21 +141,18 @@ define_peris!( | |||
| 142 | ); | 141 | ); |
| 143 | #[cfg(feature = "stm32u585ai")] | 142 | #[cfg(feature = "stm32u585ai")] |
| 144 | define_peris!( | 143 | define_peris!( |
| 145 | HASH_DMA = GPDMA1_CH0, | ||
| 146 | UART = USART3, UART_TX = PD8, UART_RX = PD9, UART_TX_DMA = GPDMA1_CH0, UART_RX_DMA = GPDMA1_CH1, | 144 | UART = USART3, UART_TX = PD8, UART_RX = PD9, UART_TX_DMA = GPDMA1_CH0, UART_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, | 145 | SPI = SPI1, SPI_SCK = PE13, SPI_MOSI = PE15, SPI_MISO = PE14, SPI_TX_DMA = GPDMA1_CH0, SPI_RX_DMA = GPDMA1_CH1, |
| 148 | @irq UART = {USART3 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::USART3>;}, | 146 | @irq UART = {USART3 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::USART3>;}, |
| 149 | ); | 147 | ); |
| 150 | #[cfg(feature = "stm32u5a5zj")] | 148 | #[cfg(feature = "stm32u5a5zj")] |
| 151 | define_peris!( | 149 | define_peris!( |
| 152 | HASH_DMA = GPDMA1_CH0, | ||
| 153 | UART = LPUART1, UART_TX = PG7, UART_RX = PG8, UART_TX_DMA = GPDMA1_CH0, UART_RX_DMA = GPDMA1_CH1, | 150 | UART = LPUART1, UART_TX = PG7, UART_RX = PG8, UART_TX_DMA = GPDMA1_CH0, UART_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, | 151 | SPI = SPI1, SPI_SCK = PA5, SPI_MOSI = PA7, SPI_MISO = PA6, SPI_TX_DMA = GPDMA1_CH0, SPI_RX_DMA = GPDMA1_CH1, |
| 155 | @irq UART = {LPUART1 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::LPUART1>;}, | 152 | @irq UART = {LPUART1 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::LPUART1>;}, |
| 156 | ); | 153 | ); |
| 157 | #[cfg(feature = "stm32h563zi")] | 154 | #[cfg(feature = "stm32h563zi")] |
| 158 | define_peris!( | 155 | define_peris!( |
| 159 | HASH_DMA = GPDMA1_CH0, | ||
| 160 | UART = LPUART1, UART_TX = PB6, UART_RX = PB7, UART_TX_DMA = GPDMA1_CH0, UART_RX_DMA = GPDMA1_CH1, | 156 | UART = LPUART1, UART_TX = PB6, UART_RX = PB7, UART_TX_DMA = GPDMA1_CH0, UART_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, | 157 | SPI = SPI4, SPI_SCK = PE12, SPI_MOSI = PE14, SPI_MISO = PE13, SPI_TX_DMA = GPDMA1_CH0, SPI_RX_DMA = GPDMA1_CH1, |
| 162 | @irq UART = {LPUART1 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::LPUART1>;}, | 158 | @irq UART = {LPUART1 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::LPUART1>;}, |
| @@ -175,7 +171,6 @@ define_peris!( | |||
| 175 | ); | 171 | ); |
| 176 | #[cfg(feature = "stm32l4a6zg")] | 172 | #[cfg(feature = "stm32l4a6zg")] |
| 177 | define_peris!( | 173 | define_peris!( |
| 178 | HASH_DMA = DMA2_CH7, | ||
| 179 | UART = USART3, UART_TX = PD8, UART_RX = PD9, UART_TX_DMA = DMA1_CH2, UART_RX_DMA = DMA1_CH3, | 174 | UART = USART3, UART_TX = PD8, UART_RX = PD9, UART_TX_DMA = DMA1_CH2, UART_RX_DMA = DMA1_CH3, |
| 180 | SPI = SPI1, SPI_SCK = PA5, SPI_MOSI = PA7, SPI_MISO = PA6, SPI_TX_DMA = DMA1_CH3, SPI_RX_DMA = DMA1_CH2, | 175 | SPI = SPI1, SPI_SCK = PA5, SPI_MOSI = PA7, SPI_MISO = PA6, SPI_TX_DMA = DMA1_CH3, SPI_RX_DMA = DMA1_CH2, |
| 181 | @irq UART = {USART3 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::USART3>;}, | 176 | @irq UART = {USART3 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::USART3>;}, |
| @@ -201,7 +196,6 @@ define_peris!( | |||
| 201 | ); | 196 | ); |
| 202 | #[cfg(feature = "stm32l552ze")] | 197 | #[cfg(feature = "stm32l552ze")] |
| 203 | define_peris!( | 198 | define_peris!( |
| 204 | HASH_DMA = DMA1_CH1, | ||
| 205 | UART = USART3, UART_TX = PD8, UART_RX = PD9, UART_TX_DMA = DMA1_CH1, UART_RX_DMA = DMA1_CH2, | 199 | UART = USART3, UART_TX = PD8, UART_RX = PD9, UART_TX_DMA = DMA1_CH1, UART_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, | 200 | SPI = SPI1, SPI_SCK = PA5, SPI_MOSI = PA7, SPI_MISO = PA6, SPI_TX_DMA = DMA1_CH1, SPI_RX_DMA = DMA1_CH2, |
| 207 | @irq UART = {USART3 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::USART3>;}, | 201 | @irq UART = {USART3 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::USART3>;}, |
| @@ -232,7 +226,6 @@ define_peris!( | |||
| 232 | ); | 226 | ); |
| 233 | #[cfg(feature = "stm32wba52cg")] | 227 | #[cfg(feature = "stm32wba52cg")] |
| 234 | define_peris!( | 228 | define_peris!( |
| 235 | HASH_DMA = GPDMA1_CH0, | ||
| 236 | UART = LPUART1, UART_TX = PB5, UART_RX = PA10, UART_TX_DMA = GPDMA1_CH0, UART_RX_DMA = GPDMA1_CH1, | 229 | UART = LPUART1, UART_TX = PB5, UART_RX = PA10, UART_TX_DMA = GPDMA1_CH0, UART_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, | 230 | SPI = SPI1, SPI_SCK = PB4, SPI_MOSI = PA15, SPI_MISO = PB3, SPI_TX_DMA = GPDMA1_CH0, SPI_RX_DMA = GPDMA1_CH1, |
| 238 | @irq UART = {LPUART1 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::LPUART1>;}, | 231 | @irq UART = {LPUART1 => embassy_stm32::usart::InterruptHandler<embassy_stm32::peripherals::LPUART1>;}, |
