mirror of
https://github.com/embassy-rs/embassy.git
synced 2024-11-21 14:22:33 +00:00
Merge pull request #3484 from embassy-rs/rp235x-pio-ie
rp/pio: ensure PADS IE=1 which is not the default in rp235x.
This commit is contained in:
commit
f319f1bc1b
@ -1054,9 +1054,17 @@ impl<'d, PIO: Instance> Common<'d, PIO> {
|
|||||||
pub fn make_pio_pin(&mut self, pin: impl Peripheral<P = impl PioPin + 'd> + 'd) -> Pin<'d, PIO> {
|
pub fn make_pio_pin(&mut self, pin: impl Peripheral<P = impl PioPin + 'd> + 'd) -> Pin<'d, PIO> {
|
||||||
into_ref!(pin);
|
into_ref!(pin);
|
||||||
pin.gpio().ctrl().write(|w| w.set_funcsel(PIO::FUNCSEL as _));
|
pin.gpio().ctrl().write(|w| w.set_funcsel(PIO::FUNCSEL as _));
|
||||||
#[cfg(feature = "_rp235x")]
|
pin.pad_ctrl().write(|w| {
|
||||||
pin.pad_ctrl().modify(|w| {
|
#[cfg(feature = "_rp235x")]
|
||||||
w.set_iso(false);
|
w.set_iso(false);
|
||||||
|
w.set_schmitt(true);
|
||||||
|
w.set_slewfast(false);
|
||||||
|
// TODO rp235x errata E9 recommends to not enable IE if we're not
|
||||||
|
// going to use input. Maybe add an API for the user to enable/disable this?
|
||||||
|
w.set_ie(true);
|
||||||
|
w.set_od(false);
|
||||||
|
w.set_pue(false);
|
||||||
|
w.set_pde(false);
|
||||||
});
|
});
|
||||||
// we can be relaxed about this because we're &mut here and nothing is cached
|
// we can be relaxed about this because we're &mut here and nothing is cached
|
||||||
PIO::state().used_pins.fetch_or(1 << pin.pin_bank(), Ordering::Relaxed);
|
PIO::state().used_pins.fetch_or(1 << pin.pin_bank(), Ordering::Relaxed);
|
||||||
|
Loading…
Reference in New Issue
Block a user