qemu: Add cpu ID to the vCPU pid list in the status XML

Note the vcpu ID so that once we allow non-contiguous vCPU topologies it
will be possible to pair thread id's with the vcpus.
This commit is contained in:
Peter Krempa 2016-06-30 15:06:46 +02:00
parent b91335afe4
commit 3f57ce4a76
2 changed files with 14 additions and 2 deletions

View File

@ -1337,7 +1337,7 @@ qemuDomainObjPrivateXMLFormatVcpus(virBufferPtr buf,
virBufferAdjustIndent(buf, 2);
for (i = 0; i < nvcpupids; i++)
virBufferAsprintf(buf, "<vcpu pid='%d'/>\n", vcpupids[i]);
virBufferAsprintf(buf, "<vcpu id='%zu' pid='%d'/>\n", i, vcpupids[i]);
virBufferAdjustIndent(buf, -2);
virBufferAddLit(buf, "</vcpus>\n");
@ -1466,9 +1466,19 @@ qemuDomainObjPrivateXMLParseVcpu(xmlNodePtr node,
unsigned int idx,
qemuDomainObjPrivatePtr priv)
{
char *idstr;
char *pidstr;
int ret = -1;
if ((idstr = virXMLPropString(node, "id"))) {
if (virStrToLong_uip(idstr, NULL, 10, &idx) < 0 ||
idx >= priv->nvcpupids) {
virReportError(VIR_ERR_INTERNAL_ERROR,
_("invalid vcpu index '%s'"), idstr);
goto cleanup;
}
}
if (!(pidstr = virXMLPropString(node, "pid")))
goto cleanup;
@ -1478,6 +1488,7 @@ qemuDomainObjPrivateXMLParseVcpu(xmlNodePtr node,
ret = 0;
cleanup:
VIR_FREE(idstr);
VIR_FREE(pidstr);
return ret;
}

View File

@ -113,7 +113,8 @@ testGetStatuXMLPrefixVcpus(virBufferPtr buf,
virBufferAdjustIndent(buf, 2);
while ((vcpuid = virBitmapNextSetBit(data->activeVcpus, vcpuid)) >= 0)
virBufferAsprintf(buf, "<vcpu pid='%zd'/>\n", vcpuid + 3803519);
virBufferAsprintf(buf, "<vcpu id='%zd' pid='%zd'/>\n",
vcpuid, vcpuid + 3803519);
virBufferAdjustIndent(buf, -2);
virBufferAddLit(buf, "</vcpus>\n");