Merge pull request #2943 from joelsa/add-miso-pullup

Add miso pullup to spi configuration
This commit is contained in:
Dario Nieuwenhuis 2024-05-24 15:01:18 +00:00 committed by GitHub
commit a5763b4df4
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 46 additions and 2 deletions

View file

@ -681,6 +681,38 @@ pub(crate) trait SealedPin {
#[cfg(gpio_v2)]
self.block().ospeedr().modify(|w| w.set_ospeedr(pin, speed.into()));
}
/// Get the pull-up configuration.
#[inline]
fn pull(&self) -> Pull {
critical_section::with(|_| {
let r = self.block();
let n = self._pin() as usize;
#[cfg(gpio_v1)]
{
let crlh = if n < 8 { 0 } else { 1 };
match r.cr(crlh).read().mode(n % 8) {
vals::Mode::INPUT => match r.cr(crlh).read().cnf_in(n % 8) {
vals::CnfIn::PULL => match r.odr().read().odr(n) {
vals::Odr::LOW => Pull::Down,
vals::Odr::HIGH => Pull::Up,
},
_ => Pull::None,
},
_ => Pull::None,
}
}
#[cfg(gpio_v2)]
{
match r.pupdr().read().pupdr(n) {
vals::Pupdr::FLOATING => Pull::None,
vals::Pupdr::PULLDOWN => Pull::Down,
vals::Pupdr::PULLUP => Pull::Up,
vals::Pupdr::_RESERVED_3 => Pull::None,
}
}
})
}
}
/// GPIO pin trait.

View file

@ -50,6 +50,11 @@ pub struct Config {
pub bit_order: BitOrder,
/// Clock frequency.
pub frequency: Hertz,
/// Enable internal pullup on MISO.
///
/// There are some ICs that require a pull-up on the MISO pin for some applications.
/// If you are unsure, you probably don't need this.
pub miso_pull: Pull,
}
impl Default for Config {
@ -58,6 +63,7 @@ impl Default for Config {
mode: MODE_0,
bit_order: BitOrder::MsbFirst,
frequency: Hertz(1_000_000),
miso_pull: Pull::None,
}
}
}
@ -273,6 +279,11 @@ impl<'d, M: PeriMode> Spi<'d, M> {
BitOrder::MsbFirst
};
let miso_pull = match &self.miso {
None => Pull::None,
Some(pin) => pin.pull(),
};
#[cfg(any(spi_v1, spi_f1, spi_v2))]
let br = cfg.br();
#[cfg(any(spi_v3, spi_v4, spi_v5))]
@ -284,6 +295,7 @@ impl<'d, M: PeriMode> Spi<'d, M> {
mode: Mode { polarity, phase },
bit_order,
frequency,
miso_pull,
}
}
@ -406,7 +418,7 @@ impl<'d> Spi<'d, Blocking> {
peri,
new_pin!(sck, AFType::OutputPushPull, Speed::VeryHigh, config.sck_pull_mode()),
new_pin!(mosi, AFType::OutputPushPull, Speed::VeryHigh),
new_pin!(miso, AFType::Input, Speed::VeryHigh),
new_pin!(miso, AFType::Input, Speed::VeryHigh, config.miso_pull),
None,
None,
config,
@ -424,7 +436,7 @@ impl<'d> Spi<'d, Blocking> {
peri,
new_pin!(sck, AFType::OutputPushPull, Speed::VeryHigh, config.sck_pull_mode()),
None,
new_pin!(miso, AFType::Input, Speed::VeryHigh),
new_pin!(miso, AFType::Input, Speed::VeryHigh, config.miso_pull),
None,
None,
config,