提交 65fa7bba 编写于 作者: J Jiri Denemark

cpu_conf: Fix default value for CPU match attribute

Commit v0.8.4-66-g95ff6b18 (9 years ago) changed the default value for
the cpu/@match attribute to 'exact' in a rather complicated way. It did
so only if <model> subelement was present and set -1 otherwise (which is
not expected to ever happen). Thus the following two equivalent XML
elements:

    <cpu mode='host-model'/>

and

    <cpu mode='host-model'>
      <model/>
    </cpu>

would be parsed differently. The former would end up with match == -1
while the latter would have match == 1 ('exact'). This is not a big deal
since the match attribute is ignored for host-model CPUs, but we can
simplify the code and make it a little bit saner anyway.
Signed-off-by: NJiri Denemark <jdenemar@redhat.com>
Reviewed-by: NJán Tomko <jtomko@redhat.com>
上级 d3f2a8bd
...@@ -46,8 +46,8 @@ VIR_ENUM_IMPL(virCPUMode, ...@@ -46,8 +46,8 @@ VIR_ENUM_IMPL(virCPUMode,
VIR_ENUM_IMPL(virCPUMatch, VIR_ENUM_IMPL(virCPUMatch,
VIR_CPU_MATCH_LAST, VIR_CPU_MATCH_LAST,
"minimum",
"exact", "exact",
"minimum",
"strict", "strict",
); );
...@@ -388,12 +388,7 @@ virCPUDefParseXML(xmlXPathContextPtr ctxt, ...@@ -388,12 +388,7 @@ virCPUDefParseXML(xmlXPathContextPtr ctxt,
char *match = virXMLPropString(ctxt->node, "match"); char *match = virXMLPropString(ctxt->node, "match");
char *check; char *check;
if (!match) { if (match) {
if (virXPathBoolean("boolean(./model)", ctxt))
def->match = VIR_CPU_MATCH_EXACT;
else
def->match = -1;
} else {
def->match = virCPUMatchTypeFromString(match); def->match = virCPUMatchTypeFromString(match);
VIR_FREE(match); VIR_FREE(match);
......
...@@ -52,8 +52,8 @@ typedef enum { ...@@ -52,8 +52,8 @@ typedef enum {
VIR_ENUM_DECL(virCPUMode); VIR_ENUM_DECL(virCPUMode);
typedef enum { typedef enum {
VIR_CPU_MATCH_MINIMUM,
VIR_CPU_MATCH_EXACT, VIR_CPU_MATCH_EXACT,
VIR_CPU_MATCH_MINIMUM,
VIR_CPU_MATCH_STRICT, VIR_CPU_MATCH_STRICT,
VIR_CPU_MATCH_LAST VIR_CPU_MATCH_LAST
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册