pwm_input.rs 1.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. //! Testing PWM input
  2. #![deny(unsafe_code)]
  3. #![no_main]
  4. #![no_std]
  5. use panic_halt as _;
  6. use cortex_m_rt::entry;
  7. use stm32f1xx_hal::{pac, prelude::*, pwm_input::*, timer::Timer};
  8. #[entry]
  9. fn main() -> ! {
  10. let p = pac::Peripherals::take().unwrap();
  11. let mut flash = p.FLASH.constrain();
  12. let mut rcc = p.RCC.constrain();
  13. let clocks = rcc.cfgr.freeze(&mut flash.acr);
  14. let mut afio = p.AFIO.constrain(&mut rcc.apb2);
  15. let mut dbg = p.DBGMCU;
  16. let gpioa = p.GPIOA.split(&mut rcc.apb2);
  17. let gpiob = p.GPIOB.split(&mut rcc.apb2);
  18. let (_pa15, _pb3, pb4) = afio.mapr.disable_jtag(gpioa.pa15, gpiob.pb3, gpiob.pb4);
  19. let pb5 = gpiob.pb5;
  20. let pwm_input = Timer::tim3(p.TIM3, &clocks, &mut rcc.apb1).pwm_input(
  21. (pb4, pb5),
  22. &mut afio.mapr,
  23. &mut dbg,
  24. Configuration::Frequency(10.khz()),
  25. );
  26. loop {
  27. let _freq = pwm_input
  28. .read_frequency(ReadMode::Instant, &clocks)
  29. .unwrap();
  30. let _duty_cycle = pwm_input.read_duty(ReadMode::Instant).unwrap();
  31. }
  32. }