Merge #511
511: Fix wrong pin configuration in STM32's SPI v3. r=matoushybl a=matoushybl Co-authored-by: Matous Hybl <hyblmatous@gmail.com>
This commit is contained in:
commit
2d620df9d6
2 changed files with 34 additions and 61 deletions
|
@ -1,9 +1,8 @@
|
||||||
#![macro_use]
|
#![macro_use]
|
||||||
|
|
||||||
use crate::dma::NoDma;
|
use crate::dma::NoDma;
|
||||||
use crate::gpio::{AnyPin, Pin};
|
use crate::gpio::sealed::Pin;
|
||||||
use crate::pac::gpio::vals::{Afr, Moder};
|
use crate::gpio::AnyPin;
|
||||||
use crate::pac::gpio::Gpio;
|
|
||||||
use crate::pac::spi;
|
use crate::pac::spi;
|
||||||
use crate::spi::{
|
use crate::spi::{
|
||||||
ByteOrder, Config, Error, Instance, MisoPin, MosiPin, RxDmaChannel, SckPin, TxDmaChannel,
|
ByteOrder, Config, Error, Instance, MisoPin, MosiPin, RxDmaChannel, SckPin, TxDmaChannel,
|
||||||
|
@ -68,12 +67,18 @@ impl<'d, T: Instance, Tx, Rx> Spi<'d, T, Tx, Rx> {
|
||||||
let miso = miso.degrade_optional();
|
let miso = miso.degrade_optional();
|
||||||
|
|
||||||
unsafe {
|
unsafe {
|
||||||
sck.as_ref()
|
sck.as_ref().map(|x| {
|
||||||
.map(|x| Self::configure_pin(x.block(), x.pin() as _, sck_af));
|
x.set_as_af(sck_af, crate::gpio::sealed::AFType::OutputPushPull);
|
||||||
mosi.as_ref()
|
x.set_speed(crate::gpio::Speed::VeryHigh);
|
||||||
.map(|x| Self::configure_pin(x.block(), x.pin() as _, mosi_af));
|
});
|
||||||
miso.as_ref()
|
mosi.as_ref().map(|x| {
|
||||||
.map(|x| Self::configure_pin(x.block(), x.pin() as _, miso_af));
|
x.set_as_af(mosi_af, crate::gpio::sealed::AFType::OutputPushPull);
|
||||||
|
x.set_speed(crate::gpio::Speed::VeryHigh);
|
||||||
|
});
|
||||||
|
miso.as_ref().map(|x| {
|
||||||
|
x.set_as_af(miso_af, crate::gpio::sealed::AFType::Input);
|
||||||
|
x.set_speed(crate::gpio::Speed::VeryHigh);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
let pclk = T::frequency();
|
let pclk = T::frequency();
|
||||||
|
@ -122,16 +127,6 @@ impl<'d, T: Instance, Tx, Rx> Spi<'d, T, Tx, Rx> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
unsafe fn configure_pin(block: Gpio, pin: usize, af_num: u8) {
|
|
||||||
let (afr, n_af) = if pin < 8 { (0, pin) } else { (1, pin - 8) };
|
|
||||||
block.moder().modify(|w| w.set_moder(pin, Moder::ALTERNATE));
|
|
||||||
block.afr(afr).modify(|w| w.set_afr(n_af, Afr(af_num)));
|
|
||||||
}
|
|
||||||
|
|
||||||
unsafe fn unconfigure_pin(block: Gpio, pin: usize) {
|
|
||||||
block.moder().modify(|w| w.set_moder(pin, Moder::ANALOG));
|
|
||||||
}
|
|
||||||
|
|
||||||
fn compute_baud_rate(clocks: Hertz, freq: Hertz) -> u8 {
|
fn compute_baud_rate(clocks: Hertz, freq: Hertz) -> u8 {
|
||||||
match clocks.0 / freq.0 {
|
match clocks.0 / freq.0 {
|
||||||
0 => unreachable!(),
|
0 => unreachable!(),
|
||||||
|
@ -322,15 +317,9 @@ impl<'d, T: Instance, Tx, Rx> Spi<'d, T, Tx, Rx> {
|
||||||
impl<'d, T: Instance, Tx, Rx> Drop for Spi<'d, T, Tx, Rx> {
|
impl<'d, T: Instance, Tx, Rx> Drop for Spi<'d, T, Tx, Rx> {
|
||||||
fn drop(&mut self) {
|
fn drop(&mut self) {
|
||||||
unsafe {
|
unsafe {
|
||||||
self.sck
|
self.sck.as_ref().map(|x| x.set_as_analog());
|
||||||
.as_ref()
|
self.mosi.as_ref().map(|x| x.set_as_analog());
|
||||||
.map(|x| Self::unconfigure_pin(x.block(), x.pin() as _));
|
self.miso.as_ref().map(|x| x.set_as_analog());
|
||||||
self.mosi
|
|
||||||
.as_ref()
|
|
||||||
.map(|x| Self::unconfigure_pin(x.block(), x.pin() as _));
|
|
||||||
self.miso
|
|
||||||
.as_ref()
|
|
||||||
.map(|x| Self::unconfigure_pin(x.block(), x.pin() as _));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +1,8 @@
|
||||||
#![macro_use]
|
#![macro_use]
|
||||||
|
|
||||||
use crate::dma::NoDma;
|
use crate::dma::NoDma;
|
||||||
use crate::gpio::{AnyPin, Pin};
|
use crate::gpio::sealed::Pin;
|
||||||
use crate::pac::gpio::vals::{Afr, Moder};
|
use crate::gpio::AnyPin;
|
||||||
use crate::pac::gpio::Gpio;
|
|
||||||
use crate::pac::spi;
|
use crate::pac::spi;
|
||||||
use crate::spi::{
|
use crate::spi::{
|
||||||
ByteOrder, Config, Error, Instance, MisoPin, MosiPin, RxDmaChannel, SckPin, TxDmaChannel,
|
ByteOrder, Config, Error, Instance, MisoPin, MosiPin, RxDmaChannel, SckPin, TxDmaChannel,
|
||||||
|
@ -70,14 +69,18 @@ impl<'d, T: Instance, Tx, Rx> Spi<'d, T, Tx, Rx> {
|
||||||
let miso = miso.degrade_optional();
|
let miso = miso.degrade_optional();
|
||||||
|
|
||||||
unsafe {
|
unsafe {
|
||||||
sck.as_ref()
|
sck.as_ref().map(|x| {
|
||||||
.map(|x| Self::configure_pin(x.block(), x.pin() as _, sck_af));
|
x.set_as_af(sck_af, crate::gpio::sealed::AFType::OutputPushPull);
|
||||||
//sck.block().otyper().modify(|w| w.set_ot(Pin::pin(sck) as _, crate::pac::gpio::vals::Ot::PUSHPULL));
|
x.set_speed(crate::gpio::Speed::VeryHigh);
|
||||||
sck.as_ref()
|
});
|
||||||
.map(|x| Self::configure_pin(x.block(), x.pin() as _, mosi_af));
|
mosi.as_ref().map(|x| {
|
||||||
//mosi.block().otyper().modify(|w| w.set_ot(Pin::pin(mosi) as _, crate::pac::gpio::vals::Ot::PUSHPULL));
|
x.set_as_af(mosi_af, crate::gpio::sealed::AFType::OutputPushPull);
|
||||||
sck.as_ref()
|
x.set_speed(crate::gpio::Speed::VeryHigh);
|
||||||
.map(|x| Self::configure_pin(x.block(), x.pin() as _, miso_af));
|
});
|
||||||
|
miso.as_ref().map(|x| {
|
||||||
|
x.set_as_af(miso_af, crate::gpio::sealed::AFType::Input);
|
||||||
|
x.set_speed(crate::gpio::Speed::VeryHigh);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
let pclk = T::frequency();
|
let pclk = T::frequency();
|
||||||
|
@ -137,19 +140,6 @@ impl<'d, T: Instance, Tx, Rx> Spi<'d, T, Tx, Rx> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
unsafe fn configure_pin(block: Gpio, pin: usize, af_num: u8) {
|
|
||||||
let (afr, n_af) = if pin < 8 { (0, pin) } else { (1, pin - 8) };
|
|
||||||
block.moder().modify(|w| w.set_moder(pin, Moder::ALTERNATE));
|
|
||||||
block.afr(afr).modify(|w| w.set_afr(n_af, Afr(af_num)));
|
|
||||||
block
|
|
||||||
.ospeedr()
|
|
||||||
.modify(|w| w.set_ospeedr(pin, crate::pac::gpio::vals::Ospeedr::VERYHIGHSPEED));
|
|
||||||
}
|
|
||||||
|
|
||||||
unsafe fn unconfigure_pin(block: Gpio, pin: usize) {
|
|
||||||
block.moder().modify(|w| w.set_moder(pin, Moder::ANALOG));
|
|
||||||
}
|
|
||||||
|
|
||||||
fn compute_baud_rate(clocks: Hertz, freq: Hertz) -> u8 {
|
fn compute_baud_rate(clocks: Hertz, freq: Hertz) -> u8 {
|
||||||
match clocks.0 / freq.0 {
|
match clocks.0 / freq.0 {
|
||||||
0 => unreachable!(),
|
0 => unreachable!(),
|
||||||
|
@ -346,15 +336,9 @@ impl<'d, T: Instance, Tx, Rx> Spi<'d, T, Tx, Rx> {
|
||||||
impl<'d, T: Instance, Tx, Rx> Drop for Spi<'d, T, Tx, Rx> {
|
impl<'d, T: Instance, Tx, Rx> Drop for Spi<'d, T, Tx, Rx> {
|
||||||
fn drop(&mut self) {
|
fn drop(&mut self) {
|
||||||
unsafe {
|
unsafe {
|
||||||
self.sck
|
self.sck.as_ref().map(|x| x.set_as_analog());
|
||||||
.as_ref()
|
self.mosi.as_ref().map(|x| x.set_as_analog());
|
||||||
.map(|x| Self::unconfigure_pin(x.block(), x.pin() as _));
|
self.miso.as_ref().map(|x| x.set_as_analog());
|
||||||
self.mosi
|
|
||||||
.as_ref()
|
|
||||||
.map(|x| Self::unconfigure_pin(x.block(), x.pin() as _));
|
|
||||||
self.miso
|
|
||||||
.as_ref()
|
|
||||||
.map(|x| Self::unconfigure_pin(x.block(), x.pin() as _));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue