kernel::block::mq

Struct Request

Source
pub struct Request<T: Operations>(/* private fields */);
Expand description

A wrapper around a blk-mq struct request. This represents an IO request.

§Implementation details

There are four states for a request that the Rust bindings care about:

  1. Request is owned by block layer (refcount 0).
  2. Request is owned by driver but with zero ARefs in existence (refcount 1).
  3. Request is owned by driver with exactly one ARef in existence (refcount 2).
  4. Request is owned by driver with more than one ARef in existence (refcount > 2).

We need to track 1 and 2 to ensure we fail tag to request conversions for requests that are not owned by the driver.

We need to track 3 and 4 to ensure that it is safe to end the request and hand back ownership to the block layer.

The states are tracked through the private refcount field of RequestDataWrapper. This structure lives in the private data area of the C struct request.

§Invariants

  • self.0 is a valid struct request created by the C portion of the kernel.
  • The private data area associated with this request must be an initialized and valid RequestDataWrapper<T>.
  • self is reference counted by atomic modification of self.wrapper_ref().refcount().

Implementations§

Source§

impl<T: Operations> Request<T>

Source

pub fn end_ok(this: ARef<Self>) -> Result<(), ARef<Self>>

Notify the block layer that the request has been completed without errors.

This function will return Err if this is not the only ARef referencing the request.

Trait Implementations§

Source§

impl<T: Operations> AlwaysRefCounted for Request<T>

Source§

fn inc_ref(&self)

Increments the reference count on the object.
Source§

unsafe fn dec_ref(obj: NonNull<Self>)

Decrements the reference count on the object. Read more
Source§

impl<T: Operations> Send for Request<T>

Source§

impl<T: Operations> Sync for Request<T>

Auto Trait Implementations§

§

impl<T> !Freeze for Request<T>

§

impl<T> !RefUnwindSafe for Request<T>

§

impl<T> !Unpin for Request<T>

§

impl<T> UnwindSafe for Request<T>
where T: UnwindSafe,

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, E> Init<T, E> for T

Source§

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

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, E> PinInit<T, E> for T

Source§

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

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