//! Connect a potentiometer to PIN2 and see the read values change when //! rotating the shaft. Alternatively you could also connect the PIN to GND or //! 3V3 to see the maximum and minimum raw values read. #![no_std] #![no_main] use esp32c3_hal::{ adc::{AdcConfig, Attenuation, ADC, ADC1}, analog::SarAdcExt, clock::ClockControl, gpio::IO, pac::Peripherals, prelude::*, system::SystemExt, timer::TimerGroup, Delay, Rtc, }; use esp_backtrace as _; use esp_println::println; use riscv_rt::entry; #[entry] fn main() -> ! { let peripherals = Peripherals::take().unwrap(); let mut system = peripherals.SYSTEM.split(); let clocks = ClockControl::boot_defaults(system.clock_control).freeze(); // Disable the watchdog timers. For the ESP32-C3, this includes the Super WDT, // the RTC WDT, and the TIMG WDTs. let mut rtc = Rtc::new(peripherals.RTC_CNTL); let timer_group0 = TimerGroup::new(peripherals.TIMG0, &clocks); let mut wdt0 = timer_group0.wdt; let timer_group1 = TimerGroup::new(peripherals.TIMG1, &clocks); let mut wdt1 = timer_group1.wdt; rtc.swd.disable(); rtc.rwdt.disable(); wdt0.disable(); wdt1.disable(); let io = IO::new(peripherals.GPIO, peripherals.IO_MUX); let mut pin = io.pins.gpio2.into_analog(); // Create ADC instances let analog = peripherals.APB_SARADC.split(); let mut adc2_config = AdcConfig::new(); adc2_config.enable_pin(&pin, Attenuation::Attenuation11dB); let mut adc2 = ADC::::adc( &mut system.peripheral_clock_control, analog.adc1, adc2_config, ) .unwrap(); let mut delay = Delay::new(&clocks); loop { let pin_value: u16 = nb::block!(adc2.read(&mut pin)).unwrap(); println!("PIN ADC reading = {}", pin_value); delay.delay_ms(1500u32); } }