From ec26bf5125276423eb03ab128850021d9dd4d566 Mon Sep 17 00:00:00 2001 From: Tamir Duberstein Date: Thu, 9 Nov 2023 21:29:05 +0000 Subject: [PATCH] xtask: attempt to open /dev/kvm We're seeing test failures where KVM is present but we aren't able to use it. See https://github.com/actions/runner-images/issues/7670#issuecomment-1760184162. --- xtask/src/run.rs | 33 +++++++++++++++++++-------------- 1 file changed, 19 insertions(+), 14 deletions(-) diff --git a/xtask/src/run.rs b/xtask/src/run.rs index 641146209..c5e1da15a 100644 --- a/xtask/src/run.rs +++ b/xtask/src/run.rs @@ -2,7 +2,7 @@ use std::{ env::consts::{ARCH, OS}, ffi::OsString, fmt::Write as _, - fs::{copy, create_dir_all, metadata, File}, + fs::{copy, create_dir_all, OpenOptions}, io::{BufRead as _, BufReader, ErrorKind, Write as _}, path::{Path, PathBuf}, process::{Child, ChildStdin, Command, Output, Stdio}, @@ -284,9 +284,12 @@ pub fn run(opts: Options) -> Result<()> { let tmp_dir = tempfile::tempdir().context("tempdir failed")?; let initrd_image = tmp_dir.path().join("qemu-initramfs.img"); - let initrd_image_file = File::create(&initrd_image).with_context(|| { - format!("failed to create {} for writing", initrd_image.display()) - })?; + let initrd_image_file = OpenOptions::new() + .create(true) + .open(&initrd_image) + .with_context(|| { + format!("failed to create {} for writing", initrd_image.display()) + })?; let mut gen_init_cpio = Command::new(&gen_init_cpio); let mut gen_init_cpio_child = gen_init_cpio @@ -351,19 +354,21 @@ pub fn run(opts: Options) -> Result<()> { } if guest_arch == ARCH { match OS { - "linux" => match metadata("/dev/kvm") { - Ok(metadata) => { - use std::os::unix::fs::FileTypeExt as _; - if metadata.file_type().is_char_device() { + "linux" => { + const KVM: &str = "/dev/kvm"; + match OpenOptions::new().read(true).write(true).open(KVM) { + Ok(_file) => { qemu.args(["-accel", "kvm"]); } + Err(error) => match error.kind() { + ErrorKind::NotFound | ErrorKind::PermissionDenied => {} + _kind => { + return Err(error) + .with_context(|| format!("failed to open {KVM}")); + } + }, } - Err(error) => { - if error.kind() != ErrorKind::NotFound { - Err(error).context("failed to check existence of /dev/kvm")?; - } - } - }, + } "macos" => { qemu.args(["-accel", "hvf"]); }