mirror of
https://github.com/cloud-hypervisor/cloud-hypervisor.git
synced 2024-11-09 21:30:07 +00:00
c1f18fa634
HV APIC(i.e., synthetic APIC controller exposed by Microsoft Hypervisor)
does not support one-shot operation using a TSC deadline value. Due to
which we see the following backtrace inside the guest when running with
hypervisor-fw/OVMF:
[ 0.560765] unchecked MSR access error: WRMSR to 0x832 (tried to
write 0x00000000000400ec) at rIP: 0xffffffff8f473594
(native_write_msr+0x4/0x30)
[ 0.560765] Call Trace:
[ 0.560765] ? native_apic_msr_write+0x2b/0x30
[ 0.560765] __setup_APIC_LVTT+0xbc/0xe0
[ 0.560765] lapic_timer_set_oneshot+0x27/0x30
[ 0.560765] clockevents_switch_state+0xaf/0xf0
[ 0.560765] tick_setup_periodic+0x47/0x90
[ 0.560765] tick_setup_device.isra.0+0x7c/0x110
[ 0.560765] tick_check_new_device+0xce/0xf0
[ 0.560765] clockevents_register_device+0x82/0x170
[ 0.560765] clockevents_config_and_register+0x2f/0x40
[ 0.560765] setup_APIC_timer+0xe1/0xf0
[ 0.560765] setup_boot_APIC_clock+0x5f/0x66
[ 0.560765] native_smp_prepare_cpus+0x1d6/0x286
[ 0.560765] kernel_init_freeable+0xcf/0x255
[ 0.560765] ? rest_init+0xb0/0xb0
[ 0.560765] kernel_init+0xe/0x110
[ 0.560765] ret_from_fork+0x22/0x40
Also, if this feature is exposed guest would not finish booting and get
stuck right before unpacking the root filesystem.
Fixes: 06e8d1c40
("hypervisor: mshv: fix topology for Intel HW on MSHV")
Signed-off-by: Jinank Jain <jinankjain@microsoft.com>
87 lines
2.9 KiB
TOML
87 lines
2.9 KiB
TOML
[package]
|
|
authors = ["The Cloud Hypervisor Authors"]
|
|
edition = "2021"
|
|
name = "vmm"
|
|
version = "0.1.0"
|
|
|
|
[features]
|
|
dbus_api = ["blocking", "futures", "zbus"]
|
|
default = []
|
|
dhat-heap = ["dhat"] # For heap profiling
|
|
guest_debug = ["gdbstub", "gdbstub_arch", "kvm"]
|
|
igvm = ["dep:igvm", "hex", "igvm_defs", "mshv-bindings", "range_map_vec"]
|
|
io_uring = ["block/io_uring"]
|
|
kvm = [
|
|
"arch/kvm",
|
|
"hypervisor/kvm",
|
|
"pci/kvm",
|
|
"vfio-ioctls/kvm",
|
|
"vm-device/kvm",
|
|
]
|
|
mshv = ["hypervisor/mshv", "pci/mshv", "vfio-ioctls/mshv", "vm-device/mshv"]
|
|
sev_snp = ["arch/sev_snp", "hypervisor/sev_snp", "virtio-devices/sev_snp"]
|
|
tdx = ["arch/tdx", "hypervisor/tdx"]
|
|
tracing = ["tracer/tracing"]
|
|
|
|
[dependencies]
|
|
acpi_tables = { git = "https://github.com/rust-vmm/acpi_tables", branch = "main" }
|
|
anyhow = "1.0.81"
|
|
arc-swap = "1.7.1"
|
|
arch = { path = "../arch" }
|
|
bitflags = "2.5.0"
|
|
block = { path = "../block" }
|
|
blocking = { version = "1.6.1", optional = true }
|
|
cfg-if = "1.0.0"
|
|
clap = "4.5.4"
|
|
devices = { path = "../devices" }
|
|
dhat = { version = "0.3.3", optional = true }
|
|
epoll = "4.3.3"
|
|
event_monitor = { path = "../event_monitor" }
|
|
flume = "0.11.0"
|
|
futures = { version = "0.3.30", optional = true }
|
|
gdbstub = { version = "0.7.1", optional = true }
|
|
gdbstub_arch = { version = "0.3.0", optional = true }
|
|
hex = { version = "0.4.3", optional = true }
|
|
hypervisor = { path = "../hypervisor" }
|
|
igvm = { version = "0.3.1", optional = true }
|
|
igvm_defs = { version = "0.3.1", optional = true }
|
|
landlock = "0.4.0"
|
|
libc = "0.2.153"
|
|
linux-loader = { version = "0.11.0", features = ["bzimage", "elf", "pe"] }
|
|
log = "0.4.22"
|
|
micro_http = { git = "https://github.com/firecracker-microvm/micro-http", branch = "main" }
|
|
mshv-bindings = { git = "https://github.com/rust-vmm/mshv", tag = "v0.2.0", features = [
|
|
"fam-wrappers",
|
|
"with-serde",
|
|
], optional = true }
|
|
net_util = { path = "../net_util" }
|
|
once_cell = "1.19.0"
|
|
option_parser = { path = "../option_parser" }
|
|
pci = { path = "../pci" }
|
|
range_map_vec = { version = "0.2.0", optional = true }
|
|
rate_limiter = { path = "../rate_limiter" }
|
|
seccompiler = "0.4.0"
|
|
serde = { version = "1.0.197", features = ["derive", "rc"] }
|
|
serde_json = "1.0.115"
|
|
serial_buffer = { path = "../serial_buffer" }
|
|
signal-hook = "0.3.17"
|
|
thiserror = "1.0.62"
|
|
tracer = { path = "../tracer" }
|
|
uuid = "1.8.0"
|
|
vfio-ioctls = { git = "https://github.com/rust-vmm/vfio", branch = "main", default-features = false }
|
|
vfio_user = { git = "https://github.com/rust-vmm/vfio-user", branch = "main" }
|
|
virtio-devices = { path = "../virtio-devices" }
|
|
virtio-queue = "0.12.0"
|
|
vm-allocator = { path = "../vm-allocator" }
|
|
vm-device = { path = "../vm-device" }
|
|
vm-memory = { version = "0.14.1", features = [
|
|
"backend-atomic",
|
|
"backend-bitmap",
|
|
"backend-mmap",
|
|
] }
|
|
vm-migration = { path = "../vm-migration" }
|
|
vm-virtio = { path = "../vm-virtio" }
|
|
vmm-sys-util = { version = "0.12.1", features = ["with-serde"] }
|
|
zbus = { version = "4.1.2", optional = true }
|
|
zerocopy = { version = "0.7.32", features = ["alloc", "derive"] }
|