conf: Move enum virMemAccess to the NUMA code and rename it

Name it virNumaMemAccess and add it to conf/numa_conf.[ch]

Note that to avoid a circular dependency the type of the NUMA cell
memAccess variable was changed to int. It will be turned back later
after the circular dependency will not exist.
This commit is contained in:
Peter Krempa 2015-02-11 15:40:27 +01:00
parent 6bc80fa86d
commit a3673b225d
5 changed files with 23 additions and 25 deletions

View File

@ -56,12 +56,6 @@ VIR_ENUM_IMPL(virCPUFeaturePolicy, VIR_CPU_FEATURE_LAST,
"disable", "disable",
"forbid") "forbid")
VIR_ENUM_IMPL(virMemAccess, VIR_MEM_ACCESS_LAST,
"default",
"shared",
"private")
void ATTRIBUTE_NONNULL(1) void ATTRIBUTE_NONNULL(1)
virCPUDefFreeModel(virCPUDefPtr def) virCPUDefFreeModel(virCPUDefPtr def)
{ {

View File

@ -83,16 +83,6 @@ typedef enum {
VIR_ENUM_DECL(virCPUFeaturePolicy) VIR_ENUM_DECL(virCPUFeaturePolicy)
typedef enum {
VIR_MEM_ACCESS_DEFAULT,
VIR_MEM_ACCESS_SHARED,
VIR_MEM_ACCESS_PRIVATE,
VIR_MEM_ACCESS_LAST,
} virMemAccess;
VIR_ENUM_DECL(virMemAccess)
typedef struct _virCPUFeatureDef virCPUFeatureDef; typedef struct _virCPUFeatureDef virCPUFeatureDef;
typedef virCPUFeatureDef *virCPUFeatureDefPtr; typedef virCPUFeatureDef *virCPUFeatureDefPtr;
struct _virCPUFeatureDef { struct _virCPUFeatureDef {
@ -105,7 +95,7 @@ typedef virCellDef *virCellDefPtr;
struct _virCellDef { struct _virCellDef {
virBitmapPtr cpumask; /* CPUs that are part of this node */ virBitmapPtr cpumask; /* CPUs that are part of this node */
unsigned long long mem; /* Node memory in kB */ unsigned long long mem; /* Node memory in kB */
virMemAccess memAccess; int memAccess; /* virNumaMemAccess */
}; };
typedef struct _virCPUDef virCPUDef; typedef struct _virCPUDef virCPUDef;

View File

@ -43,6 +43,11 @@ VIR_ENUM_IMPL(virDomainNumatunePlacement,
"static", "static",
"auto"); "auto");
VIR_ENUM_IMPL(virNumaMemAccess, VIR_NUMA_MEM_ACCESS_LAST,
"default",
"shared",
"private");
typedef struct _virDomainNumaNode virDomainNumaNode; typedef struct _virDomainNumaNode virDomainNumaNode;
typedef virDomainNumaNode *virDomainNumaNodePtr; typedef virDomainNumaNode *virDomainNumaNodePtr;
@ -757,7 +762,7 @@ virDomainNumaDefCPUParseXML(virCPUDefPtr def,
goto cleanup; goto cleanup;
if ((tmp = virXMLPropString(nodes[i], "memAccess"))) { if ((tmp = virXMLPropString(nodes[i], "memAccess"))) {
if ((rc = virMemAccessTypeFromString(tmp)) <= 0) { if ((rc = virNumaMemAccessTypeFromString(tmp)) <= 0) {
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
_("Invalid 'memAccess' attribute value '%s'"), _("Invalid 'memAccess' attribute value '%s'"),
tmp); tmp);
@ -783,7 +788,7 @@ int
virDomainNumaDefCPUFormat(virBufferPtr buf, virDomainNumaDefCPUFormat(virBufferPtr buf,
virCPUDefPtr def) virCPUDefPtr def)
{ {
virMemAccess memAccess; virNumaMemAccess memAccess;
char *cpustr; char *cpustr;
size_t i; size_t i;
@ -805,7 +810,7 @@ virDomainNumaDefCPUFormat(virBufferPtr buf,
virBufferAddLit(buf, " unit='KiB'"); virBufferAddLit(buf, " unit='KiB'");
if (memAccess) if (memAccess)
virBufferAsprintf(buf, " memAccess='%s'", virBufferAsprintf(buf, " memAccess='%s'",
virMemAccessTypeToString(memAccess)); virNumaMemAccessTypeToString(memAccess));
virBufferAddLit(buf, "/>\n"); virBufferAddLit(buf, "/>\n");
VIR_FREE(cpustr); VIR_FREE(cpustr);
} }

View File

@ -46,6 +46,15 @@ typedef enum {
VIR_ENUM_DECL(virDomainNumatunePlacement) VIR_ENUM_DECL(virDomainNumatunePlacement)
VIR_ENUM_DECL(virDomainNumatuneMemMode) VIR_ENUM_DECL(virDomainNumatuneMemMode)
typedef enum {
VIR_NUMA_MEM_ACCESS_DEFAULT,
VIR_NUMA_MEM_ACCESS_SHARED,
VIR_NUMA_MEM_ACCESS_PRIVATE,
VIR_NUMA_MEM_ACCESS_LAST
} virNumaMemAccess;
VIR_ENUM_DECL(virNumaMemAccess)
void virDomainNumaFree(virDomainNumaPtr numa); void virDomainNumaFree(virDomainNumaPtr numa);

View File

@ -4558,7 +4558,7 @@ qemuBuildMemoryBackendStr(unsigned long long size,
virDomainHugePagePtr hugepage = NULL; virDomainHugePagePtr hugepage = NULL;
virDomainNumatuneMemMode mode; virDomainNumatuneMemMode mode;
const long system_page_size = virGetSystemPageSizeKB(); const long system_page_size = virGetSystemPageSizeKB();
virMemAccess memAccess = def->cpu->cells[guestNode].memAccess; virNumaMemAccess memAccess = def->cpu->cells[guestNode].memAccess;
size_t i; size_t i;
char *mem_path = NULL; char *mem_path = NULL;
virBitmapPtr nodemask = NULL; virBitmapPtr nodemask = NULL;
@ -4651,18 +4651,18 @@ qemuBuildMemoryBackendStr(unsigned long long size,
goto cleanup; goto cleanup;
switch (memAccess) { switch (memAccess) {
case VIR_MEM_ACCESS_SHARED: case VIR_NUMA_MEM_ACCESS_SHARED:
if (virJSONValueObjectAdd(props, "b:share", true, NULL) < 0) if (virJSONValueObjectAdd(props, "b:share", true, NULL) < 0)
goto cleanup; goto cleanup;
break; break;
case VIR_MEM_ACCESS_PRIVATE: case VIR_NUMA_MEM_ACCESS_PRIVATE:
if (virJSONValueObjectAdd(props, "b:share", false, NULL) < 0) if (virJSONValueObjectAdd(props, "b:share", false, NULL) < 0)
goto cleanup; goto cleanup;
break; break;
case VIR_MEM_ACCESS_DEFAULT: case VIR_NUMA_MEM_ACCESS_DEFAULT:
case VIR_MEM_ACCESS_LAST: case VIR_NUMA_MEM_ACCESS_LAST:
break; break;
} }
} else { } else {