esp-hal/esp32s3-hal/examples/sleep_timer_rtcio.rs
Kirill Mikhailov fdc1dbfa1d
Unify the low-power peripheral names (RTC_CNTL and LP_CLKRST to LPWR) (#1064)
* WIP

* Adjusting to changes in driver

* Adding CHANGELOG entry
2024-01-08 14:00:26 +00:00

59 lines
1.5 KiB
Rust

//! Demonstrates deep sleep with timer and ext0 (using gpio18) wakeup
#![no_std]
#![no_main]
use core::time::Duration;
use esp32s3_hal::{
clock::ClockControl,
entry,
gpio::{RTCPin, RTCPinWithResistors},
peripherals::Peripherals,
prelude::*,
rtc_cntl::{
get_reset_reason,
get_wakeup_cause,
sleep::{RtcioWakeupSource, TimerWakeupSource, WakeupLevel},
SocResetReason,
},
Cpu,
Delay,
Rtc,
IO,
};
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 mut rtc = Rtc::new(peripherals.LPWR);
let io = IO::new(peripherals.GPIO, peripherals.IO_MUX);
let mut rtcio_pin18 = io.pins.gpio18;
rtcio_pin18.rtcio_pad_hold(true);
rtcio_pin18.rtcio_pullup(true);
println!("up and runnning!");
let reason = get_reset_reason(Cpu::ProCpu).unwrap_or(SocResetReason::ChipPowerOn);
println!("reset reason: {:?}", reason);
let wake_reason = get_wakeup_cause();
println!("wake reason: {:?}", wake_reason);
let mut delay = Delay::new(&clocks);
let timer = TimerWakeupSource::new(Duration::from_secs(30));
let mut wakeup_pins: [(&mut dyn RTCPin, WakeupLevel); 1] =
[(&mut rtcio_pin18, WakeupLevel::Low)];
let rtcio = RtcioWakeupSource::new(&mut wakeup_pins);
println!("sleeping!");
delay.delay_ms(100u32);
rtc.sleep_deep(&[&timer, &rtcio], &mut delay);
}