mirror of
https://github.com/kata-containers/kata-containers.git
synced 2025-10-24 05:31:31 +00:00
dragonball: update dbs-boot to v0.4.0
dbs-boot-v0.4.0 refectors the create_fdt interface. It simplifies the parameters needed to be passed and abstracts them into three structs. By the way, it also reserves some interfaces for future feature: numa passthrough and cache passthrough. Fixes: #6969 Signed-off-by: xuejun-xj <jiyunxue@linux.alibaba.com>
This commit is contained in:
4
src/dragonball/Cargo.lock
generated
4
src/dragonball/Cargo.lock
generated
@@ -247,9 +247,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "dbs-boot"
|
name = "dbs-boot"
|
||||||
version = "0.3.1"
|
version = "0.4.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "1a74a8c05a1674d3032e610b4f201c7440c345559bad3dfe6b455ce195785108"
|
checksum = "5466a92f75aa928a9103dcb2088f6d1638ef9da8945fad7389a73864dfa0182c"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"dbs-arch",
|
"dbs-arch",
|
||||||
"kvm-bindings",
|
"kvm-bindings",
|
||||||
|
@@ -15,7 +15,7 @@ bytes = "1.1.0"
|
|||||||
dbs-address-space = "0.2.0"
|
dbs-address-space = "0.2.0"
|
||||||
dbs-allocator = "0.1.0"
|
dbs-allocator = "0.1.0"
|
||||||
dbs-arch = "0.2.0"
|
dbs-arch = "0.2.0"
|
||||||
dbs-boot = "0.3.0"
|
dbs-boot = "0.4.0"
|
||||||
dbs-device = "0.2.0"
|
dbs-device = "0.2.0"
|
||||||
dbs-interrupt = { version = "0.2.0", features = ["kvm-irq"] }
|
dbs-interrupt = { version = "0.2.0", features = ["kvm-irq"] }
|
||||||
dbs-legacy-devices = "0.1.0"
|
dbs-legacy-devices = "0.1.0"
|
||||||
|
@@ -6,65 +6,30 @@
|
|||||||
// Use of this source code is governed by a BSD-style license that can be
|
// Use of this source code is governed by a BSD-style license that can be
|
||||||
// found in the THIRD-PARTY file.
|
// found in the THIRD-PARTY file.
|
||||||
|
|
||||||
use std::collections::HashMap;
|
|
||||||
use std::fmt::Debug;
|
|
||||||
use std::ops::Deref;
|
use std::ops::Deref;
|
||||||
|
use std::sync::MutexGuard;
|
||||||
|
|
||||||
use dbs_arch::gic::GICDevice;
|
use dbs_arch::gic::GICDevice;
|
||||||
use dbs_arch::pmu::initialize_pmu;
|
use dbs_arch::pmu::initialize_pmu;
|
||||||
use dbs_arch::{DeviceInfoForFDT, DeviceType, VpmuFeatureLevel};
|
use dbs_arch::{MMIODeviceInfo, VpmuFeatureLevel};
|
||||||
|
use dbs_boot::fdt_utils::*;
|
||||||
use dbs_boot::InitrdConfig;
|
use dbs_boot::InitrdConfig;
|
||||||
use dbs_utils::epoll_manager::EpollManager;
|
use dbs_utils::epoll_manager::EpollManager;
|
||||||
use dbs_utils::time::TimestampUs;
|
use dbs_utils::time::TimestampUs;
|
||||||
use linux_loader::loader::Cmdline;
|
use linux_loader::cmdline::{Cmdline, Error as CmdlineError};
|
||||||
use vm_memory::{GuestAddressSpace, GuestMemory};
|
use vm_memory::GuestAddressSpace;
|
||||||
use vmm_sys_util::eventfd::EventFd;
|
use vmm_sys_util::eventfd::EventFd;
|
||||||
|
|
||||||
use super::{Vm, VmError};
|
use super::{Vm, VmError};
|
||||||
use crate::address_space_manager::{GuestAddressSpaceImpl, GuestMemoryImpl};
|
use crate::address_space_manager::{GuestAddressSpaceImpl, GuestMemoryImpl};
|
||||||
use crate::error::{Error, StartMicroVmError};
|
use crate::error::{Error, StartMicroVmError};
|
||||||
use crate::event_manager::EventManager;
|
use crate::event_manager::EventManager;
|
||||||
|
use crate::vcpu::VcpuManager;
|
||||||
|
|
||||||
/// Configures the system and should be called once per vm before starting vcpu threads.
|
|
||||||
/// For aarch64, we only setup the FDT.
|
|
||||||
///
|
|
||||||
/// # Arguments
|
|
||||||
///
|
|
||||||
/// * `guest_mem` - The memory to be used by the guest.
|
|
||||||
/// * `cmdline` - The kernel commandline.
|
|
||||||
/// * `vcpu_mpidr` - Array of MPIDR register values per vcpu.
|
|
||||||
/// * `device_info` - A hashmap containing the attached devices for building FDT device nodes.
|
|
||||||
/// * `gic_device` - The GIC device.
|
|
||||||
/// * `initrd` - Information about an optional initrd.
|
|
||||||
#[allow(clippy::borrowed_box)]
|
|
||||||
fn configure_system<T: DeviceInfoForFDT + Clone + Debug, M: GuestMemory>(
|
|
||||||
guest_mem: &M,
|
|
||||||
cmdline: &str,
|
|
||||||
vcpu_mpidr: Vec<u64>,
|
|
||||||
device_info: Option<&HashMap<(DeviceType, String), T>>,
|
|
||||||
gic_device: &Box<dyn GICDevice>,
|
|
||||||
initrd: &Option<super::InitrdConfig>,
|
|
||||||
vpmu_feature: &VpmuFeatureLevel,
|
|
||||||
) -> super::Result<()> {
|
|
||||||
dbs_boot::fdt::create_fdt(
|
|
||||||
guest_mem,
|
|
||||||
vcpu_mpidr,
|
|
||||||
cmdline,
|
|
||||||
device_info,
|
|
||||||
gic_device,
|
|
||||||
initrd,
|
|
||||||
vpmu_feature,
|
|
||||||
)
|
|
||||||
.map_err(Error::BootSystem)?;
|
|
||||||
Ok(())
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(target_arch = "aarch64")]
|
|
||||||
impl Vm {
|
impl Vm {
|
||||||
/// Gets a reference to the irqchip of the VM
|
/// Gets a reference to the irqchip of the VM
|
||||||
#[allow(clippy::borrowed_box)]
|
pub fn get_irqchip(&self) -> &dyn GICDevice {
|
||||||
pub fn get_irqchip(&self) -> &Box<dyn GICDevice> {
|
self.irqchip_handle.as_ref().unwrap().as_ref()
|
||||||
self.irqchip_handle.as_ref().unwrap()
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Creates the irq chip in-kernel device model.
|
/// Creates the irq chip in-kernel device model.
|
||||||
@@ -138,6 +103,50 @@ impl Vm {
|
|||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Generate fdt information about VM.
|
||||||
|
fn get_fdt_vm_info<'a>(
|
||||||
|
&'a self,
|
||||||
|
vm_memory: &'a GuestMemoryImpl,
|
||||||
|
cmdline: &'a str,
|
||||||
|
initrd_config: Option<&'a InitrdConfig>,
|
||||||
|
vcpu_manager: &'a MutexGuard<VcpuManager>,
|
||||||
|
) -> FdtVmInfo {
|
||||||
|
let guest_memory = vm_memory.memory();
|
||||||
|
let vcpu_mpidr = vcpu_manager
|
||||||
|
.vcpus()
|
||||||
|
.into_iter()
|
||||||
|
.map(|cpu| cpu.get_mpidr())
|
||||||
|
.collect();
|
||||||
|
let vcpu_boot_onlined = vec![];
|
||||||
|
let vpmu_feature = vcpu_manager.vpmu_feature();
|
||||||
|
// This configuration is used for passing cache information into guest.
|
||||||
|
// TODO: dragonball-sandbox #274; kata-containers #6969
|
||||||
|
let cache_passthrough_enabled = false;
|
||||||
|
let fdt_vcpu_info = FdtVcpuInfo::new(
|
||||||
|
vcpu_mpidr,
|
||||||
|
vcpu_boot_onlined,
|
||||||
|
vpmu_feature,
|
||||||
|
cache_passthrough_enabled,
|
||||||
|
);
|
||||||
|
|
||||||
|
FdtVmInfo::new(guest_memory, cmdline, initrd_config, fdt_vcpu_info)
|
||||||
|
}
|
||||||
|
|
||||||
|
// This method is used for passing cache/numa information into guest
|
||||||
|
// TODO: dragonball-sandbox #274,#275; kata-containers #6969
|
||||||
|
/// Generate fdt information about cache/numa
|
||||||
|
fn get_fdt_numa_info(&self) -> FdtNumaInfo {
|
||||||
|
FdtNumaInfo::default()
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Generate fdt information about devices
|
||||||
|
fn get_fdt_device_info(&self) -> FdtDeviceInfo<MMIODeviceInfo> {
|
||||||
|
FdtDeviceInfo::new(
|
||||||
|
self.device_manager().get_mmio_device_info(),
|
||||||
|
self.get_irqchip(),
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
/// Execute system architecture specific configurations.
|
/// Execute system architecture specific configurations.
|
||||||
///
|
///
|
||||||
/// 1) set guest kernel boot parameters
|
/// 1) set guest kernel boot parameters
|
||||||
@@ -149,24 +158,23 @@ impl Vm {
|
|||||||
initrd: Option<InitrdConfig>,
|
initrd: Option<InitrdConfig>,
|
||||||
) -> std::result::Result<(), StartMicroVmError> {
|
) -> std::result::Result<(), StartMicroVmError> {
|
||||||
let vcpu_manager = self.vcpu_manager().map_err(StartMicroVmError::Vcpu)?;
|
let vcpu_manager = self.vcpu_manager().map_err(StartMicroVmError::Vcpu)?;
|
||||||
let vpmu_feature = vcpu_manager.vpmu_feature();
|
let cmdline_cstring = cmdline
|
||||||
let vcpu_mpidr = vcpu_manager
|
.as_cstring()
|
||||||
.vcpus()
|
.map_err(StartMicroVmError::ProcessCommandlne)?;
|
||||||
.into_iter()
|
let fdt_vm_info = self.get_fdt_vm_info(
|
||||||
.map(|cpu| cpu.get_mpidr())
|
vm_memory,
|
||||||
.collect();
|
cmdline_cstring
|
||||||
let guest_memory = vm_memory.memory();
|
.to_str()
|
||||||
|
.map_err(|_| StartMicroVmError::ProcessCommandlne(CmdlineError::InvalidAscii))?,
|
||||||
|
initrd.as_ref(),
|
||||||
|
&vcpu_manager,
|
||||||
|
);
|
||||||
|
let fdt_numa_info = self.get_fdt_numa_info();
|
||||||
|
let fdt_device_info = self.get_fdt_device_info();
|
||||||
|
|
||||||
configure_system(
|
dbs_boot::fdt::create_fdt(fdt_vm_info, fdt_numa_info, fdt_device_info)
|
||||||
guest_memory,
|
.map(|_| ())
|
||||||
cmdline.as_cstring().unwrap().to_str().unwrap(),
|
.map_err(|e| StartMicroVmError::ConfigureSystem(Error::BootSystem(e)))
|
||||||
vcpu_mpidr,
|
|
||||||
self.device_manager.get_mmio_device_info(),
|
|
||||||
self.get_irqchip(),
|
|
||||||
&initrd,
|
|
||||||
&vpmu_feature,
|
|
||||||
)
|
|
||||||
.map_err(StartMicroVmError::ConfigureSystem)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn register_events(
|
pub(crate) fn register_events(
|
||||||
|
Reference in New Issue
Block a user