mirror of
https://github.com/cloud-hypervisor/cloud-hypervisor.git
synced 2025-01-18 10:35:23 +00:00
virtio-devices: pci_device: Split out device activation
This can then be used to activate the device from a separate thread. Signed-off-by: Rob Bradford <robert.bradford@intel.com>
This commit is contained in:
parent
7cc729c7d9
commit
dee42ebb29
@ -641,6 +641,30 @@ impl VirtioPciDevice {
|
|||||||
pub fn virtio_device(&self) -> Arc<Mutex<dyn VirtioDevice>> {
|
pub fn virtio_device(&self) -> Arc<Mutex<dyn VirtioDevice>> {
|
||||||
self.device.clone()
|
self.device.clone()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn maybe_activate(&mut self) {
|
||||||
|
if self.needs_activation() {
|
||||||
|
if let Some(virtio_interrupt) = self.virtio_interrupt.take() {
|
||||||
|
if self.memory.is_some() {
|
||||||
|
let mem = self.memory.as_ref().unwrap().clone();
|
||||||
|
let mut device = self.device.lock().unwrap();
|
||||||
|
device
|
||||||
|
.activate(
|
||||||
|
mem,
|
||||||
|
virtio_interrupt,
|
||||||
|
self.queues.clone(),
|
||||||
|
self.queue_evts.split_off(0),
|
||||||
|
)
|
||||||
|
.expect("Failed to activate device");
|
||||||
|
self.device_activated = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn needs_activation(&self) -> bool {
|
||||||
|
!self.device_activated && self.is_driver_ready() && self.are_queues_valid()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl VirtioTransport for VirtioPciDevice {
|
impl VirtioTransport for VirtioPciDevice {
|
||||||
@ -976,23 +1000,8 @@ impl PciDevice for VirtioPciDevice {
|
|||||||
_ => (),
|
_ => (),
|
||||||
};
|
};
|
||||||
|
|
||||||
if !self.device_activated && self.is_driver_ready() && self.are_queues_valid() {
|
// Try and activate the device if the driver status has changed
|
||||||
if let Some(virtio_interrupt) = self.virtio_interrupt.take() {
|
self.maybe_activate();
|
||||||
if self.memory.is_some() {
|
|
||||||
let mem = self.memory.as_ref().unwrap().clone();
|
|
||||||
let mut device = self.device.lock().unwrap();
|
|
||||||
device
|
|
||||||
.activate(
|
|
||||||
mem,
|
|
||||||
virtio_interrupt,
|
|
||||||
self.queues.clone(),
|
|
||||||
self.queue_evts.split_off(0),
|
|
||||||
)
|
|
||||||
.expect("Failed to activate device");
|
|
||||||
self.device_activated = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Device has been reset by the driver
|
// Device has been reset by the driver
|
||||||
if self.device_activated && self.is_driver_init() {
|
if self.device_activated && self.is_driver_init() {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user