pub struct RefCellDevice<'a, T> { /* private fields */ }
Expand description

RefCell-based shared bus I2c implementation.

Sharing is implemented with a RefCell. This means it has low overhead, but RefCellDevice instances are not Send, so it only allows sharing within a single thread (interrupt priority level). If you need to share a bus across several threads, use CriticalSectionDevice instead.

§Examples

Assuming there is a pressure sensor with address 0x42 on the same bus as a temperature sensor with address 0x20; RefCellDevice can be used to give access to both of these sensors from a single i2c instance.

use embedded_hal_bus::i2c;
use core::cell::RefCell;

let i2c = hal.i2c();
let i2c_ref_cell = RefCell::new(i2c);
let mut temperature_sensor = TemperatureSensor::new(
  i2c::RefCellDevice::new(&i2c_ref_cell),
  0x20,
);
let mut pressure_sensor = PressureSensor::new(
  i2c::RefCellDevice::new(&i2c_ref_cell),
  0x42,
);

Implementations§

source§

impl<'a, T> RefCellDevice<'a, T>

source

pub fn new(bus: &'a RefCell<T>) -> Self

Create a new RefCellDevice.

Trait Implementations§

source§

impl<'a, T> ErrorType for RefCellDevice<'a, T>
where T: I2c,

§

type Error = <T as ErrorType>::Error

Error type
source§

impl<'a, T> I2c for RefCellDevice<'a, T>
where T: I2c,

source§

fn read(&mut self, address: u8, read: &mut [u8]) -> Result<(), Self::Error>

Reads enough bytes from slave with address to fill read. Read more
source§

fn write(&mut self, address: u8, write: &[u8]) -> Result<(), Self::Error>

Writes bytes to slave with address address. Read more
source§

fn write_read( &mut self, address: u8, write: &[u8], read: &mut [u8] ) -> Result<(), Self::Error>

Writes bytes to slave with address address and then reads enough bytes to fill read in a single transaction. Read more
source§

fn transaction( &mut self, address: u8, operations: &mut [Operation<'_>] ) -> Result<(), Self::Error>

Execute the provided operations on the I2C bus. Read more

Auto Trait Implementations§

§

impl<'a, T> Freeze for RefCellDevice<'a, T>

§

impl<'a, T> !RefUnwindSafe for RefCellDevice<'a, T>

§

impl<'a, T> !Send for RefCellDevice<'a, T>

§

impl<'a, T> !Sync for RefCellDevice<'a, T>

§

impl<'a, T> Unpin for RefCellDevice<'a, T>

§

impl<'a, T> !UnwindSafe for RefCellDevice<'a, T>

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.