From 57469dcf610baa2d40bc97a51d517369b1d1564b Mon Sep 17 00:00:00 2001 From: HaoboGu Date: Tue, 2 Jul 2024 12:50:08 +0800 Subject: [PATCH] fix(spi): wrong transfer mode Signed-off-by: HaoboGu --- src/spi/mod.rs | 69 ++++++++++++++++++++++++++------------------------ 1 file changed, 36 insertions(+), 33 deletions(-) diff --git a/src/spi/mod.rs b/src/spi/mod.rs index b020839..5043d14 100644 --- a/src/spi/mod.rs +++ b/src/spi/mod.rs @@ -338,6 +338,7 @@ impl<'d, M: Mode> Spi<'d, M> { w.set_tokenvalue(false); w.set_dummycnt(config.dummy_cnt); w.set_rdtrancnt(0); + w.set_transmode(config.transfer_mode.into()); }); #[cfg(spi_v53)] @@ -502,40 +503,42 @@ impl<'d, M: Mode> embedded_hal::spi::ErrorType for Spi<'d, M> { impl<'d, M: Mode> embedded_hal::spi::SpiDevice for Spi<'d, M> { fn transaction(&mut self, operations: &mut [embedded_hal::spi::Operation<'_, u8>]) -> Result<(), Self::Error> { - match operations { - [embedded_hal::spi::Operation::Write(buf)] => { - let config = TransferConfig::default(); - self.blocking_write(buf, &config) - } - [embedded_hal::spi::Operation::Read(buf)] => { - let config = TransferConfig { - transfer_mode: TransferMode::ReadOnly, - ..Default::default() - }; - self.blocking_read(buf, &config) - } - [embedded_hal::spi::Operation::Transfer(read, write)] => { - let mut config = TransferConfig { - transfer_mode: TransferMode::WriteOnly, - ..Default::default() - }; - self.blocking_write(write, &config)?; - config.transfer_mode = TransferMode::ReadOnly; - self.blocking_read(read, &config) - } - [embedded_hal::spi::Operation::TransferInPlace(buf)] => { - let mut config = TransferConfig { - transfer_mode: TransferMode::WriteOnly, - ..Default::default() - }; - self.blocking_write(buf, &config)?; - config.transfer_mode = TransferMode::ReadOnly; - self.blocking_read(buf, &config) - } - [embedded_hal::spi::Operation::DelayNs(_ns)] => { - todo!(); + for operation in operations { + match operation { + embedded_hal::spi::Operation::Write(buf) => { + let config = TransferConfig::default(); + self.blocking_write(buf, &config)?; + } + embedded_hal::spi::Operation::Read(buf) => { + let config = TransferConfig { + transfer_mode: TransferMode::ReadOnly, + ..Default::default() + }; + self.blocking_read(buf, &config)?; + } + embedded_hal::spi::Operation::Transfer(read, write) => { + let mut config = TransferConfig { + transfer_mode: TransferMode::WriteOnly, + ..Default::default() + }; + self.blocking_write(write, &config)?; + config.transfer_mode = TransferMode::ReadOnly; + self.blocking_read(read, &config)?; + } + embedded_hal::spi::Operation::TransferInPlace(buf) => { + let mut config = TransferConfig { + transfer_mode: TransferMode::WriteOnly, + ..Default::default() + }; + self.blocking_write(buf, &config)?; + config.transfer_mode = TransferMode::ReadOnly; + self.blocking_read(buf, &config)?; + } + embedded_hal::spi::Operation::DelayNs(ns) => { + self.delay.delay_ns(*ns); + } } - _ => todo!("WORD not supported"), } + Ok(()) } }