diff options
| author | vinsynth <[email protected]> | 2025-02-03 22:40:42 -0500 |
|---|---|---|
| committer | vinsynth <[email protected]> | 2025-02-03 22:40:42 -0500 |
| commit | b5a635371434f4b71554d841ca8bb66ce824578f (patch) | |
| tree | f60366b56352e1eea491118862434c08bfeaa1a7 /examples/stm32f4 | |
| parent | 2c8a550410653d58b103d71b7571668872dd79fa (diff) | |
update examples/stm32f4/.../i2s_dma.rs
Diffstat (limited to 'examples/stm32f4')
| -rw-r--r-- | examples/stm32f4/src/bin/i2s_dma.rs | 86 |
1 files changed, 67 insertions, 19 deletions
diff --git a/examples/stm32f4/src/bin/i2s_dma.rs b/examples/stm32f4/src/bin/i2s_dma.rs index 68392847b..618717cc9 100644 --- a/examples/stm32f4/src/bin/i2s_dma.rs +++ b/examples/stm32f4/src/bin/i2s_dma.rs | |||
| @@ -1,33 +1,81 @@ | |||
| 1 | // This example is written for an STM32F411 chip communicating with an external | ||
| 2 | // PCM5102a DAC. Remap pins, change clock speeds, etc. as necessary for your own | ||
| 3 | // hardware. | ||
| 4 | // | ||
| 5 | // NOTE: This example outputs potentially loud audio. Please run responsibly. | ||
| 6 | |||
| 1 | #![no_std] | 7 | #![no_std] |
| 2 | #![no_main] | 8 | #![no_main] |
| 3 | 9 | ||
| 4 | use defmt::*; | ||
| 5 | use embassy_executor::Spawner; | 10 | use embassy_executor::Spawner; |
| 6 | use embassy_stm32::i2s::{Config, I2S}; | 11 | use embassy_stm32::i2s::{Config, Format, I2S}; |
| 7 | use embassy_stm32::time::Hertz; | 12 | use embassy_stm32::time::Hertz; |
| 8 | use {defmt_rtt as _, panic_probe as _}; | 13 | use {defmt_rtt as _, panic_probe as _}; |
| 9 | 14 | ||
| 10 | #[embassy_executor::main] | 15 | #[embassy_executor::main] |
| 11 | async fn main(_spawner: Spawner) { | 16 | async fn main(_spawner: Spawner) { |
| 12 | let p = embassy_stm32::init(Default::default()); | 17 | let config = { |
| 13 | info!("Hello World!"); | 18 | use embassy_stm32::rcc::*; |
| 14 | 19 | ||
| 15 | let mut dma_buffer = [0x00_u16; 128]; | 20 | let mut config = embassy_stm32::Config::default(); |
| 16 | 21 | config.rcc.hse = Some(Hse { | |
| 17 | let mut i2s = I2S::new_txonly( | 22 | freq: Hertz::mhz(25), |
| 18 | p.SPI2, | 23 | mode: HseMode::Oscillator, |
| 19 | p.PC3, // sd | 24 | }); |
| 20 | p.PB12, // ws | 25 | config.rcc.pll_src = PllSource::HSE; |
| 21 | p.PB10, // ck | 26 | config.rcc.pll = Some(Pll { |
| 22 | p.PC6, // mck | 27 | prediv: PllPreDiv::DIV25, |
| 23 | p.DMA1_CH4, | 28 | mul: PllMul::MUL192, |
| 29 | divp: Some(PllPDiv::DIV2), | ||
| 30 | divq: Some(PllQDiv::DIV4), | ||
| 31 | divr: None, | ||
| 32 | }); | ||
| 33 | config.rcc.sys = Sysclk::PLL1_P; | ||
| 34 | |||
| 35 | config.rcc.ahb_pre = AHBPrescaler::DIV1; | ||
| 36 | config.rcc.apb1_pre = APBPrescaler::DIV2; | ||
| 37 | config.rcc.apb2_pre = APBPrescaler::DIV1; | ||
| 38 | |||
| 39 | config.rcc.plli2s = Some(Pll { | ||
| 40 | prediv: PllPreDiv::DIV25, | ||
| 41 | mul: PllMul::MUL384, | ||
| 42 | divp: None, | ||
| 43 | divq: None, | ||
| 44 | divr: Some(PllRDiv::DIV5), | ||
| 45 | }); | ||
| 46 | config.enable_debug_during_sleep = true; | ||
| 47 | |||
| 48 | config | ||
| 49 | }; | ||
| 50 | |||
| 51 | let p = embassy_stm32::init(config); | ||
| 52 | |||
| 53 | // stereo wavetable generation | ||
| 54 | let mut wavetable = [0u16; 1200]; | ||
| 55 | for (i, frame) in wavetable.chunks_mut(2).enumerate() { | ||
| 56 | frame[0] = ((((i / 150) % 2) * 2048) as i16 - 1024) as u16; // 160 Hz square wave in left channel | ||
| 57 | frame[1] = ((((i / 100) % 2) * 2048) as i16 - 1024) as u16; // 240 Hz square wave in right channel | ||
| 58 | } | ||
| 59 | |||
| 60 | // i2s configuration | ||
| 61 | let mut dma_buffer = [0u16; 2400]; | ||
| 62 | |||
| 63 | let mut i2s_config = Config::default(); | ||
| 64 | i2s_config.format = Format::Data16Channel32; | ||
| 65 | i2s_config.master_clock = false; | ||
| 66 | let mut i2s = I2S::new_txonly_nomck( | ||
| 67 | p.SPI3, | ||
| 68 | p.PB5, // sd | ||
| 69 | p.PA15, // ws | ||
| 70 | p.PB3, // ck | ||
| 71 | p.DMA1_CH7, | ||
| 24 | &mut dma_buffer, | 72 | &mut dma_buffer, |
| 25 | Hertz(1_000_000), | 73 | Hertz(48_000), |
| 26 | Config::default(), | 74 | i2s_config, |
| 27 | ); | 75 | ); |
| 76 | i2s.start(); | ||
| 28 | 77 | ||
| 29 | for i in 0_u16.. { | 78 | loop { |
| 30 | i2s.write(&mut [i * 2; 64]).await.ok(); | 79 | i2s.write(&wavetable).await.ok(); |
| 31 | i2s.write(&mut [i * 2 + 1; 64]).await.ok(); | ||
| 32 | } | 80 | } |
| 33 | } | 81 | } |
