mirror of
https://github.com/esp-rs/esp-hal.git
synced 2025-10-02 14:44:42 +00:00

* Update `esp32-hal` examples * Update `esp32c2-hal` examples * Update `esp32c3-hal` examples * Update `esp32c6-hal` examples * Update `esp32h2-hal` examples * Update `esp32s2-hal` examples * Update `esp32s3-hal` examples * Fix the `ram.rs` examples
53 lines
1.6 KiB
Rust
53 lines
1.6 KiB
Rust
//! Connect a potentiometer to PIN3 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 esp32s3_hal::{
|
|
adc::{self, AdcConfig, Attenuation, ADC, ADC1},
|
|
clock::ClockControl,
|
|
gpio::IO,
|
|
peripherals::Peripherals,
|
|
prelude::*,
|
|
Delay,
|
|
};
|
|
use esp_backtrace as _;
|
|
use esp_println::println;
|
|
|
|
#[entry]
|
|
fn main() -> ! {
|
|
let peripherals = Peripherals::take();
|
|
let system = peripherals.SYSTEM.split();
|
|
let clocks = ClockControl::boot_defaults(system.clock_control).freeze();
|
|
|
|
let io = IO::new(peripherals.GPIO, peripherals.IO_MUX);
|
|
|
|
// Create ADC instances
|
|
let analog = peripherals.SENS.split();
|
|
|
|
let mut adc1_config = AdcConfig::new();
|
|
|
|
let atten = Attenuation::Attenuation11dB;
|
|
|
|
// You can try any of the following calibration methods by uncommenting them
|
|
// type AdcCal = ();
|
|
// type AdcCal = adc::AdcCalBasic<ADC1>;
|
|
// type AdcCal = adc::AdcCalLine<ADC1>;
|
|
type AdcCal = adc::AdcCalCurve<ADC1>;
|
|
|
|
let mut pin = adc1_config.enable_pin_with_cal::<_, AdcCal>(io.pins.gpio3.into_analog(), atten);
|
|
|
|
let mut adc1 = ADC::<ADC1>::adc(analog.adc1, adc1_config).unwrap();
|
|
|
|
let mut delay = Delay::new(&clocks);
|
|
|
|
loop {
|
|
let pin_value: u16 = nb::block!(adc1.read(&mut pin)).unwrap();
|
|
let pin_value_mv = pin_value as u32 * atten.ref_mv() as u32 / 4096;
|
|
println!("PIN2 ADC reading = {pin_value} ({pin_value_mv} mV)");
|
|
delay.delay_ms(1500u32);
|
|
}
|
|
}
|