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:
Rob Bradford 2020-11-09 12:51:45 +00:00
parent 7cc729c7d9
commit dee42ebb29

View File

@ -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() {