DmaSlice

Struct DmaSlice 

Source
pub struct DmaSlice<'a, T: ImmutableFromIntoBytes> { /* private fields */ }
Expand description

An immutable buffer that can be safely used for read-only DMA operations.

The buffer can be a slice of any type which implements ImmutableFromIntoBytes, such as u8 or u32.

DmaSlice wraps an immutable slice. As such, its contents MUST NOT be modified by the DMA operation. For a DMA operation that may write to the supplied buffer, use DmaSliceMut instead.

§Use with DMA

Creating a DmaSlice over an immutable Rust slice ensures that all prior Rust writes to this slice are observable by any DMA operations initiated through an MMIO write operation, where that MMIO write is performed after constructing the DmaSlice.

For this guarantee to hold, the DmaSlice instance must exist for the duration of the entire DMA operation, until the Rust program has observed that the operation is complete (such as by reading a status bit in memory or an MMIO register).

This struct uses a DmaFence implementation to ensure that all prior writes to slice are exposed to any DMA operations initiated by an MMIO read or write operation issued after this function returns, and which finish before the resulting DmaSlice is dropped.

Implementations§

Source§

impl<'a, T: ImmutableFromIntoBytes> DmaSlice<'a, T>

Source

pub fn new(slice: &[T], fence: impl DmaFence) -> DmaSlice<'_, T>

Create a DmaSlice from an immutable slice.

Source

pub fn as_ptr(&self) -> *const T

Returns a pointer to the start of the slice.

Source

pub fn len(&self) -> usize

Returns the length of the slice.

Source

pub fn get(&self) -> &'a [T]

Retrieve the inner slice reference.

This is safe, as the slice is immutable. Therefore, the DMA hardware and software may read it concurrently.

Trait Implementations§

Source§

impl<'a, T: Debug + ImmutableFromIntoBytes> Debug for DmaSlice<'a, T>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

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

§

impl<'a, T> RefUnwindSafe for DmaSlice<'a, T>
where T: RefUnwindSafe,

§

impl<'a, T> Send for DmaSlice<'a, T>
where T: Sync,

§

impl<'a, T> Sync for DmaSlice<'a, T>
where T: Sync,

§

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

§

impl<'a, T> UnwindSafe for DmaSlice<'a, T>
where T: RefUnwindSafe,

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>,

Source§

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>,

Source§

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.