conf: Handle NVRAM in virDomainLoaderDefParseXML()

All the data in the <nvram> element ends up in the same struct
as that coming from the <loader> element, so it makes sense to
have a single entry point for parsing an XML document into a
virDomainLoaderDef instance.

Signed-off-by: Andrea Bolognani <abologna@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
Andrea Bolognani 2022-06-16 18:02:14 +02:00
parent 5943e4ade6
commit 28c689dc61

View File

@ -18042,8 +18042,11 @@ virDomainLoaderDefParseXMLNvram(virDomainLoaderDef *loader,
static int static int
virDomainLoaderDefParseXML(xmlNodePtr node, virDomainLoaderDefParseXML(virDomainLoaderDef *loader,
virDomainLoaderDef *loader, xmlNodePtr node,
xmlXPathContextPtr ctxt,
virDomainXMLOption *xmlopt,
unsigned int flags,
bool fwAutoSelect) bool fwAutoSelect)
{ {
if (!fwAutoSelect) { if (!fwAutoSelect) {
@ -18066,6 +18069,11 @@ virDomainLoaderDefParseXML(xmlNodePtr node,
&loader->secure) < 0) &loader->secure) < 0)
return -1; return -1;
if (virDomainLoaderDefParseXMLNvram(loader,
ctxt, xmlopt, flags,
fwAutoSelect) < 0)
return -1;
return 0; return 0;
} }
@ -18467,12 +18475,8 @@ virDomainDefParseBootLoaderOptions(virDomainDef *def,
def->os.loader = g_new0(virDomainLoaderDef, 1); def->os.loader = g_new0(virDomainLoaderDef, 1);
if (virDomainLoaderDefParseXML(loader_node, if (virDomainLoaderDefParseXML(def->os.loader,
def->os.loader, loader_node,
fwAutoSelect) < 0)
return -1;
if (virDomainLoaderDefParseXMLNvram(def->os.loader,
ctxt, xmlopt, flags, ctxt, xmlopt, flags,
fwAutoSelect) < 0) fwAutoSelect) < 0)
return -1; return -1;