Skip to main content

IoUringConfig

Struct IoUringConfig 

Source
pub struct IoUringConfig {
    pub ring_entries: u32,
    pub mode: RingMode,
    pub sqpoll_idle_ms: u32,
    pub sqpoll_cpu: Option<u32>,
    pub buffer_size: usize,
    pub buffer_count: usize,
    pub coop_taskrun: bool,
    pub single_issuer: bool,
    pub direct_table: bool,
    pub direct_table_size: u32,
}
Expand description

Configuration for io_uring operations.

Fields§

§ring_entries: u32

Number of submission queue entries (power of 2, typically 256-4096).

§mode: RingMode

Ring operation mode.

§sqpoll_idle_ms: u32

SQPOLL idle timeout in milliseconds before kernel thread sleeps. Only used when mode uses SQPOLL.

§sqpoll_cpu: Option<u32>

CPU to pin the SQPOLL kernel thread to (usually same NUMA node as core). Only used when mode uses SQPOLL.

§buffer_size: usize

Size of each registered buffer in bytes (typically 64KB).

§buffer_count: usize

Number of buffers in the registered pool.

§coop_taskrun: bool

Enable cooperative task running to reduce kernel-userspace transitions.

§single_issuer: bool

Optimize for single-threaded submission (thread-per-core model).

§direct_table: bool

Enable direct file descriptor table for faster operations.

§direct_table_size: u32

Number of direct file descriptor slots.

Implementations§

Source§

impl IoUringConfig

Source

pub fn builder() -> IoUringConfigBuilder

Create a new builder for IoUringConfig.

Source

pub fn auto() -> Self

Create configuration with automatic detection.

Detects system capabilities and generates an optimal configuration:

  • Enables SQPOLL mode on Linux 5.11+ with the io-uring feature
  • Enables IOPOLL mode on Linux 5.19+ with NVMe storage
  • Uses optimal buffer sizes based on available memory
§Example
use laminar_core::io_uring::IoUringConfig;

let config = IoUringConfig::auto();
println!("SQPOLL: {}", config.mode.uses_sqpoll());
Source

pub const fn total_buffer_size(&self) -> usize

Total buffer pool size in bytes.

Source

pub fn validate(&self) -> Result<(), IoUringError>

Validate the configuration.

§Errors

Returns an error if the configuration is invalid.

Trait Implementations§

Source§

impl Clone for IoUringConfig

Source§

fn clone(&self) -> IoUringConfig

Returns a duplicate of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for IoUringConfig

Source§

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

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

impl Default for IoUringConfig

Source§

fn default() -> Self

Returns the “default value” for a type. Read more

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

Source§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
Source§

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

Converts some archived metadata to the pointer metadata for itself.
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> 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> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. 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> LayoutRaw for T

Source§

fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>

Returns the layout of the type.
Source§

impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
where T: SharedNiching<N1, N2>, N1: Niching<T>, N2: Niching<T>,

Source§

unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool

Returns whether the given value has been niched. Read more
Source§

fn resolve_niched(out: Place<NichedOption<T, N1>>)

Writes data to out indicating that a T is niched.
Source§

impl<T> Pointee for T

Source§

type Metadata = ()

The metadata type for pointers and references to this type.
Source§

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

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. 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.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> Allocation for T
where T: RefUnwindSafe + Send + Sync,