mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-03 11:35:19 +00:00
Generic shared impls of all NUMA apis
This commit is contained in:
parent
3621d42e0f
commit
b0b968efd5
13
ChangeLog
13
ChangeLog
@ -1,3 +1,16 @@
|
|||||||
|
Wed Jun 3 14:28:52 BST 2009 Daniel P. Berrange <berrange@redhat.com>
|
||||||
|
|
||||||
|
Generic shared impls of all NUMA apis
|
||||||
|
* src/libvirt_private.syms: Add all nodeinfo.c APIs
|
||||||
|
* src/lxc_conf.c, src/openvz_conf, src/qemu_conf.c,
|
||||||
|
src/vbox/vbox_tmpl.c, src/uml_conf.c: Update for
|
||||||
|
changed API names in nodeinfo.h
|
||||||
|
* src/nodeinfo.c, src/nodeinfo.h: Add generic impls of
|
||||||
|
the virNodeGetCellsFreeMemory & virNodeGetFreeMemory APis
|
||||||
|
* src/openvz_driver.c: Use nodeGetInfo() directly in driver
|
||||||
|
* src/qemu_driver.c, src/uml_driver.c: Remove NUMA APis impls
|
||||||
|
in favour of generic impl in nodeinfo.c
|
||||||
|
|
||||||
Wed Jun 3 14:12:47 CEST 2009 Daniel Veillard <veillard@redhat.com>
|
Wed Jun 3 14:12:47 CEST 2009 Daniel Veillard <veillard@redhat.com>
|
||||||
|
|
||||||
* src/openvz_conf.c src/virsh.c: various typo or english fixups
|
* src/openvz_conf.c src/virsh.c: various typo or english fixups
|
||||||
|
@ -219,8 +219,10 @@ virNetworkObjUnlock;
|
|||||||
|
|
||||||
|
|
||||||
# nodeinfo.h
|
# nodeinfo.h
|
||||||
virNodeInfoPopulate;
|
nodeGetInfo;
|
||||||
virCapsInitNUMA;
|
nodeCapsInitNUMA;
|
||||||
|
nodeGetCellsFreeMemory;
|
||||||
|
nodeGetFreeMemory;
|
||||||
|
|
||||||
|
|
||||||
# node_device_conf.h
|
# node_device_conf.h
|
||||||
|
@ -46,7 +46,7 @@ virCapsPtr lxcCapsInit(void)
|
|||||||
0, 0)) == NULL)
|
0, 0)) == NULL)
|
||||||
goto no_memory;
|
goto no_memory;
|
||||||
|
|
||||||
if (virCapsInitNUMA(caps) < 0)
|
if (nodeCapsInitNUMA(caps) < 0)
|
||||||
goto no_memory;
|
goto no_memory;
|
||||||
|
|
||||||
/* XXX shouldn't 'borrow' KVM's prefix */
|
/* XXX shouldn't 'borrow' KVM's prefix */
|
||||||
|
127
src/nodeinfo.c
127
src/nodeinfo.c
@ -48,6 +48,10 @@
|
|||||||
|
|
||||||
#define VIR_FROM_THIS VIR_FROM_NONE
|
#define VIR_FROM_THIS VIR_FROM_NONE
|
||||||
|
|
||||||
|
#define nodeReportError(conn, code, fmt...) \
|
||||||
|
virReportErrorHelper(conn, VIR_FROM_NONE, code, __FILE__, \
|
||||||
|
__FUNCTION__, __LINE__, fmt)
|
||||||
|
|
||||||
#ifdef __linux__
|
#ifdef __linux__
|
||||||
#define CPUINFO_PATH "/proc/cpuinfo"
|
#define CPUINFO_PATH "/proc/cpuinfo"
|
||||||
|
|
||||||
@ -73,9 +77,8 @@ int linuxNodeInfoCPUPopulate(virConnectPtr conn, FILE *cpuinfo, virNodeInfoPtr n
|
|||||||
while (*buf && c_isspace(*buf))
|
while (*buf && c_isspace(*buf))
|
||||||
buf++;
|
buf++;
|
||||||
if (*buf != ':') {
|
if (*buf != ':') {
|
||||||
virRaiseError(conn, NULL, NULL, 0, VIR_ERR_INTERNAL_ERROR,
|
nodeReportError(conn, VIR_ERR_INTERNAL_ERROR,
|
||||||
VIR_ERR_ERROR, NULL, NULL, NULL, 0, 0,
|
"%s", _("parsing cpuinfo processor"));
|
||||||
"%s", _("parsing cpuinfo processor"));
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
nodeinfo->cpus++;
|
nodeinfo->cpus++;
|
||||||
@ -86,9 +89,8 @@ int linuxNodeInfoCPUPopulate(virConnectPtr conn, FILE *cpuinfo, virNodeInfoPtr n
|
|||||||
while (*buf && c_isspace(*buf))
|
while (*buf && c_isspace(*buf))
|
||||||
buf++;
|
buf++;
|
||||||
if (*buf != ':' || !buf[1]) {
|
if (*buf != ':' || !buf[1]) {
|
||||||
virRaiseError(conn, NULL, NULL, 0, VIR_ERR_INTERNAL_ERROR,
|
nodeReportError(conn, VIR_ERR_INTERNAL_ERROR,
|
||||||
VIR_ERR_ERROR, NULL, NULL, NULL, 0, 0,
|
"%s", _("parsing cpuinfo cpu MHz"));
|
||||||
"%s", _("parsing cpuinfo cpu MHz"));
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
if (virStrToLong_ui(buf+1, &p, 10, &ui) == 0
|
if (virStrToLong_ui(buf+1, &p, 10, &ui) == 0
|
||||||
@ -102,9 +104,8 @@ int linuxNodeInfoCPUPopulate(virConnectPtr conn, FILE *cpuinfo, virNodeInfoPtr n
|
|||||||
while (*buf && c_isspace(*buf))
|
while (*buf && c_isspace(*buf))
|
||||||
buf++;
|
buf++;
|
||||||
if (*buf != ':' || !buf[1]) {
|
if (*buf != ':' || !buf[1]) {
|
||||||
virRaiseError(conn, NULL, NULL, 0, VIR_ERR_INTERNAL_ERROR,
|
nodeReportError(conn, VIR_ERR_INTERNAL_ERROR,
|
||||||
VIR_ERR_ERROR, NULL, NULL, NULL, 0, 0,
|
"parsing cpuinfo cpu cores %c", *buf);
|
||||||
"parsing cpuinfo cpu cores %c", *buf);
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
if (virStrToLong_ui(buf+1, &p, 10, &id) == 0
|
if (virStrToLong_ui(buf+1, &p, 10, &id) == 0
|
||||||
@ -115,9 +116,8 @@ int linuxNodeInfoCPUPopulate(virConnectPtr conn, FILE *cpuinfo, virNodeInfoPtr n
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!nodeinfo->cpus) {
|
if (!nodeinfo->cpus) {
|
||||||
virRaiseError(conn, NULL, NULL, 0, VIR_ERR_INTERNAL_ERROR,
|
nodeReportError(conn, VIR_ERR_INTERNAL_ERROR,
|
||||||
VIR_ERR_ERROR, NULL, NULL, NULL, 0, 0,
|
"%s", _("no cpus found"));
|
||||||
"%s", _("no cpus found"));
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -133,8 +133,8 @@ int linuxNodeInfoCPUPopulate(virConnectPtr conn, FILE *cpuinfo, virNodeInfoPtr n
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int virNodeInfoPopulate(virConnectPtr conn,
|
int nodeGetInfo(virConnectPtr conn,
|
||||||
virNodeInfoPtr nodeinfo) {
|
virNodeInfoPtr nodeinfo) {
|
||||||
#ifdef HAVE_UNAME
|
#ifdef HAVE_UNAME
|
||||||
struct utsname info;
|
struct utsname info;
|
||||||
|
|
||||||
@ -170,9 +170,8 @@ int virNodeInfoPopulate(virConnectPtr conn,
|
|||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
/* XXX Solaris will need an impl later if they port QEMU driver */
|
/* XXX Solaris will need an impl later if they port QEMU driver */
|
||||||
virRaiseError(conn, NULL, NULL, 0, VIR_ERR_INTERNAL_ERROR,
|
nodeError(conn, VIR_ERR_NO_SUPPORT, "%s"
|
||||||
VIR_ERR_ERROR, NULL, NULL, NULL, 0, 0,
|
_("node info not implemented on this platform"));
|
||||||
"%s:%s not implemented on this platform\n", __FILE__, __FUNCTION__);
|
|
||||||
return -1;
|
return -1;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@ -189,7 +188,7 @@ int virNodeInfoPopulate(virConnectPtr conn,
|
|||||||
(((mask)[((cpu) / n_bits(*(mask)))] >> ((cpu) % n_bits(*(mask)))) & 1)
|
(((mask)[((cpu) / n_bits(*(mask)))] >> ((cpu) % n_bits(*(mask)))) & 1)
|
||||||
|
|
||||||
int
|
int
|
||||||
virCapsInitNUMA(virCapsPtr caps)
|
nodeCapsInitNUMA(virCapsPtr caps)
|
||||||
{
|
{
|
||||||
int n;
|
int n;
|
||||||
unsigned long *mask = NULL;
|
unsigned long *mask = NULL;
|
||||||
@ -237,6 +236,96 @@ cleanup:
|
|||||||
VIR_FREE(mask);
|
VIR_FREE(mask);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int
|
||||||
|
nodeGetCellsFreeMemory(virConnectPtr conn,
|
||||||
|
unsigned long long *freeMems,
|
||||||
|
int startCell,
|
||||||
|
int maxCells)
|
||||||
|
{
|
||||||
|
int n, lastCell, numCells;
|
||||||
|
int ret = -1;
|
||||||
|
int maxCell;
|
||||||
|
|
||||||
|
if (numa_available() < 0) {
|
||||||
|
nodeReportError(conn, VIR_ERR_NO_SUPPORT,
|
||||||
|
"%s", _("NUMA not supported on this host"));
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
maxCell = numa_max_node();
|
||||||
|
if (startCell > maxCell) {
|
||||||
|
nodeReportError(conn, VIR_ERR_INTERNAL_ERROR,
|
||||||
|
_("start cell %d out of range (0-%d)"),
|
||||||
|
startCell, maxCell);
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
lastCell = startCell + maxCells - 1;
|
||||||
|
if (lastCell > maxCell)
|
||||||
|
lastCell = maxCell;
|
||||||
|
|
||||||
|
for (numCells = 0, n = startCell ; n <= lastCell ; n++) {
|
||||||
|
long long mem;
|
||||||
|
if (numa_node_size64(n, &mem) < 0) {
|
||||||
|
nodeReportError(conn, VIR_ERR_INTERNAL_ERROR,
|
||||||
|
"%s", _("Failed to query NUMA free memory"));
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
freeMems[numCells++] = mem;
|
||||||
|
}
|
||||||
|
ret = numCells;
|
||||||
|
|
||||||
|
cleanup:
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
unsigned long long
|
||||||
|
nodeGetFreeMemory(virConnectPtr conn)
|
||||||
|
{
|
||||||
|
unsigned long long freeMem = 0;
|
||||||
|
int n;
|
||||||
|
|
||||||
|
if (numa_available() < 0) {
|
||||||
|
nodeReportError(conn, VIR_ERR_NO_SUPPORT,
|
||||||
|
"%s", _("NUMA not supported on this host"));
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (n = 0 ; n <= numa_max_node() ; n++) {
|
||||||
|
long long mem;
|
||||||
|
if (numa_node_size64(n, &mem) < 0) {
|
||||||
|
nodeReportError(conn, VIR_ERR_INTERNAL_ERROR,
|
||||||
|
"%s", _("Failed to query NUMA free memory"));
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
freeMem += mem;
|
||||||
|
}
|
||||||
|
|
||||||
|
cleanup:
|
||||||
|
return freeMem;
|
||||||
|
}
|
||||||
|
|
||||||
#else
|
#else
|
||||||
int virCapsInitNUMA(virCapsPtr caps ATTRIBUTE_UNUSED) { return 0; }
|
int nodeCapsInitNUMA(virCapsPtr caps ATTRIBUTE_UNUSED) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int nodeGetCellsFreeMemory(virConnectPtr conn,
|
||||||
|
unsigned long long *freeMems ATTRIBUTE_UNUSED,
|
||||||
|
int startCell ATTRIBUTE_UNUSED,
|
||||||
|
int maxCells ATTRIBUTE_UNUSED)
|
||||||
|
{
|
||||||
|
nodeReportError(conn, VIR_ERR_NO_SUPPORT, "%s",
|
||||||
|
_("NUMA memory information not available on this platform"));
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
unsigned long long nodeGetFreeMemory(virConnectPtr conn)
|
||||||
|
{
|
||||||
|
nodeReportError(conn, VIR_ERR_NO_SUPPORT, "%s",
|
||||||
|
_("NUMA memory information not available on this platform"));
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
@ -27,7 +27,14 @@
|
|||||||
#include "libvirt/libvirt.h"
|
#include "libvirt/libvirt.h"
|
||||||
#include "capabilities.h"
|
#include "capabilities.h"
|
||||||
|
|
||||||
int virNodeInfoPopulate(virConnectPtr conn, virNodeInfoPtr nodeinfo);
|
int nodeGetInfo(virConnectPtr conn, virNodeInfoPtr nodeinfo);
|
||||||
int virCapsInitNUMA(virCapsPtr caps);
|
int nodeCapsInitNUMA(virCapsPtr caps);
|
||||||
|
|
||||||
|
|
||||||
|
int nodeGetCellsFreeMemory(virConnectPtr conn,
|
||||||
|
unsigned long long *freeMems,
|
||||||
|
int startCell,
|
||||||
|
int maxCells);
|
||||||
|
unsigned long long nodeGetFreeMemory(virConnectPtr conn);
|
||||||
|
|
||||||
#endif /* __VIR_NODEINFO_H__*/
|
#endif /* __VIR_NODEINFO_H__*/
|
||||||
|
@ -148,7 +148,7 @@ virCapsPtr openvzCapsInit(void)
|
|||||||
0, 0)) == NULL)
|
0, 0)) == NULL)
|
||||||
goto no_memory;
|
goto no_memory;
|
||||||
|
|
||||||
if (virCapsInitNUMA(caps) < 0)
|
if (nodeCapsInitNUMA(caps) < 0)
|
||||||
goto no_memory;
|
goto no_memory;
|
||||||
|
|
||||||
virCapabilitiesSetMacPrefix(caps, (unsigned char[]){ 0x52, 0x54, 0x00 });
|
virCapabilitiesSetMacPrefix(caps, (unsigned char[]){ 0x52, 0x54, 0x00 });
|
||||||
@ -527,11 +527,8 @@ openvzGetNodeCPUs(void)
|
|||||||
{
|
{
|
||||||
virNodeInfo nodeinfo;
|
virNodeInfo nodeinfo;
|
||||||
|
|
||||||
if (virNodeInfoPopulate(NULL, &nodeinfo) < 0) {
|
if (nodeGetInfo(NULL, &nodeinfo) < 0)
|
||||||
openvzError(NULL, VIR_ERR_INTERNAL_ERROR,
|
|
||||||
"%s", _("Could not read nodeinfo"));
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
|
||||||
|
|
||||||
return nodeinfo.cpus;
|
return nodeinfo.cpus;
|
||||||
}
|
}
|
||||||
|
@ -1136,11 +1136,6 @@ static const char *openvzGetType(virConnectPtr conn ATTRIBUTE_UNUSED) {
|
|||||||
return strdup("OpenVZ");
|
return strdup("OpenVZ");
|
||||||
}
|
}
|
||||||
|
|
||||||
static int openvzGetNodeInfo(virConnectPtr conn,
|
|
||||||
virNodeInfoPtr nodeinfo) {
|
|
||||||
return virNodeInfoPopulate(conn, nodeinfo);
|
|
||||||
}
|
|
||||||
|
|
||||||
static char *openvzGetCapabilities(virConnectPtr conn) {
|
static char *openvzGetCapabilities(virConnectPtr conn) {
|
||||||
struct openvz_driver *driver = conn->privateData;
|
struct openvz_driver *driver = conn->privateData;
|
||||||
char *ret;
|
char *ret;
|
||||||
@ -1316,7 +1311,7 @@ static virDriver openvzDriver = {
|
|||||||
openvzGetVersion, /* version */
|
openvzGetVersion, /* version */
|
||||||
NULL, /* getHostname */
|
NULL, /* getHostname */
|
||||||
openvzGetMaxVCPUs, /* getMaxVcpus */
|
openvzGetMaxVCPUs, /* getMaxVcpus */
|
||||||
openvzGetNodeInfo, /* nodeGetInfo */
|
nodeGetInfo, /* nodeGetInfo */
|
||||||
openvzGetCapabilities, /* getCapabilities */
|
openvzGetCapabilities, /* getCapabilities */
|
||||||
openvzListDomains, /* listDomains */
|
openvzListDomains, /* listDomains */
|
||||||
openvzNumDomains, /* numOfDomains */
|
openvzNumDomains, /* numOfDomains */
|
||||||
|
@ -377,7 +377,7 @@ virCapsPtr qemudCapsInit(void) {
|
|||||||
/* Using KVM's mac prefix for QEMU too */
|
/* Using KVM's mac prefix for QEMU too */
|
||||||
virCapabilitiesSetMacPrefix(caps, (unsigned char[]){ 0x52, 0x54, 0x00 });
|
virCapabilitiesSetMacPrefix(caps, (unsigned char[]){ 0x52, 0x54, 0x00 });
|
||||||
|
|
||||||
if (virCapsInitNUMA(caps) < 0)
|
if (nodeCapsInitNUMA(caps) < 0)
|
||||||
goto no_memory;
|
goto no_memory;
|
||||||
|
|
||||||
virCapabilitiesAddHostMigrateTransport(caps,
|
virCapabilitiesAddHostMigrateTransport(caps,
|
||||||
|
@ -44,11 +44,6 @@
|
|||||||
#include <sys/wait.h>
|
#include <sys/wait.h>
|
||||||
#include <sys/ioctl.h>
|
#include <sys/ioctl.h>
|
||||||
|
|
||||||
#if HAVE_NUMACTL
|
|
||||||
#define NUMA_VERSION1_COMPATIBILITY 1
|
|
||||||
#include <numa.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if HAVE_SCHED_H
|
#if HAVE_SCHED_H
|
||||||
#include <sched.h>
|
#include <sched.h>
|
||||||
#endif
|
#endif
|
||||||
@ -1103,7 +1098,7 @@ qemudInitCpus(virConnectPtr conn,
|
|||||||
int i, maxcpu = QEMUD_CPUMASK_LEN;
|
int i, maxcpu = QEMUD_CPUMASK_LEN;
|
||||||
virNodeInfo nodeinfo;
|
virNodeInfo nodeinfo;
|
||||||
|
|
||||||
if (virNodeInfoPopulate(conn, &nodeinfo) < 0)
|
if (nodeGetInfo(conn, &nodeinfo) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
/* setaffinity fails if you set bits for CPUs which
|
/* setaffinity fails if you set bits for CPUs which
|
||||||
@ -1880,11 +1875,6 @@ static int qemudGetMaxVCPUs(virConnectPtr conn, const char *type) {
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int qemudGetNodeInfo(virConnectPtr conn,
|
|
||||||
virNodeInfoPtr nodeinfo) {
|
|
||||||
return virNodeInfoPopulate(conn, nodeinfo);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static char *qemudGetCapabilities(virConnectPtr conn) {
|
static char *qemudGetCapabilities(virConnectPtr conn) {
|
||||||
struct qemud_driver *driver = conn->privateData;
|
struct qemud_driver *driver = conn->privateData;
|
||||||
@ -1901,76 +1891,6 @@ static char *qemudGetCapabilities(virConnectPtr conn) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#if HAVE_NUMACTL
|
|
||||||
static int
|
|
||||||
qemudNodeGetCellsFreeMemory(virConnectPtr conn,
|
|
||||||
unsigned long long *freeMems,
|
|
||||||
int startCell,
|
|
||||||
int maxCells)
|
|
||||||
{
|
|
||||||
int n, lastCell, numCells;
|
|
||||||
int ret = -1;
|
|
||||||
int maxCell;
|
|
||||||
|
|
||||||
if (numa_available() < 0) {
|
|
||||||
qemudReportError(conn, NULL, NULL, VIR_ERR_NO_SUPPORT,
|
|
||||||
"%s", _("NUMA not supported on this host"));
|
|
||||||
goto cleanup;
|
|
||||||
}
|
|
||||||
maxCell = numa_max_node();
|
|
||||||
if (startCell > maxCell) {
|
|
||||||
qemudReportError(conn, NULL, NULL, VIR_ERR_INTERNAL_ERROR,
|
|
||||||
_("start cell %d out of range (0-%d)"),
|
|
||||||
startCell, maxCell);
|
|
||||||
goto cleanup;
|
|
||||||
}
|
|
||||||
lastCell = startCell + maxCells - 1;
|
|
||||||
if (lastCell > maxCell)
|
|
||||||
lastCell = maxCell;
|
|
||||||
|
|
||||||
for (numCells = 0, n = startCell ; n <= lastCell ; n++) {
|
|
||||||
long long mem;
|
|
||||||
if (numa_node_size64(n, &mem) < 0) {
|
|
||||||
qemudReportError(conn, NULL, NULL, VIR_ERR_INTERNAL_ERROR,
|
|
||||||
"%s", _("Failed to query NUMA free memory"));
|
|
||||||
goto cleanup;
|
|
||||||
}
|
|
||||||
freeMems[numCells++] = mem;
|
|
||||||
}
|
|
||||||
ret = numCells;
|
|
||||||
|
|
||||||
cleanup:
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
static unsigned long long
|
|
||||||
qemudNodeGetFreeMemory (virConnectPtr conn)
|
|
||||||
{
|
|
||||||
unsigned long long freeMem = 0;
|
|
||||||
int n;
|
|
||||||
|
|
||||||
if (numa_available() < 0) {
|
|
||||||
qemudReportError(conn, NULL, NULL, VIR_ERR_NO_SUPPORT,
|
|
||||||
"%s", _("NUMA not supported on this host"));
|
|
||||||
goto cleanup;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (n = 0 ; n <= numa_max_node() ; n++) {
|
|
||||||
long long mem;
|
|
||||||
if (numa_node_size64(n, &mem) < 0) {
|
|
||||||
qemudReportError(conn, NULL, NULL, VIR_ERR_INTERNAL_ERROR,
|
|
||||||
"%s", _("Failed to query NUMA free memory"));
|
|
||||||
goto cleanup;
|
|
||||||
}
|
|
||||||
freeMem += mem;
|
|
||||||
}
|
|
||||||
|
|
||||||
cleanup:
|
|
||||||
return freeMem;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static int qemudGetProcessInfo(unsigned long long *cpuTime, int pid) {
|
static int qemudGetProcessInfo(unsigned long long *cpuTime, int pid) {
|
||||||
char proc[PATH_MAX];
|
char proc[PATH_MAX];
|
||||||
FILE *pidinfo;
|
FILE *pidinfo;
|
||||||
@ -2995,7 +2915,7 @@ qemudDomainPinVcpu(virDomainPtr dom,
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (virNodeInfoPopulate(dom->conn, &nodeinfo) < 0)
|
if (nodeGetInfo(dom->conn, &nodeinfo) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
maxcpu = maplen * 8;
|
maxcpu = maplen * 8;
|
||||||
@ -3057,7 +2977,7 @@ qemudDomainGetVcpus(virDomainPtr dom,
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (virNodeInfoPopulate(dom->conn, &nodeinfo) < 0)
|
if (nodeGetInfo(dom->conn, &nodeinfo) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
maxcpu = maplen * 8;
|
maxcpu = maplen * 8;
|
||||||
@ -5349,7 +5269,7 @@ static virDriver qemuDriver = {
|
|||||||
qemudGetVersion, /* version */
|
qemudGetVersion, /* version */
|
||||||
qemudGetHostname, /* getHostname */
|
qemudGetHostname, /* getHostname */
|
||||||
qemudGetMaxVCPUs, /* getMaxVcpus */
|
qemudGetMaxVCPUs, /* getMaxVcpus */
|
||||||
qemudGetNodeInfo, /* nodeGetInfo */
|
nodeGetInfo, /* nodeGetInfo */
|
||||||
qemudGetCapabilities, /* getCapabilities */
|
qemudGetCapabilities, /* getCapabilities */
|
||||||
qemudListDomains, /* listDomains */
|
qemudListDomains, /* listDomains */
|
||||||
qemudNumDomains, /* numOfDomains */
|
qemudNumDomains, /* numOfDomains */
|
||||||
@ -5403,13 +5323,8 @@ static virDriver qemuDriver = {
|
|||||||
qemudDomainInterfaceStats, /* domainInterfaceStats */
|
qemudDomainInterfaceStats, /* domainInterfaceStats */
|
||||||
qemudDomainBlockPeek, /* domainBlockPeek */
|
qemudDomainBlockPeek, /* domainBlockPeek */
|
||||||
qemudDomainMemoryPeek, /* domainMemoryPeek */
|
qemudDomainMemoryPeek, /* domainMemoryPeek */
|
||||||
#if HAVE_NUMACTL
|
nodeGetCellsFreeMemory, /* nodeGetCellsFreeMemory */
|
||||||
qemudNodeGetCellsFreeMemory, /* nodeGetCellsFreeMemory */
|
nodeGetFreeMemory, /* getFreeMemory */
|
||||||
qemudNodeGetFreeMemory, /* getFreeMemory */
|
|
||||||
#else
|
|
||||||
NULL, /* nodeGetCellsFreeMemory */
|
|
||||||
NULL, /* getFreeMemory */
|
|
||||||
#endif
|
|
||||||
qemudDomainEventRegister, /* domainEventRegister */
|
qemudDomainEventRegister, /* domainEventRegister */
|
||||||
qemudDomainEventDeregister, /* domainEventDeregister */
|
qemudDomainEventDeregister, /* domainEventDeregister */
|
||||||
qemudDomainMigratePrepare2, /* domainMigratePrepare2 */
|
qemudDomainMigratePrepare2, /* domainMigratePrepare2 */
|
||||||
|
@ -63,7 +63,7 @@ virCapsPtr umlCapsInit(void) {
|
|||||||
0, 0)) == NULL)
|
0, 0)) == NULL)
|
||||||
goto no_memory;
|
goto no_memory;
|
||||||
|
|
||||||
if (virCapsInitNUMA(caps) < 0)
|
if (nodeCapsInitNUMA(caps) < 0)
|
||||||
goto no_memory;
|
goto no_memory;
|
||||||
|
|
||||||
if ((guest = virCapabilitiesAddGuest(caps,
|
if ((guest = virCapabilitiesAddGuest(caps,
|
||||||
|
@ -45,11 +45,6 @@
|
|||||||
#include <sys/ioctl.h>
|
#include <sys/ioctl.h>
|
||||||
#include <sys/inotify.h>
|
#include <sys/inotify.h>
|
||||||
|
|
||||||
#if HAVE_NUMACTL
|
|
||||||
#define NUMA_VERSION1_COMPATIBILITY 1
|
|
||||||
#include <numa.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "uml_driver.h"
|
#include "uml_driver.h"
|
||||||
#include "uml_conf.h"
|
#include "uml_conf.h"
|
||||||
#include "event.h"
|
#include "event.h"
|
||||||
@ -964,11 +959,6 @@ static const char *umlGetType(virConnectPtr conn ATTRIBUTE_UNUSED) {
|
|||||||
return "UML";
|
return "UML";
|
||||||
}
|
}
|
||||||
|
|
||||||
static int umlGetNodeInfo(virConnectPtr conn,
|
|
||||||
virNodeInfoPtr nodeinfo) {
|
|
||||||
return virNodeInfoPopulate(conn, nodeinfo);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static char *umlGetCapabilities(virConnectPtr conn) {
|
static char *umlGetCapabilities(virConnectPtr conn) {
|
||||||
struct uml_driver *driver = (struct uml_driver *)conn->privateData;
|
struct uml_driver *driver = (struct uml_driver *)conn->privateData;
|
||||||
@ -983,69 +973,6 @@ static char *umlGetCapabilities(virConnectPtr conn) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#if HAVE_NUMACTL
|
|
||||||
static int
|
|
||||||
umlNodeGetCellsFreeMemory(virConnectPtr conn,
|
|
||||||
unsigned long long *freeMems,
|
|
||||||
int startCell,
|
|
||||||
int maxCells)
|
|
||||||
{
|
|
||||||
int n, lastCell, numCells;
|
|
||||||
int ret = -1;
|
|
||||||
|
|
||||||
if (numa_available() < 0) {
|
|
||||||
umlReportError(conn, NULL, NULL, VIR_ERR_NO_SUPPORT,
|
|
||||||
"%s", _("NUMA not supported on this host"));
|
|
||||||
goto cleanup;
|
|
||||||
}
|
|
||||||
lastCell = startCell + maxCells - 1;
|
|
||||||
if (lastCell > numa_max_node())
|
|
||||||
lastCell = numa_max_node();
|
|
||||||
|
|
||||||
for (numCells = 0, n = startCell ; n <= lastCell ; n++) {
|
|
||||||
long long mem;
|
|
||||||
if (numa_node_size64(n, &mem) < 0) {
|
|
||||||
umlReportError(conn, NULL, NULL, VIR_ERR_INTERNAL_ERROR,
|
|
||||||
"%s", _("Failed to query NUMA free memory"));
|
|
||||||
goto cleanup;
|
|
||||||
}
|
|
||||||
freeMems[numCells++] = mem;
|
|
||||||
}
|
|
||||||
ret = numCells;
|
|
||||||
|
|
||||||
cleanup:
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
static unsigned long long
|
|
||||||
umlNodeGetFreeMemory (virConnectPtr conn)
|
|
||||||
{
|
|
||||||
unsigned long long freeMem = 0;
|
|
||||||
unsigned long long ret = -1;
|
|
||||||
int n;
|
|
||||||
|
|
||||||
if (numa_available() < 0) {
|
|
||||||
umlReportError(conn, NULL, NULL, VIR_ERR_NO_SUPPORT,
|
|
||||||
"%s", _("NUMA not supported on this host"));
|
|
||||||
goto cleanup;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (n = 0 ; n <= numa_max_node() ; n++) {
|
|
||||||
long long mem;
|
|
||||||
if (numa_node_size64(n, &mem) < 0) {
|
|
||||||
umlReportError(conn, NULL, NULL, VIR_ERR_INTERNAL_ERROR,
|
|
||||||
"%s", _("Failed to query NUMA free memory"));
|
|
||||||
goto cleanup;
|
|
||||||
}
|
|
||||||
freeMem += mem;
|
|
||||||
}
|
|
||||||
ret = freeMem;
|
|
||||||
|
|
||||||
cleanup:
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static int umlGetProcessInfo(unsigned long long *cpuTime, int pid) {
|
static int umlGetProcessInfo(unsigned long long *cpuTime, int pid) {
|
||||||
char proc[PATH_MAX];
|
char proc[PATH_MAX];
|
||||||
@ -1855,7 +1782,7 @@ static virDriver umlDriver = {
|
|||||||
umlGetVersion, /* version */
|
umlGetVersion, /* version */
|
||||||
umlGetHostname, /* getHostname */
|
umlGetHostname, /* getHostname */
|
||||||
NULL, /* getMaxVcpus */
|
NULL, /* getMaxVcpus */
|
||||||
umlGetNodeInfo, /* nodeGetInfo */
|
nodeGetInfo, /* nodeGetInfo */
|
||||||
umlGetCapabilities, /* getCapabilities */
|
umlGetCapabilities, /* getCapabilities */
|
||||||
umlListDomains, /* listDomains */
|
umlListDomains, /* listDomains */
|
||||||
umlNumDomains, /* numOfDomains */
|
umlNumDomains, /* numOfDomains */
|
||||||
@ -1904,13 +1831,8 @@ static virDriver umlDriver = {
|
|||||||
NULL, /* domainInterfaceStats */
|
NULL, /* domainInterfaceStats */
|
||||||
umlDomainBlockPeek, /* domainBlockPeek */
|
umlDomainBlockPeek, /* domainBlockPeek */
|
||||||
NULL, /* domainMemoryPeek */
|
NULL, /* domainMemoryPeek */
|
||||||
#if HAVE_NUMACTL
|
virNodeGetCellsFreeMemory, /* nodeGetCellsFreeMemory */
|
||||||
umlNodeGetCellsFreeMemory, /* nodeGetCellsFreeMemory */
|
virNodeGetFreeMemory, /* getFreeMemory */
|
||||||
umlNodeGetFreeMemory, /* getFreeMemory */
|
|
||||||
#else
|
|
||||||
NULL, /* nodeGetCellsFreeMemory */
|
|
||||||
NULL, /* getFreeMemory */
|
|
||||||
#endif
|
|
||||||
NULL, /* domainEventRegister */
|
NULL, /* domainEventRegister */
|
||||||
NULL, /* domainEventDeregister */
|
NULL, /* domainEventDeregister */
|
||||||
NULL, /* domainMigratePrepare2 */
|
NULL, /* domainMigratePrepare2 */
|
||||||
|
@ -186,7 +186,7 @@ static virCapsPtr vboxCapsInit(void) {
|
|||||||
0, 0)) == NULL)
|
0, 0)) == NULL)
|
||||||
goto no_memory;
|
goto no_memory;
|
||||||
|
|
||||||
if (virCapsInitNUMA(caps) < 0)
|
if (nodeCapsInitNUMA(caps) < 0)
|
||||||
goto no_memory;
|
goto no_memory;
|
||||||
|
|
||||||
virCapabilitiesSetMacPrefix(caps, (unsigned char[]){ 0x08, 0x00, 0x27 });
|
virCapabilitiesSetMacPrefix(caps, (unsigned char[]){ 0x08, 0x00, 0x27 });
|
||||||
@ -413,9 +413,6 @@ static int vboxGetMaxVcpus(virConnectPtr conn, const char *type ATTRIBUTE_UNUSED
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int vboxNodeGetInfo(virConnectPtr conn, virNodeInfoPtr nodeinfo) {
|
|
||||||
return virNodeInfoPopulate(conn, nodeinfo);
|
|
||||||
}
|
|
||||||
|
|
||||||
static char *vboxGetCapabilities(virConnectPtr conn) {
|
static char *vboxGetCapabilities(virConnectPtr conn) {
|
||||||
vboxGlobalData *data = conn->privateData;
|
vboxGlobalData *data = conn->privateData;
|
||||||
@ -4909,7 +4906,7 @@ virDriver NAME(Driver) = {
|
|||||||
.version = vboxGetVersion,
|
.version = vboxGetVersion,
|
||||||
.getHostname = vboxGetHostname,
|
.getHostname = vboxGetHostname,
|
||||||
.getMaxVcpus = vboxGetMaxVcpus,
|
.getMaxVcpus = vboxGetMaxVcpus,
|
||||||
.nodeGetInfo = vboxNodeGetInfo,
|
.nodeGetInfo = nodeGetInfo,
|
||||||
.getCapabilities = vboxGetCapabilities,
|
.getCapabilities = vboxGetCapabilities,
|
||||||
.listDomains = vboxListDomains,
|
.listDomains = vboxListDomains,
|
||||||
.numOfDomains = vboxNumOfDomains,
|
.numOfDomains = vboxNumOfDomains,
|
||||||
|
Loading…
Reference in New Issue
Block a user