From d3d82ad87d9f170e4858ae30143fe44ab5ddd0bd Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Henrik=20Alse=CC=81r?= Date: Wed, 6 Jul 2022 03:31:21 +0200 Subject: [PATCH] Mutex --- .../src/shared_bus/blocking/i2c.rs | 91 +++++++++++-------- .../src/shared_bus/blocking/spi.rs | 14 +-- 2 files changed, 60 insertions(+), 45 deletions(-) diff --git a/embassy-embedded-hal/src/shared_bus/blocking/i2c.rs b/embassy-embedded-hal/src/shared_bus/blocking/i2c.rs index 2a6ea6dc8..2c762fe14 100644 --- a/embassy-embedded-hal/src/shared_bus/blocking/i2c.rs +++ b/embassy-embedded-hal/src/shared_bus/blocking/i2c.rs @@ -1,67 +1,82 @@ //! Blocking shared I2C bus use core::cell::RefCell; -use core::fmt::Debug; -use core::future::Future; -use embedded_hal_1::i2c; +use embassy::blocking_mutex::raw::RawMutex; +use embassy::blocking_mutex::Mutex; +use embedded_hal_1::i2c::blocking::{I2c, Operation}; +use embedded_hal_1::i2c::ErrorType; -#[derive(Copy, Clone, Eq, PartialEq, Debug)] -pub enum I2cBusDeviceError { - I2c(BUS), +use crate::shared_bus::i2c::I2cBusDeviceError; + +pub struct I2cBusDevice<'a, M: RawMutex, BUS> { + bus: &'a Mutex>, } -impl i2c::Error for I2cBusDeviceError -where - BUS: i2c::Error + Debug, -{ - fn kind(&self) -> i2c::ErrorKind { - match self { - Self::I2c(e) => e.kind(), - } - } -} - -pub struct I2cBusDevice<'a, BUS> { - bus: &'a RefCell, -} - -impl<'a, BUS> I2cBusDevice<'a, BUS> { - pub fn new(bus: &'a RefCell) -> Self { +impl<'a, M: RawMutex, BUS> I2cBusDevice<'a, M, BUS> { + pub fn new(bus: &'a Mutex>) -> Self { Self { bus } } } -impl<'a, BUS> i2c::ErrorType for I2cBusDevice<'a, BUS> +impl<'a, M: RawMutex, BUS> ErrorType for I2cBusDevice<'a, M, BUS> where - BUS: i2c::ErrorType, + BUS: ErrorType, { type Error = I2cBusDeviceError; } -impl i2c::I2c for I2cBusDevice<'_, BUS> +impl I2c for I2cBusDevice<'_, M, BUS> where - BUS: i2c::I2c, + M: RawMutex, + BUS: I2c, { fn read(&mut self, address: u8, buffer: &mut [u8]) -> Result<(), Self::Error> { - let mut bus = self.bus.borrow_mut(); - bus.read(address, buffer).map_err(I2cBusDeviceError::I2c)?; - Ok(()) + self.bus + .lock(|bus| bus.borrow_mut().read(address, buffer).map_err(I2cBusDeviceError::I2c)) } fn write(&mut self, address: u8, bytes: &[u8]) -> Result<(), Self::Error> { - let mut bus = self.bus.borrow_mut(); - bus.write(address, bytes).map_err(I2cBusDeviceError::I2c)?; - Ok(()) + self.bus + .lock(|bus| bus.borrow_mut().write(address, bytes).map_err(I2cBusDeviceError::I2c)) } fn write_read(&mut self, address: u8, wr_buffer: &[u8], rd_buffer: &mut [u8]) -> Result<(), Self::Error> { - let mut bus = self.bus.borrow_mut(); - bus.write_read(address, wr_buffer, rd_buffer) - .map_err(I2cBusDeviceError::I2c)?; - Ok(()) + self.bus.lock(|bus| { + bus.borrow_mut() + .write_read(address, wr_buffer, rd_buffer) + .map_err(I2cBusDeviceError::I2c) + }) } - fn transaction<'a>(&mut self, address: u8, operations: &mut [i2c::Operation<'a>]) -> Result<(), Self::Error> { + fn transaction<'a>(&mut self, address: u8, operations: &mut [Operation<'a>]) -> Result<(), Self::Error> { + let _ = address; + let _ = operations; + todo!() + } + + fn write_iter>(&mut self, addr: u8, bytes: B) -> Result<(), Self::Error> { + let _ = addr; + let _ = bytes; + todo!() + } + + fn write_iter_read>( + &mut self, + addr: u8, + bytes: B, + buffer: &mut [u8], + ) -> Result<(), Self::Error> { + let _ = addr; + let _ = bytes; + let _ = buffer; + todo!() + } + + fn transaction_iter<'a, O: IntoIterator>>( + &mut self, + address: u8, + operations: O, + ) -> Result<(), Self::Error> { let _ = address; let _ = operations; todo!() diff --git a/embassy-embedded-hal/src/shared_bus/blocking/spi.rs b/embassy-embedded-hal/src/shared_bus/blocking/spi.rs index 0d01a590b..2583c699c 100644 --- a/embassy-embedded-hal/src/shared_bus/blocking/spi.rs +++ b/embassy-embedded-hal/src/shared_bus/blocking/spi.rs @@ -4,7 +4,7 @@ use core::fmt::Debug; use embedded_hal_1::digital::blocking::OutputPin; use embedded_hal_1::spi; -use embedded_hal_1::spi::blocking::SpiDevice; +use embedded_hal_1::spi::blocking::{SpiBusFlush, SpiDevice}; #[derive(Copy, Clone, Eq, PartialEq, Debug)] pub enum SpiBusDeviceError { @@ -44,15 +44,15 @@ where type Error = SpiBusDeviceError; } -impl spi::SpiDevice for SpiBusDevice<'_, BUS, CS> +impl SpiDevice for SpiBusDevice<'_, BUS, CS> where - BUS: spi::SpiBusFlush, + BUS: SpiBusFlush, CS: OutputPin, { type Bus = BUS; fn transaction(&mut self, f: impl FnOnce(&mut Self::Bus) -> Result) -> Result { let mut bus = self.bus.borrow_mut(); - self.cs.set_low().map_err(SpiDeviceWithCsError::Cs)?; + self.cs.set_low().map_err(SpiBusDeviceError::Cs)?; let f_res = f(&mut bus); @@ -60,9 +60,9 @@ where let flush_res = bus.flush(); let cs_res = self.cs.set_high(); - let f_res = f_res.map_err(SpiDeviceWithCsError::Spi)?; - flush_res.map_err(SpiDeviceWithCsError::Spi)?; - cs_res.map_err(SpiDeviceWithCsError::Cs)?; + let f_res = f_res.map_err(SpiBusDeviceError::Spi)?; + flush_res.map_err(SpiBusDeviceError::Spi)?; + cs_res.map_err(SpiBusDeviceError::Cs)?; Ok(f_res) }