pub struct VfioPlatformDevice {
    device: Arc<VfioDevice>,
    interrupt_edge_evt: Vec<IrqEdgeEvent>,
    interrupt_level_evt: Vec<IrqLevelEvent>,
    mmio_regions: Vec<MmioInfo>,
    vm_memory_client: VmMemoryClient,
    mem: Vec<MemoryMapping>,
}

Fields§

§device: Arc<VfioDevice>§interrupt_edge_evt: Vec<IrqEdgeEvent>§interrupt_level_evt: Vec<IrqLevelEvent>§mmio_regions: Vec<MmioInfo>§vm_memory_client: VmMemoryClient§mem: Vec<MemoryMapping>

Implementations§

source§

impl VfioPlatformDevice

source

pub fn new(device: VfioDevice, vm_memory_client: VmMemoryClient) -> Self

Constructs a new Vfio Platform device for the given Vfio device

source

pub fn get_platform_irqs(&self) -> Result<Vec<VfioIrq>, VfioError>

source

pub fn irq_is_automask(&self, irq: &VfioIrq) -> bool

source

fn setup_irq_resample(&mut self, resample_evt: &Event, index: u32) -> Result<()>

source

pub fn assign_edge_platform_irq( &mut self, irq_evt: &IrqEdgeEvent, index: u32 ) -> Result<()>

source

pub fn assign_level_platform_irq( &mut self, irq_evt: &IrqLevelEvent, index: u32 ) -> Result<()>

source

fn find_region(&self, addr: u64) -> Option<MmioInfo>

source

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

source

fn region_mmap_early(&self, vm: &mut impl Vm, index: usize, start_addr: u64)

source

pub fn regions_mmap_early(&mut self, vm: &mut impl Vm)

Force adding the MMIO regions to the guest memory space.

By default, MMIO regions are mapped lazily when the guest first accesses them. Instead, this function maps them, even if the guest might end up not accessing them. It only runs in the current thread and can therefore be called before the VM is started.

source

fn region_mmap(&self, index: usize, start_addr: u64) -> Vec<MemoryMapping>

source

fn regions_mmap(&mut self)

source

fn disable_irqs(&mut self, index: u32)

source

fn read_mmio(&mut self, addr: u64, data: &mut [u8])

source

fn write_mmio(&mut self, addr: u64, data: &[u8])

source

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

source

pub fn device_file(&self) -> &File

Gets the vfio device backing File.

source

pub fn dt_symbol(&self) -> Option<&str>

Returns the DT symbol (node label) of the VFIO device.

source

pub fn iommu(&self) -> Option<(IommuDevType, Option<u32>, &[u32])>

Returns the type and indentifier (if applicable) of the IOMMU used by this VFIO device and its master IDs.

Trait Implementations§

source§

impl BusDevice for VfioPlatformDevice

source§

fn device_id(&self) -> DeviceId

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

fn debug_label(&self) -> String

Returns a label suitable for debug output.
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 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 on_sandboxed(&mut self)

Invoked when the device is sandboxed.
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 VfioPlatformDevice

source§

impl Suspendable for VfioPlatformDevice

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

impl<T> DowncastSync for Twhere T: Any + Send + Sync,

§

fn into_any_arc(self: Arc<T, Global>) -> Arc<dyn Any + Sync + Send, Global>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
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