From ec248edfcfd4713a010135f0fa1f851951fd3077 Mon Sep 17 00:00:00 2001 From: Ludvig Liljenberg Date: Thu, 17 Apr 2025 09:57:40 -0700 Subject: [PATCH 1/2] Removes the word 'Error' from non-error log messages when checking if specific hypervisors exist. This caused confusion if both kvm and mshv cargo features were enabled Signed-off-by: Ludvig Liljenberg --- src/hyperlight_host/src/hypervisor/hyperv_linux.rs | 4 ++-- src/hyperlight_host/src/hypervisor/kvm.rs | 2 +- .../src/hypervisor/windows_hypervisor_platform.rs | 5 ++++- src/tests/rust_guests/callbackguest/Cargo.lock | 4 ++-- src/tests/rust_guests/simpleguest/Cargo.lock | 4 ++-- 5 files changed, 11 insertions(+), 8 deletions(-) diff --git a/src/hyperlight_host/src/hypervisor/hyperv_linux.rs b/src/hyperlight_host/src/hypervisor/hyperv_linux.rs index 6e1e8ec6d..514cbf19e 100644 --- a/src/hyperlight_host/src/hypervisor/hyperv_linux.rs +++ b/src/hyperlight_host/src/hypervisor/hyperv_linux.rs @@ -278,8 +278,8 @@ pub(crate) fn is_hypervisor_present() -> bool { } // must explicitly close fd to avoid a leak true } - Err(e) => { - log::info!("Error creating MSHV object: {:?}", e); + Err(_) => { + log::info!("MSHV is not available on this system"); false } } diff --git a/src/hyperlight_host/src/hypervisor/kvm.rs b/src/hyperlight_host/src/hypervisor/kvm.rs index e106755c5..967555ffc 100644 --- a/src/hyperlight_host/src/hypervisor/kvm.rs +++ b/src/hyperlight_host/src/hypervisor/kvm.rs @@ -59,7 +59,7 @@ pub(crate) fn is_hypervisor_present() -> bool { } } } else { - log::info!("Error creating KVM object"); + log::info!("KVM is not available on this system"); false } } diff --git a/src/hyperlight_host/src/hypervisor/windows_hypervisor_platform.rs b/src/hyperlight_host/src/hypervisor/windows_hypervisor_platform.rs index 810c6da77..47e200d38 100644 --- a/src/hyperlight_host/src/hypervisor/windows_hypervisor_platform.rs +++ b/src/hyperlight_host/src/hypervisor/windows_hypervisor_platform.rs @@ -53,7 +53,10 @@ pub(crate) fn is_hypervisor_present() -> bool { ) } { Ok(_) => unsafe { capability.HypervisorPresent.as_bool() }, - Err(_) => false, + Err(_) => { + log::info!("Windows Hypervisor Platform is not available on this system"); + false + } } } diff --git a/src/tests/rust_guests/callbackguest/Cargo.lock b/src/tests/rust_guests/callbackguest/Cargo.lock index 45c7e59af..e65396646 100644 --- a/src/tests/rust_guests/callbackguest/Cargo.lock +++ b/src/tests/rust_guests/callbackguest/Cargo.lock @@ -4,9 +4,9 @@ version = 3 [[package]] name = "anyhow" -version = "1.0.97" +version = "1.0.98" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dcfed56ad506cb2c684a14971b8861fdc3baaaae314b9e5f9bb532cbe3ba7a4f" +checksum = "e16d2d3311acee920a9eb8d33b8cbc1787ce4a264e85f964c2404b969bdcd487" [[package]] name = "autocfg" diff --git a/src/tests/rust_guests/simpleguest/Cargo.lock b/src/tests/rust_guests/simpleguest/Cargo.lock index 7a0077535..9d1d1c7eb 100644 --- a/src/tests/rust_guests/simpleguest/Cargo.lock +++ b/src/tests/rust_guests/simpleguest/Cargo.lock @@ -4,9 +4,9 @@ version = 3 [[package]] name = "anyhow" -version = "1.0.97" +version = "1.0.98" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dcfed56ad506cb2c684a14971b8861fdc3baaaae314b9e5f9bb532cbe3ba7a4f" +checksum = "e16d2d3311acee920a9eb8d33b8cbc1787ce4a264e85f964c2404b969bdcd487" [[package]] name = "autocfg" From 010b2867907e962ed677395cff9c1ae0e45de727 Mon Sep 17 00:00:00 2001 From: Ludvig Liljenberg Date: Thu, 17 Apr 2025 09:58:54 -0700 Subject: [PATCH 2/2] Use Mshv::new() instead of Mshv::open_with_cloexec() to avoid manually needing to close fd Signed-off-by: Ludvig Liljenberg --- src/hyperlight_host/src/hypervisor/hyperv_linux.rs | 9 ++------- 1 file changed, 2 insertions(+), 7 deletions(-) diff --git a/src/hyperlight_host/src/hypervisor/hyperv_linux.rs b/src/hyperlight_host/src/hypervisor/hyperv_linux.rs index 514cbf19e..8419cb073 100644 --- a/src/hyperlight_host/src/hypervisor/hyperv_linux.rs +++ b/src/hyperlight_host/src/hypervisor/hyperv_linux.rs @@ -271,13 +271,8 @@ mod debug { /// and functional. #[instrument(skip_all, parent = Span::current(), level = "Trace")] pub(crate) fn is_hypervisor_present() -> bool { - match Mshv::open_with_cloexec(true) { - Ok(fd) => { - unsafe { - libc::close(fd); - } // must explicitly close fd to avoid a leak - true - } + match Mshv::new() { + Ok(_) => true, Err(_) => { log::info!("MSHV is not available on this system"); false