550da471be
The idea behind OptionalPin has a few problems: - you need to impl the signal traits for NoPin which is a bit weird https://github.com/embassy-rs/embassy/blob/master/embassy-stm32/src/dcmi.rs#L413-L416 - you can pass any combination of set/unset pins, which needs checking at runtime https://github.com/embassy-rs/embassy/blob/master/embassy-stm32/src/dcmi.rs#L130 The replacement is to do multiple `new` constructors for each combination of pins you want to take.
41 lines
858 B
Rust
41 lines
858 B
Rust
#![no_std]
|
|
#![no_main]
|
|
#![feature(type_alias_impl_trait)]
|
|
|
|
#[path = "../example_common.rs"]
|
|
mod example_common;
|
|
|
|
use example_common::*;
|
|
|
|
use cortex_m_rt::entry;
|
|
use embassy_stm32::dac::{Channel, Dac, Value};
|
|
|
|
#[entry]
|
|
fn main() -> ! {
|
|
info!("Hello World, dude!");
|
|
|
|
let p = embassy_stm32::init(config());
|
|
|
|
let mut dac = Dac::new_1ch(p.DAC1, p.PA4);
|
|
|
|
loop {
|
|
for v in 0..=255 {
|
|
unwrap!(dac.set(Channel::Ch1, Value::Bit8(to_sine_wave(v))));
|
|
unwrap!(dac.trigger(Channel::Ch1));
|
|
}
|
|
}
|
|
}
|
|
|
|
use micromath::F32Ext;
|
|
|
|
fn to_sine_wave(v: u8) -> u8 {
|
|
if v >= 128 {
|
|
// top half
|
|
let r = 3.14 * ((v - 128) as f32 / 128.0);
|
|
(r.sin() * 128.0 + 127.0) as u8
|
|
} else {
|
|
// bottom half
|
|
let r = 3.14 + 3.14 * (v as f32 / 128.0);
|
|
(r.sin() * 128.0 + 127.0) as u8
|
|
}
|
|
}
|