@@ -97,6 +97,9 @@ EXPORT_SYMBOL_GPL(halt_poll_ns_shrink);
bool debugfs_per_vm = true;
module_param(debugfs_per_vm, bool, 0644);
+bool disable_uevent_notify;
+module_param(disable_uevent_notify, bool, 0444);
+
/*
* Ordering of locks:
*
@@ -6276,7 +6279,7 @@ static void kvm_uevent_notify_change(unsigned int type, struct kvm *kvm)
struct kobj_uevent_env *env;
unsigned long long created, active;
- if (!kvm_dev.this_device || !kvm)
+ if (!kvm_dev.this_device || !kvm || disable_uevent_notify)
return;
mutex_lock(&kvm_lock);
Handling of uevents in userlevel is a bottleneck for tiny VMs. Running 10_000 VMs keeps one and a half cores busy for 5.4 seconds to let systemd-udevd handle all messages. That is roughly 27x longer than the 0.2 seconds needed for running the VMs without them. We choose a read-only module parameter here due to its simplicity and ease of maintenance. Signed-off-by: Bernhard Kauer <bk@alpico.io> --- virt/kvm/kvm_main.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-)