]> xenbits.xensource.com Git - libvirt.git/commitdiff
conf: domain: Improve vcpus validation reporting
authorCole Robinson <crobinso@redhat.com>
Mon, 22 Nov 2010 16:34:27 +0000 (11:34 -0500)
committerCole Robinson <crobinso@redhat.com>
Tue, 23 Nov 2010 13:42:45 +0000 (08:42 -0500)
src/conf/domain_conf.c

index 1ae48400120d382617dda2fcc2f293a2461cff06..e8d030dbe0cac090507614d241a90f5697603310 100644 (file)
@@ -4569,7 +4569,7 @@ static virDomainDefPtr virDomainDefParseXML(virCapsPtr caps,
         def->maxvcpus = 1;
     } else {
         def->maxvcpus = count;
-        if (def->maxvcpus != count || count == 0) {
+        if (count == 0) {
             virDomainReportError(VIR_ERR_XML_ERROR,
                                  _("invalid maxvcpus %lu"), count);
             goto error;
@@ -4585,11 +4585,18 @@ static virDomainDefPtr virDomainDefParseXML(virCapsPtr caps,
         def->vcpus = def->maxvcpus;
     } else {
         def->vcpus = count;
-        if (def->vcpus != count || count == 0 || def->maxvcpus < count) {
+        if (count == 0) {
             virDomainReportError(VIR_ERR_XML_ERROR,
                                  _("invalid current vcpus %lu"), count);
             goto error;
         }
+
+        if (def->maxvcpus < count) {
+            virDomainReportError(VIR_ERR_INTERNAL_ERROR,
+                _("maxvcpus must not be less than current vcpus (%d < %lu)"),
+                def->maxvcpus, count);
+            goto error;
+        }
     }
 
     tmp = virXPathString("string(./vcpu[1]/@cpuset)", ctxt);