add dma example; rename uarte
This commit is contained in:
		| @@ -6,6 +6,7 @@ members = [ | ||||
|     "embassy-stm32f4", | ||||
|     "embassy-macros", | ||||
|     "examples", | ||||
|     "examples-stm32f4", | ||||
| ] | ||||
|  | ||||
| exclude = [ | ||||
|   | ||||
| @@ -361,6 +361,6 @@ macro_rules! waker_interrupt { | ||||
| // This mod MUST go first, so that the others see its macros. | ||||
| pub(crate) mod fmt; | ||||
|  | ||||
| pub mod uarte; | ||||
| pub mod serial; | ||||
|  | ||||
| pub use cortex_m_rt::interrupt; | ||||
|   | ||||
							
								
								
									
										38
									
								
								examples-stm32f4/Cargo.toml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								examples-stm32f4/Cargo.toml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,38 @@ | ||||
| [package] | ||||
| authors = ["Dario Nieuwenhuis <dirbaio@dirbaio.net>"] | ||||
| edition = "2018" | ||||
| name = "embassy-examples-stm32f4" | ||||
| version = "0.1.0" | ||||
|  | ||||
| [features] | ||||
| default = [ | ||||
|     "defmt-default", | ||||
| ] | ||||
| defmt-default = [] | ||||
| defmt-trace = [] | ||||
| defmt-debug = [] | ||||
| defmt-info = [] | ||||
| defmt-warn = [] | ||||
| defmt-error = [] | ||||
|  | ||||
|  | ||||
| [dependencies] | ||||
| embassy = { version = "0.1.0", path = "../embassy", features = ["defmt", "defmt-trace"] } | ||||
| # embassy-stm32f4 = { version = "*", path = "../embassy-stm32f4", features = ["stm32f405"] } | ||||
|  | ||||
| defmt = "0.1.3" | ||||
| defmt-rtt = "0.1.0" | ||||
|  | ||||
| cortex-m        = { version = "0.6.3" } | ||||
| cortex-m-rt = "0.6.13" | ||||
| embedded-hal    = { version = "0.2.4" } | ||||
| panic-probe = "0.1.0" | ||||
| stm32f4xx-hal  = { version = "0.8.3", features = ["rt", "stm32f405"], git = "https://github.com/xoviat/stm32f4xx-hal.git", branch = "dma-is-done"} | ||||
| futures = { version = "0.3.8", default-features = false, features = ["async-await"] } | ||||
| cortex-m-rtic = "0.5" # { git = "https://github.com/rtic-rs/cortex-m-rtic", branch = "master"} | ||||
| rtt-target = { version = "0.3", features = ["cortex-m"] } | ||||
|  | ||||
|  | ||||
| [[bin]] | ||||
| name = "dma_adc" | ||||
| path = "src/dma_adc.rs" | ||||
							
								
								
									
										125
									
								
								examples-stm32f4/src/dma_adc.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										125
									
								
								examples-stm32f4/src/dma_adc.rs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,125 @@ | ||||
| #![no_std] | ||||
| #![no_main] | ||||
| #![feature(lang_items)] | ||||
|  | ||||
| use core::{ | ||||
|     panic::PanicInfo, | ||||
|     sync::atomic::{compiler_fence, Ordering}, | ||||
| }; | ||||
|  | ||||
| use cortex_m::singleton; | ||||
| use rtic::app; | ||||
| // use rtt_target::{rprintln, rtt_init_print}; | ||||
| use stm32f4xx_hal::{ | ||||
|     dma::{config::DmaConfig, Channel0, PeripheralToMemory, Stream0, StreamsTuple, Transfer}, | ||||
|     pac::{ADC1, DMA2, RCC}, | ||||
|     prelude::*, | ||||
| }; | ||||
|  | ||||
| #[lang = "eh_personality"] | ||||
| extern "C" fn eh_personality() {} | ||||
|  | ||||
| type DmaTransfer = | ||||
|     Transfer<Stream0<DMA2>, Channel0, ADC1, PeripheralToMemory, &'static mut [u16; 128]>; | ||||
|  | ||||
| #[app(device = stm32f4xx_hal::pac, peripherals = true)] | ||||
| const APP: () = { | ||||
|     struct Resources { | ||||
|         transfer: DmaTransfer, | ||||
|         triple_buffer: Option<&'static mut [u16; 128]>, | ||||
|     } | ||||
|  | ||||
|     #[init] | ||||
|     fn init(cx: init::Context) -> init::LateResources { | ||||
|         let rcc = cx.device.RCC.constrain(); | ||||
|  | ||||
|         // rtt_init_print!(); | ||||
|         // rprintln!("Init"); | ||||
|  | ||||
|         let _clocks = rcc | ||||
|             .cfgr | ||||
|             .sysclk(84.mhz()) | ||||
|             .pclk2(28.mhz()) | ||||
|             .pclk1(28.mhz()) | ||||
|             .freeze(); | ||||
|  | ||||
|         let gpioa = cx.device.GPIOA.split(); | ||||
|         let _pa0 = gpioa.pa0.into_analog(); | ||||
|  | ||||
|         let stream_0 = StreamsTuple::new(cx.device.DMA2).0; | ||||
|         let config = DmaConfig::default() | ||||
|             .transfer_complete_interrupt(true) | ||||
|             .memory_increment(true) | ||||
|             .double_buffer(true); | ||||
|  | ||||
|         let rcc = unsafe { &*RCC::ptr() }; | ||||
|         rcc.apb2enr.modify(|_, w| w.adc1en().enabled()); | ||||
|         rcc.apb2rstr.modify(|_, w| w.adcrst().set_bit()); | ||||
|         rcc.apb2rstr.modify(|_, w| w.adcrst().clear_bit()); | ||||
|         let adc = cx.device.ADC1; | ||||
|         adc.cr2.modify(|_, w| { | ||||
|             w.dma() | ||||
|                 .enabled() | ||||
|                 .cont() | ||||
|                 .continuous() | ||||
|                 .dds() | ||||
|                 .continuous() | ||||
|                 .adon() | ||||
|                 .enabled() | ||||
|         }); | ||||
|  | ||||
|         let first_buffer = singleton!(: [u16; 128] = [0; 128]).unwrap(); | ||||
|         let second_buffer = singleton!(: [u16; 128] = [0; 128]).unwrap(); | ||||
|         let triple_buffer = Some(singleton!(: [u16; 128] = [0; 128]).unwrap()); | ||||
|  | ||||
|         let transfer = Transfer::init(stream_0, adc, first_buffer, Some(second_buffer), config); | ||||
|  | ||||
|         // rprintln!("Finished init"); | ||||
|         init::LateResources { | ||||
|             transfer, | ||||
|             triple_buffer, | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     #[idle(resources = [transfer])] | ||||
|     fn idle(mut cx: idle::Context) -> ! { | ||||
|         cx.resources.transfer.lock(|shared| { | ||||
|             shared.start(|adc| { | ||||
|                 adc.cr2.modify(|_, w| w.swstart().start()); | ||||
|             }); | ||||
|         }); | ||||
|         // rprintln!("DMA started"); | ||||
|         loop { | ||||
|             compiler_fence(Ordering::SeqCst); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     #[task(binds = DMA2_STREAM0, priority = 2, resources = [transfer, triple_buffer])] | ||||
|     fn dma(cx: dma::Context) { | ||||
|         static mut COUNT: usize = 0; | ||||
|  | ||||
|         let triple = cx.resources.triple_buffer.take().unwrap(); | ||||
|         let buf = cx | ||||
|             .resources | ||||
|             .transfer | ||||
|             .next_transfer(triple) | ||||
|             .map_err(|_| {}) | ||||
|             .unwrap() | ||||
|             .0; | ||||
|         if *COUNT % (1 << 14) == 0 { | ||||
|             // rprintln!("Buf: {:?}", &buf[0..10]); | ||||
|         } | ||||
|         *COUNT += 1; | ||||
|         *cx.resources.triple_buffer = Some(buf); | ||||
|     } | ||||
| }; | ||||
|  | ||||
| #[inline(never)] | ||||
| #[panic_handler] | ||||
| fn panic(info: &PanicInfo) -> ! { | ||||
|     cortex_m::interrupt::disable(); | ||||
|     // rprintln!("{}", info); | ||||
|     loop { | ||||
|         compiler_fence(Ordering::SeqCst); | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user