serial-dma-peek.rs 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. //! Serial interface DMA RX transfer test
  2. #![deny(unsafe_code)]
  3. #![no_main]
  4. #![no_std]
  5. use panic_halt as _;
  6. use cortex_m::{asm, singleton};
  7. use cortex_m_rt::entry;
  8. use stm32f1xx_hal::{
  9. pac,
  10. prelude::*,
  11. serial::{Config, Serial},
  12. };
  13. #[entry]
  14. fn main() -> ! {
  15. let p = pac::Peripherals::take().unwrap();
  16. let mut flash = p.FLASH.constrain();
  17. let mut rcc = p.RCC.constrain();
  18. let clocks = rcc.cfgr.freeze(&mut flash.acr);
  19. let mut afio = p.AFIO.constrain(&mut rcc.apb2);
  20. let channels = p.DMA1.split(&mut rcc.ahb);
  21. let mut gpioa = p.GPIOA.split(&mut rcc.apb2);
  22. // let mut gpiob = p.GPIOB.split(&mut rcc.apb2);
  23. // USART1
  24. let tx = gpioa.pa9.into_alternate_push_pull(&mut gpioa.crh);
  25. let rx = gpioa.pa10;
  26. // USART1
  27. // let tx = gpiob.pb6.into_alternate_push_pull(&mut gpiob.crl);
  28. // let rx = gpiob.pb7;
  29. // USART2
  30. // let tx = gpioa.pa2.into_alternate_push_pull(&mut gpioa.crl);
  31. // let rx = gpioa.pa3;
  32. // USART3
  33. // let tx = gpiob.pb10.into_alternate_push_pull(&mut gpiob.crh);
  34. // let rx = gpiob.pb11;
  35. let serial = Serial::usart1(
  36. p.USART1,
  37. (tx, rx),
  38. &mut afio.mapr,
  39. Config::default(),
  40. clocks,
  41. &mut rcc.apb2,
  42. );
  43. let rx = serial.split().1.with_dma(channels.5);
  44. let buf = singleton!(: [u8; 8] = [0; 8]).unwrap();
  45. let t = rx.read(buf);
  46. while !t.is_done() {
  47. let _slice = t.peek();
  48. asm::bkpt();
  49. }
  50. asm::bkpt();
  51. loop {}
  52. }