pub struct VirtioBlockDevice {
base_addr: usize,
virtqueues: Mutex<[VirtQueue<'static>; 1]>,
capacity: RwLock<u64>,
sector_size: RwLock<u32>,
features: RwLock<u32>,
read_only: RwLock<bool>,
request_queue: Mutex<VecDeque<Box<BlockIORequest>>>,
}Fields§
§base_addr: usize§virtqueues: Mutex<[VirtQueue<'static>; 1]>§capacity: RwLock<u64>§sector_size: RwLock<u32>§features: RwLock<u32>§read_only: RwLock<bool>§request_queue: Mutex<VecDeque<Box<BlockIORequest>>>Implementations§
Source§impl VirtioBlockDevice
impl VirtioBlockDevice
pub fn new(base_addr: usize) -> Self
fn process_request(&self, req: &mut BlockIORequest) -> Result<(), &'static str>
Sourcefn process_requests_batch(
&self,
requests: &mut [Box<BlockIORequest>],
) -> Vec<Result<(), &'static str>>
fn process_requests_batch( &self, requests: &mut [Box<BlockIORequest>], ) -> Vec<Result<(), &'static str>>
Process multiple requests in a true batch manner All requests are submitted first, then we wait for all completions
Trait Implementations§
Source§impl BlockDevice for VirtioBlockDevice
impl BlockDevice for VirtioBlockDevice
Source§fn get_disk_name(&self) -> &'static str
fn get_disk_name(&self) -> &'static str
Get the disk name
Source§fn get_disk_size(&self) -> usize
fn get_disk_size(&self) -> usize
Get the disk size in bytes
Source§fn enqueue_request(&self, request: Box<BlockIORequest>)
fn enqueue_request(&self, request: Box<BlockIORequest>)
Enqueue a block I/O request
Source§fn process_requests(&self) -> Vec<BlockIOResult>
fn process_requests(&self) -> Vec<BlockIOResult>
Process all queued requests Read more
Source§impl ControlOps for VirtioBlockDevice
impl ControlOps for VirtioBlockDevice
Source§impl Device for VirtioBlockDevice
impl Device for VirtioBlockDevice
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_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 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 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_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_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 MemoryMappingOps for VirtioBlockDevice
impl MemoryMappingOps for VirtioBlockDevice
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 Selectable for VirtioBlockDevice
impl Selectable for VirtioBlockDevice
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 VirtioBlockDevice
impl VirtioDevice for VirtioBlockDevice
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