serial-dma-tx.rs 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. //! Serial interface DMA TX transfer test
  2. #![deny(unsafe_code)]
  3. #![no_main]
  4. #![no_std]
  5. use panic_halt as _;
  6. use cortex_m::asm;
  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().baudrate(9600.bps()),
  40. clocks,
  41. &mut rcc.apb2,
  42. );
  43. let tx = serial.split().0.with_dma(channels.4);
  44. let (_, tx) = tx.write(b"The quick brown fox").wait();
  45. asm::bkpt();
  46. let (_, tx) = tx.write(b" jumps").wait();
  47. asm::bkpt();
  48. tx.write(b" over the lazy dog.").wait();
  49. asm::bkpt();
  50. loop {}
  51. }