pub struct PcieConfig {
    msi_config: Option<Arc<Mutex<MsiConfig>>>,
    slot_control: Option<u16>,
    slot_status: u16,
    root_cap: Arc<Mutex<PcieRootCap>>,
    port_type: PcieDevicePortType,
    hpc_sender: Option<HotPlugCompleteSender>,
    hp_interrupt_pending: bool,
    removed_downstream_valid: bool,
    enabled: bool,
    hot_plug_ready_notifications: Vec<Event>,
    cap_mapping: Option<PciCapMapping>,
}

Fields§

§msi_config: Option<Arc<Mutex<MsiConfig>>>§slot_control: Option<u16>§slot_status: u16§root_cap: Arc<Mutex<PcieRootCap>>§port_type: PcieDevicePortType§hpc_sender: Option<HotPlugCompleteSender>§hp_interrupt_pending: bool§removed_downstream_valid: bool§enabled: bool§hot_plug_ready_notifications: Vec<Event>§cap_mapping: Option<PciCapMapping>

Implementations§

source§

impl PcieConfig

source

fn new( root_cap: Arc<Mutex<PcieRootCap>>, slot_implemented: bool, port_type: PcieDevicePortType ) -> Self

source

fn read_pcie_cap(&self, offset: usize, data: &mut u32)

source

fn is_hotplug_ready(&self) -> bool

source

fn get_ready_notification(&mut self) -> Result<Event, PciDeviceError>

Gets a notification when the port is ready for hotplug. If the port is already ready, then the notification event is triggerred immediately.

source

fn write_pcie_cap(&mut self, offset: usize, data: &[u8])

source

fn get_slot_control(&self) -> u16

source

fn trigger_cc_interrupt(&self)

source

fn trigger_hp_interrupt(&mut self)

source

fn mask_slot_status(&mut self, mask: u16)

source

fn set_slot_status(&mut self, flag: u16)

Trait Implementations§

source§

impl PciCapConfig for PcieConfig

source§

fn read_mask(&self) -> &'static [u32]

Returns the read mask used by read_reg.
source§

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

Reads a 32bit register from the capability. Only the bits set in the read mask will be used, while the rest of the bits will be taken from the PciConfiguration’s register data. reg_idx - index into the capability
source§

fn write_reg( &mut self, reg_idx: usize, offset: u64, data: &[u8] ) -> Option<Box<dyn PciCapConfigWriteResult>>

Writes data to the capability. reg_idx - index into PciConfiguration.registers. offset - PciConfiguration.registers is in unit of DWord, offset define byte offset in the DWord. data - The data to write.
source§

fn set_cap_mapping(&mut self, mapping: PciCapMapping)

Used to pass the mmio region for the capability to the implementation. If any external events update the capability’s registers, then PciCapMapping.set_reg must be called to make the changes visible to the guest.
source§

fn num_regs(&self) -> usize

Auto Trait Implementations§

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

source§

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

Mutably borrows from an owned value. Read more
§

impl<T> Downcast for T
where T: 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>

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 T
where T: Any + Send + Sync,

§

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

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 T
where 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 T
where 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 T
where 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 T
where V: MultiLane<T>,

§

fn vzip(self) -> V