pub struct VirtioInputDevice {
base_addr: usize,
eventq: Mutex<VirtQueue<'static>>,
statusq: Mutex<VirtQueue<'static>>,
event_device: Arc<EventDevice>,
initialized: Mutex<bool>,
event_buffers: Mutex<Vec<Box<[u8]>>>,
interrupt_id: Mutex<Option<u32>>,
}Expand description
VirtIO Input Device
Fields§
§base_addr: usize§eventq: Mutex<VirtQueue<'static>>§statusq: Mutex<VirtQueue<'static>>§event_device: Arc<EventDevice>§initialized: Mutex<bool>§event_buffers: Mutex<Vec<Box<[u8]>>>§interrupt_id: Mutex<Option<u32>>Implementations§
Source§impl VirtioInputDevice
impl VirtioInputDevice
Sourcefn read8_config(&self, offset: usize) -> u8
fn read8_config(&self, offset: usize) -> u8
Read a u8 from configuration space
Sourcefn write8_config(&self, offset: usize, value: u8)
fn write8_config(&self, offset: usize, value: u8)
Write a u8 to configuration space
Sourcefn read_device_name(&self) -> Option<String>
fn read_device_name(&self) -> Option<String>
Read device name from configuration
Sourcefn determine_device_type(name: &str) -> &'static str
fn determine_device_type(name: &str) -> &'static str
Determine device type from name
Sourcefn setup_queues(&mut self) -> Result<(), &'static str>
fn setup_queues(&mut self) -> Result<(), &'static str>
Setup virtqueues
Sourcefn prefill_event_queue(&mut self) -> Result<(), &'static str>
fn prefill_event_queue(&mut self) -> Result<(), &'static str>
Prefill event queue with receive buffers
Sourcepub fn handle_interrupt(&self)
pub fn handle_interrupt(&self)
Handle input events from the device
This should be called from the interrupt handler or periodically polled
Sourcepub fn poll_events(&self)
pub fn poll_events(&self)
Poll for events (for testing without interrupt support)
This can be called periodically to check for events when interrupt handling is not yet implemented
Sourcefn process_events(&self)
fn process_events(&self)
Process events from the event queue
Sourcepub fn enable_interrupts(&self, interrupt_id: u32) -> Result<(), &'static str>
pub fn enable_interrupts(&self, interrupt_id: u32) -> Result<(), &'static str>
Enable interrupts for this device
Sourcepub fn get_event_device(&self) -> Arc<EventDevice>
pub fn get_event_device(&self) -> Arc<EventDevice>
Get the EventDevice for this input device
Trait Implementations§
Source§impl ControlOps for VirtioInputDevice
impl ControlOps for VirtioInputDevice
Source§impl Device for VirtioInputDevice
impl Device for VirtioInputDevice
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 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 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 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 InterruptCapableDevice for VirtioInputDevice
impl InterruptCapableDevice for VirtioInputDevice
fn handle_interrupt(&self) -> InterruptResult<()>
fn interrupt_id(&self) -> Option<InterruptId>
Source§impl MemoryMappingOps for VirtioInputDevice
impl MemoryMappingOps for VirtioInputDevice
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 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 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 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 Selectable for VirtioInputDevice
impl Selectable for VirtioInputDevice
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 VirtioInputDevice
impl VirtioDevice for VirtioInputDevice
fn get_base_addr(&self) -> usize
Source§fn get_device_info(&self) -> (u32, u32)
fn get_device_info(&self) -> (u32, u32)
Get device and vendor IDs Read more
fn get_virtqueue_count(&self) -> usize
fn get_virtqueue_size(&self, queue_idx: usize) -> usize
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
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
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_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