pub struct UringSource<F: AsRawDescriptor> {
    registered_source: RegisteredSource,
    source: F,
}
Expand description

UringSource wraps FD backed IO sources for use with io_uring. It is a thin wrapper around registering an IO source with the uring that provides an IoSource implementation.

Fields§

§registered_source: RegisteredSource§source: F

Implementations§

source§

impl<F: AsRawDescriptor> UringSource<F>

source

pub fn new( io_source: F, ex: &Arc<RawExecutor<UringReactor>> ) -> Result<UringSource<F>>

Creates a new UringSource that wraps the given io_source object.

source

pub async fn read_to_vec( &self, file_offset: Option<u64>, vec: Vec<u8> ) -> AsyncResult<(usize, Vec<u8>)>

Reads from the iosource at file_offset and fill the given vec.

source

pub async fn wait_readable(&self) -> AsyncResult<()>

Wait for the FD of self to be readable.

source

pub async fn read_to_mem( &self, file_offset: Option<u64>, mem: Arc<dyn BackingMemory + Send + Sync>, mem_offsets: impl IntoIterator<Item = MemRegion> ) -> AsyncResult<usize>

Reads to the given mem at the given offsets from the file starting at file_offset.

source

pub async fn write_from_vec( &self, file_offset: Option<u64>, vec: Vec<u8> ) -> AsyncResult<(usize, Vec<u8>)>

Writes from the given vec to the file starting at file_offset.

source

pub async fn write_from_mem( &self, file_offset: Option<u64>, mem: Arc<dyn BackingMemory + Send + Sync>, mem_offsets: impl IntoIterator<Item = MemRegion> ) -> AsyncResult<usize>

Writes from the given mem from the given offsets to the file starting at file_offset.

source

pub async fn punch_hole(&self, file_offset: u64, len: u64) -> AsyncResult<()>

Deallocates the given range of a file.

source

pub async fn write_zeroes_at( &self, file_offset: u64, len: u64 ) -> AsyncResult<()>

Fills the given range with zeroes.

source

pub async fn fsync(&self) -> AsyncResult<()>

Sync all completed write operations to the backing storage.

source

pub async fn fdatasync(&self) -> AsyncResult<()>

Sync all data of completed write operations to the backing storage. Currently, the implementation is equivalent to fsync.

source

pub fn into_source(self) -> F

Yields the underlying IO source.

source

pub fn as_source(&self) -> &F

Provides a mutable ref to the underlying IO source.

source

pub fn as_source_mut(&mut self) -> &mut F

Provides a ref to the underlying IO source.

Trait Implementations§

source§

impl<F: AsRawDescriptor> Deref for UringSource<F>

§

type Target = F

The resulting type after dereferencing.
source§

fn deref(&self) -> &Self::Target

Dereferences the value.
source§

impl<F: AsRawDescriptor> DerefMut for UringSource<F>

source§

fn deref_mut(&mut self) -> &mut Self::Target

Mutably dereferences the value.

Auto Trait Implementations§

§

impl<F> RefUnwindSafe for UringSource<F>
where F: RefUnwindSafe,

§

impl<F> Send for UringSource<F>
where F: Send,

§

impl<F> Sync for UringSource<F>
where F: Sync,

§

impl<F> Unpin for UringSource<F>
where F: Unpin,

§

impl<F> UnwindSafe for UringSource<F>
where F: 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, 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.