]> xenbits.xensource.com Git - libvirt.git/commitdiff
conf: Introduce virDomainMemoryDefNew()
authorMichal Privoznik <mprivozn@redhat.com>
Mon, 17 Oct 2022 12:55:04 +0000 (14:55 +0200)
committerMichal Privoznik <mprivozn@redhat.com>
Wed, 16 Nov 2022 11:52:02 +0000 (12:52 +0100)
This is new allocator for virDomainMemoryDef struct which also
sets some default values: @model and @targetNode.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Tim Wiederhake <twiederh@redhat.com>
src/conf/domain_conf.c
src/conf/domain_conf.h

index 622f83590f9e131602fedb02ab1048907d6bfe6e..d3b8ef36567d1d3aec410ad02c6ac0f00503ecfe 100644 (file)
@@ -13088,9 +13088,6 @@ virDomainMemoryTargetDefParseXML(xmlNodePtr node,
 
     ctxt->node = node;
 
-    /* initialize to value which marks that the user didn't specify it */
-    def->targetNode = -1;
-
     if ((rv = virXPathInt("string(./node)", ctxt, &def->targetNode)) == -2 ||
         (rv == 0 && def->targetNode < 0)) {
         virReportError(VIR_ERR_XML_ERROR, "%s",
@@ -13226,6 +13223,20 @@ virDomainSecDefParseXML(xmlNodePtr lsecNode,
 }
 
 
+virDomainMemoryDef *
+virDomainMemoryDefNew(virDomainMemoryModel model)
+{
+    virDomainMemoryDef *def = NULL;
+
+    def = g_new0(virDomainMemoryDef, 1);
+    def->model = model;
+    /* initialize to value which marks that the user didn't specify it */
+    def->targetNode = -1;
+
+    return def;
+}
+
+
 static virDomainMemoryDef *
 virDomainMemoryDefParseXML(virDomainXMLOption *xmlopt,
                            xmlNodePtr memdevNode,
@@ -13234,18 +13245,19 @@ virDomainMemoryDefParseXML(virDomainXMLOption *xmlopt,
 {
     VIR_XPATH_NODE_AUTORESTORE(ctxt)
     xmlNodePtr node;
-    virDomainMemoryDef *def;
+    virDomainMemoryDef *def = NULL;
+    virDomainMemoryModel model;
     g_autofree char *tmp = NULL;
 
-    def = g_new0(virDomainMemoryDef, 1);
-
     ctxt->node = memdevNode;
 
     if (virXMLPropEnum(memdevNode, "model", virDomainMemoryModelTypeFromString,
                        VIR_XML_PROP_REQUIRED | VIR_XML_PROP_NONZERO,
-                       &def->model) < 0)
+                       &model) < 0)
         goto error;
 
+    def = virDomainMemoryDefNew(model);
+
     if (virXMLPropEnum(memdevNode, "access", virDomainMemoryAccessTypeFromString,
                        VIR_XML_PROP_NONZERO, &def->access) < 0)
         goto error;
index e16558988d6baf3ddf62dfb05ba248028e5c68b2..d29ebf8b8ac676077b0e6b4afb6e7e037b249b3d 100644 (file)
@@ -2619,6 +2619,7 @@ struct _virDomainMemoryDef {
     virDomainDeviceInfo info;
 };
 
+virDomainMemoryDef *virDomainMemoryDefNew(virDomainMemoryModel model);
 void virDomainMemoryDefFree(virDomainMemoryDef *def);
 
 struct _virDomainIdMapEntry {