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
impl VirtioNetDevice
pub fn register_interface(self: &Arc<Self>, name: &str)
Sourcefn read_device_config(&mut self, negotiated_features: u32)
fn read_device_config(&mut self, negotiated_features: u32)
Read device configuration from the VirtIO config space
Sourcefn get_header_size(&self) -> usize
fn get_header_size(&self) -> usize
Get the appropriate header size based on device features
Sourcefn setup_rx_buffers(&self) -> Result<(), &'static str>
fn setup_rx_buffers(&self) -> Result<(), &'static str>
Setup receive buffers in the RX queue
Sourcefn transmit_packet(&self, packet: &DevicePacket) -> Result<(), &'static str>
fn transmit_packet(&self, packet: &DevicePacket) -> Result<(), &'static str>
Process a single packet transmission
Sourcefn process_received_packets(&self) -> Result<Vec<DevicePacket>, &'static str>
fn process_received_packets(&self) -> Result<Vec<DevicePacket>, &'static str>
Process received packets from RX queue
Sourcefn check_link_status(&self) -> bool
fn check_link_status(&self) -> bool
Check link status from device configuration
Sourcepub fn enable_interrupts(
&self,
interrupt_id: InterruptId,
) -> Result<(), &'static str>
pub fn enable_interrupts( &self, interrupt_id: InterruptId, ) -> Result<(), &'static str>
Enable interrupts for this device
Sourcepub fn set_interface_name(&self, name: &str)
pub fn set_interface_name(&self, name: &str)
Set interface name for interrupt dispatch
Trait Implementations§
Source§impl ControlOps for VirtioNetDevice
impl ControlOps for VirtioNetDevice
Source§impl Device for VirtioNetDevice
impl Device for VirtioNetDevice
fn device_type(&self) -> DeviceType
fn name(&self) -> &'static str
fn as_any(&self) -> &dyn Any
fn as_any_mut(&mut self) -> &mut dyn Any
Source§fn as_network_device(&self) -> Option<&dyn NetworkDevice>
fn as_network_device(&self) -> Option<&dyn NetworkDevice>
Cast to NetworkDevice if this device is a network device
Source§fn capabilities(&self) -> &'static [DeviceCapability]
fn capabilities(&self) -> &'static [DeviceCapability]
Optional capabilities exposed by this device (default: none)
Source§fn as_event_capable(&self) -> Option<&dyn EventCapableDevice>
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>
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>
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>
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>>
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>>
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>>
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>>
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
impl EthernetDevice for VirtioNetDevice
Source§fn mac_address(&self) -> Result<MacAddress, &'static str>
fn mac_address(&self) -> Result<MacAddress, &'static str>
Get the Ethernet MAC address for this device.
Source§impl InterruptCapableDevice for VirtioNetDevice
impl InterruptCapableDevice for VirtioNetDevice
fn handle_interrupt(&self) -> InterruptResult<()>
fn interrupt_id(&self) -> Option<InterruptId>
Source§impl MemoryMappingOps for VirtioNetDevice
impl MemoryMappingOps for VirtioNetDevice
Source§fn get_mapping_info(
&self,
_offset: usize,
_length: usize,
) -> Result<(usize, usize, bool), &'static str>
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,
)
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)
fn on_unmapped(&self, _vaddr: usize, _length: usize)
Notification that a mapping has been removed Read more
Source§fn supports_mmap(&self) -> bool
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>
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
fn mmap_owner_name(&self) -> String
Diagnostic helper: return a short owner name for logging Read more
fn resolve_fault( &self, access: &AccessKind, map: &VirtualMemoryMap, ) -> Result<ResolveFaultResult, ResolveFaultError>
Source§impl NetworkDevice for VirtioNetDevice
impl NetworkDevice for VirtioNetDevice
Source§fn get_interface_name(&self) -> &'static str
fn get_interface_name(&self) -> &'static str
Get the network interface name
Source§fn get_mac_address(&self) -> Result<MacAddress, &'static str>
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>
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>
fn get_interface_config(&self) -> Result<NetworkInterfaceConfig, &'static str>
Get the full interface configuration
Source§fn send_packet(&self, packet: DevicePacket) -> Result<(), &'static str>
fn send_packet(&self, packet: DevicePacket) -> Result<(), &'static str>
Send a packet
Source§fn receive_packets(&self) -> Result<Vec<DevicePacket>, &'static str>
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>
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>
fn init_network(&mut self) -> Result<(), &'static str>
Initialize the network device
Source§fn is_link_up(&self) -> bool
fn is_link_up(&self) -> bool
Check if the link is up
Source§fn get_stats(&self) -> NetworkStats
fn get_stats(&self) -> NetworkStats
Get network device statistics
Source§impl Selectable for VirtioNetDevice
impl Selectable for VirtioNetDevice
Source§fn wait_until_ready(
&self,
_interest: ReadyInterest,
_trapframe: &mut Trapframe,
_timeout_ticks: Option<u64>,
) -> SelectWaitOutcome
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
fn current_ready(&self, interest: ReadyInterest) -> ReadySet
Return current readiness for the given interest set.
Source§fn set_nonblocking(&self, _enabled: bool)
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
fn is_nonblocking(&self) -> bool
Query whether non-blocking I/O semantics are enabled on this object.
Source§impl VirtioDevice for VirtioNetDevice
impl VirtioDevice for VirtioNetDevice
fn get_base_addr(&self) -> usize
fn get_virtqueue_count(&self) -> usize
fn get_virtqueue_size(&self, queue_idx: usize) -> usize
Source§fn get_supported_features(&self, device_features: u32) -> u32
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>
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>
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>
fn get_queue_device_addr(&self, queue_idx: usize) -> Option<u64>
Get the device area address for a virtqueue
fn debug_dump_mmio_state(&self, tag: &'static str)
fn debug_log_status_transition( &self, tag: &'static str, old: u32, new: u32, readback: u32, )
fn wait_for_status_zero( &self, tag: &'static str, max_iters: usize, ) -> Result<(), &'static str>
fn is_modern_device(&self) -> bool
fn supports_feature(&self, feature: u32) -> bool
Source§fn reset(&mut self) -> Result<(), &'static str>
fn reset(&mut self) -> Result<(), &'static str>
Reset the device by writing 0 to the Status register
Source§fn acknowledge(&mut self)
fn acknowledge(&mut self)
Set ACKNOWLEDGE status bit
Source§fn set_failed(&mut self)
fn set_failed(&mut self)
Set FAILED status bit
Source§fn negotiate_features(&mut self) -> Result<u32, &'static str>
fn negotiate_features(&mut self) -> Result<u32, &'static str>
Negotiate device features Read more
fn allow_ring_features(&self) -> bool
Source§fn setup_queue(&mut self, queue_idx: usize, queue_size: usize) -> bool
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
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)
fn write_config<T: Sized>(&self, offset: usize, value: T)
Write device-specific configuration Read more
Source§fn get_device_info(&self) -> (u32, u32)
fn get_device_info(&self) -> (u32, u32)
Get device and vendor IDs Read more
Source§fn get_interrupt_status(&self) -> u32
fn get_interrupt_status(&self) -> u32
Get interrupt status Read more
Source§fn process_interrupts(&mut self) -> u32
fn process_interrupts(&mut self) -> u32
Process interrupts (polling method) Read more
Source§fn memory_barrier(&self)
fn memory_barrier(&self)
Memory barrier for ensuring memory operations ordering
Source§fn notify(&self, virtqueue_idx: usize)
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
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)
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
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)
fn write64_register(&self, register: Register, value: u64)
Write a 64-bit value to a device register Read more