VirtioInputDevice

Struct VirtioInputDevice 

Source
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

Source

fn read8_config(&self, offset: usize) -> u8

Read a u8 from configuration space

Source

fn write8_config(&self, offset: usize, value: u8)

Write a u8 to configuration space

Source

fn read_device_name(&self) -> Option<String>

Read device name from configuration

Source

fn determine_device_type(name: &str) -> &'static str

Determine device type from name

Source

pub fn new(base_addr: usize) -> Self

Create a new VirtIO Input device

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

A new instance of VirtioInputDevice

Source

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

Initialize the VirtIO input device

Source

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

Setup virtqueues

Source

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

Prefill event queue with receive buffers

Source

pub fn handle_interrupt(&self)

Handle input events from the device

This should be called from the interrupt handler or periodically polled

Source

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

Source

fn process_events(&self)

Process events from the event queue

Source

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

Enable interrupts for this device

Source

pub fn get_event_device(&self) -> Arc<EventDevice>

Get the EventDevice for this input device

Trait Implementations§

Source§

impl ControlOps for VirtioInputDevice

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 VirtioInputDevice

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

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 InterruptCapableDevice for VirtioInputDevice

Source§

impl MemoryMappingOps for VirtioInputDevice

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 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)

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 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 Selectable for VirtioInputDevice

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 VirtioInputDevice

Source§

fn get_base_addr(&self) -> usize

Source§

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

Get device and vendor IDs Read more
Source§

fn get_virtqueue_count(&self) -> usize

Source§

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

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 get_supported_features(&self, device_features: u32) -> u32

Get device features supported by this driver 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_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 VirtioInputDevice

§

impl !RefUnwindSafe for VirtioInputDevice

§

impl Send for VirtioInputDevice

§

impl Sync for VirtioInputDevice

§

impl Unpin for VirtioInputDevice

§

impl !UnwindSafe for VirtioInputDevice

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.