Skip to main content

DmaMask

Struct DmaMask 

Source
pub struct DmaMask(/* private fields */);
Expand description

A DMA mask that holds a bitmask with the lowest n bits set.

Use DmaMask::new or DmaMask::try_new to construct a value. Values are guaranteed to never exceed the bit width of u64.

This is the Rust equivalent of the C macro DMA_BIT_MASK().

Implementations§

Source§

impl DmaMask

Source

pub const fn new<const N: u32>() -> Self

Constructs a DmaMask with the lowest n bits set to 1.

For n <= 64, sets exactly the lowest n bits. For n > 64, results in a build error.

§Examples
use kernel::dma::DmaMask;

let mask0 = DmaMask::new::<0>();
assert_eq!(mask0.value(), 0);

let mask1 = DmaMask::new::<1>();
assert_eq!(mask1.value(), 0b1);

let mask64 = DmaMask::new::<64>();
assert_eq!(mask64.value(), u64::MAX);

// Build failure.
// let mask_overflow = DmaMask::new::<100>();
Source

pub const fn try_new(n: u32) -> Result<Self>

Constructs a DmaMask with the lowest n bits set to 1.

For n <= 64, sets exactly the lowest n bits. For n > 64, returns EINVAL.

§Examples
use kernel::dma::DmaMask;

let mask0 = DmaMask::try_new(0)?;
assert_eq!(mask0.value(), 0);

let mask1 = DmaMask::try_new(1)?;
assert_eq!(mask1.value(), 0b1);

let mask64 = DmaMask::try_new(64)?;
assert_eq!(mask64.value(), u64::MAX);

let mask_overflow = DmaMask::try_new(100);
assert!(mask_overflow.is_err());
Source

pub const fn value(&self) -> u64

Returns the underlying u64 bitmask value.

Trait Implementations§

Source§

impl Clone for DmaMask

Source§

fn clone(&self) -> DmaMask

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Copy for DmaMask

Source§

impl Debug for DmaMask

Source§

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

Formats the value using the given formatter. Read more
Source§

impl Eq for DmaMask

Source§

impl PartialEq for DmaMask

Source§

fn eq(&self, other: &DmaMask) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 (const: unstable) · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl StructuralPartialEq for DmaMask

Auto Trait Implementations§

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
§

impl<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
where ST: ?Sized, DT: ?Sized,

§

impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Init<T> for T

Source§

unsafe fn __init(self, slot: *mut T) -> Result<(), Infallible>

Initializes slot. Read more
Source§

fn chain<F>(self, f: F) -> ChainInit<Self, F, T, E>
where F: FnOnce(&mut T) -> Result<(), E>,

First initializes the value using self then calls the function f with the initialized value. Read more
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> KnownSize for T

Source§

fn size(_: *const T) -> usize

Get the size of an object of this type in bytes, with the metadata of the given pointer.
Source§

impl<T> PinInit<T> for T

Source§

unsafe fn __pinned_init(self, slot: *mut T) -> Result<(), Infallible>

Initializes slot. Read more
Source§

fn pin_chain<F>(self, f: F) -> ChainPinInit<Self, F, T, E>
where F: FnOnce(Pin<&mut T>) -> Result<(), E>,

First initializes the value using self then calls the function f with the initialized value. Read more
§

impl<T> Read<Exclusive, BecauseExclusive> for T
where T: ?Sized,

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.
Source§

impl<T, U, const N: u32> TryIntoBounded<T, N> for U
where T: Integer, U: TryInto<T>,

Source§

fn try_into_bounded(self) -> Option<Bounded<T, N>>

Attempts to convert self into a Bounded using N bits. Read more
Source§

impl<T> Writer for T
where T: Debug,

Source§

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

Formats the value using the given formatter.