pub struct I2CMasterSlaveDriver<'a, I: I2CMasterSlave<'a>> { /* private fields */ }

Implementations§

source§

impl<'a, I: I2CMasterSlave<'a>> I2CMasterSlaveDriver<'a, I>

source

pub fn new( i2c: &'a I, master_buffer: &'static mut [u8], slave_buffer1: &'static mut [u8], slave_buffer2: &'static mut [u8], grant: Grant<App, UpcallCount<1>, AllowRoCount<{ ro_allow::COUNT }>, AllowRwCount<{ rw_allow::COUNT }>> ) -> I2CMasterSlaveDriver<'a, I>

Trait Implementations§

source§

impl<'a, I: I2CMasterSlave<'a>> I2CHwMasterClient for I2CMasterSlaveDriver<'a, I>

source§

fn command_complete(&self, buffer: &'static mut [u8], status: Result<(), Error>)

Called when an I2C command completed. The error denotes whether the command completed successfully or if an error occurred.
source§

impl<'a, I: I2CMasterSlave<'a>> I2CHwSlaveClient for I2CMasterSlaveDriver<'a, I>

source§

fn command_complete( &self, buffer: &'static mut [u8], length: usize, transmission_type: SlaveTransmissionType )

Called when an I2C command completed.
source§

fn read_expected(&self)

Called from the I2C slave hardware to say that a Master has sent us a read message, but the driver did not have a buffer containing data setup, and therefore cannot respond. The I2C slave hardware will stretch the clock while waiting for the upper layer capsule to provide data to send to the remote master. Call I2CSlave::read_send() to provide data.
source§

fn write_expected(&self)

Called from the I2C slave hardware to say that a Master has sent us a write message, but there was no buffer setup to read the bytes into. The HW will stretch the clock while waiting for the user to call I2CSlave::write_receive() with a buffer.
source§

impl<'a, I: I2CMasterSlave<'a>> SyscallDriver for I2CMasterSlaveDriver<'a, I>

source§

fn command( &self, command_num: usize, data: usize, _: usize, process_id: ProcessId ) -> CommandReturn

System call for a process to perform a short synchronous operation or start a long-running split-phase operation (whose completion is signaled with an upcall). Command 0 is a reserved command to detect if a peripheral system call driver is installed and must always return a CommandReturn::Success.
source§

fn allocate_grant(&self, processid: ProcessId) -> Result<(), Error>

Request to allocate a capsule’s grant for a specific process. Read more
source§

fn allow_userspace_readable( &self, app: ProcessId, which: usize, slice: ReadWriteProcessBuffer ) -> Result<ReadWriteProcessBuffer, (ReadWriteProcessBuffer, ErrorCode)>

System call for a process to pass a buffer (a UserspaceReadableProcessBuffer) to the kernel that the kernel can either read or write. The kernel calls this method only after it checks that the entire buffer is within memory the process can both read and write. Read more

Auto Trait Implementations§

§

impl<'a, I> !Freeze for I2CMasterSlaveDriver<'a, I>

§

impl<'a, I> !RefUnwindSafe for I2CMasterSlaveDriver<'a, I>

§

impl<'a, I> !Send for I2CMasterSlaveDriver<'a, I>

§

impl<'a, I> !Sync for I2CMasterSlaveDriver<'a, I>

§

impl<'a, I> Unpin for I2CMasterSlaveDriver<'a, I>

§

impl<'a, I> !UnwindSafe for I2CMasterSlaveDriver<'a, I>

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> SizedTypeProperties for T

source§

#[doc(hidden)] const IS_ZST: bool = _

🔬This is a nightly-only experimental API. (sized_type_properties)
true if this type requires no storage. false if its size is greater than zero. Read more
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.