Set gain at runtime

This commit is contained in:
Quentin Smith
2022-08-20 17:08:29 -04:00
parent a46f33b214
commit 530f192acc
3 changed files with 41 additions and 10 deletions

View File

@ -88,6 +88,8 @@ impl<'d> Pdm<'d> {
w
});
Self::_set_gain(r, gain_left, gain_right);
r.psel.din.write(|w| unsafe { w.bits(data.psel_bits()) });
r.psel.clk.write(|w| unsafe { w.bits(clock.psel_bits()) });
@ -115,6 +117,18 @@ impl<'d> Pdm<'d> {
}
}
fn _set_gain(r: &pdm::RegisterBlock, gain_left: I7F1, gain_right: I7F1) {
let gain_left = gain_left.saturating_add(I7F1::from_bits(40)).saturating_to_num::<u8>().clamp(0, 0x50);
let gain_right = gain_right.saturating_add(I7F1::from_bits(40)).saturating_to_num::<u8>().clamp(0, 0x50);
r.gainl.write(|w| unsafe { w.gainl().bits(gain_left) });
r.gainr.write(|w| unsafe { w.gainr().bits(gain_right) });
}
pub fn set_gain(&mut self, gain_left: I7F1, gain_right: I7F1) {
Self::_set_gain(Self::regs(), gain_left, gain_right)
}
fn regs() -> &'static pdm::RegisterBlock {
unsafe { &*PDM::ptr() }
}
@ -154,6 +168,13 @@ impl<'d> Pdm<'d> {
}
}
impl<'d> Drop for Pdm<'d> {
fn drop(&mut self) {
let r = Self::regs();
r.enable.write(|w| w.enable().disabled());
}
}
#[derive(Clone, Copy, PartialEq)]
pub enum Edge {
FallingEdge,