forked from pool/libvirt
9be1e0080f
- Update to libvirt 8.9.0 - jsc#PED-620, jsc#PED-1540 - New subpackage libvirt-client-qemu providing client utilities to interact with QEMU-specific features of libvirt - Many incremental improvements and bug fixes, see https://libvirt.org/news.html#v8-9-0-2022-11-01 OBS-URL: https://build.opensuse.org/request/show/1032947 OBS-URL: https://build.opensuse.org/package/show/Virtualization/libvirt?expand=0&rev=951
92 lines
3.3 KiB
Diff
92 lines
3.3 KiB
Diff
From a844460158d37bc6f984384f8edb9d369208e390 Mon Sep 17 00:00:00 2001
|
|
From: Jim Fehlig <jfehlig@suse.com>
|
|
Date: Tue, 5 Jul 2022 13:51:37 -0600
|
|
Subject: libxl: disable autoballooning
|
|
|
|
Xen 4.12 introduced a CONFIG_DOM0_MEM option, which our xen package uses
|
|
to configure dom0 with a sensible initial memory value and disables
|
|
autoballooning. This patch changes libvirt to also disable autoballooning
|
|
by default. It can only be enabled with the 'autoballoon' setting in
|
|
libxl.conf. See jsc#SLE-3059 for more details.
|
|
|
|
Signed-off-by: Jim Fehlig <jfehlig@suse.com>
|
|
---
|
|
src/libxl/libxl.conf | 9 ++++-----
|
|
src/libxl/libxl_conf.c | 16 +++-------------
|
|
src/libxl/test_libvirtd_libxl.aug.in | 2 +-
|
|
3 files changed, 8 insertions(+), 19 deletions(-)
|
|
|
|
Index: libvirt-8.9.0/src/libxl/libxl.conf
|
|
===================================================================
|
|
--- libvirt-8.9.0.orig/src/libxl/libxl.conf
|
|
+++ libvirt-8.9.0/src/libxl/libxl.conf
|
|
@@ -4,12 +4,11 @@
|
|
|
|
# Enable autoballooning of domain0
|
|
#
|
|
-# By default, autoballooning of domain0 is enabled unless its memory
|
|
-# is already limited with Xen's "dom0_mem=" parameter, in which case
|
|
-# autoballooning is disabled. Override the default behavior with the
|
|
-# autoballoon setting.
|
|
+# By default, autoballooning of domain0 is disabled. Traditionally it
|
|
+# could also be disabled by using Xen's "dom0_mem=" parameter. Set to
|
|
+# 1 to enable autoballooning.
|
|
#
|
|
-#autoballoon = 1
|
|
+#autoballoon = 0
|
|
|
|
|
|
# In order to prevent accidentally starting two domains that
|
|
Index: libvirt-8.9.0/src/libxl/libxl_conf.c
|
|
===================================================================
|
|
--- libvirt-8.9.0.orig/src/libxl/libxl_conf.c
|
|
+++ libvirt-8.9.0/src/libxl/libxl_conf.c
|
|
@@ -1737,15 +1737,12 @@ libxlMakeBuildInfoVfb(virPortAllocatorRa
|
|
/*
|
|
* Get domain0 autoballoon configuration. Honor user-specified
|
|
* setting in libxl.conf first. If not specified, autoballooning
|
|
- * is disabled when domain0's memory is set with 'dom0_mem'.
|
|
- * Otherwise autoballooning is enabled.
|
|
+ * is disabled.
|
|
*/
|
|
static int
|
|
libxlGetAutoballoonConf(libxlDriverConfig *cfg,
|
|
virConf *conf)
|
|
{
|
|
- g_autoptr(GRegex) regex = NULL;
|
|
- g_autoptr(GError) err = NULL;
|
|
int res;
|
|
|
|
res = virConfGetValueBool(conf, "autoballoon", &cfg->autoballoon);
|
|
@@ -1754,15 +1751,8 @@ libxlGetAutoballoonConf(libxlDriverConfi
|
|
else if (res == 1)
|
|
return 0;
|
|
|
|
- regex = g_regex_new("(^| )dom0_mem=((|min:|max:)[0-9]+[bBkKmMgG]?,?)+($| )",
|
|
- 0, 0, &err);
|
|
- if (!regex) {
|
|
- virReportError(VIR_ERR_INTERNAL_ERROR,
|
|
- _("Failed to compile regex %s"), err->message);
|
|
- return -1;
|
|
- }
|
|
-
|
|
- cfg->autoballoon = !g_regex_match(regex, cfg->verInfo->commandline, 0, NULL);
|
|
+ /* make it explicit */
|
|
+ cfg->autoballoon = 0;
|
|
return 0;
|
|
}
|
|
|
|
Index: libvirt-8.9.0/src/libxl/test_libvirtd_libxl.aug.in
|
|
===================================================================
|
|
--- libvirt-8.9.0.orig/src/libxl/test_libvirtd_libxl.aug.in
|
|
+++ libvirt-8.9.0/src/libxl/test_libvirtd_libxl.aug.in
|
|
@@ -2,7 +2,7 @@ module Test_libvirtd_libxl =
|
|
@CONFIG@
|
|
|
|
test Libvirtd_libxl.lns get conf =
|
|
-{ "autoballoon" = "1" }
|
|
+{ "autoballoon" = "0" }
|
|
{ "lock_manager" = "lockd" }
|
|
{ "keepalive_interval" = "5" }
|
|
{ "keepalive_count" = "5" }
|