Skip to content

Commit

Permalink
Add support for starting VMs with passt network
Browse files Browse the repository at this point in the history
This required adding another field to the config. This is done by
migrating the old config to a newer version.
We are backwards compatible on configuration but not forwards compatible
(older versions of krunvm will not be able to use the config from
this version)
If we want forward compatibility, I feel like we need to ditch the confy
crate.

Signed-off-by: Matej Hrica <[email protected]>
  • Loading branch information
mtjhrc committed Nov 8, 2023
1 parent 90a8299 commit 5e610e0
Show file tree
Hide file tree
Showing 15 changed files with 497 additions and 58 deletions.
58 changes: 56 additions & 2 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -16,3 +16,4 @@ serde = "1.0.120"
serde_derive = "1.0.120"
text_io = "0.1.8"
nix = {version = "0.27.1", features = ["socket", "fs"]}
rand="0.8.5"
1 change: 1 addition & 0 deletions src/bindings.rs
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ extern "C" {
pub fn krun_set_mapped_volumes(ctx: u32, mapped_volumes: *const *const c_char) -> i32;
pub fn krun_set_port_map(ctx: u32, port_map: *const *const c_char) -> i32;
pub fn krun_set_workdir(ctx: u32, workdir_path: *const c_char) -> i32;
pub fn krun_set_passt_fd(ctx: u32, fd: c_int) -> i32;
pub fn krun_set_exec(
ctx: u32,
exec_path: *const c_char,
Expand Down
14 changes: 11 additions & 3 deletions src/commands/changevm.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,12 +4,12 @@
use clap::Args;
use std::collections::HashMap;

use crate::config::{KrunvmConfig, NetworkMode};
use crate::utils::{path_pairs_to_hash_map, port_pairs_to_hash_map, PathPair, PortPair};
use crate::{KrunvmConfig, APP_NAME};

use super::list::printvm;

/// Change the configuration of a microVM
/// Change the config of a microVM
#[derive(Args, Debug)]
pub struct ChangeVmCmd {
/// Name of the VM to be modified
Expand Down Expand Up @@ -46,6 +46,9 @@ pub struct ChangeVmCmd {
/// Port(s) in format "host_port:guest_port" to be exposed to the host
#[arg(long = "port")]
ports: Vec<PortPair>,

#[arg(long)]
network_mode: Option<NetworkMode>,
}

impl ChangeVmCmd {
Expand Down Expand Up @@ -130,12 +133,17 @@ impl ChangeVmCmd {
cfg_changed = true;
}

if let Some(network_mode) = self.network_mode {
vmcfg.network_mode = network_mode;
cfg_changed = true;
}

println!();
printvm(vmcfg);
println!();

if cfg_changed {
confy::store(APP_NAME, &cfg).unwrap();
crate::config::save(cfg).unwrap();
}
}
}
17 changes: 14 additions & 3 deletions src/commands/config.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
// Copyright 2021 Red Hat, Inc.
// SPDX-License-Identifier: Apache-2.0

use crate::{KrunvmConfig, APP_NAME};
use crate::config::{KrunvmConfig, NetworkMode};
use clap::Args;

/// Configure global values
Expand All @@ -18,6 +18,10 @@ pub struct ConfigCmd {
/// DNS server to use in the microVM
#[arg(long)]
dns: Option<String>,

/// Default network mode to use
#[arg(long)]
network_mode: Option<NetworkMode>,
}

impl ConfigCmd {
Expand Down Expand Up @@ -47,11 +51,18 @@ impl ConfigCmd {
cfg_changed = true;
}

if let Some(network_mode) = self.network_mode {
if network_mode != cfg.default_network_mode {
cfg.default_network_mode = network_mode;
cfg_changed = true;
}
}

if cfg_changed {
confy::store(APP_NAME, &cfg).unwrap();
crate::config::save(cfg).unwrap();
}

println!("Global configuration:");
println!("Global config:");
println!(
"Default number of CPUs for newly created VMs: {}",
cfg.default_cpus
Expand Down
12 changes: 10 additions & 2 deletions src/commands/create.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
// Copyright 2021 Red Hat, Inc.
// SPDX-License-Identifier: Apache-2.0

use crate::config::{KrunvmConfig, NetworkMode, VmConfig};
use crate::APP_NAME;
use clap::Args;
use std::fs;
use std::io::Write;
Expand All @@ -12,8 +14,6 @@ use crate::utils::{
get_buildah_args, mount_container, path_pairs_to_hash_map, port_pairs_to_hash_map,
umount_container, BuildahCommand, PathPair, PortPair,
};
use crate::{KrunvmConfig, VmConfig, APP_NAME};

#[cfg(target_os = "macos")]
const KRUNVM_ROSETTA_FILE: &str = ".krunvm-rosetta";

Expand Down Expand Up @@ -51,6 +51,10 @@ pub struct CreateCmd {
#[arg(long = "port")]
ports: Vec<PortPair>,

/// Network mode to use
#[arg(long)]
network_mode: Option<NetworkMode>,

/// Create a x86_64 microVM even on an Aarch64 host
#[arg(short, long)]
#[cfg(target_os = "macos")]
Expand All @@ -68,6 +72,9 @@ impl CreateCmd {
let mapped_ports = port_pairs_to_hash_map(self.ports);
let image = self.image;
let name = self.name;
let network_mode = self
.network_mode
.unwrap_or_else(|| cfg.default_network_mode.clone());

if let Some(ref name) = name {
if cfg.vmconfig_map.contains_key(name) {
Expand Down Expand Up @@ -160,6 +167,7 @@ https://threedots.ovh/blog/2022/06/quick-look-at-rosetta-on-linux/
workdir: workdir.to_string(),
mapped_volumes,
mapped_ports,
network_mode,
};

let rootfs = mount_container(cfg, &vmcfg).unwrap();
Expand Down
5 changes: 3 additions & 2 deletions src/commands/delete.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
// Copyright 2021 Red Hat, Inc.
// SPDX-License-Identifier: Apache-2.0

use crate::{KrunvmConfig, APP_NAME};
use crate::config;
use crate::config::KrunvmConfig;
use clap::Args;

use crate::utils::{remove_container, umount_container};
Expand All @@ -26,6 +27,6 @@ impl DeleteCmd {
umount_container(cfg, &vmcfg).unwrap();
remove_container(cfg, &vmcfg).unwrap();

confy::store(APP_NAME, &cfg).unwrap();
config::save(cfg).unwrap()
}
}
3 changes: 2 additions & 1 deletion src/commands/list.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
// Copyright 2021 Red Hat, Inc.
// SPDX-License-Identifier: Apache-2.0

use crate::{KrunvmConfig, VmConfig};
use crate::config::{KrunvmConfig, VmConfig};
use clap::Args;

/// List microVMs
Expand Down Expand Up @@ -33,6 +33,7 @@ pub fn printvm(vm: &VmConfig) {
println!(" DNS server: {}", vm.dns);
println!(" Buildah container: {}", vm.container);
println!(" Workdir: {}", vm.workdir);
println!(" Network mode: {:?}", vm.network_mode);
println!(" Mapped volumes: {:?}", vm.mapped_volumes);
println!(" Mapped ports: {:?}", vm.mapped_ports);
}
Loading

0 comments on commit 5e610e0

Please sign in to comment.