Page MenuHomeFreeBSD

bhyve: Sleep briefly in the VMEXIT_DEBUG handler
ClosedPublic

Authored by markj on Mar 20 2023, 2:57 PM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Jan 14, 7:13 AM
Unknown Object (File)
Sat, Dec 28, 6:40 PM
Unknown Object (File)
Nov 24 2024, 2:39 PM
Unknown Object (File)
Nov 23 2024, 3:50 PM
Unknown Object (File)
Nov 22 2024, 11:35 AM
Unknown Object (File)
Nov 21 2024, 10:05 AM
Unknown Object (File)
Nov 11 2024, 8:18 AM
Unknown Object (File)
Nov 11 2024, 8:18 AM
Subscribers

Details

Summary

As of commit 0bda8d3e9f7a ("vmm: permit some IPIs to be handled by
userspace") and commit 9cc9abf409cc ("bhyve: create all vcpus on
startup"), we have a misbehaviour where AP vCPU threads spin until they
receive a SIPI. In particular, since they are "suspended", they simply
call the VMEXIT_DEBUG handler in a loop, but the handler is a no-op by
default.

This is tricky to fix since the gdb stub isn't aware of whether a given
vCPU is supposed to be running. For 13.2's sake, introduce a simple
workaround wherein the VMEXIT_DEBUG handler sleeps for a short period.
This ensures that host CPU usage remains sane when VMs are starting.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 50484
Build 47375: arc lint + arc unit