Struct devices::virtio::scsi::Controller
source · pub struct Controller {
avail_features: u64,
queue_sizes: Vec<u16>,
seg_max: u32,
sense_size: u32,
cdb_size: u32,
executor_kind: ExecutorKind,
worker_threads: Vec<WorkerThread<()>>,
targets: Option<Targets>,
multi_queue: bool,
}
Expand description
Vitio device for exposing SCSI command operations on a host file.
Fields§
§avail_features: u64
§queue_sizes: Vec<u16>
§seg_max: u32
§sense_size: u32
§cdb_size: u32
§executor_kind: ExecutorKind
§worker_threads: Vec<WorkerThread<()>>
§targets: Option<Targets>
§multi_queue: bool
Implementations§
source§impl Controller
impl Controller
sourcepub fn new(base_features: u64, disks: Vec<DiskConfig>) -> Result<Self>
pub fn new(base_features: u64, disks: Vec<DiskConfig>) -> Result<Self>
Creates a virtio-scsi device.
fn build_config_space(&self) -> virtio_scsi_config
fn execute_control( reader: &mut Reader, writer: &mut Writer, target_ids: &BTreeSet<u8> ) -> Result<(), ExecuteError>
fn execute_tmf( tmf: virtio_scsi_ctrl_tmf_req, target_ids: &BTreeSet<u8> ) -> virtio_scsi_ctrl_tmf_resp
async fn execute_request( reader: &mut Reader, resp_writer: &mut Writer, data_writer: &mut Writer, targets: &BTreeMap<u8, AsyncLogicalUnit>, sense_size: u32, cdb_size: u32 ) -> Result<(), ExecuteError>
fn get_logical_unit( lun: [u8; 8], targets: &BTreeMap<u8, AsyncLogicalUnit> ) -> Option<&AsyncLogicalUnit>
Trait Implementations§
source§impl VirtioDevice for Controller
impl VirtioDevice for Controller
source§fn keep_rds(&self) -> Vec<RawDescriptor>
fn keep_rds(&self) -> Vec<RawDescriptor>
A vector of device-specific file descriptors that must be kept open
after jailing. Must be called before the process is jailed.
source§fn features(&self) -> u64
fn features(&self) -> u64
The set of feature bits that this device supports in addition to the base features.
source§fn device_type(&self) -> VirtioDeviceType
fn device_type(&self) -> VirtioDeviceType
The virtio device type.
source§fn queue_max_sizes(&self) -> &[u16]
fn queue_max_sizes(&self) -> &[u16]
The maximum size of each queue that this device supports.
source§fn read_config(&self, offset: u64, data: &mut [u8])
fn read_config(&self, offset: u64, data: &mut [u8])
Reads this device configuration space at
offset
.source§fn write_config(&mut self, offset: u64, data: &[u8])
fn write_config(&mut self, offset: u64, data: &[u8])
Writes to this device configuration space at
offset
.source§fn activate(
&mut self,
_mem: GuestMemory,
interrupt: Interrupt,
queues: BTreeMap<usize, Queue>
) -> Result<()>
fn activate( &mut self, _mem: GuestMemory, interrupt: Interrupt, queues: BTreeMap<usize, Queue> ) -> Result<()>
Activates this device for real usage.
source§fn debug_label(&self) -> String
fn debug_label(&self) -> String
Returns a label suitable for debug output.
source§fn num_interrupts(&self) -> usize
fn num_interrupts(&self) -> usize
The number of interrupts used by this device.
source§fn ack_features(&mut self, value: u64)
fn ack_features(&mut self, value: u64)
Acknowledges that this set of features should be enabled.
source§fn reset(&mut self) -> Result<()>
fn reset(&mut self) -> Result<()>
Optionally deactivates this device. If the reset method is
not able to reset the virtio device, or the virtio device model doesn’t
implement the reset method, an
Err
value is returned to indicate
the reset is not successful. Otherwise Ok(())
should be returned.source§fn get_device_bars(&mut self, _address: PciAddress) -> Vec<PciBarConfiguration>
fn get_device_bars(&mut self, _address: PciAddress) -> Vec<PciBarConfiguration>
Returns any additional BAR configuration required by the device.
source§fn get_device_caps(&self) -> Vec<Box<dyn PciCapability>>
fn get_device_caps(&self) -> Vec<Box<dyn PciCapability>>
Returns any additional capabiltiies required by the device.
source§fn on_device_sandboxed(&mut self)
fn on_device_sandboxed(&mut self)
Invoked when the device is sandboxed.
fn control_notify(&self, _behavior: MsixStatus)
fn generate_acpi( &mut self, _pci_address: &Option<PciAddress>, sdts: Vec<SDT> ) -> Option<Vec<SDT>>
source§fn read_bar(&mut self, _bar_index: PciBarIndex, _offset: u64, _data: &mut [u8])
fn read_bar(&mut self, _bar_index: PciBarIndex, _offset: u64, _data: &mut [u8])
Reads from a BAR region mapped in to the device. Read more
source§fn write_bar(&mut self, _bar_index: PciBarIndex, _offset: u64, _data: &[u8])
fn write_bar(&mut self, _bar_index: PciBarIndex, _offset: u64, _data: &[u8])
Writes to a BAR region mapped in to the device. Read more
source§fn pci_address(&self) -> Option<PciAddress>
fn pci_address(&self) -> Option<PciAddress>
Returns the PCI address where the device will be allocated.
Returns
None
if any address is good for the device.source§fn transport_type(&self) -> VirtioTransportType
fn transport_type(&self) -> VirtioTransportType
Returns the Virtio transport type: PCI (default for crosvm) or MMIO.
Returns the device’s shared memory region if present.
source§fn expose_shmem_descriptors_with_viommu(&self) -> bool
fn expose_shmem_descriptors_with_viommu(&self) -> bool
If true, VFIO passthrough devices can access descriptors mapped into
this region by mapping the corresponding addresses from this device’s
PCI bar into their IO address space with virtio-iommu. Read more
Provides the trait object used to map files into the device’s shared
memory region. Read more
Provides the base address of the shared memory region, if one is present. Will
be called before
activate
. Read moreQueries the implementation whether a single prepared hypervisor memory mapping with explicit
caching type should be setup lazily on first mapping request, or whether to dynamically
setup a hypervisor mapping with every request’s caching type.
source§fn virtio_sleep(&mut self) -> Result<Option<BTreeMap<usize, Queue>>>
fn virtio_sleep(&mut self) -> Result<Option<BTreeMap<usize, Queue>>>
Pause all processing. Read more
source§fn virtio_wake(
&mut self,
_queues_state: Option<(GuestMemory, Interrupt, BTreeMap<usize, Queue>)>
) -> Result<()>
fn virtio_wake( &mut self, _queues_state: Option<(GuestMemory, Interrupt, BTreeMap<usize, Queue>)> ) -> Result<()>
Resume all processing. Read more
source§fn virtio_snapshot(&mut self) -> Result<Value>
fn virtio_snapshot(&mut self) -> Result<Value>
Snapshot current state. Device must be asleep.
source§fn virtio_restore(&mut self, _data: Value) -> Result<()>
fn virtio_restore(&mut self, _data: Value) -> Result<()>
Restore device state from a snapshot.
TODO(b/280607404): Vhost user will need fds passed to the device process.
fn bootorder_fw_cfg(&self, _pci_address: u8) -> Option<(Vec<u8>, usize)>
Auto Trait Implementations§
impl !RefUnwindSafe for Controller
impl Send for Controller
impl !Sync for Controller
impl Unpin for Controller
impl !UnwindSafe for Controller
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Convert
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Convert
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Convert
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Convert
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.