pub struct XdpLoader { /* private fields */ }Expand description
XDP program loader for Linux.
Loads and attaches XDP programs to network interfaces for packet filtering and CPU steering.
§Example
ⓘ
use laminar_core::xdp::{XdpConfig, XdpLoader};
let config = XdpConfig::builder()
.enabled(true)
.interface("eth0")
.port(9999)
.build()?;
let loader = XdpLoader::load_and_attach(&config, 4)?;
println!("XDP active: {}", loader.is_active());
// Get statistics
let stats = loader.stats();
println!("Redirected: {}", stats.redirected);Implementations§
Source§impl XdpLoader
impl XdpLoader
Sourcepub fn update_cpu_steering(
&self,
partition: u32,
cpu: u32,
) -> Result<(), XdpError>
pub fn update_cpu_steering( &self, partition: u32, cpu: u32, ) -> Result<(), XdpError>
Updates CPU steering for a partition.
This allows runtime reconfiguration of which CPU handles packets for a given partition.
§Errors
Returns XdpError::InvalidConfig if the CPU index is out of range.
Sourcepub fn detach(&self) -> Result<(), XdpError>
pub fn detach(&self) -> Result<(), XdpError>
Detaches the XDP program from the interface.
§Errors
Currently infallible, but may return errors in future implementations when actual XDP detachment is performed.
Sourcepub fn attach_mode(&self) -> XdpAttachMode
pub fn attach_mode(&self) -> XdpAttachMode
Returns the attach mode.
Sourcepub fn record_packet(&self, was_valid: bool, bytes: u64)
pub fn record_packet(&self, was_valid: bool, bytes: u64)
Records a packet being processed (for tracking without XDP).
Trait Implementations§
Auto Trait Implementations§
impl !Freeze for XdpLoader
impl RefUnwindSafe for XdpLoader
impl Send for XdpLoader
impl Sync for XdpLoader
impl Unpin for XdpLoader
impl UnwindSafe for XdpLoader
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
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
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
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>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
Writes data to
out indicating that a T is niched.