pwm.rs 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. //! Testing PWM output for pre-defined pin combination: all pins for default mapping
  2. #![deny(unsafe_code)]
  3. #![no_main]
  4. #![no_std]
  5. use panic_halt as _;
  6. use cortex_m::asm;
  7. use stm32f1xx_hal::{
  8. prelude::*,
  9. pac,
  10. timer::Timer,
  11. };
  12. use cortex_m_rt::entry;
  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 mut gpioa = p.GPIOA.split(&mut rcc.apb2);
  21. let mut gpiob = p.GPIOB.split(&mut rcc.apb2);
  22. // TIM2
  23. // let c1 = gpioa.pa0.into_alternate_push_pull(&mut gpioa.crl);
  24. // let c2 = gpioa.pa1.into_alternate_push_pull(&mut gpioa.crl);
  25. // let c3 = gpioa.pa2.into_alternate_push_pull(&mut gpioa.crl);
  26. // let c4 = gpioa.pa3.into_alternate_push_pull(&mut gpioa.crl);
  27. // TIM3
  28. // let c1 = gpioa.pa6.into_alternate_push_pull(&mut gpioa.crl);
  29. // let c2 = gpioa.pa7.into_alternate_push_pull(&mut gpioa.crl);
  30. // let c3 = gpiob.pb0.into_alternate_push_pull(&mut gpiob.crl);
  31. // let c4 = gpiob.pb1.into_alternate_push_pull(&mut gpiob.crl);
  32. // TIM4
  33. let c1 = gpiob.pb6.into_alternate_push_pull(&mut gpiob.crl);
  34. let c2 = gpiob.pb7.into_alternate_push_pull(&mut gpiob.crl);
  35. let c3 = gpiob.pb8.into_alternate_push_pull(&mut gpiob.crh);
  36. let c4 = gpiob.pb9.into_alternate_push_pull(&mut gpiob.crh);
  37. let mut pwm = Timer::tim4(p.TIM4, &clocks, &mut rcc.apb1)
  38. .pwm((c1, c2, c3, c4), &mut afio.mapr, 1.khz())
  39. .3;
  40. let max = pwm.get_max_duty();
  41. pwm.enable();
  42. // full
  43. pwm.set_duty(max);
  44. asm::bkpt();
  45. // dim
  46. pwm.set_duty(max / 4);
  47. asm::bkpt();
  48. // zero
  49. pwm.set_duty(0);
  50. asm::bkpt();
  51. loop {}
  52. }