pub struct VirtioMmioDevice {
Show 15 fields device: Box<dyn VirtioDevice>, device_activated: bool, interrupt: Option<Interrupt>, interrupt_evt: Option<IrqEdgeEvent>, async_intr_status: bool, queues: Vec<QueueConfig>, queue_evts: Vec<Event>, mem: GuestMemory, device_feature_select: u32, driver_feature_select: u32, queue_select: u16, driver_status: u8, mmio_base: u64, irq_num: u32, config_generation: u32,
}
Expand description

Implements the MMIO transport for virtio devices.

Fields§

§device: Box<dyn VirtioDevice>§device_activated: bool§interrupt: Option<Interrupt>§interrupt_evt: Option<IrqEdgeEvent>§async_intr_status: bool§queues: Vec<QueueConfig>§queue_evts: Vec<Event>§mem: GuestMemory§device_feature_select: u32§driver_feature_select: u32§queue_select: u16§driver_status: u8§mmio_base: u64§irq_num: u32§config_generation: u32

Implementations§

source§

impl VirtioMmioDevice

source

pub fn new( mem: GuestMemory, device: Box<dyn VirtioDevice>, async_intr_status: bool ) -> Result<Self>

Constructs a new MMIO transport for the given virtio device.

source

pub fn ioevents(&self) -> Vec<(&Event, u64, Datamatch)>

source

fn is_driver_ready(&self) -> bool

source

fn is_reset_requested(&self) -> bool

Determines if the driver has requested the device reset itself

source

fn device_type(&self) -> u32

source

fn activate(&mut self) -> Result<()>

Activates the underlying VirtioDevice. assign_irq has to be called first.

source

fn read_mmio(&self, info: BusAccessInfo, data: &mut [u8])

source

fn write_mmio(&mut self, info: BusAccessInfo, data: &[u8])

source

fn with_queue<U, F>(&self, f: F) -> Option<U>where F: FnOnce(&QueueConfig) -> U,

source

fn with_queue_mut<F>(&mut self, f: F)where F: FnOnce(&mut QueueConfig),

source

pub fn allocate_regions( &mut self, resources: &mut SystemAllocator ) -> Result<Vec<(u64, u64)>, Error>

source

pub fn assign_irq(&mut self, irq_evt: &IrqEdgeEvent, irq_num: u32)

source

pub fn keep_rds(&self) -> Vec<RawDescriptor>

source

fn on_device_sandboxed(&mut self)

source

pub fn generate_acpi(&mut self, sdts: Vec<SDT>) -> Option<Vec<SDT>>

Trait Implementations§

source§

impl Aml for VirtioMmioDevice

source§

fn to_aml_bytes(&self, bytes: &mut Vec<u8>)

Translate an ACPI object into AML code and append to the vector buffer. Read more
source§

impl BusDevice for VirtioMmioDevice

source§

fn debug_label(&self) -> String

Returns a label suitable for debug output.
source§

fn device_id(&self) -> DeviceId

Returns a unique id per device type suitable for metrics gathering.
source§

fn read(&mut self, info: BusAccessInfo, data: &mut [u8])

Reads at offset from this device
source§

fn write(&mut self, info: BusAccessInfo, data: &[u8])

Writes at offset into this device
source§

fn on_sandboxed(&mut self)

Invoked when the device is sandboxed.
source§

fn config_register_write( &mut self, reg_idx: usize, offset: u64, data: &[u8] ) -> ConfigWriteResult

Sets a register in the configuration space. Only used by PCI. Read more
source§

fn config_register_read(&self, reg_idx: usize) -> u32

Gets a register from the configuration space. Only used by PCI. Read more
source§

fn init_pci_config_mapping( &mut self, shmem: &SharedMemory, base: usize, len: usize ) -> bool

Provides a memory region to back MMIO access to the configuration space. If the device can keep the memory region up to date, then it should return true, after which no more calls to config_register_read will be made. Otherwise the device should return false. Read more
source§

fn virtual_config_register_write(&mut self, reg_idx: usize, value: u32)

Sets a register in the virtual config space. Only used by PCI. Read more
source§

fn virtual_config_register_read(&self, reg_idx: usize) -> u32

Gets a register from the virtual config space. Only used by PCI. Read more
source§

fn get_ranges(&self) -> Vec<(BusRange, BusType)>

Gets a list of all ranges registered by this BusDevice.
source§

fn destroy_device(&mut self)

Invoked when the device is destroyed
source§

fn is_bridge(&self) -> Option<u8>

Returns the secondary bus number if this bus device is pci bridge
source§

impl BusDeviceObj for VirtioMmioDevice

source§

impl Suspendable for VirtioMmioDevice

source§

fn snapshot(&mut self) -> Result<Value>

Save the device state in an image that can be restored.
source§

fn restore(&mut self, _data: Value) -> Result<()>

Load a saved snapshot of an image.
source§

fn sleep(&mut self) -> Result<()>

Stop all threads related to the device. Sleep should be idempotent.
source§

fn wake(&mut self) -> Result<()>

Create/Resume all threads related to the device. Wake should be idempotent.

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> Downcast for Twhere T: Any,

§

fn into_any(self: Box<T, Global>) -> Box<dyn Any, Global>

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, Global>) -> Rc<dyn Any, Global>

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)

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)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for Twhere V: MultiLane<T>,

§

fn vzip(self) -> V