VirtioNetDevice

Struct VirtioNetDevice 

Source
pub struct VirtioNetDevice {
    base_addr: usize,
    virtqueues: Mutex<[VirtQueue<'static>; 2]>,
    config: RwLock<Option<NetworkInterfaceConfig>>,
    features: RwLock<u32>,
    stats: Mutex<NetworkStats>,
    initialized: Mutex<bool>,
    rx_buffers: Mutex<Vec<Box<[u8]>>>,
    interrupt_id: Mutex<Option<InterruptId>>,
    interface_name: Mutex<Option<String>>,
}
Expand description

VirtIO Network Device

Fields§

§base_addr: usize§virtqueues: Mutex<[VirtQueue<'static>; 2]>§config: RwLock<Option<NetworkInterfaceConfig>>§features: RwLock<u32>§stats: Mutex<NetworkStats>§initialized: Mutex<bool>§rx_buffers: Mutex<Vec<Box<[u8]>>>§interrupt_id: Mutex<Option<InterruptId>>§interface_name: Mutex<Option<String>>

Implementations§

Source§

impl VirtioNetDevice

Source

pub fn new(base_addr: usize) -> Self

Create a new VirtIO Network device

§Arguments
  • base_addr - The base address of the device
§Returns

A new instance of VirtioNetDevice

Source

pub fn register_interface(self: &Arc<Self>, name: &str)

Source

fn read_device_config(&mut self, negotiated_features: u32)

Read device configuration from the VirtIO config space

Source

fn get_header_size(&self) -> usize

Get the appropriate header size based on device features

Source

fn setup_rx_buffers(&self) -> Result<(), &'static str>

Setup receive buffers in the RX queue

Source

fn transmit_packet(&self, packet: &DevicePacket) -> Result<(), &'static str>

Process a single packet transmission

Source

fn process_received_packets(&self) -> Result<Vec<DevicePacket>, &'static str>

Process received packets from RX queue

Check link status from device configuration

Source

pub fn enable_interrupts( &self, interrupt_id: InterruptId, ) -> Result<(), &'static str>

Enable interrupts for this device

Source

pub fn set_interface_name(&self, name: &str)

Set interface name for interrupt dispatch

Trait Implementations§

Source§

impl ControlOps for VirtioNetDevice

Source§

fn control(&self, _command: u32, _arg: usize) -> Result<i32, &'static str>

Perform a control operation Read more
Source§

fn supported_control_commands(&self) -> Vec<(u32, &'static str)>

Get a list of supported control commands Read more
Source§

impl Device for VirtioNetDevice

Source§

fn device_type(&self) -> DeviceType

Source§

fn name(&self) -> &'static str

Source§

fn as_any(&self) -> &dyn Any

Source§

fn as_any_mut(&mut self) -> &mut dyn Any

Source§

fn as_network_device(&self) -> Option<&dyn NetworkDevice>

Cast to NetworkDevice if this device is a network device
Source§

fn capabilities(&self) -> &'static [DeviceCapability]

Optional capabilities exposed by this device (default: none)
Source§

fn as_event_capable(&self) -> Option<&dyn EventCapableDevice>

Cast to EventCapableDevice if this device can emit events
Source§

fn as_char_device(&self) -> Option<&dyn CharDevice>

Cast to CharDevice if this device is a character device
Source§

fn as_block_device(&self) -> Option<&dyn BlockDevice>

Cast to BlockDevice if this device is a block device
Source§

fn as_graphics_device(&self) -> Option<&dyn GraphicsDevice>

Cast to GraphicsDevice if this device is a graphics device
Source§

fn into_block_device(self: Arc<Self>) -> Option<Arc<dyn BlockDevice>>

Cast Arc to Arc if this device is a block device This allows direct ownership of the block device for efficient I/O operations
Source§

fn into_char_device(self: Arc<Self>) -> Option<Arc<dyn CharDevice>>

Cast Arc to Arc if this device is a character device This allows direct ownership of the char device for efficient I/O operations
Source§

fn into_graphics_device(self: Arc<Self>) -> Option<Arc<dyn GraphicsDevice>>

Cast Arc to Arc if this device is a graphics device This allows direct ownership of the graphics device for efficient operations
Source§

fn into_network_device(self: Arc<Self>) -> Option<Arc<dyn NetworkDevice>>

Cast Arc to Arc if this device is a network device This allows direct ownership of the network device for efficient operations
Source§

impl EthernetDevice for VirtioNetDevice

Source§

fn mac_address(&self) -> Result<MacAddress, &'static str>

Get the Ethernet MAC address for this device.
Source§

impl InterruptCapableDevice for VirtioNetDevice

Source§

impl MemoryMappingOps for VirtioNetDevice

Source§

fn get_mapping_info( &self, _offset: usize, _length: usize, ) -> Result<(usize, usize, bool), &'static str>

Get mapping information for a region of the object Read more
Source§

fn on_mapped( &self, _vaddr: usize, _paddr: usize, _length: usize, _offset: usize, )

Notification that a mapping has been created Read more
Source§

fn on_unmapped(&self, _vaddr: usize, _length: usize)

Notification that a mapping has been removed Read more
Source§

fn supports_mmap(&self) -> bool

Check if memory mapping is supported Read more
Source§

fn get_mapping_info_with( &self, offset: usize, length: usize, _is_shared: bool, ) -> Result<(usize, usize, bool), &'static str>

Get mapping information with sharing intent. Read more
Source§

fn mmap_owner_name(&self) -> String

Diagnostic helper: return a short owner name for logging Read more
Source§

fn resolve_fault( &self, access: &AccessKind, map: &VirtualMemoryMap, ) -> Result<ResolveFaultResult, ResolveFaultError>

Source§

impl NetworkDevice for VirtioNetDevice

Source§

fn get_interface_name(&self) -> &'static str

Get the network interface name
Source§

fn get_mac_address(&self) -> Result<MacAddress, &'static str>

Get the MAC address of the interface
Source§

fn get_mtu(&self) -> Result<usize, &'static str>

Get the MTU (Maximum Transmission Unit) of the interface
Source§

fn get_interface_config(&self) -> Result<NetworkInterfaceConfig, &'static str>

Get the full interface configuration
Source§

fn send_packet(&self, packet: DevicePacket) -> Result<(), &'static str>

Send a packet
Source§

fn receive_packets(&self) -> Result<Vec<DevicePacket>, &'static str>

Receive packets (non-blocking) Returns all currently available packets
Source§

fn set_promiscuous_mode(&self, _enabled: bool) -> Result<(), &'static str>

Set promiscuous mode (receive all packets on the network)
Source§

fn init_network(&mut self) -> Result<(), &'static str>

Initialize the network device
Check if the link is up
Source§

fn get_stats(&self) -> NetworkStats

Get network device statistics
Source§

impl Selectable for VirtioNetDevice

Source§

fn wait_until_ready( &self, _interest: ReadyInterest, _trapframe: &mut Trapframe, _timeout_ticks: Option<u64>, ) -> SelectWaitOutcome

Block the current task using the provided trapframe until the interest becomes ready or the optional timeout (in ticks) expires. Read more
Source§

fn current_ready(&self, interest: ReadyInterest) -> ReadySet

Return current readiness for the given interest set.
Source§

fn set_nonblocking(&self, _enabled: bool)

Enable or disable non-blocking I/O semantics on this object. Read more
Source§

fn is_nonblocking(&self) -> bool

Query whether non-blocking I/O semantics are enabled on this object.
Source§

impl VirtioDevice for VirtioNetDevice

Source§

fn get_base_addr(&self) -> usize

Source§

fn get_virtqueue_count(&self) -> usize

Source§

fn get_virtqueue_size(&self, queue_idx: usize) -> usize

Source§

fn get_supported_features(&self, device_features: u32) -> u32

Get device features supported by this driver Read more
Source§

fn get_queue_desc_addr(&self, queue_idx: usize) -> Option<u64>

Get the descriptor address for a virtqueue
Source§

fn get_queue_driver_addr(&self, queue_idx: usize) -> Option<u64>

Get the driver area address for a virtqueue
Source§

fn get_queue_device_addr(&self, queue_idx: usize) -> Option<u64>

Get the device area address for a virtqueue
Source§

fn debug_dump_mmio_state(&self, tag: &'static str)

Source§

fn debug_log_status_transition( &self, tag: &'static str, old: u32, new: u32, readback: u32, )

Source§

fn wait_for_status_zero( &self, tag: &'static str, max_iters: usize, ) -> Result<(), &'static str>

Source§

fn init(&mut self) -> Result<u32, &'static str>

Initialize the device Read more
Source§

fn is_modern_device(&self) -> bool

Source§

fn supports_feature(&self, feature: u32) -> bool

Source§

fn reset(&mut self) -> Result<(), &'static str>

Reset the device by writing 0 to the Status register
Source§

fn acknowledge(&mut self)

Set ACKNOWLEDGE status bit
Source§

fn driver(&mut self)

Set DRIVER status bit
Source§

fn driver_ok(&mut self)

Set DRIVER_OK status bit
Source§

fn set_failed(&mut self)

Set FAILED status bit
Source§

fn negotiate_features(&mut self) -> Result<u32, &'static str>

Negotiate device features Read more
Source§

fn allow_ring_features(&self) -> bool

Source§

fn setup_queue(&mut self, queue_idx: usize, queue_size: usize) -> bool

Set up a virtqueue Read more
Source§

fn read_config<T: Sized>(&self, offset: usize) -> T

Read device-specific configuration Read more
Source§

fn write_config<T: Sized>(&self, offset: usize, value: T)

Write device-specific configuration Read more
Source§

fn get_device_info(&self) -> (u32, u32)

Get device and vendor IDs Read more
Source§

fn get_interrupt_status(&self) -> u32

Get interrupt status Read more
Source§

fn process_interrupts(&mut self) -> u32

Process interrupts (polling method) Read more
Source§

fn memory_barrier(&self)

Memory barrier for ensuring memory operations ordering
Source§

fn notify(&self, virtqueue_idx: usize)

Notify the device about new buffers in a specified virtqueue Read more
Source§

fn read32_register(&self, register: Register) -> u32

Read a 32-bit value from a device register Read more
Source§

fn write32_register(&self, register: Register, value: u32)

Write a 32-bit value to a device register Read more
Source§

fn read64_register(&self, register: Register) -> u64

Read a 64-bit value from a device register Read more
Source§

fn write64_register(&self, register: Register, value: u64)

Write a 64-bit value to a device register Read more

Auto Trait Implementations§

§

impl !Freeze for VirtioNetDevice

§

impl !RefUnwindSafe for VirtioNetDevice

§

impl Send for VirtioNetDevice

§

impl Sync for VirtioNetDevice

§

impl Unpin for VirtioNetDevice

§

impl !UnwindSafe for VirtioNetDevice

Blanket Implementations§

§

impl<T> Any for T
where T: 'static + ?Sized,

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> Borrow<T> for T
where T: ?Sized,

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

impl<T> BorrowMut<T> for T
where T: ?Sized,

§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T, U> Into<U> for T
where U: From<T>,

§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of [From]<T> for U chooses to do.

§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
§

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

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.