pub struct PluginVcpu {
    shared_vcpu_state: Arc<RwLock<SharedVcpuState>>,
    per_vcpu_state: Arc<Mutex<PerVcpuState>>,
    read_pipe: File,
    write_pipe: File,
    wait_reason: Cell<Option<Wait>>,
    request_buffer: RefCell<Vec<u8>>,
    response_buffer: RefCell<Vec<u8>>,
}
Expand description

State object for a VCPU’s connection with the plugin process.

This is used by a VCPU thread to allow the plugin process to handle vmexits. Each method may block indefinitely while the plugin process is handling requests. In order to cleanly shutdown during these blocking calls, the connection socket should be shutdown. This will end the blocking calls,

Fields§

§shared_vcpu_state: Arc<RwLock<SharedVcpuState>>§per_vcpu_state: Arc<Mutex<PerVcpuState>>§read_pipe: File§write_pipe: File§wait_reason: Cell<Option<Wait>>§request_buffer: RefCell<Vec<u8>>§response_buffer: RefCell<Vec<u8>>

Implementations§

source§

impl PluginVcpu

source

pub fn new( shared_vcpu_state: Arc<RwLock<SharedVcpuState>>, per_vcpu_state: Arc<Mutex<PerVcpuState>>, read_pipe: File, write_pipe: File ) -> PluginVcpu

Creates the plugin state and connection container for a VCPU thread.

source

pub fn init(&self, vcpu: &Vcpu) -> SysResult<()>

Tells the plugin process to initialize this VCPU.

This should be called for each VCPU before the first run of any of the VCPUs in the VM.

source

pub fn pre_run(&self, vcpu: &Vcpu) -> SysResult<()>

The VCPU thread should call this before rerunning a VM in order to handle pending requests to this VCPU.

source

fn process( &self, io_space: IoSpace, addr: u64, data: VcpuRunData<'_>, vcpu: &Vcpu ) -> bool

source

pub fn io_read(&self, addr: u64, data: &mut [u8], vcpu: &Vcpu) -> bool

Has the plugin process handle a IO port read.

source

pub fn io_write(&self, addr: u64, data: &[u8], vcpu: &Vcpu) -> bool

Has the plugin process handle a IO port write.

source

pub fn mmio_read(&self, addr: u64, data: &mut [u8], vcpu: &Vcpu) -> bool

Has the plugin process handle a MMIO read.

source

pub fn mmio_write(&self, addr: u64, data: &[u8], vcpu: &Vcpu) -> bool

Has the plugin process handle a MMIO write.

source

pub fn hyperv_call( &self, input: u64, params: [u64; 2], data: &mut [u8], vcpu: &Vcpu ) -> bool

Has the plugin process handle a hyper-v call.

source

pub fn hyperv_synic( &self, msr: u32, control: u64, evt_page: u64, msg_page: u64, vcpu: &Vcpu ) -> bool

Has the plugin process handle a synic config change.

source

fn handle_request(&self, vcpu: &Vcpu) -> SysResult<Option<Vec<u8>>>

source

fn handle_until_resume(&self, vcpu: &Vcpu) -> SysResult<Vec<u8>>

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