compile pwm_input example
This commit is contained in:
parent
642465a7da
commit
41b9a12574
4 changed files with 55 additions and 3 deletions
2
examples/stm32f4/.vscode/launch.json
vendored
2
examples/stm32f4/.vscode/launch.json
vendored
|
@ -15,7 +15,7 @@
|
||||||
"cwd": "${workspaceRoot}",
|
"cwd": "${workspaceRoot}",
|
||||||
"preLaunchTask": "Cargo Build (debug)",
|
"preLaunchTask": "Cargo Build (debug)",
|
||||||
"runToEntryPoint": "main",
|
"runToEntryPoint": "main",
|
||||||
"executable": "./target/thumbv7em-none-eabihf/debug/multiprio",
|
"executable": "./target/thumbv7em-none-eabihf/debug/pwm_input",
|
||||||
/* Run `cargo build --example itm` and uncomment this line to run itm example */
|
/* Run `cargo build --example itm` and uncomment this line to run itm example */
|
||||||
// "executable": "./target/thumbv7em-none-eabihf/debug/examples/itm",
|
// "executable": "./target/thumbv7em-none-eabihf/debug/examples/itm",
|
||||||
"device": "STM32F446RET6",
|
"device": "STM32F446RET6",
|
||||||
|
|
2
examples/stm32f4/.vscode/tasks.json
vendored
2
examples/stm32f4/.vscode/tasks.json
vendored
|
@ -9,7 +9,7 @@
|
||||||
],
|
],
|
||||||
"args": [
|
"args": [
|
||||||
"--bin",
|
"--bin",
|
||||||
"multiprio"
|
"pwm_input"
|
||||||
],
|
],
|
||||||
"group": {
|
"group": {
|
||||||
"kind": "build",
|
"kind": "build",
|
||||||
|
|
52
examples/stm32f4/src/bin/pwm_input.rs
Normal file
52
examples/stm32f4/src/bin/pwm_input.rs
Normal file
|
@ -0,0 +1,52 @@
|
||||||
|
#![no_std]
|
||||||
|
#![no_main]
|
||||||
|
|
||||||
|
use defmt::*;
|
||||||
|
use embassy_executor::Spawner;
|
||||||
|
use embassy_stm32::gpio::{Level, Output, Pull, Speed};
|
||||||
|
use embassy_stm32::time::khz;
|
||||||
|
use embassy_stm32::timer::input_capture::{CapturePin, InputCapture};
|
||||||
|
use embassy_stm32::timer::{self, Channel};
|
||||||
|
use embassy_stm32::{bind_interrupts, peripherals};
|
||||||
|
use embassy_time::Timer;
|
||||||
|
use {defmt_rtt as _, panic_probe as _};
|
||||||
|
|
||||||
|
/// Connect PB2 and PB10 with a 1k Ohm resistor
|
||||||
|
|
||||||
|
#[embassy_executor::task]
|
||||||
|
async fn blinky(led: peripherals::PB2) {
|
||||||
|
let mut led = Output::new(led, Level::High, Speed::Low);
|
||||||
|
|
||||||
|
loop {
|
||||||
|
info!("high");
|
||||||
|
led.set_high();
|
||||||
|
Timer::after_millis(300).await;
|
||||||
|
|
||||||
|
info!("low");
|
||||||
|
led.set_low();
|
||||||
|
Timer::after_millis(300).await;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bind_interrupts!(struct Irqs {
|
||||||
|
TIM2 => timer::CaptureCompareInterruptHandler<peripherals::TIM2>;
|
||||||
|
});
|
||||||
|
|
||||||
|
#[embassy_executor::main]
|
||||||
|
async fn main(spawner: Spawner) {
|
||||||
|
let p = embassy_stm32::init(Default::default());
|
||||||
|
info!("Hello World!");
|
||||||
|
|
||||||
|
unwrap!(spawner.spawn(blinky(p.PB2)));
|
||||||
|
|
||||||
|
let ch3 = CapturePin::new_ch3(p.PB10, Pull::None);
|
||||||
|
let mut ic = InputCapture::new(p.TIM2, None, None, Some(ch3), None, Irqs, khz(1000), Default::default());
|
||||||
|
|
||||||
|
loop {
|
||||||
|
info!("wait for risign edge");
|
||||||
|
ic.wait_for_rising_edge(Channel::Ch3).await;
|
||||||
|
|
||||||
|
let capture_value = ic.get_capture_value(Channel::Ch3);
|
||||||
|
info!("new capture! {}", capture_value);
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,5 +1,5 @@
|
||||||
[toolchain]
|
[toolchain]
|
||||||
channel = "1.78"
|
channel = "1.77"
|
||||||
components = [ "rust-src", "rustfmt", "llvm-tools" ]
|
components = [ "rust-src", "rustfmt", "llvm-tools" ]
|
||||||
targets = [
|
targets = [
|
||||||
"thumbv7em-none-eabi",
|
"thumbv7em-none-eabi",
|
||||||
|
|
Loading…
Add table
Reference in a new issue