adc.rs 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. #![deny(unsafe_code)]
  2. #![no_main]
  3. #![no_std]
  4. use panic_semihosting as _;
  5. use stm32f1xx_hal::{
  6. prelude::*,
  7. pac,
  8. adc,
  9. };
  10. use cortex_m_rt::entry;
  11. use cortex_m_semihosting::hprintln;
  12. #[entry]
  13. fn main() -> ! {
  14. // Acquire peripherals
  15. let p = pac::Peripherals::take().unwrap();
  16. let mut flash = p.FLASH.constrain();
  17. let mut rcc = p.RCC.constrain();
  18. // Configure ADC clocks
  19. // Default value is the slowest possible ADC clock: PCLK2 / 8. Meanwhile ADC
  20. // clock is configurable. So its frequency may be tweaked to meet certain
  21. // practical needs. User specified value is be approximated using supported
  22. // prescaler values 2/4/6/8.
  23. let clocks = rcc.cfgr.adcclk(2.mhz()).freeze(&mut flash.acr);
  24. hprintln!("adc freq: {}", clocks.adcclk().0).unwrap();
  25. // Setup ADC
  26. let mut adc1 = adc::Adc::adc1(p.ADC1, &mut rcc.apb2, clocks);
  27. #[cfg(feature = "stm32f103")]
  28. let mut adc2 = adc::Adc::adc2(p.ADC2, &mut rcc.apb2, clocks);
  29. // Setup GPIOB
  30. let mut gpiob = p.GPIOB.split(&mut rcc.apb2);
  31. // Configure pb0, pb1 as an analog input
  32. let mut ch0 = gpiob.pb0.into_analog(&mut gpiob.crl);
  33. #[cfg(feature = "stm32f103")]
  34. let mut ch1 = gpiob.pb1.into_analog(&mut gpiob.crl);
  35. loop {
  36. let data: u16 = adc1.read(&mut ch0).unwrap();
  37. hprintln!("adc1: {}", data).unwrap();
  38. #[cfg(feature = "stm32f103")]
  39. {
  40. let data1: u16 = adc2.read(&mut ch1).unwrap();
  41. hprintln!("adc2: {}", data1).unwrap();
  42. }
  43. }
  44. }