mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-25 22:15:20 +00:00
allow memballoon type of none to desactivate it
The balloon device is automatically added to qemu guests if supported, but it may be useful to desactivate it. The simplest to not change the existing behaviour is to allow <memballoon type="none"/> as an extra option to desactivate it (it is automatically added if the memballoon construct is missing for the domain). The following simple patch just adds the extra option and does not change the default behaviour but avoid creating a balloon device if type="none" is used. * docs/schemas/domain.rng: add the extra type attribute value * src/conf/domain_conf.c src/conf/domain_conf.h: add the extra enum value * src/qemu/qemu_conf.c: if enum is NONE, don't activate the device, i.e. don't pass the args to qemu/kvm
This commit is contained in:
parent
0495fe59ad
commit
79c27a620a
@ -1354,6 +1354,7 @@
|
|||||||
<choice>
|
<choice>
|
||||||
<value>virtio</value>
|
<value>virtio</value>
|
||||||
<value>xen</value>
|
<value>xen</value>
|
||||||
|
<value>none</value>
|
||||||
</choice>
|
</choice>
|
||||||
</attribute>
|
</attribute>
|
||||||
<optional>
|
<optional>
|
||||||
|
@ -203,7 +203,8 @@ VIR_ENUM_IMPL(virDomainSoundModel, VIR_DOMAIN_SOUND_MODEL_LAST,
|
|||||||
|
|
||||||
VIR_ENUM_IMPL(virDomainMemballoonModel, VIR_DOMAIN_MEMBALLOON_MODEL_LAST,
|
VIR_ENUM_IMPL(virDomainMemballoonModel, VIR_DOMAIN_MEMBALLOON_MODEL_LAST,
|
||||||
"virtio",
|
"virtio",
|
||||||
"xen");
|
"xen",
|
||||||
|
"none");
|
||||||
|
|
||||||
VIR_ENUM_IMPL(virDomainWatchdogModel, VIR_DOMAIN_WATCHDOG_MODEL_LAST,
|
VIR_ENUM_IMPL(virDomainWatchdogModel, VIR_DOMAIN_WATCHDOG_MODEL_LAST,
|
||||||
"i6300esb",
|
"i6300esb",
|
||||||
|
@ -581,6 +581,7 @@ struct _virDomainHostdevDef {
|
|||||||
enum {
|
enum {
|
||||||
VIR_DOMAIN_MEMBALLOON_MODEL_VIRTIO,
|
VIR_DOMAIN_MEMBALLOON_MODEL_VIRTIO,
|
||||||
VIR_DOMAIN_MEMBALLOON_MODEL_XEN,
|
VIR_DOMAIN_MEMBALLOON_MODEL_XEN,
|
||||||
|
VIR_DOMAIN_MEMBALLOON_MODEL_NONE,
|
||||||
|
|
||||||
VIR_DOMAIN_MEMBALLOON_MODEL_LAST
|
VIR_DOMAIN_MEMBALLOON_MODEL_LAST
|
||||||
};
|
};
|
||||||
|
@ -4958,7 +4958,8 @@ int qemudBuildCommandLine(virConnectPtr conn,
|
|||||||
* NB: Earlier we declared that VirtIO balloon will always be in
|
* NB: Earlier we declared that VirtIO balloon will always be in
|
||||||
* slot 0x3 on bus 0x0
|
* slot 0x3 on bus 0x0
|
||||||
*/
|
*/
|
||||||
if (def->memballoon) {
|
if ((def->memballoon) &&
|
||||||
|
(def->memballoon->model != VIR_DOMAIN_MEMBALLOON_MODEL_NONE)) {
|
||||||
if (def->memballoon->model != VIR_DOMAIN_MEMBALLOON_MODEL_VIRTIO) {
|
if (def->memballoon->model != VIR_DOMAIN_MEMBALLOON_MODEL_VIRTIO) {
|
||||||
qemuReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
qemuReportError(VIR_ERR_CONFIG_UNSUPPORTED,
|
||||||
_("Memory balloon device type '%s' is not supported by this version of qemu"),
|
_("Memory balloon device type '%s' is not supported by this version of qemu"),
|
||||||
@ -6575,6 +6576,9 @@ virDomainDefPtr qemuParseCommandLine(virCapsPtr caps,
|
|||||||
def->videos[def->nvideos++] = vid;
|
def->videos[def->nvideos++] = vid;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* having a balloon is the default, define one with type="none" to avoid it
|
||||||
|
*/
|
||||||
if (!def->memballoon) {
|
if (!def->memballoon) {
|
||||||
virDomainMemballoonDefPtr memballoon;
|
virDomainMemballoonDefPtr memballoon;
|
||||||
if (VIR_ALLOC(memballoon) < 0)
|
if (VIR_ALLOC(memballoon) < 0)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user