//! Demonstrates generating pulse sequences with RMT //! //! Connect a logic analyzer to GPIO4 to see the generated pulses. //% CHIPS: esp32 esp32c3 esp32c6 esp32h2 esp32s2 esp32s3 #![no_std] #![no_main] use esp_backtrace as _; use esp_hal::{ clock::ClockControl, delay::Delay, gpio::Io, peripherals::Peripherals, prelude::*, rmt::{PulseCode, Rmt, TxChannel, TxChannelConfig, TxChannelCreator}, }; #[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); cfg_if::cfg_if! { if #[cfg(feature = "esp32h2")] { let freq = 32.MHz(); } else { let freq = 80.MHz(); } }; let rmt = Rmt::new(peripherals.RMT, freq, &clocks, None).unwrap(); let tx_config = TxChannelConfig { clk_divider: 255, ..TxChannelConfig::default() }; let mut channel = rmt.channel0.configure(io.pins.gpio4, tx_config).unwrap(); let delay = Delay::new(&clocks); let mut data = [PulseCode { level1: true, length1: 200, level2: false, length2: 50, }; 20]; data[data.len() - 2] = PulseCode { level1: true, length1: 3000, level2: false, length2: 500, }; data[data.len() - 1] = PulseCode::default(); loop { let transaction = channel.transmit(&data); channel = transaction.wait().unwrap(); delay.delay_millis(500); } }