mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-22 04:25:18 +00:00
python: add virDomainGetCPUStats python binding API
dom.getCPUStats(True, 0) [{'cpu_time': 24699446159L, 'system_time': 10870000000L, 'user_time': 950000000L}] dom.getCPUStats(False, 0) [{'cpu_time': 8535292289L}, {'cpu_time': 1005395355L}, {'cpu_time': 9351766377L}, {'cpu_time': 5813545649L}] *generator.py Add a new naming rule *libvirt-override-api.xml The API function description *libvirt-override.c Implement it.
This commit is contained in:
parent
558ebc256d
commit
a772f4eebc
@ -423,7 +423,7 @@ skip_impl = (
|
|||||||
'virDomainGetBlockIoTune',
|
'virDomainGetBlockIoTune',
|
||||||
'virDomainSetInterfaceParameters',
|
'virDomainSetInterfaceParameters',
|
||||||
'virDomainGetInterfaceParameters',
|
'virDomainGetInterfaceParameters',
|
||||||
'virDomainGetCPUStats', # not implemented now.
|
'virDomainGetCPUStats',
|
||||||
'virDomainGetDiskErrors',
|
'virDomainGetDiskErrors',
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -967,6 +967,9 @@ def nameFixup(name, classe, type, file):
|
|||||||
elif name[0:19] == "virStorageVolLookup":
|
elif name[0:19] == "virStorageVolLookup":
|
||||||
func = name[3:]
|
func = name[3:]
|
||||||
func = string.lower(func[0:1]) + func[1:]
|
func = string.lower(func[0:1]) + func[1:]
|
||||||
|
elif name[0:20] == "virDomainGetCPUStats":
|
||||||
|
func = name[9:]
|
||||||
|
func = string.lower(func[0:1]) + func[1:]
|
||||||
elif name[0:12] == "virDomainGet":
|
elif name[0:12] == "virDomainGet":
|
||||||
func = name[12:]
|
func = name[12:]
|
||||||
func = string.lower(func[0:1]) + func[1:]
|
func = string.lower(func[0:1]) + func[1:]
|
||||||
|
@ -149,6 +149,19 @@
|
|||||||
<arg name='path' type='char *' info='the path for the block device'/>
|
<arg name='path' type='char *' info='the path for the block device'/>
|
||||||
<arg name='flags' type='int' info='flags (unused; pass 0)'/>
|
<arg name='flags' type='int' info='flags (unused; pass 0)'/>
|
||||||
</function>
|
</function>
|
||||||
|
<function name='virDomainGetCPUStats' file='python'>
|
||||||
|
<info>Extracts CPU statistics for a running domain. On success it will
|
||||||
|
return a list of data of dictionary type. If boolean total is False, the
|
||||||
|
first element of the list refers to CPU0 on the host, second element is
|
||||||
|
CPU1, and so on. The format of data struct is as follows:
|
||||||
|
[{cpu_time:xxx}, {cpu_time:xxx}, ...]
|
||||||
|
If it is True, it returns total domain CPU statistics in the format of
|
||||||
|
[{cpu_time:xxx, user_time:xxx, system_time:xxx}]</info>
|
||||||
|
<return type='str *' info='returns a list of dictionary in case of success, None in case of error'/>
|
||||||
|
<arg name='domain' type='virDomainPtr' info='pointer to domain object'/>
|
||||||
|
<arg name='total' type='bool' info='on true, return total domain CPU statistics, false return per-cpu info'/>
|
||||||
|
<arg name='flags' type='int' info='flags (unused; pass 0)'/>
|
||||||
|
</function>
|
||||||
<function name='virDomainInterfaceStats' file='python'>
|
<function name='virDomainInterfaceStats' file='python'>
|
||||||
<info>Extracts interface device statistics for a domain</info>
|
<info>Extracts interface device statistics for a domain</info>
|
||||||
<return type='virDomainInterfaceStats' info='a tuple of statistics'/>
|
<return type='virDomainInterfaceStats' info='a tuple of statistics'/>
|
||||||
|
@ -377,6 +377,152 @@ cleanup:
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static PyObject *
|
||||||
|
libvirt_virDomainGetCPUStats(PyObject *self ATTRIBUTE_UNUSED, PyObject *args)
|
||||||
|
{
|
||||||
|
virDomainPtr domain;
|
||||||
|
PyObject *pyobj_domain, *totalbool;
|
||||||
|
PyObject *cpu, *total;
|
||||||
|
PyObject *ret = NULL;
|
||||||
|
PyObject *error = NULL;
|
||||||
|
int ncpus = -1, start_cpu = 0;
|
||||||
|
int sumparams = 0, nparams = -1;
|
||||||
|
int i, i_retval;
|
||||||
|
unsigned int flags, totalflag;
|
||||||
|
virTypedParameterPtr params = NULL, cpuparams;
|
||||||
|
|
||||||
|
if (!PyArg_ParseTuple(args, (char *)"OOi:virDomainGetCPUStats",
|
||||||
|
&pyobj_domain, &totalbool, &flags))
|
||||||
|
return NULL;
|
||||||
|
domain = (virDomainPtr) PyvirDomain_Get(pyobj_domain);
|
||||||
|
|
||||||
|
if (!PyBool_Check(totalbool)) {
|
||||||
|
PyErr_Format(PyExc_TypeError,
|
||||||
|
"The \"total\" attribute must be bool");
|
||||||
|
return NULL;
|
||||||
|
} else {
|
||||||
|
/* Hack - Python's definition of Py_True breaks strict
|
||||||
|
* aliasing rules, so can't directly compare
|
||||||
|
*/
|
||||||
|
PyObject *hacktrue = PyBool_FromLong(1);
|
||||||
|
totalflag = hacktrue == totalbool ? 1 : 0;
|
||||||
|
Py_DECREF(hacktrue);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((ret = PyList_New(0)) == NULL)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
if (!totalflag) {
|
||||||
|
LIBVIRT_BEGIN_ALLOW_THREADS;
|
||||||
|
ncpus = virDomainGetCPUStats(domain, NULL, 0, 0, 0, flags);
|
||||||
|
LIBVIRT_END_ALLOW_THREADS;
|
||||||
|
|
||||||
|
if (ncpus < 0) {
|
||||||
|
error = VIR_PY_NONE;
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
|
||||||
|
LIBVIRT_BEGIN_ALLOW_THREADS;
|
||||||
|
nparams = virDomainGetCPUStats(domain, NULL, 0, 0, 1, flags);
|
||||||
|
LIBVIRT_END_ALLOW_THREADS;
|
||||||
|
|
||||||
|
if (nparams < 0) {
|
||||||
|
error = VIR_PY_NONE;
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
|
||||||
|
sumparams = nparams * MIN(ncpus, 128);
|
||||||
|
|
||||||
|
if (VIR_ALLOC_N(params, sumparams) < 0) {
|
||||||
|
error = PyErr_NoMemory();
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
|
||||||
|
while (ncpus) {
|
||||||
|
int queried_ncpus = MIN(ncpus, 128);
|
||||||
|
if (nparams) {
|
||||||
|
|
||||||
|
LIBVIRT_BEGIN_ALLOW_THREADS;
|
||||||
|
i_retval = virDomainGetCPUStats(domain, params,
|
||||||
|
nparams, start_cpu, queried_ncpus, flags);
|
||||||
|
LIBVIRT_END_ALLOW_THREADS;
|
||||||
|
|
||||||
|
if (i_retval < 0) {
|
||||||
|
error = VIR_PY_NONE;
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
i_retval = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < queried_ncpus; i++) {
|
||||||
|
cpuparams = ¶ms[i * nparams];
|
||||||
|
if ((cpu = getPyVirTypedParameter(cpuparams, i_retval)) == NULL) {
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (PyList_Append(ret, cpu) < 0) {
|
||||||
|
Py_DECREF(cpu);
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
Py_DECREF(cpu);
|
||||||
|
}
|
||||||
|
|
||||||
|
start_cpu += queried_ncpus;
|
||||||
|
ncpus -= queried_ncpus;
|
||||||
|
virTypedParameterArrayClear(params, sumparams);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
LIBVIRT_BEGIN_ALLOW_THREADS;
|
||||||
|
nparams = virDomainGetCPUStats(domain, NULL, 0, -1, 1, flags);
|
||||||
|
LIBVIRT_END_ALLOW_THREADS;
|
||||||
|
|
||||||
|
if (nparams < 0) {
|
||||||
|
error = VIR_PY_NONE;
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (nparams) {
|
||||||
|
sumparams = nparams;
|
||||||
|
|
||||||
|
if (VIR_ALLOC_N(params, nparams) < 0) {
|
||||||
|
error = PyErr_NoMemory();
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
|
||||||
|
LIBVIRT_BEGIN_ALLOW_THREADS;
|
||||||
|
i_retval = virDomainGetCPUStats(domain, params, nparams, -1, 1, flags);
|
||||||
|
LIBVIRT_END_ALLOW_THREADS;
|
||||||
|
|
||||||
|
if (i_retval < 0) {
|
||||||
|
error = VIR_PY_NONE;
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
i_retval = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((total = getPyVirTypedParameter(params, i_retval)) == NULL) {
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
if (PyList_Append(ret, total) < 0) {
|
||||||
|
Py_DECREF(total);
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
Py_DECREF(total);
|
||||||
|
}
|
||||||
|
|
||||||
|
virTypedParameterArrayClear(params, sumparams);
|
||||||
|
VIR_FREE(params);
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
error:
|
||||||
|
virTypedParameterArrayClear(params, sumparams);
|
||||||
|
VIR_FREE(params);
|
||||||
|
Py_DECREF(ret);
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
|
||||||
static PyObject *
|
static PyObject *
|
||||||
libvirt_virDomainInterfaceStats(PyObject *self ATTRIBUTE_UNUSED, PyObject *args) {
|
libvirt_virDomainInterfaceStats(PyObject *self ATTRIBUTE_UNUSED, PyObject *args) {
|
||||||
virDomainPtr domain;
|
virDomainPtr domain;
|
||||||
@ -5398,6 +5544,7 @@ static PyMethodDef libvirtMethods[] = {
|
|||||||
{(char *) "virNetworkGetAutostart", libvirt_virNetworkGetAutostart, METH_VARARGS, NULL},
|
{(char *) "virNetworkGetAutostart", libvirt_virNetworkGetAutostart, METH_VARARGS, NULL},
|
||||||
{(char *) "virDomainBlockStats", libvirt_virDomainBlockStats, METH_VARARGS, NULL},
|
{(char *) "virDomainBlockStats", libvirt_virDomainBlockStats, METH_VARARGS, NULL},
|
||||||
{(char *) "virDomainBlockStatsFlags", libvirt_virDomainBlockStatsFlags, METH_VARARGS, NULL},
|
{(char *) "virDomainBlockStatsFlags", libvirt_virDomainBlockStatsFlags, METH_VARARGS, NULL},
|
||||||
|
{(char *) "virDomainGetCPUStats", libvirt_virDomainGetCPUStats, METH_VARARGS, NULL},
|
||||||
{(char *) "virDomainInterfaceStats", libvirt_virDomainInterfaceStats, METH_VARARGS, NULL},
|
{(char *) "virDomainInterfaceStats", libvirt_virDomainInterfaceStats, METH_VARARGS, NULL},
|
||||||
{(char *) "virDomainMemoryStats", libvirt_virDomainMemoryStats, METH_VARARGS, NULL},
|
{(char *) "virDomainMemoryStats", libvirt_virDomainMemoryStats, METH_VARARGS, NULL},
|
||||||
{(char *) "virNodeGetCellsFreeMemory", libvirt_virNodeGetCellsFreeMemory, METH_VARARGS, NULL},
|
{(char *) "virNodeGetCellsFreeMemory", libvirt_virNodeGetCellsFreeMemory, METH_VARARGS, NULL},
|
||||||
|
Loading…
x
Reference in New Issue
Block a user