From nobody Fri Apr 26 16:12:55 2024
Delivered-To: importer@patchew.org
Received-SPF: pass (zoho.com: domain of redhat.com designates 209.132.183.25
as permitted sender) client-ip=209.132.183.25;
envelope-from=libvir-list-bounces@redhat.com; helo=mx4-phx2.redhat.com;
Authentication-Results: mx.zoho.com;
spf=pass (zoho.com: domain of redhat.com designates 209.132.183.25 as
permitted sender) smtp.mailfrom=libvir-list-bounces@redhat.com;
Return-Path:
Received: from mx4-phx2.redhat.com (mx4-phx2.redhat.com [209.132.183.25]) by
mx.zohomail.com
with SMTPS id 1489075795262552.5397579180371;
Thu, 9 Mar 2017 08:09:55 -0800 (PST)
Received: from lists01.pubmisc.prod.ext.phx2.redhat.com
(lists01.pubmisc.prod.ext.phx2.redhat.com [10.5.19.33])
by mx4-phx2.redhat.com (8.13.8/8.13.8) with ESMTP id v29G6ZRB017823;
Thu, 9 Mar 2017 11:06:35 -0500
Received: from smtp.corp.redhat.com (int-mx16.intmail.prod.int.phx2.redhat.com
[10.5.11.28])
by lists01.pubmisc.prod.ext.phx2.redhat.com (8.13.8/8.13.8) with ESMTP
id v29G6VP1032371 for ;
Thu, 9 Mar 2017 11:06:31 -0500
Received: by smtp.corp.redhat.com (Postfix)
id ECCBD2D655; Thu, 9 Mar 2017 16:06:31 +0000 (UTC)
Received: from moe.brq.redhat.com (dhcp129-131.brq.redhat.com [10.34.129.131])
by smtp.corp.redhat.com (Postfix) with ESMTP id 746372D653
for ; Thu, 9 Mar 2017 16:06:31 +0000 (UTC)
From: Michal Privoznik
To: libvir-list@redhat.com
Date: Thu, 9 Mar 2017 17:06:10 +0100
Message-Id:
<7c5a4acf58142ba2b9400d88a3094f4f29b89d1e.1489075458.git.mprivozn@redhat.com>
In-Reply-To:
References:
In-Reply-To:
References:
X-Scanned-By: MIMEDefang 2.74 on 10.5.11.28
X-loop: libvir-list@redhat.com
Subject: [libvirt] [PATCH v3 01/17] qemuBuildMemoryBackendStr: Don't
overwrite @force
X-BeenThere: libvir-list@redhat.com
X-Mailman-Version: 2.1.12
Precedence: junk
List-Id: Development discussions about the libvirt library & tools
List-Unsubscribe: ,
List-Archive:
List-Post:
List-Help:
List-Subscribe: ,
MIME-Version: 1.0
Content-Transfer-Encoding: quoted-printable
Sender: libvir-list-bounces@redhat.com
Errors-To: libvir-list-bounces@redhat.com
X-ZohoMail: RSF_0 Z_629925259 SPT_0
Content-Type: text/plain; charset="utf-8"
This is an input argument. We should not overwrite it.
Signed-off-by: Michal Privoznik
---
src/qemu/qemu_command.c | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/src/qemu/qemu_command.c b/src/qemu/qemu_command.c
index 6545a9325..f145cf9d8 100644
--- a/src/qemu/qemu_command.c
+++ b/src/qemu/qemu_command.c
@@ -3203,7 +3203,6 @@ qemuBuildMemoryBackendStr(unsigned long long size,
=20
if (def->mem.source =3D=3D VIR_DOMAIN_MEMORY_SOURCE_FILE) {
/* we can have both pagesize and mem source, then check mem so=
urce first */
- force =3D true;
if (virJSONValueObjectAdd(props,
"s:mem-path", cfg->memoryBackingDir,
NULL) < 0)
@@ -3273,7 +3272,8 @@ qemuBuildMemoryBackendStr(unsigned long long size,
}
=20
/* If none of the following is requested... */
- if (!needHugepage && !userNodeset && !memAccess && !nodeSpecified && !=
force) {
+ if (!needHugepage && !userNodeset && !memAccess && !nodeSpecified &&
+ def->mem.source !=3D VIR_DOMAIN_MEMORY_SOURCE_FILE && !force) {
/* report back that using the new backend is not necessary
* to achieve the desired configuration */
ret =3D 1;
--=20
2.11.0
--
libvir-list mailing list
libvir-list@redhat.com
https://www.redhat.com/mailman/listinfo/libvir-list
From nobody Fri Apr 26 16:12:55 2024
Delivered-To: importer@patchew.org
Received-SPF: pass (zoho.com: domain of redhat.com designates 209.132.183.37
as permitted sender) client-ip=209.132.183.37;
envelope-from=libvir-list-bounces@redhat.com; helo=mx5-phx2.redhat.com;
Authentication-Results: mx.zoho.com;
spf=pass (zoho.com: domain of redhat.com designates 209.132.183.37 as
permitted sender) smtp.mailfrom=libvir-list-bounces@redhat.com;
Return-Path:
Received: from mx5-phx2.redhat.com (mx5-phx2.redhat.com [209.132.183.37]) by
mx.zohomail.com
with SMTPS id 14890757943168.219274764906231;
Thu, 9 Mar 2017 08:09:54 -0800 (PST)
Received: from lists01.pubmisc.prod.ext.phx2.redhat.com
(lists01.pubmisc.prod.ext.phx2.redhat.com [10.5.19.33])
by mx5-phx2.redhat.com (8.14.4/8.14.4) with ESMTP id v29G6ZnL051426;
Thu, 9 Mar 2017 11:06:35 -0500
Received: from smtp.corp.redhat.com (int-mx16.intmail.prod.int.phx2.redhat.com
[10.5.11.28])
by lists01.pubmisc.prod.ext.phx2.redhat.com (8.13.8/8.13.8) with ESMTP
id v29G6WY2032379 for ;
Thu, 9 Mar 2017 11:06:32 -0500
Received: by smtp.corp.redhat.com (Postfix)
id BC4DF2D5C0; Thu, 9 Mar 2017 16:06:32 +0000 (UTC)
Received: from moe.brq.redhat.com (dhcp129-131.brq.redhat.com [10.34.129.131])
by smtp.corp.redhat.com (Postfix) with ESMTP id 4422A2D653
for ; Thu, 9 Mar 2017 16:06:32 +0000 (UTC)
From: Michal Privoznik
To: libvir-list@redhat.com
Date: Thu, 9 Mar 2017 17:06:11 +0100
Message-Id:
<9e68e9e763de971985ca18e3f60a0d9ebe93c720.1489075458.git.mprivozn@redhat.com>
In-Reply-To:
References:
In-Reply-To:
References:
X-Scanned-By: MIMEDefang 2.74 on 10.5.11.28
X-loop: libvir-list@redhat.com
Subject: [libvirt] [PATCH v3 02/17] qemuBuildMemoryBackendStr: Check for
@memAccess properly
X-BeenThere: libvir-list@redhat.com
X-Mailman-Version: 2.1.12
Precedence: junk
List-Id: Development discussions about the libvirt library & tools
List-Unsubscribe: ,
List-Archive:
List-Post:
List-Help:
List-Subscribe: ,
MIME-Version: 1.0
Content-Transfer-Encoding: quoted-printable
Sender: libvir-list-bounces@redhat.com
Errors-To: libvir-list-bounces@redhat.com
X-ZohoMail: RSF_0 Z_629925259 SPT_0
Content-Type: text/plain; charset="utf-8"
Even though this variable contains just values from an enum where
zero has the usual meaning, it's enum after all and we should
check it as such.
Signed-off-by: Michal Privoznik
---
src/qemu/qemu_command.c | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/src/qemu/qemu_command.c b/src/qemu/qemu_command.c
index f145cf9d8..62d3a0a4e 100644
--- a/src/qemu/qemu_command.c
+++ b/src/qemu/qemu_command.c
@@ -3272,7 +3272,8 @@ qemuBuildMemoryBackendStr(unsigned long long size,
}
=20
/* If none of the following is requested... */
- if (!needHugepage && !userNodeset && !memAccess && !nodeSpecified &&
+ if (!needHugepage && !userNodeset && !nodeSpecified &&
+ memAccess =3D=3D VIR_DOMAIN_MEMORY_ACCESS_DEFAULT &&
def->mem.source !=3D VIR_DOMAIN_MEMORY_SOURCE_FILE && !force) {
/* report back that using the new backend is not necessary
* to achieve the desired configuration */
--=20
2.11.0
--
libvir-list mailing list
libvir-list@redhat.com
https://www.redhat.com/mailman/listinfo/libvir-list
From nobody Fri Apr 26 16:12:55 2024
Delivered-To: importer@patchew.org
Received-SPF: pass (zoho.com: domain of redhat.com designates 209.132.183.37
as permitted sender) client-ip=209.132.183.37;
envelope-from=libvir-list-bounces@redhat.com; helo=mx5-phx2.redhat.com;
Authentication-Results: mx.zoho.com;
spf=pass (zoho.com: domain of redhat.com designates 209.132.183.37 as
permitted sender) smtp.mailfrom=libvir-list-bounces@redhat.com;
Return-Path:
Received: from mx5-phx2.redhat.com (mx5-phx2.redhat.com [209.132.183.37]) by
mx.zohomail.com
with SMTPS id 1489075800383648.9956177077697;
Thu, 9 Mar 2017 08:10:00 -0800 (PST)
Received: from lists01.pubmisc.prod.ext.phx2.redhat.com
(lists01.pubmisc.prod.ext.phx2.redhat.com [10.5.19.33])
by mx5-phx2.redhat.com (8.14.4/8.14.4) with ESMTP id v29G6qIf051467;
Thu, 9 Mar 2017 11:06:52 -0500
Received: from smtp.corp.redhat.com (int-mx16.intmail.prod.int.phx2.redhat.com
[10.5.11.28])
by lists01.pubmisc.prod.ext.phx2.redhat.com (8.13.8/8.13.8) with ESMTP
id v29G6Xc0032386 for ;
Thu, 9 Mar 2017 11:06:33 -0500
Received: by smtp.corp.redhat.com (Postfix)
id 8D03C2D655; Thu, 9 Mar 2017 16:06:33 +0000 (UTC)
Received: from moe.brq.redhat.com (dhcp129-131.brq.redhat.com [10.34.129.131])
by smtp.corp.redhat.com (Postfix) with ESMTP id 1405B2D653
for ; Thu, 9 Mar 2017 16:06:32 +0000 (UTC)
From: Michal Privoznik
To: libvir-list@redhat.com
Date: Thu, 9 Mar 2017 17:06:12 +0100
Message-Id:
In-Reply-To:
References:
In-Reply-To:
References:
X-Scanned-By: MIMEDefang 2.74 on 10.5.11.28
X-loop: libvir-list@redhat.com
Subject: [libvirt] [PATCH v3 03/17] qemuBuildMemoryBackendStr: Pass
virDomainMemoryDefPtr
X-BeenThere: libvir-list@redhat.com
X-Mailman-Version: 2.1.12
Precedence: junk
List-Id: Development discussions about the libvirt library & tools
List-Unsubscribe: ,
List-Archive:
List-Post:
List-Help:
List-Subscribe: ,
MIME-Version: 1.0
Content-Transfer-Encoding: quoted-printable
Sender: libvir-list-bounces@redhat.com
Errors-To: libvir-list-bounces@redhat.com
X-ZohoMail: RSF_0 Z_629925259 SPT_0
Content-Type: text/plain; charset="utf-8"
Signed-off-by: Michal Privoznik
---
src/qemu/qemu_command.c | 49 ++++++++++++++++++++++-----------------------=
----
src/qemu/qemu_command.h | 5 +----
src/qemu/qemu_hotplug.c | 6 ++----
3 files changed, 25 insertions(+), 35 deletions(-)
diff --git a/src/qemu/qemu_command.c b/src/qemu/qemu_command.c
index 62d3a0a4e..cbe3e3492 100644
--- a/src/qemu/qemu_command.c
+++ b/src/qemu/qemu_command.c
@@ -3078,11 +3078,7 @@ qemuBuildControllerDevCommandLine(virCommandPtr cmd,
=20
/**
* qemuBuildMemoryBackendStr:
- * @size: size of the memory device in kibibytes
- * @pagesize: size of the requested memory page in KiB, 0 for default
- * @guestNode: NUMA node in the guest that the memory object will be attac=
hed
- * to, or -1 if NUMA is not used in the guest
- * @hostNodes: map of host nodes to alloc the memory in, NULL for default
+ * @mem: memory definition object
* @autoNodeset: fallback nodeset in case of automatic numa placement
* @def: domain definition object
* @qemuCaps: qemu capabilities object
@@ -3100,10 +3096,7 @@ qemuBuildControllerDevCommandLine(virCommandPtr cmd,
* -1 in case of an error.
*/
int
-qemuBuildMemoryBackendStr(unsigned long long size,
- unsigned long long pagesize,
- int guestNode,
- virBitmapPtr userNodeset,
+qemuBuildMemoryBackendStr(virDomainMemoryDefPtr mem,
virBitmapPtr autoNodeset,
virDomainDefPtr def,
virQEMUCapsPtr qemuCaps,
@@ -3122,26 +3115,27 @@ qemuBuildMemoryBackendStr(unsigned long long size,
virBitmapPtr nodemask =3D NULL;
int ret =3D -1;
virJSONValuePtr props =3D NULL;
- bool nodeSpecified =3D virDomainNumatuneNodeSpecified(def->numa, guest=
Node);
+ bool nodeSpecified =3D virDomainNumatuneNodeSpecified(def->numa, mem->=
targetNode);
+ unsigned long long pagesize =3D mem->pagesize;
bool needHugepage =3D !!pagesize;
=20
*backendProps =3D NULL;
*backendType =3D NULL;
=20
- if (guestNode >=3D 0) {
+ if (mem->targetNode >=3D 0) {
/* memory devices could provide a invalid guest node */
- if (guestNode >=3D virDomainNumaGetNodeCount(def->numa)) {
+ if (mem->targetNode >=3D virDomainNumaGetNodeCount(def->numa)) {
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
_("can't add memory backend for guest node '%d'=
as "
"the guest has only '%zu' NUMA nodes configur=
ed"),
- guestNode, virDomainNumaGetNodeCount(def->numa)=
);
+ mem->targetNode, virDomainNumaGetNodeCount(def-=
>numa));
return -1;
}
=20
- memAccess =3D virDomainNumaGetNodeMemoryAccessMode(def->numa, gues=
tNode);
+ memAccess =3D virDomainNumaGetNodeMemoryAccessMode(def->numa, mem-=
>targetNode);
}
=20
- if (virDomainNumatuneGetMode(def->numa, guestNode, &mode) < 0 &&
+ if (virDomainNumatuneGetMode(def->numa, mem->targetNode, &mode) < 0 &&
virDomainNumatuneGetMode(def->numa, -1, &mode) < 0)
mode =3D VIR_DOMAIN_NUMATUNE_MEM_STRICT;
=20
@@ -3158,10 +3152,10 @@ qemuBuildMemoryBackendStr(unsigned long long size,
}
=20
/* just find the master hugepage in case we don't use NUMA */
- if (guestNode < 0)
+ if (mem->targetNode < 0)
continue;
=20
- if (virBitmapGetBit(hugepage->nodemask, guestNode,
+ if (virBitmapGetBit(hugepage->nodemask, mem->targetNode,
&thisHugepage) < 0) {
/* Ignore this error. It's not an error after all. Well,
* the nodemask for this can contain lower NUMA
@@ -3250,14 +3244,14 @@ qemuBuildMemoryBackendStr(unsigned long long size,
*backendType =3D "memory-backend-ram";
}
=20
- if (virJSONValueObjectAdd(props, "U:size", size * 1024, NULL) < 0)
+ if (virJSONValueObjectAdd(props, "U:size", mem->size * 1024, NULL) < 0)
goto cleanup;
=20
- if (userNodeset) {
- nodemask =3D userNodeset;
+ if (mem->sourceNodes) {
+ nodemask =3D mem->sourceNodes;
} else {
if (virDomainNumatuneMaybeGetNodeset(def->numa, autoNodeset,
- &nodemask, guestNode) < 0)
+ &nodemask, mem->targetNode) <=
0)
goto cleanup;
}
=20
@@ -3272,7 +3266,7 @@ qemuBuildMemoryBackendStr(unsigned long long size,
}
=20
/* If none of the following is requested... */
- if (!needHugepage && !userNodeset && !nodeSpecified &&
+ if (!needHugepage && !mem->sourceNodes && !nodeSpecified &&
memAccess =3D=3D VIR_DOMAIN_MEMORY_ACCESS_DEFAULT &&
def->mem.source !=3D VIR_DOMAIN_MEMORY_SOURCE_FILE && !force) {
/* report back that using the new backend is not necessary
@@ -3321,17 +3315,19 @@ qemuBuildMemoryCellBackendStr(virDomainDefPtr def,
const char *backendType;
int ret =3D -1;
int rc;
+ virDomainMemoryDef mem =3D { 0 };
unsigned long long memsize =3D virDomainNumaGetNodeMemorySize(def->num=
a,
cell);
=20
*backendStr =3D NULL;
+ mem.size =3D memsize;
+ mem.targetNode =3D cell;
=20
if (virAsprintf(&alias, "ram-node%zu", cell) < 0)
goto cleanup;
=20
- if ((rc =3D qemuBuildMemoryBackendStr(memsize, 0, cell, NULL, auto_nod=
eset,
- def, qemuCaps, cfg, &backendType,
- &props, false)) < 0)
+ if ((rc =3D qemuBuildMemoryBackendStr(&mem, auto_nodeset, def, qemuCap=
s,
+ cfg, &backendType, &props, false))=
< 0)
goto cleanup;
=20
if (!(*backendStr =3D virQEMUBuildObjectCommandlineFromJSON(backendTyp=
e,
@@ -3370,8 +3366,7 @@ qemuBuildMemoryDimmBackendStr(virDomainMemoryDefPtr m=
em,
if (virAsprintf(&alias, "mem%s", mem->info.alias) < 0)
goto cleanup;
=20
- if (qemuBuildMemoryBackendStr(mem->size, mem->pagesize,
- mem->targetNode, mem->sourceNodes, auto_=
nodeset,
+ if (qemuBuildMemoryBackendStr(mem, auto_nodeset,
def, qemuCaps, cfg,
&backendType, &props, true) < 0)
goto cleanup;
diff --git a/src/qemu/qemu_command.h b/src/qemu/qemu_command.h
index 69fe84613..9b2b81f55 100644
--- a/src/qemu/qemu_command.h
+++ b/src/qemu/qemu_command.h
@@ -124,10 +124,7 @@ char *qemuBuildControllerDevStr(const virDomainDef *do=
mainDef,
virQEMUCapsPtr qemuCaps,
int *nusbcontroller);
=20
-int qemuBuildMemoryBackendStr(unsigned long long size,
- unsigned long long pagesize,
- int guestNode,
- virBitmapPtr userNodeset,
+int qemuBuildMemoryBackendStr(virDomainMemoryDefPtr mem,
virBitmapPtr autoNodeset,
virDomainDefPtr def,
virQEMUCapsPtr qemuCaps,
diff --git a/src/qemu/qemu_hotplug.c b/src/qemu/qemu_hotplug.c
index 0e4af830f..39710db19 100644
--- a/src/qemu/qemu_hotplug.c
+++ b/src/qemu/qemu_hotplug.c
@@ -2240,10 +2240,8 @@ qemuDomainAttachMemory(virQEMUDriverPtr driver,
if (!(devstr =3D qemuBuildMemoryDeviceStr(mem)))
goto cleanup;
=20
- if (qemuBuildMemoryBackendStr(mem->size, mem->pagesize,
- mem->targetNode, mem->sourceNodes, NULL,
- vm->def, priv->qemuCaps, cfg,
- &backendType, &props, true) < 0)
+ if (qemuBuildMemoryBackendStr(mem, NULL, vm->def, priv->qemuCaps,
+ cfg, &backendType, &props, true) < 0)
goto cleanup;
=20
if (virDomainMemoryInsert(vm->def, mem) < 0) {
--=20
2.11.0
--
libvir-list mailing list
libvir-list@redhat.com
https://www.redhat.com/mailman/listinfo/libvir-list
From nobody Fri Apr 26 16:12:55 2024
Delivered-To: importer@patchew.org
Received-SPF: pass (zoho.com: domain of redhat.com designates 209.132.183.25
as permitted sender) client-ip=209.132.183.25;
envelope-from=libvir-list-bounces@redhat.com; helo=mx4-phx2.redhat.com;
Authentication-Results: mx.zoho.com;
spf=pass (zoho.com: domain of redhat.com designates 209.132.183.25 as
permitted sender) smtp.mailfrom=libvir-list-bounces@redhat.com;
Return-Path:
Received: from mx4-phx2.redhat.com (mx4-phx2.redhat.com [209.132.183.25]) by
mx.zohomail.com
with SMTPS id 148907581274582.04568340820936;
Thu, 9 Mar 2017 08:10:12 -0800 (PST)
Received: from lists01.pubmisc.prod.ext.phx2.redhat.com
(lists01.pubmisc.prod.ext.phx2.redhat.com [10.5.19.33])
by mx4-phx2.redhat.com (8.13.8/8.13.8) with ESMTP id v29G6qtf017852;
Thu, 9 Mar 2017 11:06:52 -0500
Received: from smtp.corp.redhat.com (int-mx16.intmail.prod.int.phx2.redhat.com
[10.5.11.28])
by lists01.pubmisc.prod.ext.phx2.redhat.com (8.13.8/8.13.8) with ESMTP
id v29G6Y5L032391 for ;
Thu, 9 Mar 2017 11:06:34 -0500
Received: by smtp.corp.redhat.com (Postfix)
id 5E46E2D655; Thu, 9 Mar 2017 16:06:34 +0000 (UTC)
Received: from moe.brq.redhat.com (dhcp129-131.brq.redhat.com [10.34.129.131])
by smtp.corp.redhat.com (Postfix) with ESMTP id D955D2D653
for ; Thu, 9 Mar 2017 16:06:33 +0000 (UTC)
From: Michal Privoznik
To: libvir-list@redhat.com
Date: Thu, 9 Mar 2017 17:06:13 +0100
Message-Id:
<4640900046d99c303e31dc573838fde949a0215c.1489075458.git.mprivozn@redhat.com>
In-Reply-To:
References:
In-Reply-To:
References:
X-Scanned-By: MIMEDefang 2.74 on 10.5.11.28
X-loop: libvir-list@redhat.com
Subject: [libvirt] [PATCH v3 04/17] qemuBuildMemoryBackendStr: Reorder args
and update comment
X-BeenThere: libvir-list@redhat.com
X-Mailman-Version: 2.1.12
Precedence: junk
List-Id: Development discussions about the libvirt library & tools
List-Unsubscribe: ,
List-Archive:
List-Post:
List-Help:
List-Subscribe: ,
MIME-Version: 1.0
Content-Transfer-Encoding: quoted-printable
Sender: libvir-list-bounces@redhat.com
Errors-To: libvir-list-bounces@redhat.com
X-ZohoMail: RSF_0 Z_629925259 SPT_0
Content-Type: text/plain; charset="utf-8"
Frankly, this function is one big mess. A lot of arguments,
complicated behaviour. It's really surprising that arguments were
in random order (input and output arguments were mixed together),
the documentation was outdated, the description of return values
was bogus.
Signed-off-by: Michal Privoznik
---
src/qemu/qemu_command.c | 54 +++++++++++++++++++++++++++------------------=
----
src/qemu/qemu_command.h | 12 +++++------
src/qemu/qemu_hotplug.c | 4 ++--
3 files changed, 38 insertions(+), 32 deletions(-)
diff --git a/src/qemu/qemu_command.c b/src/qemu/qemu_command.c
index cbe3e3492..0cca99567 100644
--- a/src/qemu/qemu_command.c
+++ b/src/qemu/qemu_command.c
@@ -3078,31 +3078,38 @@ qemuBuildControllerDevCommandLine(virCommandPtr cmd,
=20
/**
* qemuBuildMemoryBackendStr:
- * @mem: memory definition object
- * @autoNodeset: fallback nodeset in case of automatic numa placement
- * @def: domain definition object
- * @qemuCaps: qemu capabilities object
+ * @backendProps: [out] constructed object
+ * @backendType: [out] type of the backennd used
* @cfg: qemu driver config object
- * @aliasPrefix: prefix string of the alias (to allow for multiple fronten=
ts)
- * @id: index of the device (to construct the alias)
- * @backendStr: returns the object string
+ * @qemuCaps: qemu capabilities object
+ * @def: domain definition object
+ * @mem: memory definition object
+ * @autoNodeset: fallback nodeset in case of automatic NUMA placement
+ * @force: forcibly use one of the backends
*
- * Formats the configuration string for the memory device backend according
- * to the configuration. @pagesize and @hostNodes can be used to override =
the
- * default source configuration, both are optional.
+ * Creates a configuration object that represents memory backend of given =
guest
+ * NUMA node (domain @def and @mem). Use @autoNodeset to fine tune the
+ * placement of the memory on the host NUMA nodes.
*
- * Returns 0 on success, 1 if only the implicit memory-device-ram with no
- * other configuration was used (to detect legacy configurations). Returns
- * -1 in case of an error.
+ * By default, if no memory-backend-* object is necessary to fulfil the gu=
est
+ * configuration value of 1 is returned. This behaviour can be suppressed =
by
+ * setting @force to true in which case 0 would be returned.
+ *
+ * Then, if one of the two memory-backend-* should be used, the @qemuCaps =
is
+ * consulted to check if qemu does support it.
+ *
+ * Returns: 0 on success,
+ * 1 on success and if there's no need to use memory-backend-*
+ * -1 on error.
*/
int
-qemuBuildMemoryBackendStr(virDomainMemoryDefPtr mem,
- virBitmapPtr autoNodeset,
- virDomainDefPtr def,
- virQEMUCapsPtr qemuCaps,
- virQEMUDriverConfigPtr cfg,
+qemuBuildMemoryBackendStr(virJSONValuePtr *backendProps,
const char **backendType,
- virJSONValuePtr *backendProps,
+ virQEMUDriverConfigPtr cfg,
+ virQEMUCapsPtr qemuCaps,
+ virDomainDefPtr def,
+ virDomainMemoryDefPtr mem,
+ virBitmapPtr autoNodeset,
bool force)
{
virDomainHugePagePtr master_hugepage =3D NULL;
@@ -3326,8 +3333,8 @@ qemuBuildMemoryCellBackendStr(virDomainDefPtr def,
if (virAsprintf(&alias, "ram-node%zu", cell) < 0)
goto cleanup;
=20
- if ((rc =3D qemuBuildMemoryBackendStr(&mem, auto_nodeset, def, qemuCap=
s,
- cfg, &backendType, &props, false))=
< 0)
+ if ((rc =3D qemuBuildMemoryBackendStr(&props, &backendType, cfg, qemuC=
aps,
+ def, &mem, auto_nodeset, false)) <=
0)
goto cleanup;
=20
if (!(*backendStr =3D virQEMUBuildObjectCommandlineFromJSON(backendTyp=
e,
@@ -3366,9 +3373,8 @@ qemuBuildMemoryDimmBackendStr(virDomainMemoryDefPtr m=
em,
if (virAsprintf(&alias, "mem%s", mem->info.alias) < 0)
goto cleanup;
=20
- if (qemuBuildMemoryBackendStr(mem, auto_nodeset,
- def, qemuCaps, cfg,
- &backendType, &props, true) < 0)
+ if (qemuBuildMemoryBackendStr(&props, &backendType, cfg, qemuCaps,
+ def, mem, auto_nodeset, true) < 0)
goto cleanup;
=20
ret =3D virQEMUBuildObjectCommandlineFromJSON(backendType, alias, prop=
s);
diff --git a/src/qemu/qemu_command.h b/src/qemu/qemu_command.h
index 9b2b81f55..f3ed9e7e4 100644
--- a/src/qemu/qemu_command.h
+++ b/src/qemu/qemu_command.h
@@ -124,13 +124,13 @@ char *qemuBuildControllerDevStr(const virDomainDef *d=
omainDef,
virQEMUCapsPtr qemuCaps,
int *nusbcontroller);
=20
-int qemuBuildMemoryBackendStr(virDomainMemoryDefPtr mem,
- virBitmapPtr autoNodeset,
- virDomainDefPtr def,
- virQEMUCapsPtr qemuCaps,
- virQEMUDriverConfigPtr cfg,
+int qemuBuildMemoryBackendStr(virJSONValuePtr *backendProps,
const char **backendType,
- virJSONValuePtr *backendProps,
+ virQEMUDriverConfigPtr cfg,
+ virQEMUCapsPtr qemuCaps,
+ virDomainDefPtr def,
+ virDomainMemoryDefPtr mem,
+ virBitmapPtr autoNodeset,
bool force);
=20
char *qemuBuildMemoryDeviceStr(virDomainMemoryDefPtr mem);
diff --git a/src/qemu/qemu_hotplug.c b/src/qemu/qemu_hotplug.c
index 39710db19..4e416b12e 100644
--- a/src/qemu/qemu_hotplug.c
+++ b/src/qemu/qemu_hotplug.c
@@ -2240,8 +2240,8 @@ qemuDomainAttachMemory(virQEMUDriverPtr driver,
if (!(devstr =3D qemuBuildMemoryDeviceStr(mem)))
goto cleanup;
=20
- if (qemuBuildMemoryBackendStr(mem, NULL, vm->def, priv->qemuCaps,
- cfg, &backendType, &props, true) < 0)
+ if (qemuBuildMemoryBackendStr(&props, &backendType, cfg,
+ priv->qemuCaps, vm->def, mem, NULL, true=
) < 0)
goto cleanup;
=20
if (virDomainMemoryInsert(vm->def, mem) < 0) {
--=20
2.11.0
--
libvir-list mailing list
libvir-list@redhat.com
https://www.redhat.com/mailman/listinfo/libvir-list
From nobody Fri Apr 26 16:12:55 2024
Delivered-To: importer@patchew.org
Received-SPF: pass (zoho.com: domain of redhat.com designates 209.132.183.39
as permitted sender) client-ip=209.132.183.39;
envelope-from=libvir-list-bounces@redhat.com; helo=mx6-phx2.redhat.com;
Authentication-Results: mx.zoho.com;
spf=pass (zoho.com: domain of redhat.com designates 209.132.183.39 as
permitted sender) smtp.mailfrom=libvir-list-bounces@redhat.com;
Return-Path:
Received: from mx6-phx2.redhat.com (mx6-phx2.redhat.com [209.132.183.39]) by
mx.zohomail.com
with SMTPS id 1489075830020679.3798617761187;
Thu, 9 Mar 2017 08:10:30 -0800 (PST)
Received: from lists01.pubmisc.prod.ext.phx2.redhat.com
(lists01.pubmisc.prod.ext.phx2.redhat.com [10.5.19.33])
by mx6-phx2.redhat.com (8.14.4/8.14.4) with ESMTP id v29G6te9058578;
Thu, 9 Mar 2017 11:06:55 -0500
Received: from smtp.corp.redhat.com (int-mx16.intmail.prod.int.phx2.redhat.com
[10.5.11.28])
by lists01.pubmisc.prod.ext.phx2.redhat.com (8.13.8/8.13.8) with ESMTP
id v29G6Z9O032402 for ;
Thu, 9 Mar 2017 11:06:35 -0500
Received: by smtp.corp.redhat.com (Postfix)
id 551892D5C0; Thu, 9 Mar 2017 16:06:35 +0000 (UTC)
Received: from moe.brq.redhat.com (dhcp129-131.brq.redhat.com [10.34.129.131])
by smtp.corp.redhat.com (Postfix) with ESMTP id AA4562D653
for ; Thu, 9 Mar 2017 16:06:34 +0000 (UTC)
From: Michal Privoznik
To: libvir-list@redhat.com
Date: Thu, 9 Mar 2017 17:06:14 +0100
Message-Id:
In-Reply-To:
References:
In-Reply-To:
References:
X-Scanned-By: MIMEDefang 2.74 on 10.5.11.28
X-loop: libvir-list@redhat.com
Subject: [libvirt] [PATCH v3 05/17] Introduce NVDIMM memory model
X-BeenThere: libvir-list@redhat.com
X-Mailman-Version: 2.1.12
Precedence: junk
List-Id: Development discussions about the libvirt library & tools
List-Unsubscribe: ,
List-Archive:
List-Post:
List-Help:
List-Subscribe: ,
MIME-Version: 1.0
Content-Transfer-Encoding: quoted-printable
Sender: libvir-list-bounces@redhat.com
Errors-To: libvir-list-bounces@redhat.com
X-ZohoMail: RSF_0 Z_629925259 SPT_0
Content-Type: text/plain; charset="utf-8"
NVDIMM is new type of memory introduced into QEMU 2.6. The idea
is that we have a Non-Volatile memory module that keeps the data
persistent across domain reboots.
At the domain XML level, we already have some representation of
'dimm' modules. Long story short, we have element that
lives under . Now, the element even has @model
attribute which we can use to introduce new memory type:
5232640
So far, this is just a XML parser/formatter extension. QEMU
driver implementation is in the next commit.
For more info on NVDIMM visit the following web page:
http://pmem.io/
Signed-off-by: Michal Privoznik
---
docs/formatdomain.html.in | 56 +++++++++----
docs/schemas/domaincommon.rng | 32 ++++---
src/conf/domain_conf.c | 97 ++++++++++++++++--=
----
src/conf/domain_conf.h | 2 +
src/qemu/qemu_command.c | 6 ++
src/qemu/qemu_domain.c | 5 ++
.../qemuxml2argv-memory-hotplug-nvdimm.xml | 56 +++++++++++++
.../qemuxml2xmlout-memory-hotplug-nvdimm.xml | 1 +
tests/qemuxml2xmltest.c | 1 +
9 files changed, 205 insertions(+), 51 deletions(-)
create mode 100644 tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdi=
mm.xml
create mode 120000 tests/qemuxml2xmloutdata/qemuxml2xmlout-memory-hotplug-=
nvdimm.xml
diff --git a/docs/formatdomain.html.in b/docs/formatdomain.html.in
index 3095111c4..6e89bfe3a 100644
--- a/docs/formatdomain.html.in
+++ b/docs/formatdomain.html.in
@@ -7091,7 +7091,6 @@ qemu-kvm -net nic,model=3D? /dev/null
guests' memory resource needs.
=20
Some hypervisors may require NUMA configured for the guest.
- Since 1.2.14
- Currently only the dimm model is supported in order=
to
- add a virtual DIMM module to the guest.
+ Provide dimm to add a virtual DIMM module to the gu=
est.
+ Since 1.2.14
+ Provide nvdimm model adds a Non-Volatile DIMM
+ module. Since 3.2.0
=20
source
- The optional source element allows to fine tune the source of the
- memory used for the given memory device. If the element is not
- provided defaults configured via numatune are used.
+ For model dimm this element is optional and allows =
to
+ fine tune the source of the memory used for the given memory dev=
ice.
+ If the element is not provided defaults configured via
+ numatune are used. If dimm is provided,
+ then the following optional elements can be provided as well:
-
- pagesize can optionally be used to override the def=
ault
- host page size used for backing the memory device.
=20
- The configured value must correspond to a page size supported by=
the
- host.
-
+
+
pagesize
+
+
+ This element can be used to override the default
+ host page size used for backing the memory device.
+ The configured value must correspond to a page size
+ supported by the host.
+
+
+
+
nodemask
+
+
+ This element can be used to override the default
+ set of NUMA nodes where the memory would be
+ allocated.
+
+
+
+
- nodemask can optionally be used to override the def=
ault
- set of NUMA nodes where the memory would be allocated.
+ For model nvdimm this element is mandatory and has a
+ single child element path that represents a path
+ in the host that backs the nvdimm module in the guest.
=20
diff --git a/docs/schemas/domaincommon.rng b/docs/schemas/domaincommon.rng
index 1860f9075..07b3c52ad 100644
--- a/docs/schemas/domaincommon.rng
+++ b/docs/schemas/domaincommon.rng
@@ -4746,6 +4746,7 @@
dimm
+ nvdimm
@@ -4765,18 +4766,27 @@
=20
-
-
-
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
-
-
-
-
-
-
-
+
+
=20
diff --git a/src/conf/domain_conf.c b/src/conf/domain_conf.c
index a58f99762..e23ce0015 100644
--- a/src/conf/domain_conf.c
+++ b/src/conf/domain_conf.c
@@ -858,8 +858,11 @@ VIR_ENUM_DECL(virDomainBlockJob)
VIR_ENUM_IMPL(virDomainBlockJob, VIR_DOMAIN_BLOCK_JOB_TYPE_LAST,
"", "", "copy", "", "active-commit")
=20
-VIR_ENUM_IMPL(virDomainMemoryModel, VIR_DOMAIN_MEMORY_MODEL_LAST,
- "", "dimm")
+VIR_ENUM_IMPL(virDomainMemoryModel,
+ VIR_DOMAIN_MEMORY_MODEL_LAST,
+ "",
+ "dimm",
+ "nvdimm")
=20
VIR_ENUM_IMPL(virDomainShmemModel, VIR_DOMAIN_SHMEM_MODEL_LAST,
"ivshmem",
@@ -2418,6 +2421,7 @@ void virDomainMemoryDefFree(virDomainMemoryDefPtr def)
if (!def)
return;
=20
+ VIR_FREE(def->nvdimmPath);
virBitmapFree(def->sourceNodes);
virDomainDeviceInfoClear(&def->info);
VIR_FREE(def);
@@ -13769,20 +13773,36 @@ virDomainMemorySourceDefParseXML(xmlNodePtr node,
xmlNodePtr save =3D ctxt->node;
ctxt->node =3D node;
=20
- if (virDomainParseMemory("./pagesize", "./pagesize/@unit", ctxt,
- &def->pagesize, false, false) < 0)
- goto cleanup;
-
- if ((nodemask =3D virXPathString("string(./nodemask)", ctxt))) {
- if (virBitmapParse(nodemask, &def->sourceNodes,
- VIR_DOMAIN_CPUMASK_LEN) < 0)
+ switch ((virDomainMemoryModel) def->model) {
+ case VIR_DOMAIN_MEMORY_MODEL_DIMM:
+ if (virDomainParseMemory("./pagesize", "./pagesize/@unit", ctxt,
+ &def->pagesize, false, false) < 0)
goto cleanup;
=20
- if (virBitmapIsAllClear(def->sourceNodes)) {
- virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
- _("Invalid value of 'nodemask': %s"), nodemask);
+ if ((nodemask =3D virXPathString("string(./nodemask)", ctxt))) {
+ if (virBitmapParse(nodemask, &def->sourceNodes,
+ VIR_DOMAIN_CPUMASK_LEN) < 0)
+ goto cleanup;
+
+ if (virBitmapIsAllClear(def->sourceNodes)) {
+ virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
+ _("Invalid value of 'nodemask': %s"), nodem=
ask);
+ goto cleanup;
+ }
+ }
+ break;
+
+ case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
+ if (!(def->nvdimmPath =3D virXPathString("string(./path)", ctxt)))=
{
+ virReportError(VIR_ERR_XML_DETAIL, "%s",
+ _("path is required for model nvdimm'"));
goto cleanup;
}
+ break;
+
+ case VIR_DOMAIN_MEMORY_MODEL_NONE:
+ case VIR_DOMAIN_MEMORY_MODEL_LAST:
+ break;
}
=20
ret =3D 0;
@@ -15187,12 +15207,25 @@ virDomainMemoryFindByDefInternal(virDomainDefPtr =
def,
tmp->size !=3D mem->size)
continue;
=20
- /* source stuff -> match with device */
- if (tmp->pagesize !=3D mem->pagesize)
- continue;
+ switch ((virDomainMemoryModel) mem->model) {
+ case VIR_DOMAIN_MEMORY_MODEL_DIMM:
+ /* source stuff -> match with device */
+ if (tmp->pagesize !=3D mem->pagesize)
+ continue;
=20
- if (!virBitmapEqual(tmp->sourceNodes, mem->sourceNodes))
- continue;
+ if (!virBitmapEqual(tmp->sourceNodes, mem->sourceNodes))
+ continue;
+ break;
+
+ case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
+ if (STRNEQ(tmp->nvdimmPath, mem->nvdimmPath))
+ continue;
+ break;
+
+ case VIR_DOMAIN_MEMORY_MODEL_NONE:
+ case VIR_DOMAIN_MEMORY_MODEL_LAST:
+ break;
+ }
=20
break;
}
@@ -22585,23 +22618,35 @@ virDomainMemorySourceDefFormat(virBufferPtr buf,
char *bitmap =3D NULL;
int ret =3D -1;
=20
- if (!def->pagesize && !def->sourceNodes)
+ if (!def->pagesize && !def->sourceNodes && !def->nvdimmPath)
return 0;
=20
virBufferAddLit(buf, "\n");
=20
diff --git a/src/conf/domain_conf.h b/src/conf/domain_conf.h
index 1e53cc328..823582253 100644
--- a/src/conf/domain_conf.h
+++ b/src/conf/domain_conf.h
@@ -1996,6 +1996,7 @@ struct _virDomainRNGDef {
typedef enum {
VIR_DOMAIN_MEMORY_MODEL_NONE,
VIR_DOMAIN_MEMORY_MODEL_DIMM, /* dimm hotpluggable memory device */
+ VIR_DOMAIN_MEMORY_MODEL_NVDIMM, /* nvdimm memory device */
=20
VIR_DOMAIN_MEMORY_MODEL_LAST
} virDomainMemoryModel;
@@ -2004,6 +2005,7 @@ struct _virDomainMemoryDef {
/* source */
virBitmapPtr sourceNodes;
unsigned long long pagesize; /* kibibytes */
+ char *nvdimmPath;
=20
/* target */
int model; /* virDomainMemoryModel */
diff --git a/src/qemu/qemu_command.c b/src/qemu/qemu_command.c
index 0cca99567..07178f839 100644
--- a/src/qemu/qemu_command.c
+++ b/src/qemu/qemu_command.c
@@ -3416,6 +3416,12 @@ qemuBuildMemoryDeviceStr(virDomainMemoryDefPtr mem)
=20
break;
=20
+ case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
+ virReportError(VIR_ERR_NO_SUPPORT, "%s",
+ _("nvdimm not supported yet"));
+ return NULL;
+ break;
+
case VIR_DOMAIN_MEMORY_MODEL_NONE:
case VIR_DOMAIN_MEMORY_MODEL_LAST:
break;
diff --git a/src/qemu/qemu_domain.c b/src/qemu/qemu_domain.c
index 1a42fcf1b..66c0e5911 100644
--- a/src/qemu/qemu_domain.c
+++ b/src/qemu/qemu_domain.c
@@ -5951,6 +5951,11 @@ qemuDomainDefValidateMemoryHotplugDevice(const virDo=
mainMemoryDef *mem,
}
break;
=20
+ case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
+ virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
+ _("nvdimm hotplug not supported yet"));
+ return -1;
+
case VIR_DOMAIN_MEMORY_MODEL_NONE:
case VIR_DOMAIN_MEMORY_MODEL_LAST:
return -1;
diff --git a/tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdimm.xml =
b/tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdimm.xml
new file mode 100644
index 000000000..1578db453
--- /dev/null
+++ b/tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdimm.xml
@@ -0,0 +1,56 @@
+
+ QEMUGuest1
+ c7a5fdbd-edaf-9455-926a-d65c16db1809
+ 1099511627776
+ 1267710
+ 1267710
+ 2
+
+ hvm
+
+
+
+
+
+
+
+
+
+
+
+
+
+ destroy
+ restart
+ destroy
+
+ /usr/bin/qemu
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 523264
+ 0
+
+
+
+
+
diff --git a/tests/qemuxml2xmloutdata/qemuxml2xmlout-memory-hotplug-nvdimm.=
xml b/tests/qemuxml2xmloutdata/qemuxml2xmlout-memory-hotplug-nvdimm.xml
new file mode 120000
index 000000000..4cac477a9
--- /dev/null
+++ b/tests/qemuxml2xmloutdata/qemuxml2xmlout-memory-hotplug-nvdimm.xml
@@ -0,0 +1 @@
+../qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdimm.xml
\ No newline at end of file
diff --git a/tests/qemuxml2xmltest.c b/tests/qemuxml2xmltest.c
index 4353ad245..e1c341dd5 100644
--- a/tests/qemuxml2xmltest.c
+++ b/tests/qemuxml2xmltest.c
@@ -1078,6 +1078,7 @@ mymain(void)
DO_TEST("memory-hotplug", NONE);
DO_TEST("memory-hotplug-nonuma", NONE);
DO_TEST("memory-hotplug-dimm", NONE);
+ DO_TEST("memory-hotplug-nvdimm", NONE);
DO_TEST("net-udp", NONE);
=20
DO_TEST("video-virtio-gpu-device", NONE);
--=20
2.11.0
--
libvir-list mailing list
libvir-list@redhat.com
https://www.redhat.com/mailman/listinfo/libvir-list
From nobody Fri Apr 26 16:12:55 2024
Delivered-To: importer@patchew.org
Received-SPF: pass (zoho.com: domain of redhat.com designates 209.132.183.39
as permitted sender) client-ip=209.132.183.39;
envelope-from=libvir-list-bounces@redhat.com; helo=mx6-phx2.redhat.com;
Authentication-Results: mx.zoho.com;
spf=pass (zoho.com: domain of redhat.com designates 209.132.183.39 as
permitted sender) smtp.mailfrom=libvir-list-bounces@redhat.com;
Return-Path:
Received: from mx6-phx2.redhat.com (mx6-phx2.redhat.com [209.132.183.39]) by
mx.zohomail.com
with SMTPS id 1489075818176176.32269911296078;
Thu, 9 Mar 2017 08:10:18 -0800 (PST)
Received: from lists01.pubmisc.prod.ext.phx2.redhat.com
(lists01.pubmisc.prod.ext.phx2.redhat.com [10.5.19.33])
by mx6-phx2.redhat.com (8.14.4/8.14.4) with ESMTP id v29G6t18058579;
Thu, 9 Mar 2017 11:06:55 -0500
Received: from smtp.corp.redhat.com (int-mx16.intmail.prod.int.phx2.redhat.com
[10.5.11.28])
by lists01.pubmisc.prod.ext.phx2.redhat.com (8.13.8/8.13.8) with ESMTP
id v29G6aR6032415 for ;
Thu, 9 Mar 2017 11:06:36 -0500
Received: by smtp.corp.redhat.com (Postfix)
id 2A6292D655; Thu, 9 Mar 2017 16:06:36 +0000 (UTC)
Received: from moe.brq.redhat.com (dhcp129-131.brq.redhat.com [10.34.129.131])
by smtp.corp.redhat.com (Postfix) with ESMTP id 9FFBD2D653
for ; Thu, 9 Mar 2017 16:06:35 +0000 (UTC)
From: Michal Privoznik
To: libvir-list@redhat.com
Date: Thu, 9 Mar 2017 17:06:15 +0100
Message-Id:
<99038b1716cf045da98fe048e578360b5a53cf19.1489075458.git.mprivozn@redhat.com>
In-Reply-To:
References:
In-Reply-To:
References:
X-Scanned-By: MIMEDefang 2.74 on 10.5.11.28
X-loop: libvir-list@redhat.com
Subject: [libvirt] [PATCH v3 06/17] qemu: Introduce QEMU_CAPS_DEVICE_NVDIMM
X-BeenThere: libvir-list@redhat.com
X-Mailman-Version: 2.1.12
Precedence: junk
List-Id: Development discussions about the libvirt library & tools
List-Unsubscribe: ,
List-Archive:
List-Post:
List-Help:
List-Subscribe: ,
MIME-Version: 1.0
Content-Transfer-Encoding: quoted-printable
Sender: libvir-list-bounces@redhat.com
Errors-To: libvir-list-bounces@redhat.com
X-ZohoMail: RSF_0 Z_629925259 SPT_0
Content-Type: text/plain; charset="utf-8"
Introduce a qemu capability for -device nvdimm.
Signed-off-by: Michal Privoznik
---
src/qemu/qemu_capabilities.c | 9 +++++++++
src/qemu/qemu_capabilities.h | 1 +
2 files changed, 10 insertions(+)
diff --git a/src/qemu/qemu_capabilities.c b/src/qemu/qemu_capabilities.c
index 5a3b4ac50..2f459d128 100644
--- a/src/qemu/qemu_capabilities.c
+++ b/src/qemu/qemu_capabilities.c
@@ -359,6 +359,7 @@ VIR_ENUM_IMPL(virQEMUCaps, QEMU_CAPS_LAST,
"query-cpu-model-expansion", /* 245 */
"virtio-net.host_mtu",
"spice-rendernode",
+ "nvdimm",
);
=20
=20
@@ -1626,6 +1627,7 @@ struct virQEMUCapsStringFlags virQEMUCapsObjectTypes[=
] =3D {
{ "ivshmem-plain", QEMU_CAPS_DEVICE_IVSHMEM_PLAIN },
{ "ivshmem-doorbell", QEMU_CAPS_DEVICE_IVSHMEM_DOORBELL },
{ "vhost-scsi", QEMU_CAPS_DEVICE_VHOST_SCSI },
+ { "nvdimm", QEMU_CAPS_DEVICE_NVDIMM },
};
=20
static struct virQEMUCapsStringFlags virQEMUCapsObjectPropsVirtioBalloon[]=
=3D {
@@ -4545,6 +4547,13 @@ virQEMUCapsInitQMPMonitor(virQEMUCapsPtr qemuCaps,
virQEMUCapsProbeQMPGICCapabilities(qemuCaps, mon) < 0)
goto cleanup;
=20
+ /* Prealloc on NVDIMMs is broken on older QEMUs leading to
+ * user data corruption. If we are dealing with such version
+ * of QEMU pretend we don't know how to NVDIMM. */
+ if (qemuCaps->version < 2009000 &&
+ virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_NVDIMM))
+ virQEMUCapsClear(qemuCaps, QEMU_CAPS_DEVICE_NVDIMM);
+
ret =3D 0;
cleanup:
return ret;
diff --git a/src/qemu/qemu_capabilities.h b/src/qemu/qemu_capabilities.h
index cc9f46e65..1b4bcfb2f 100644
--- a/src/qemu/qemu_capabilities.h
+++ b/src/qemu/qemu_capabilities.h
@@ -394,6 +394,7 @@ typedef enum {
QEMU_CAPS_QUERY_CPU_MODEL_EXPANSION, /* qmp query-cpu-model-expansion =
*/
QEMU_CAPS_VIRTIO_NET_HOST_MTU, /* virtio-net-*.host_mtu */
QEMU_CAPS_SPICE_RENDERNODE, /* -spice rendernode */
+ QEMU_CAPS_DEVICE_NVDIMM, /* -device nvdimm */
=20
QEMU_CAPS_LAST /* this must always be the last item */
} virQEMUCapsFlags;
--=20
2.11.0
--
libvir-list mailing list
libvir-list@redhat.com
https://www.redhat.com/mailman/listinfo/libvir-list
From nobody Fri Apr 26 16:12:55 2024
Delivered-To: importer@patchew.org
Received-SPF: pass (zoho.com: domain of redhat.com designates 209.132.183.37
as permitted sender) client-ip=209.132.183.37;
envelope-from=libvir-list-bounces@redhat.com; helo=mx5-phx2.redhat.com;
Authentication-Results: mx.zoho.com;
spf=pass (zoho.com: domain of redhat.com designates 209.132.183.37 as
permitted sender) smtp.mailfrom=libvir-list-bounces@redhat.com;
Return-Path:
Received: from mx5-phx2.redhat.com (mx5-phx2.redhat.com [209.132.183.37]) by
mx.zohomail.com
with SMTPS id 1489075808289899.4322744285131;
Thu, 9 Mar 2017 08:10:08 -0800 (PST)
Received: from lists01.pubmisc.prod.ext.phx2.redhat.com
(lists01.pubmisc.prod.ext.phx2.redhat.com [10.5.19.33])
by mx5-phx2.redhat.com (8.14.4/8.14.4) with ESMTP id v29G6s0x051474;
Thu, 9 Mar 2017 11:06:54 -0500
Received: from smtp.corp.redhat.com (int-mx16.intmail.prod.int.phx2.redhat.com
[10.5.11.28])
by lists01.pubmisc.prod.ext.phx2.redhat.com (8.13.8/8.13.8) with ESMTP
id v29G6bop032423 for ;
Thu, 9 Mar 2017 11:06:37 -0500
Received: by smtp.corp.redhat.com (Postfix)
id EF4E02D655; Thu, 9 Mar 2017 16:06:36 +0000 (UTC)
Received: from moe.brq.redhat.com (dhcp129-131.brq.redhat.com [10.34.129.131])
by smtp.corp.redhat.com (Postfix) with ESMTP id 778E42D653
for ; Thu, 9 Mar 2017 16:06:36 +0000 (UTC)
From: Michal Privoznik
To: libvir-list@redhat.com
Date: Thu, 9 Mar 2017 17:06:16 +0100
Message-Id:
<12266bf7b6c3390a02ec675a6ecadac1b449c807.1489075458.git.mprivozn@redhat.com>
In-Reply-To:
References:
In-Reply-To:
References:
X-Scanned-By: MIMEDefang 2.74 on 10.5.11.28
X-loop: libvir-list@redhat.com
Subject: [libvirt] [PATCH v3 07/17] qemu: Implement NVDIMM
X-BeenThere: libvir-list@redhat.com
X-Mailman-Version: 2.1.12
Precedence: junk
List-Id: Development discussions about the libvirt library & tools
List-Unsubscribe: ,
List-Archive:
List-Post:
List-Help:
List-Subscribe: ,
MIME-Version: 1.0
Content-Transfer-Encoding: quoted-printable
Sender: libvir-list-bounces@redhat.com
Errors-To: libvir-list-bounces@redhat.com
X-ZohoMail: RSF_0 Z_629925259 SPT_0
Content-Type: text/plain; charset="utf-8"
So, majority of the code is just ready as-is. Well, with one
slight change: differentiate between dimm and nvdimm in places
like device alias generation, generating the command line and so
on.
Speaking of the command line, we also need to append 'nvdimm=3Don'
to the '-machine' argument so that the nvdimm feature is
advertised in the ACPI tables properly.
Signed-off-by: Michal Privoznik
---
src/qemu/qemu_alias.c | 10 ++-
src/qemu/qemu_command.c | 76 +++++++++++++++---=
----
src/qemu/qemu_domain.c | 42 ++++++++----
.../qemuxml2argv-memory-hotplug-nvdimm.args | 26 ++++++++
tests/qemuxml2argvtest.c | 4 +-
5 files changed, 121 insertions(+), 37 deletions(-)
create mode 100644 tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdi=
mm.args
diff --git a/src/qemu/qemu_alias.c b/src/qemu/qemu_alias.c
index 4cccf231e..05e1293ef 100644
--- a/src/qemu/qemu_alias.c
+++ b/src/qemu/qemu_alias.c
@@ -352,17 +352,23 @@ qemuAssignDeviceMemoryAlias(virDomainDefPtr def,
size_t i;
int maxidx =3D 0;
int idx;
+ const char *prefix;
+
+ if (mem->model =3D=3D VIR_DOMAIN_MEMORY_MODEL_DIMM)
+ prefix =3D "dimm";
+ else
+ prefix =3D "nvdimm";
=20
if (oldAlias) {
for (i =3D 0; i < def->nmems; i++) {
- if ((idx =3D qemuDomainDeviceAliasIndex(&def->mems[i]->info, "=
dimm")) >=3D maxidx)
+ if ((idx =3D qemuDomainDeviceAliasIndex(&def->mems[i]->info, p=
refix)) >=3D maxidx)
maxidx =3D idx + 1;
}
} else {
maxidx =3D mem->info.addr.dimm.slot;
}
=20
- if (virAsprintf(&mem->info.alias, "dimm%d", maxidx) < 0)
+ if (virAsprintf(&mem->info.alias, "%s%d", prefix, maxidx) < 0)
return -1;
=20
return 0;
diff --git a/src/qemu/qemu_command.c b/src/qemu/qemu_command.c
index 07178f839..a66ce6645 100644
--- a/src/qemu/qemu_command.c
+++ b/src/qemu/qemu_command.c
@@ -3118,7 +3118,8 @@ qemuBuildMemoryBackendStr(virJSONValuePtr *backendPro=
ps,
const long system_page_size =3D virGetSystemPageSizeKB();
virDomainMemoryAccess memAccess =3D VIR_DOMAIN_MEMORY_ACCESS_DEFAULT;
size_t i;
- char *mem_path =3D NULL;
+ char *memPath =3D NULL;
+ bool prealloc =3D false;
virBitmapPtr nodemask =3D NULL;
int ret =3D -1;
virJSONValuePtr props =3D NULL;
@@ -3199,26 +3200,31 @@ qemuBuildMemoryBackendStr(virJSONValuePtr *backendP=
rops,
if (!(props =3D virJSONValueNewObject()))
return -1;
=20
- if (pagesize || def->mem.source =3D=3D VIR_DOMAIN_MEMORY_SOURCE_FILE) {
+ if (pagesize || mem->nvdimmPath ||
+ def->mem.source =3D=3D VIR_DOMAIN_MEMORY_SOURCE_FILE) {
*backendType =3D "memory-backend-file";
=20
- if (def->mem.source =3D=3D VIR_DOMAIN_MEMORY_SOURCE_FILE) {
- /* we can have both pagesize and mem source, then check mem so=
urce first */
- if (virJSONValueObjectAdd(props,
- "s:mem-path", cfg->memoryBackingDir,
- NULL) < 0)
+ if (mem->nvdimmPath) {
+ if (VIR_STRDUP(memPath, mem->nvdimmPath) < 0)
+ goto cleanup;
+ prealloc =3D true;
+ } else if (def->mem.source =3D=3D VIR_DOMAIN_MEMORY_SOURCE_FILE) {
+ /* We can have both pagesize and mem source,
+ * then check mem source first. */
+ if (VIR_STRDUP(memPath, cfg->memoryBackingDir) < 0)
goto cleanup;
} else {
- if (qemuGetDomainHupageMemPath(def, cfg, pagesize, &mem_path) =
< 0)
- goto cleanup;
-
- if (virJSONValueObjectAdd(props,
- "b:prealloc", true,
- "s:mem-path", mem_path,
- NULL) < 0)
+ if (qemuGetDomainHupageMemPath(def, cfg, pagesize, &memPath) <=
0)
goto cleanup;
+ prealloc =3D true;
}
=20
+ if (virJSONValueObjectAdd(props,
+ "B:prealloc", prealloc,
+ "s:mem-path", memPath,
+ NULL) < 0)
+ goto cleanup;
+
switch (memAccess) {
case VIR_DOMAIN_MEMORY_ACCESS_SHARED:
if (virJSONValueObjectAdd(props, "b:share", true, NULL) < 0)
@@ -3274,6 +3280,7 @@ qemuBuildMemoryBackendStr(virJSONValuePtr *backendPro=
ps,
=20
/* If none of the following is requested... */
if (!needHugepage && !mem->sourceNodes && !nodeSpecified &&
+ !mem->nvdimmPath &&
memAccess =3D=3D VIR_DOMAIN_MEMORY_ACCESS_DEFAULT &&
def->mem.source !=3D VIR_DOMAIN_MEMORY_SOURCE_FILE && !force) {
/* report back that using the new backend is not necessary
@@ -3303,8 +3310,7 @@ qemuBuildMemoryBackendStr(virJSONValuePtr *backendPro=
ps,
=20
cleanup:
virJSONValueFree(props);
- VIR_FREE(mem_path);
-
+ VIR_FREE(memPath);
return ret;
}
=20
@@ -3391,6 +3397,7 @@ char *
qemuBuildMemoryDeviceStr(virDomainMemoryDefPtr mem)
{
virBuffer buf =3D VIR_BUFFER_INITIALIZER;
+ const char *device;
=20
if (!mem->info.alias) {
virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
@@ -3399,8 +3406,15 @@ qemuBuildMemoryDeviceStr(virDomainMemoryDefPtr mem)
}
=20
switch ((virDomainMemoryModel) mem->model) {
+ case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
- virBufferAddLit(&buf, "pc-dimm,");
+
+ if (mem->model =3D=3D VIR_DOMAIN_MEMORY_MODEL_DIMM)
+ device =3D "pc-dimm";
+ else
+ device =3D "nvdimm";
+
+ virBufferAsprintf(&buf, "%s,", device);
=20
if (mem->targetNode >=3D 0)
virBufferAsprintf(&buf, "node=3D%d,", mem->targetNode);
@@ -3416,12 +3430,6 @@ qemuBuildMemoryDeviceStr(virDomainMemoryDefPtr mem)
=20
break;
=20
- case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
- virReportError(VIR_ERR_NO_SUPPORT, "%s",
- _("nvdimm not supported yet"));
- return NULL;
- break;
-
case VIR_DOMAIN_MEMORY_MODEL_NONE:
case VIR_DOMAIN_MEMORY_MODEL_LAST:
break;
@@ -6972,6 +6980,7 @@ qemuBuildMachineCommandLine(virCommandPtr cmd,
{
virBuffer buf =3D VIR_BUFFER_INITIALIZER;
bool obsoleteAccel =3D false;
+ size_t i;
int ret =3D -1;
=20
/* This should *never* be NULL, since we always provide
@@ -7008,6 +7017,15 @@ qemuBuildMachineCommandLine(virCommandPtr cmd,
"with this QEMU binary"));
return -1;
}
+
+ for (i =3D 0; i < def->nmems; i++) {
+ if (def->mems[i]->model =3D=3D VIR_DOMAIN_MEMORY_MODEL_NVDIMM)=
{
+ virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
+ _("nvdimm not is not available "
+ "with this QEMU binary"));
+ return -1;
+ }
+ }
} else {
virTristateSwitch vmport =3D def->features[VIR_DOMAIN_FEATURE_VMPO=
RT];
virTristateSwitch smm =3D def->features[VIR_DOMAIN_FEATURE_SMM];
@@ -7128,6 +7146,18 @@ qemuBuildMachineCommandLine(virCommandPtr cmd,
}
}
=20
+ for (i =3D 0; i < def->nmems; i++) {
+ if (def->mems[i]->model =3D=3D VIR_DOMAIN_MEMORY_MODEL_NVDIMM)=
{
+ if (!virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_NVDIMM)) {
+ virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
+ _("nvdimm isn't supported by this QEMU =
binary"));
+ goto cleanup;
+ }
+ virBufferAddLit(&buf, ",nvdimm=3Don");
+ break;
+ }
+ }
+
virCommandAddArgBuffer(cmd, &buf);
}
=20
diff --git a/src/qemu/qemu_domain.c b/src/qemu/qemu_domain.c
index 66c0e5911..495242981 100644
--- a/src/qemu/qemu_domain.c
+++ b/src/qemu/qemu_domain.c
@@ -5919,6 +5919,7 @@ qemuDomainDefValidateMemoryHotplugDevice(const virDom=
ainMemoryDef *mem,
{
switch ((virDomainMemoryModel) mem->model) {
case VIR_DOMAIN_MEMORY_MODEL_DIMM:
+ case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
if (mem->info.type !=3D VIR_DOMAIN_DEVICE_ADDRESS_TYPE_DIMM &&
mem->info.type !=3D VIR_DOMAIN_DEVICE_ADDRESS_TYPE_NONE) {
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
@@ -5951,11 +5952,6 @@ qemuDomainDefValidateMemoryHotplugDevice(const virDo=
mainMemoryDef *mem,
}
break;
=20
- case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
- virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
- _("nvdimm hotplug not supported yet"));
- return -1;
-
case VIR_DOMAIN_MEMORY_MODEL_NONE:
case VIR_DOMAIN_MEMORY_MODEL_LAST:
return -1;
@@ -5986,6 +5982,8 @@ qemuDomainDefValidateMemoryHotplug(const virDomainDef=
*def,
unsigned int nmems =3D def->nmems;
unsigned long long hotplugSpace;
unsigned long long hotplugMemory =3D 0;
+ bool needPCDimmCap =3D false;
+ bool needNvdimmCap =3D false;
size_t i;
=20
hotplugSpace =3D def->mem.max_memory - virDomainDefGetMemoryInitial(de=
f);
@@ -6009,12 +6007,6 @@ qemuDomainDefValidateMemoryHotplug(const virDomainDe=
f *def,
return 0;
}
=20
- if (!virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_PC_DIMM)) {
- virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
- _("memory hotplug isn't supported by this QEMU bina=
ry"));
- return -1;
- }
-
if (!ARCH_IS_PPC64(def->os.arch)) {
/* due to guest support, qemu would silently enable NUMA with one =
node
* once the memory hotplug backend is enabled. To avoid possible
@@ -6038,6 +6030,34 @@ qemuDomainDefValidateMemoryHotplug(const virDomainDe=
f *def,
for (i =3D 0; i < def->nmems; i++) {
hotplugMemory +=3D def->mems[i]->size;
=20
+ switch ((virDomainMemoryModel) def->mems[i]->model) {
+ case VIR_DOMAIN_MEMORY_MODEL_DIMM:
+ needPCDimmCap =3D true;
+ break;
+
+ case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
+ needNvdimmCap =3D true;
+ break;
+
+ case VIR_DOMAIN_MEMORY_MODEL_NONE:
+ case VIR_DOMAIN_MEMORY_MODEL_LAST:
+ break;
+ }
+
+ if (needPCDimmCap &&
+ !virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_PC_DIMM)) {
+ virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
+ _("memory hotplug isn't supported by this QEMU =
binary"));
+ return -1;
+ }
+
+ if (needNvdimmCap &&
+ !virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_NVDIMM)) {
+ virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
+ _("nvdimm isn't supported by this QEMU binary")=
);
+ return -1;
+ }
+
/* already existing devices don't need to be checked on hotplug */
if (!mem &&
qemuDomainDefValidateMemoryHotplugDevice(def->mems[i], def) < =
0)
diff --git a/tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdimm.args=
b/tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdimm.args
new file mode 100644
index 000000000..907bcbeda
--- /dev/null
+++ b/tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdimm.args
@@ -0,0 +1,26 @@
+LC_ALL=3DC \
+PATH=3D/bin \
+HOME=3D/home/test \
+USER=3Dtest \
+LOGNAME=3Dtest \
+QEMU_AUDIO_DRV=3Dnone \
+/usr/bin/qemu \
+-name QEMUGuest1 \
+-S \
+-machine pc,accel=3Dtcg,nvdimm=3Don \
+-m size=3D1048576k,slots=3D16,maxmem=3D1099511627776k \
+-smp 2,sockets=3D2,cores=3D1,threads=3D1 \
+-numa node,nodeid=3D0,cpus=3D0-1,mem=3D1024 \
+-object memory-backend-file,id=3Dmemnvdimm0,prealloc=3Dyes,mem-path=3D/tmp=
/nvdimm,\
+size=3D536870912 \
+-device nvdimm,node=3D0,memdev=3Dmemnvdimm0,id=3Dnvdimm0,slot=3D0 \
+-uuid c7a5fdbd-edaf-9455-926a-d65c16db1809 \
+-nographic \
+-nodefaults \
+-monitor unix:/tmp/lib/domain--1-QEMUGuest1/monitor.sock,server,nowait \
+-no-acpi \
+-boot c \
+-usb \
+-drive file=3D/dev/HostVG/QEMUGuest1,format=3Draw,if=3Dnone,id=3Ddrive-ide=
0-0-0 \
+-device ide-drive,bus=3Dide.0,unit=3D0,drive=3Ddrive-ide0-0-0,id=3Dide0-0-=
0 \
+-device virtio-balloon-pci,id=3Dballoon0,bus=3Dpci.0,addr=3D0x3
diff --git a/tests/qemuxml2argvtest.c b/tests/qemuxml2argvtest.c
index d2d267fce..b6fdaaeb3 100644
--- a/tests/qemuxml2argvtest.c
+++ b/tests/qemuxml2argvtest.c
@@ -2329,7 +2329,7 @@ mymain(void)
=20
DO_TEST_FAILURE("memory-align-fail", NONE);
DO_TEST_FAILURE("memory-hotplug-nonuma", QEMU_CAPS_DEVICE_PC_DIMM);
- DO_TEST_FAILURE("memory-hotplug", NONE);
+ DO_TEST("memory-hotplug", NONE);
DO_TEST("memory-hotplug", QEMU_CAPS_DEVICE_PC_DIMM, QEMU_CAPS_NUMA);
DO_TEST("memory-hotplug-dimm", QEMU_CAPS_DEVICE_PC_DIMM, QEMU_CAPS_NUM=
A,
QEMU_CAPS_OBJECT_MEMORY_RAM, QEMU_CAPS_OBJECT_MEMORY_FILE);
@@ -2337,6 +2337,8 @@ mymain(void)
QEMU_CAPS_OBJECT_MEMORY_RAM, QEMU_CAPS_OBJECT_MEMORY_FILE);
DO_TEST("memory-hotplug-ppc64-nonuma", QEMU_CAPS_KVM, QEMU_CAPS_DEVICE=
_PC_DIMM, QEMU_CAPS_NUMA,
QEMU_CAPS_OBJECT_MEMORY_RAM, QEMU_CAPS_OBJECT_MEMORY_FILE);
+ DO_TEST("memory-hotplug-nvdimm", QEMU_CAPS_MACHINE_OPT, QEMU_CAPS_DEVI=
CE_NVDIMM,
+ QEMU_CAPS_NUMA, QEMU_CAPS_OBJECT_MEMORY_RAM, QEMU_CAPS_OBJECT_=
MEMORY_FILE);
=20
DO_TEST("machine-aeskeywrap-on-caps",
QEMU_CAPS_MACHINE_OPT, QEMU_CAPS_AES_KEY_WRAP,
--=20
2.11.0
--
libvir-list mailing list
libvir-list@redhat.com
https://www.redhat.com/mailman/listinfo/libvir-list
From nobody Fri Apr 26 16:12:55 2024
Delivered-To: importer@patchew.org
Received-SPF: pass (zoho.com: domain of redhat.com designates 209.132.183.39
as permitted sender) client-ip=209.132.183.39;
envelope-from=libvir-list-bounces@redhat.com; helo=mx6-phx2.redhat.com;
Authentication-Results: mx.zoho.com;
spf=pass (zoho.com: domain of redhat.com designates 209.132.183.39 as
permitted sender) smtp.mailfrom=libvir-list-bounces@redhat.com;
Return-Path:
Received: from mx6-phx2.redhat.com (mx6-phx2.redhat.com [209.132.183.39]) by
mx.zohomail.com
with SMTPS id 1489075820383158.4422319494472;
Thu, 9 Mar 2017 08:10:20 -0800 (PST)
Received: from lists01.pubmisc.prod.ext.phx2.redhat.com
(lists01.pubmisc.prod.ext.phx2.redhat.com [10.5.19.33])
by mx6-phx2.redhat.com (8.14.4/8.14.4) with ESMTP id v29G6vgF058604;
Thu, 9 Mar 2017 11:06:57 -0500
Received: from smtp.corp.redhat.com (int-mx16.intmail.prod.int.phx2.redhat.com
[10.5.11.28])
by lists01.pubmisc.prod.ext.phx2.redhat.com (8.13.8/8.13.8) with ESMTP
id v29G6bQQ032431 for ;
Thu, 9 Mar 2017 11:06:37 -0500
Received: by smtp.corp.redhat.com (Postfix)
id BF5C42D655; Thu, 9 Mar 2017 16:06:37 +0000 (UTC)
Received: from moe.brq.redhat.com (dhcp129-131.brq.redhat.com [10.34.129.131])
by smtp.corp.redhat.com (Postfix) with ESMTP id 479942D653
for ; Thu, 9 Mar 2017 16:06:37 +0000 (UTC)
From: Michal Privoznik
To: libvir-list@redhat.com
Date: Thu, 9 Mar 2017 17:06:17 +0100
Message-Id:
<1aebdf2f278a185611c85cbc4049b23522922357.1489075458.git.mprivozn@redhat.com>
In-Reply-To:
References:
In-Reply-To:
References:
X-Scanned-By: MIMEDefang 2.74 on 10.5.11.28
X-loop: libvir-list@redhat.com
Subject: [libvirt] [PATCH v3 08/17] conf: Introduce @access to
X-BeenThere: libvir-list@redhat.com
X-Mailman-Version: 2.1.12
Precedence: junk
List-Id: Development discussions about the libvirt library & tools
List-Unsubscribe: ,
List-Archive:
List-Post:
List-Help:
List-Subscribe: ,
MIME-Version: 1.0
Content-Transfer-Encoding: quoted-printable
Sender: libvir-list-bounces@redhat.com
Errors-To: libvir-list-bounces@redhat.com
X-ZohoMail: RSF_0 Z_629925259 SPT_0
Content-Type: text/plain; charset="utf-8"
Now that NVDIMM has found its way into libvirt, users might want
to fine tune some settings for each module separately. One such
setting is 'share=3Don|off' for the memory-backend-file object.
This setting - just like its name suggest already - enables
sharing the nvdimm module with other applications. Under the hood
it controls whether qemu mmaps() the file as MAP_PRIVATE or
MAP_SHARED.
Yet again, we have such config knob in domain XML, but it's just
an attribute to numa . This does not give fine enough
tuning on per-memdevice basis so we need to have the attribute
for each device too.
Signed-off-by: Michal Privoznik
---
docs/formatdomain.html.in | 16 ++++++-
docs/schemas/domaincommon.rng | 8 ++++
src/conf/domain_conf.c | 15 +++++-
src/conf/domain_conf.h | 2 +
.../qemuxml2argv-memory-hotplug-nvdimm-access.xml | 56 ++++++++++++++++++=
++++
...qemuxml2xmlout-memory-hotplug-nvdimm-access.xml | 1 +
tests/qemuxml2xmltest.c | 1 +
7 files changed, 96 insertions(+), 3 deletions(-)
create mode 100644 tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdi=
mm-access.xml
create mode 120000 tests/qemuxml2xmloutdata/qemuxml2xmlout-memory-hotplug-=
nvdimm-access.xml
diff --git a/docs/formatdomain.html.in b/docs/formatdomain.html.in
index 6e89bfe3a..4bc3d92f9 100644
--- a/docs/formatdomain.html.in
+++ b/docs/formatdomain.html.in
@@ -1417,7 +1417,7 @@
Since 1.2.9 the optional attribute
memAccess can control whether the memory is to be
mapped as "shared" or "private". This is valid only for
- hugepages-backed memory.
+ hugepages-backed memory and nvdimm modules.
=20
+ An optional attribute access
+ (since 3.2.0) that provides
+ capability to fine tune mapping of the memory on per
+ module basis. Values are the same as
+ Memory Backing:
+ shared and private.
+
+
+
source
diff --git a/docs/schemas/domaincommon.rng b/docs/schemas/domaincommon.rng
index 07b3c52ad..5e7e75950 100644
--- a/docs/schemas/domaincommon.rng
+++ b/docs/schemas/domaincommon.rng
@@ -4749,6 +4749,14 @@
nvdimm
+
+
+
+ shared
+ private
+
+
+
diff --git a/src/conf/domain_conf.c b/src/conf/domain_conf.c
index e23ce0015..bf3f2fb86 100644
--- a/src/conf/domain_conf.c
+++ b/src/conf/domain_conf.c
@@ -13874,6 +13874,15 @@ virDomainMemoryDefParseXML(xmlNodePtr memdevNode,
}
VIR_FREE(tmp);
=20
+ tmp =3D virXMLPropString(memdevNode, "access");
+ if (tmp &&
+ (def->access =3D virDomainMemoryAccessTypeFromString(tmp)) <=3D 0)=
{
+ virReportError(VIR_ERR_XML_ERROR,
+ _("invalid access mode '%s'"), tmp);
+ goto error;
+ }
+ VIR_FREE(tmp);
+
/* source */
if ((node =3D virXPathNode("./source", ctxt)) &&
virDomainMemorySourceDefParseXML(node, ctxt, def) < 0)
@@ -22680,7 +22689,11 @@ virDomainMemoryDefFormat(virBufferPtr buf,
{
const char *model =3D virDomainMemoryModelTypeToString(def->model);
=20
- virBufferAsprintf(buf, "\n", model);
+ virBufferAsprintf(buf, "access)
+ virBufferAsprintf(buf, " access=3D'%s'",
+ virDomainMemoryAccessTypeToString(def->access));
+ virBufferAddLit(buf, ">\n");
virBufferAdjustIndent(buf, 2);
=20
if (virDomainMemorySourceDefFormat(buf, def) < 0)
diff --git a/src/conf/domain_conf.h b/src/conf/domain_conf.h
index 823582253..fa27708ce 100644
--- a/src/conf/domain_conf.h
+++ b/src/conf/domain_conf.h
@@ -2002,6 +2002,8 @@ typedef enum {
} virDomainMemoryModel;
=20
struct _virDomainMemoryDef {
+ virDomainMemoryAccess access;
+
/* source */
virBitmapPtr sourceNodes;
unsigned long long pagesize; /* kibibytes */
diff --git a/tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdimm-acce=
ss.xml b/tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdimm-access.x=
ml
new file mode 100644
index 000000000..700e961a6
--- /dev/null
+++ b/tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdimm-access.xml
@@ -0,0 +1,56 @@
+
+ QEMUGuest1
+ c7a5fdbd-edaf-9455-926a-d65c16db1809
+ 1099511627776
+ 1267710
+ 1267710
+ 2
+
+ hvm
+
+
+
+
+
+
+
+
+
+
+
+
+
+ destroy
+ restart
+ destroy
+
+ /usr/bin/qemu
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 523264
+ 0
+
+
+
+
+
diff --git a/tests/qemuxml2xmloutdata/qemuxml2xmlout-memory-hotplug-nvdimm-=
access.xml b/tests/qemuxml2xmloutdata/qemuxml2xmlout-memory-hotplug-nvdimm-=
access.xml
new file mode 120000
index 000000000..4b0496ad5
--- /dev/null
+++ b/tests/qemuxml2xmloutdata/qemuxml2xmlout-memory-hotplug-nvdimm-access.=
xml
@@ -0,0 +1 @@
+/home/zippy/work/libvirt/libvirt.git/tests/qemuxml2argvdata/qemuxml2argv-m=
emory-hotplug-nvdimm-access.xml
\ No newline at end of file
diff --git a/tests/qemuxml2xmltest.c b/tests/qemuxml2xmltest.c
index e1c341dd5..ef49a79ca 100644
--- a/tests/qemuxml2xmltest.c
+++ b/tests/qemuxml2xmltest.c
@@ -1079,6 +1079,7 @@ mymain(void)
DO_TEST("memory-hotplug-nonuma", NONE);
DO_TEST("memory-hotplug-dimm", NONE);
DO_TEST("memory-hotplug-nvdimm", NONE);
+ DO_TEST("memory-hotplug-nvdimm-access", NONE);
DO_TEST("net-udp", NONE);
=20
DO_TEST("video-virtio-gpu-device", NONE);
--=20
2.11.0
--
libvir-list mailing list
libvir-list@redhat.com
https://www.redhat.com/mailman/listinfo/libvir-list
From nobody Fri Apr 26 16:12:55 2024
Delivered-To: importer@patchew.org
Received-SPF: pass (zoho.com: domain of redhat.com designates 209.132.183.24
as permitted sender) client-ip=209.132.183.24;
envelope-from=libvir-list-bounces@redhat.com; helo=mx3-phx2.redhat.com;
Authentication-Results: mx.zoho.com;
spf=pass (zoho.com: domain of redhat.com designates 209.132.183.24 as
permitted sender) smtp.mailfrom=libvir-list-bounces@redhat.com;
Return-Path:
Received: from mx3-phx2.redhat.com (mx3-phx2.redhat.com [209.132.183.24]) by
mx.zohomail.com
with SMTPS id 14890758308190.755232357709474;
Thu, 9 Mar 2017 08:10:30 -0800 (PST)
Received: from lists01.pubmisc.prod.ext.phx2.redhat.com
(lists01.pubmisc.prod.ext.phx2.redhat.com [10.5.19.33])
by mx3-phx2.redhat.com (8.13.8/8.13.8) with ESMTP id v29G6xhd015223;
Thu, 9 Mar 2017 11:06:59 -0500
Received: from smtp.corp.redhat.com (int-mx16.intmail.prod.int.phx2.redhat.com
[10.5.11.28])
by lists01.pubmisc.prod.ext.phx2.redhat.com (8.13.8/8.13.8) with ESMTP
id v29G6c5E032446 for ;
Thu, 9 Mar 2017 11:06:38 -0500
Received: by smtp.corp.redhat.com (Postfix)
id 8EFE82D655; Thu, 9 Mar 2017 16:06:38 +0000 (UTC)
Received: from moe.brq.redhat.com (dhcp129-131.brq.redhat.com [10.34.129.131])
by smtp.corp.redhat.com (Postfix) with ESMTP id 168A52D653
for ; Thu, 9 Mar 2017 16:06:37 +0000 (UTC)
From: Michal Privoznik
To: libvir-list@redhat.com
Date: Thu, 9 Mar 2017 17:06:18 +0100
Message-Id:
In-Reply-To:
References:
In-Reply-To:
References:
X-Scanned-By: MIMEDefang 2.74 on 10.5.11.28
X-loop: libvir-list@redhat.com
Subject: [libvirt] [PATCH v3 09/17] qemu: Implement @access for
banks
X-BeenThere: libvir-list@redhat.com
X-Mailman-Version: 2.1.12
Precedence: junk
List-Id: Development discussions about the libvirt library & tools
List-Unsubscribe: ,
List-Archive:
List-Post:
List-Help:
List-Subscribe: ,
MIME-Version: 1.0
Content-Transfer-Encoding: quoted-printable
Sender: libvir-list-bounces@redhat.com
Errors-To: libvir-list-bounces@redhat.com
X-ZohoMail: RSF_0 Z_629925259 SPT_0
Content-Type: text/plain; charset="utf-8"
Signed-off-by: Michal Privoznik
---
src/qemu/qemu_command.c | 5 +++--
.../qemuxml2argv-memory-hotplug-nvdimm-access.args | 26 ++++++++++++++++++=
++++
tests/qemuxml2argvtest.c | 2 ++
3 files changed, 31 insertions(+), 2 deletions(-)
create mode 100644 tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdi=
mm-access.args
diff --git a/src/qemu/qemu_command.c b/src/qemu/qemu_command.c
index a66ce6645..86a52ef62 100644
--- a/src/qemu/qemu_command.c
+++ b/src/qemu/qemu_command.c
@@ -3116,7 +3116,7 @@ qemuBuildMemoryBackendStr(virJSONValuePtr *backendPro=
ps,
virDomainHugePagePtr hugepage =3D NULL;
virDomainNumatuneMemMode mode;
const long system_page_size =3D virGetSystemPageSizeKB();
- virDomainMemoryAccess memAccess =3D VIR_DOMAIN_MEMORY_ACCESS_DEFAULT;
+ virDomainMemoryAccess memAccess =3D mem->access;
size_t i;
char *memPath =3D NULL;
bool prealloc =3D false;
@@ -3130,7 +3130,8 @@ qemuBuildMemoryBackendStr(virJSONValuePtr *backendPro=
ps,
*backendProps =3D NULL;
*backendType =3D NULL;
=20
- if (mem->targetNode >=3D 0) {
+ if (memAccess =3D=3D VIR_DOMAIN_MEMORY_ACCESS_DEFAULT &&
+ mem->targetNode >=3D 0) {
/* memory devices could provide a invalid guest node */
if (mem->targetNode >=3D virDomainNumaGetNodeCount(def->numa)) {
virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
diff --git a/tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdimm-acce=
ss.args b/tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdimm-access.=
args
new file mode 100644
index 000000000..d398b2294
--- /dev/null
+++ b/tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdimm-access.args
@@ -0,0 +1,26 @@
+LC_ALL=3DC \
+PATH=3D/bin \
+HOME=3D/home/test \
+USER=3Dtest \
+LOGNAME=3Dtest \
+QEMU_AUDIO_DRV=3Dnone \
+/usr/bin/qemu \
+-name QEMUGuest1 \
+-S \
+-machine pc,accel=3Dtcg,nvdimm=3Don \
+-m size=3D219136k,slots=3D16,maxmem=3D1099511627776k \
+-smp 2,sockets=3D2,cores=3D1,threads=3D1 \
+-numa node,nodeid=3D0,cpus=3D0-1,mem=3D214 \
+-object memory-backend-file,id=3Dmemnvdimm0,prealloc=3Dyes,mem-path=3D/tmp=
/nvdimm,\
+share=3Dno,size=3D536870912 \
+-device nvdimm,node=3D0,memdev=3Dmemnvdimm0,id=3Dnvdimm0,slot=3D0 \
+-uuid c7a5fdbd-edaf-9455-926a-d65c16db1809 \
+-nographic \
+-nodefaults \
+-monitor unix:/tmp/lib/domain--1-QEMUGuest1/monitor.sock,server,nowait \
+-no-acpi \
+-boot c \
+-usb \
+-drive file=3D/dev/HostVG/QEMUGuest1,format=3Draw,if=3Dnone,id=3Ddrive-ide=
0-0-0 \
+-device ide-drive,bus=3Dide.0,unit=3D0,drive=3Ddrive-ide0-0-0,id=3Dide0-0-=
0 \
+-device virtio-balloon-pci,id=3Dballoon0,bus=3Dpci.0,addr=3D0x3
diff --git a/tests/qemuxml2argvtest.c b/tests/qemuxml2argvtest.c
index b6fdaaeb3..bf839fe93 100644
--- a/tests/qemuxml2argvtest.c
+++ b/tests/qemuxml2argvtest.c
@@ -2339,6 +2339,8 @@ mymain(void)
QEMU_CAPS_OBJECT_MEMORY_RAM, QEMU_CAPS_OBJECT_MEMORY_FILE);
DO_TEST("memory-hotplug-nvdimm", QEMU_CAPS_MACHINE_OPT, QEMU_CAPS_DEVI=
CE_NVDIMM,
QEMU_CAPS_NUMA, QEMU_CAPS_OBJECT_MEMORY_RAM, QEMU_CAPS_OBJECT_=
MEMORY_FILE);
+ DO_TEST("memory-hotplug-nvdimm-access", QEMU_CAPS_MACHINE_OPT, QEMU_CA=
PS_DEVICE_NVDIMM,
+ QEMU_CAPS_NUMA, QEMU_CAPS_OBJECT_MEMORY_RAM, QEMU_CAPS_OBJECT_=
MEMORY_FILE);
=20
DO_TEST("machine-aeskeywrap-on-caps",
QEMU_CAPS_MACHINE_OPT, QEMU_CAPS_AES_KEY_WRAP,
--=20
2.11.0
--
libvir-list mailing list
libvir-list@redhat.com
https://www.redhat.com/mailman/listinfo/libvir-list
From nobody Fri Apr 26 16:12:55 2024
Delivered-To: importer@patchew.org
Received-SPF: pass (zoho.com: domain of redhat.com designates 209.132.183.39
as permitted sender) client-ip=209.132.183.39;
envelope-from=libvir-list-bounces@redhat.com; helo=mx6-phx2.redhat.com;
Authentication-Results: mx.zoho.com;
spf=pass (zoho.com: domain of redhat.com designates 209.132.183.39 as
permitted sender) smtp.mailfrom=libvir-list-bounces@redhat.com;
Return-Path:
Received: from mx6-phx2.redhat.com (mx6-phx2.redhat.com [209.132.183.39]) by
mx.zohomail.com
with SMTPS id 1489075825055621.2233900744947;
Thu, 9 Mar 2017 08:10:25 -0800 (PST)
Received: from lists01.pubmisc.prod.ext.phx2.redhat.com
(lists01.pubmisc.prod.ext.phx2.redhat.com [10.5.19.33])
by mx6-phx2.redhat.com (8.14.4/8.14.4) with ESMTP id v29G6v6H058613;
Thu, 9 Mar 2017 11:06:57 -0500
Received: from smtp.corp.redhat.com (int-mx16.intmail.prod.int.phx2.redhat.com
[10.5.11.28])
by lists01.pubmisc.prod.ext.phx2.redhat.com (8.13.8/8.13.8) with ESMTP
id v29G6dYr032455 for ;
Thu, 9 Mar 2017 11:06:39 -0500
Received: by smtp.corp.redhat.com (Postfix)
id 5F4382D655; Thu, 9 Mar 2017 16:06:39 +0000 (UTC)
Received: from moe.brq.redhat.com (dhcp129-131.brq.redhat.com [10.34.129.131])
by smtp.corp.redhat.com (Postfix) with ESMTP id DA91F2D653
for ; Thu, 9 Mar 2017 16:06:38 +0000 (UTC)
From: Michal Privoznik
To: libvir-list@redhat.com
Date: Thu, 9 Mar 2017 17:06:19 +0100
Message-Id:
<3520e21a9549bff6dedafef82ee40d354a443842.1489075458.git.mprivozn@redhat.com>
In-Reply-To:
References:
In-Reply-To:
References:
X-Scanned-By: MIMEDefang 2.74 on 10.5.11.28
X-loop: libvir-list@redhat.com
Subject: [libvirt] [PATCH v3 10/17] qemu: Introduce label-size for NVDIMMs
X-BeenThere: libvir-list@redhat.com
X-Mailman-Version: 2.1.12
Precedence: junk
List-Id: Development discussions about the libvirt library & tools
List-Unsubscribe: ,
List-Archive:
List-Post:
List-Help:
List-Subscribe: ,
MIME-Version: 1.0
Content-Transfer-Encoding: quoted-printable
Sender: libvir-list-bounces@redhat.com
Errors-To: libvir-list-bounces@redhat.com
X-ZohoMail: RSF_0 Z_629925259 SPT_0
Content-Type: text/plain; charset="utf-8"
For NVDIMM devices it is optionally possible to specify the size
of internal storage for namespaces. Namespaces are a feature that
allows users to partition the NVDIMM for different uses.
Signed-off-by: Michal Privoznik
---
docs/formatdomain.html.in | 11 ++++
docs/schemas/domaincommon.rng | 7 +++
src/conf/domain_conf.c | 34 +++++++++++++
src/conf/domain_conf.h | 1 +
src/qemu/qemu_command.c | 3 ++
.../qemuxml2argv-memory-hotplug-nvdimm-label.args | 26 ++++++++++
.../qemuxml2argv-memory-hotplug-nvdimm-label.xml | 59 ++++++++++++++++++=
++++
tests/qemuxml2argvtest.c | 2 +
.../qemuxml2xmlout-memory-hotplug-nvdimm-label.xml | 1 +
tests/qemuxml2xmltest.c | 1 +
10 files changed, 145 insertions(+)
create mode 100644 tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdi=
mm-label.args
create mode 100644 tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdi=
mm-label.xml
create mode 120000 tests/qemuxml2xmloutdata/qemuxml2xmlout-memory-hotplug-=
nvdimm-label.xml
diff --git a/docs/formatdomain.html.in b/docs/formatdomain.html.in
index 4bc3d92f9..bb6df4542 100644
--- a/docs/formatdomain.html.in
+++ b/docs/formatdomain.html.in
@@ -7122,6 +7122,9 @@ qemu-kvm -net nic,model=3D? /dev/null
<target>
<size unit=3D'KiB'>524288</size>
<node>1</node>
+ <label>
+ <size unit=3D'KiB'>128</size>
+ </label>
</target>
</memory>
</devices>
@@ -7203,6 +7206,14 @@ qemu-kvm -net nic,model=3D? /dev/null
attach the memory to. The element shall be used only if the gues=
t has
NUMA nodes configured.
+
+ For NVDIMM type devices one can optionally use
+ label and its subelement size
+ to configure the size of namespaces label storage
+ within the NVDIMM module. The size element
+ has usual meaning described
+ here.
+
=20
diff --git a/docs/schemas/domaincommon.rng b/docs/schemas/domaincommon.rng
index 5e7e75950..88b01ee5a 100644
--- a/docs/schemas/domaincommon.rng
+++ b/docs/schemas/domaincommon.rng
@@ -4809,6 +4809,13 @@
+
+
+
+
+
+
+
diff --git a/src/conf/domain_conf.c b/src/conf/domain_conf.c
index bf3f2fb86..0f6ab39d6 100644
--- a/src/conf/domain_conf.c
+++ b/src/conf/domain_conf.c
@@ -13838,6 +13838,24 @@ virDomainMemoryTargetDefParseXML(xmlNodePtr node,
&def->size, true, false) < 0)
goto cleanup;
=20
+ if (def->model =3D=3D VIR_DOMAIN_MEMORY_MODEL_NVDIMM) {
+ if (virDomainParseMemory("./label/size", "./label/size/@unit", ctx=
t,
+ &def->labelsize, false, false) < 0)
+ goto cleanup;
+
+ if (def->labelsize && def->labelsize < 128) {
+ virReportError(VIR_ERR_XML_ERROR, "%s",
+ _("nvdimm label must be at least 128KiB"));
+ goto cleanup;
+ }
+
+ if (def->labelsize >=3D def->size) {
+ virReportError(VIR_ERR_XML_ERROR, "%s",
+ _("label size must be smaller than NVDIMM size"=
));
+ goto cleanup;
+ }
+ }
+
ret =3D 0;
=20
cleanup:
@@ -19521,6 +19539,15 @@ virDomainMemoryDefCheckABIStability(virDomainMemor=
yDefPtr src,
return false;
}
=20
+ if (src->model =3D=3D VIR_DOMAIN_MEMORY_MODEL_NVDIMM &&
+ src->labelsize !=3D dst->labelsize) {
+ virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
+ _("Target NVDIMM label size '%llu' doesn't match "
+ "source NVDIMM label size '%llu'"),
+ src->labelsize, dst->labelsize);
+ return false;
+ }
+
return virDomainDeviceInfoCheckABIStability(&src->info, &dst->info);
}
=20
@@ -22677,6 +22704,13 @@ virDomainMemoryTargetDefFormat(virBufferPtr buf,
virBufferAsprintf(buf, "%llu\n", def->size);
if (def->targetNode >=3D 0)
virBufferAsprintf(buf, "%d\n", def->targetNode);
+ if (def->labelsize) {
+ virBufferAddLit(buf, "\n");
+ }
=20
virBufferAdjustIndent(buf, -2);
virBufferAddLit(buf, "\n");
diff --git a/src/conf/domain_conf.h b/src/conf/domain_conf.h
index fa27708ce..c66a901c2 100644
--- a/src/conf/domain_conf.h
+++ b/src/conf/domain_conf.h
@@ -2013,6 +2013,7 @@ struct _virDomainMemoryDef {
int model; /* virDomainMemoryModel */
int targetNode;
unsigned long long size; /* kibibytes */
+ unsigned long long labelsize; /* kibibytes; valid only for NVDIMM */
=20
virDomainDeviceInfo info;
};
diff --git a/src/qemu/qemu_command.c b/src/qemu/qemu_command.c
index 86a52ef62..89d47e50d 100644
--- a/src/qemu/qemu_command.c
+++ b/src/qemu/qemu_command.c
@@ -3420,6 +3420,9 @@ qemuBuildMemoryDeviceStr(virDomainMemoryDefPtr mem)
if (mem->targetNode >=3D 0)
virBufferAsprintf(&buf, "node=3D%d,", mem->targetNode);
=20
+ if (mem->labelsize)
+ virBufferAsprintf(&buf, "label-size=3D%llu,", mem->labelsize *=
1024);
+
virBufferAsprintf(&buf, "memdev=3Dmem%s,id=3D%s",
mem->info.alias, mem->info.alias);
=20
diff --git a/tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdimm-labe=
l.args b/tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdimm-label.ar=
gs
new file mode 100644
index 000000000..8669f2d84
--- /dev/null
+++ b/tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdimm-label.args
@@ -0,0 +1,26 @@
+LC_ALL=3DC \
+PATH=3D/bin \
+HOME=3D/home/test \
+USER=3Dtest \
+LOGNAME=3Dtest \
+QEMU_AUDIO_DRV=3Dnone \
+/usr/bin/qemu \
+-name QEMUGuest1 \
+-S \
+-machine pc,accel=3Dtcg,nvdimm=3Don \
+-m size=3D219136k,slots=3D16,maxmem=3D1099511627776k \
+-smp 2,sockets=3D2,cores=3D1,threads=3D1 \
+-numa node,nodeid=3D0,cpus=3D0-1,mem=3D214 \
+-object memory-backend-file,id=3Dmemnvdimm0,prealloc=3Dyes,mem-path=3D/tmp=
/nvdimm,\
+share=3Dno,size=3D536870912 \
+-device nvdimm,node=3D0,label-size=3D131072,memdev=3Dmemnvdimm0,id=3Dnvdim=
m0,slot=3D0 \
+-uuid c7a5fdbd-edaf-9455-926a-d65c16db1809 \
+-nographic \
+-nodefaults \
+-monitor unix:/tmp/lib/domain--1-QEMUGuest1/monitor.sock,server,nowait \
+-no-acpi \
+-boot c \
+-usb \
+-drive file=3D/dev/HostVG/QEMUGuest1,format=3Draw,if=3Dnone,id=3Ddrive-ide=
0-0-0 \
+-device ide-drive,bus=3Dide.0,unit=3D0,drive=3Ddrive-ide0-0-0,id=3Dide0-0-=
0 \
+-device virtio-balloon-pci,id=3Dballoon0,bus=3Dpci.0,addr=3D0x3
diff --git a/tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdimm-labe=
l.xml b/tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdimm-label.xml
new file mode 100644
index 000000000..425385251
--- /dev/null
+++ b/tests/qemuxml2argvdata/qemuxml2argv-memory-hotplug-nvdimm-label.xml
@@ -0,0 +1,59 @@
+
+ QEMUGuest1
+ c7a5fdbd-edaf-9455-926a-d65c16db1809
+ 1099511627776
+ 1267710
+ 1267710
+ 2
+
+ hvm
+
+
+
+
+
+
+
+
+
+
+
+
+
+ destroy
+ restart
+ destroy
+
+ /usr/bin/qemu
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 523264
+ 0
+
+
+
+
+
+
diff --git a/tests/qemuxml2argvtest.c b/tests/qemuxml2argvtest.c
index bf839fe93..127ebae49 100644
--- a/tests/qemuxml2argvtest.c
+++ b/tests/qemuxml2argvtest.c
@@ -2341,6 +2341,8 @@ mymain(void)
QEMU_CAPS_NUMA, QEMU_CAPS_OBJECT_MEMORY_RAM, QEMU_CAPS_OBJECT_=
MEMORY_FILE);
DO_TEST("memory-hotplug-nvdimm-access", QEMU_CAPS_MACHINE_OPT, QEMU_CA=
PS_DEVICE_NVDIMM,
QEMU_CAPS_NUMA, QEMU_CAPS_OBJECT_MEMORY_RAM, QEMU_CAPS_OBJECT_=
MEMORY_FILE);
+ DO_TEST("memory-hotplug-nvdimm-label", QEMU_CAPS_MACHINE_OPT, QEMU_CAP=
S_DEVICE_NVDIMM,
+ QEMU_CAPS_NUMA, QEMU_CAPS_OBJECT_MEMORY_RAM, QEMU_CAPS_OBJECT_=
MEMORY_FILE);
=20
DO_TEST("machine-aeskeywrap-on-caps",
QEMU_CAPS_MACHINE_OPT, QEMU_CAPS_AES_KEY_WRAP,
diff --git a/tests/qemuxml2xmloutdata/qemuxml2xmlout-memory-hotplug-nvdimm-=
label.xml b/tests/qemuxml2xmloutdata/qemuxml2xmlout-memory-hotplug-nvdimm-l=
abel.xml
new file mode 120000
index 000000000..e357ec582
--- /dev/null
+++ b/tests/qemuxml2xmloutdata/qemuxml2xmlout-memory-hotplug-nvdimm-label.x=
ml
@@ -0,0 +1 @@
+/home/zippy/work/libvirt/libvirt.git/tests/qemuxml2argvdata/qemuxml2argv-m=
emory-hotplug-nvdimm-label.xml
\ No newline at end of file
diff --git a/tests/qemuxml2xmltest.c b/tests/qemuxml2xmltest.c
index ef49a79ca..bf62dbbb2 100644
--- a/tests/qemuxml2xmltest.c
+++ b/tests/qemuxml2xmltest.c
@@ -1080,6 +1080,7 @@ mymain(void)
DO_TEST("memory-hotplug-dimm", NONE);
DO_TEST("memory-hotplug-nvdimm", NONE);
DO_TEST("memory-hotplug-nvdimm-access", NONE);
+ DO_TEST("memory-hotplug-nvdimm-label", NONE);
DO_TEST("net-udp", NONE);
=20
DO_TEST("video-virtio-gpu-device", NONE);
--=20
2.11.0
--
libvir-list mailing list
libvir-list@redhat.com
https://www.redhat.com/mailman/listinfo/libvir-list
From nobody Fri Apr 26 16:12:55 2024
Delivered-To: importer@patchew.org
Received-SPF: pass (zoho.com: domain of redhat.com designates 209.132.183.25
as permitted sender) client-ip=209.132.183.25;
envelope-from=libvir-list-bounces@redhat.com; helo=mx4-phx2.redhat.com;
Authentication-Results: mx.zoho.com;
spf=pass (zoho.com: domain of redhat.com designates 209.132.183.25 as
permitted sender) smtp.mailfrom=libvir-list-bounces@redhat.com;
Return-Path:
Received: from mx4-phx2.redhat.com (mx4-phx2.redhat.com [209.132.183.25]) by
mx.zohomail.com
with SMTPS id 1489075832418739.0498102224557;
Thu, 9 Mar 2017 08:10:32 -0800 (PST)
Received: from lists01.pubmisc.prod.ext.phx2.redhat.com
(lists01.pubmisc.prod.ext.phx2.redhat.com [10.5.19.33])
by mx4-phx2.redhat.com (8.13.8/8.13.8) with ESMTP id v29G72pV017889;
Thu, 9 Mar 2017 11:07:02 -0500
Received: from smtp.corp.redhat.com (int-mx16.intmail.prod.int.phx2.redhat.com
[10.5.11.28])
by lists01.pubmisc.prod.ext.phx2.redhat.com (8.13.8/8.13.8) with ESMTP
id v29G6eFh032463 for ;
Thu, 9 Mar 2017 11:06:40 -0500
Received: by smtp.corp.redhat.com (Postfix)
id 30B5F2D5C1; Thu, 9 Mar 2017 16:06:40 +0000 (UTC)
Received: from moe.brq.redhat.com (dhcp129-131.brq.redhat.com [10.34.129.131])
by smtp.corp.redhat.com (Postfix) with ESMTP id AACED2D655
for ; Thu, 9 Mar 2017 16:06:39 +0000 (UTC)
From: Michal Privoznik
To: libvir-list@redhat.com
Date: Thu, 9 Mar 2017 17:06:20 +0100
Message-Id:
In-Reply-To:
References:
In-Reply-To:
References:
X-Scanned-By: MIMEDefang 2.74 on 10.5.11.28
X-loop: libvir-list@redhat.com
Subject: [libvirt] [PATCH v3 11/17] security_dac: Label host side of NVDIMM
X-BeenThere: libvir-list@redhat.com
X-Mailman-Version: 2.1.12
Precedence: junk
List-Id: Development discussions about the libvirt library & tools
List-Unsubscribe: ,
List-Archive:
List-Post:
List-Help:
List-Subscribe: ,
MIME-Version: 1.0
Content-Transfer-Encoding: quoted-printable
Sender: libvir-list-bounces@redhat.com
Errors-To: libvir-list-bounces@redhat.com
X-ZohoMail: RSF_0 Z_629925259 SPT_0
Content-Type: text/plain; charset="utf-8"
When domain is being started up, we ought to relabel the host
side of NVDIMM so qemu has access to it.
Signed-off-by: Michal Privoznik
---
src/security/security_dac.c | 73 +++++++++++++++++++++++++++++++++++++++++=
++++
1 file changed, 73 insertions(+)
diff --git a/src/security/security_dac.c b/src/security/security_dac.c
index 67219170c..27aa2bd6a 100644
--- a/src/security/security_dac.c
+++ b/src/security/security_dac.c
@@ -1386,6 +1386,30 @@ virSecurityDACRestoreInputLabel(virSecurityManagerPt=
r mgr,
}
=20
=20
+static int
+virSecurityDACRestoreMemoryLabel(virSecurityManagerPtr mgr,
+ virDomainDefPtr def ATTRIBUTE_UNUSED,
+ virDomainMemoryDefPtr mem)
+{
+ virSecurityDACDataPtr priv =3D virSecurityManagerGetPrivateData(mgr);
+ int ret =3D -1;
+
+ switch ((virDomainMemoryModel) mem->model) {
+ case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
+ ret =3D virSecurityDACRestoreFileLabel(priv, mem->nvdimmPath);
+ break;
+
+ case VIR_DOMAIN_MEMORY_MODEL_DIMM:
+ case VIR_DOMAIN_MEMORY_MODEL_LAST:
+ case VIR_DOMAIN_MEMORY_MODEL_NONE:
+ ret =3D 0;
+ break;
+ }
+
+ return ret;
+}
+
+
static int
virSecurityDACRestoreAllLabel(virSecurityManagerPtr mgr,
virDomainDefPtr def,
@@ -1425,6 +1449,13 @@ virSecurityDACRestoreAllLabel(virSecurityManagerPtr =
mgr,
rc =3D -1;
}
=20
+ for (i =3D 0; i < def->nmems; i++) {
+ if (virSecurityDACRestoreMemoryLabel(mgr,
+ def,
+ def->mems[i]) < 0)
+ rc =3D -1;
+ }
+
if (virDomainChrDefForeach(def,
false,
virSecurityDACRestoreChardevCallback,
@@ -1457,6 +1488,41 @@ virSecurityDACSetChardevCallback(virDomainDefPtr def,
}
=20
=20
+static int
+virSecurityDACSetMemoryLabel(virSecurityManagerPtr mgr,
+ virDomainDefPtr def,
+ virDomainMemoryDefPtr mem)
+
+{
+ virSecurityDACDataPtr priv =3D virSecurityManagerGetPrivateData(mgr);
+ virSecurityLabelDefPtr seclabel;
+ int ret =3D -1;
+ uid_t user;
+ gid_t group;
+
+ switch ((virDomainMemoryModel) mem->model) {
+ case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
+ seclabel =3D virDomainDefGetSecurityLabelDef(def, SECURITY_DAC_NAM=
E);
+ if (seclabel && !seclabel->relabel)
+ return 0;
+
+ if (virSecurityDACGetIds(seclabel, priv, &user, &group, NULL, NULL=
) < 0)
+ return -1;
+
+ ret =3D virSecurityDACSetOwnership(priv, NULL, mem->nvdimmPath, us=
er, group);
+ break;
+
+ case VIR_DOMAIN_MEMORY_MODEL_DIMM:
+ case VIR_DOMAIN_MEMORY_MODEL_LAST:
+ case VIR_DOMAIN_MEMORY_MODEL_NONE:
+ ret =3D 0;
+ break;
+ }
+
+ return ret;
+}
+
+
static int
virSecurityDACSetAllLabel(virSecurityManagerPtr mgr,
virDomainDefPtr def,
@@ -1496,6 +1562,13 @@ virSecurityDACSetAllLabel(virSecurityManagerPtr mgr,
return -1;
}
=20
+ for (i =3D 0; i < def->nmems; i++) {
+ if (virSecurityDACSetMemoryLabel(mgr,
+ def,
+ def->mems[i]) < 0)
+ return -1;
+ }
+
if (virDomainChrDefForeach(def,
true,
virSecurityDACSetChardevCallback,
--=20
2.11.0
--
libvir-list mailing list
libvir-list@redhat.com
https://www.redhat.com/mailman/listinfo/libvir-list
From nobody Fri Apr 26 16:12:55 2024
Delivered-To: importer@patchew.org
Received-SPF: pass (zoho.com: domain of redhat.com designates 209.132.183.24
as permitted sender) client-ip=209.132.183.24;
envelope-from=libvir-list-bounces@redhat.com; helo=mx3-phx2.redhat.com;
Authentication-Results: mx.zoho.com;
spf=pass (zoho.com: domain of redhat.com designates 209.132.183.24 as
permitted sender) smtp.mailfrom=libvir-list-bounces@redhat.com;
Return-Path:
Received: from mx3-phx2.redhat.com (mx3-phx2.redhat.com [209.132.183.24]) by
mx.zohomail.com
with SMTPS id 1489075822648662.6207805840211;
Thu, 9 Mar 2017 08:10:22 -0800 (PST)
Received: from lists01.pubmisc.prod.ext.phx2.redhat.com
(lists01.pubmisc.prod.ext.phx2.redhat.com [10.5.19.33])
by mx3-phx2.redhat.com (8.13.8/8.13.8) with ESMTP id v29G74FK015240;
Thu, 9 Mar 2017 11:07:05 -0500
Received: from smtp.corp.redhat.com (int-mx16.intmail.prod.int.phx2.redhat.com
[10.5.11.28])
by lists01.pubmisc.prod.ext.phx2.redhat.com (8.13.8/8.13.8) with ESMTP
id v29G6flE032476 for ;
Thu, 9 Mar 2017 11:06:41 -0500
Received: by smtp.corp.redhat.com (Postfix)
id 0183D2D5C0; Thu, 9 Mar 2017 16:06:41 +0000 (UTC)
Received: from moe.brq.redhat.com (dhcp129-131.brq.redhat.com [10.34.129.131])
by smtp.corp.redhat.com (Postfix) with ESMTP id 7CDAD2D655
for ; Thu, 9 Mar 2017 16:06:40 +0000 (UTC)
From: Michal Privoznik
To: libvir-list@redhat.com
Date: Thu, 9 Mar 2017 17:06:21 +0100
Message-Id:
<97fac7f800d659665964ae300337f84607e31e0b.1489075458.git.mprivozn@redhat.com>
In-Reply-To:
References:
In-Reply-To:
References:
X-Scanned-By: MIMEDefang 2.74 on 10.5.11.28
X-loop: libvir-list@redhat.com
Subject: [libvirt] [PATCH v3 12/17] security_selinux: Label host side of
NVDIMM
X-BeenThere: libvir-list@redhat.com
X-Mailman-Version: 2.1.12
Precedence: junk
List-Id: Development discussions about the libvirt library & tools
List-Unsubscribe: ,
List-Archive:
List-Post:
List-Help:
List-Subscribe: ,
MIME-Version: 1.0
Content-Transfer-Encoding: quoted-printable
Sender: libvir-list-bounces@redhat.com
Errors-To: libvir-list-bounces@redhat.com
X-ZohoMail: RSF_0 Z_629925259 SPT_0
Content-Type: text/plain; charset="utf-8"
When domain is being started up, we ought to relabel the host
side of NVDIMM so qemu has access to it.
Signed-off-by: Michal Privoznik
---
src/security/security_selinux.c | 66 +++++++++++++++++++++++++++++++++++++=
++++
1 file changed, 66 insertions(+)
diff --git a/src/security/security_selinux.c b/src/security/security_selinu=
x.c
index e22de0653..1be2acd27 100644
--- a/src/security/security_selinux.c
+++ b/src/security/security_selinux.c
@@ -1381,6 +1381,62 @@ virSecuritySELinuxRestoreInputLabel(virSecurityManag=
erPtr mgr,
}
=20
=20
+static int
+virSecuritySELinuxSetMemoryLabel(virSecurityManagerPtr mgr,
+ virDomainDefPtr def,
+ virDomainMemoryDefPtr mem)
+{
+ virSecurityLabelDefPtr seclabel;
+
+ seclabel =3D virDomainDefGetSecurityLabelDef(def, SECURITY_SELINUX_NAM=
E);
+ if (seclabel =3D=3D NULL)
+ return 0;
+
+ switch ((virDomainMemoryModel) mem->model) {
+ case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
+ if (virSecuritySELinuxSetFilecon(mgr, mem->nvdimmPath,
+ seclabel->imagelabel) < 0)
+ return -1;
+ break;
+
+ case VIR_DOMAIN_MEMORY_MODEL_NONE:
+ case VIR_DOMAIN_MEMORY_MODEL_DIMM:
+ case VIR_DOMAIN_MEMORY_MODEL_LAST:
+ break;
+ }
+
+ return 0;
+}
+
+
+static int
+virSecuritySELinuxRestoreMemoryLabel(virSecurityManagerPtr mgr,
+ virDomainDefPtr def,
+ virDomainMemoryDefPtr mem)
+{
+ int ret =3D -1;
+ virSecurityLabelDefPtr seclabel;
+
+ switch ((virDomainMemoryModel) mem->model) {
+ case VIR_DOMAIN_MEMORY_MODEL_NVDIMM:
+ seclabel =3D virDomainDefGetSecurityLabelDef(def, SECURITY_SELINUX=
_NAME);
+ if (seclabel =3D=3D NULL)
+ return 0;
+
+ ret =3D virSecuritySELinuxRestoreFileLabel(mgr, mem->nvdimmPath);
+ break;
+
+ case VIR_DOMAIN_MEMORY_MODEL_DIMM:
+ case VIR_DOMAIN_MEMORY_MODEL_NONE:
+ case VIR_DOMAIN_MEMORY_MODEL_LAST:
+ ret =3D 0;
+ break;
+ }
+
+ return ret;
+}
+
+
static int
virSecuritySELinuxSetTPMFileLabel(virSecurityManagerPtr mgr,
virDomainDefPtr def,
@@ -2325,6 +2381,11 @@ virSecuritySELinuxRestoreAllLabel(virSecurityManager=
Ptr mgr,
rc =3D -1;
}
=20
+ for (i =3D 0; i < def->nmems; i++) {
+ if (virSecuritySELinuxRestoreMemoryLabel(mgr, def, def->mems[i]) <=
0)
+ return -1;
+ }
+
for (i =3D 0; i < def->ndisks; i++) {
virDomainDiskDefPtr disk =3D def->disks[i];
=20
@@ -2711,6 +2772,11 @@ virSecuritySELinuxSetAllLabel(virSecurityManagerPtr =
mgr,
return -1;
}
=20
+ for (i =3D 0; i < def->nmems; i++) {
+ if (virSecuritySELinuxSetMemoryLabel(mgr, def, def->mems[i]) < 0)
+ return -1;
+ }
+
if (def->tpm) {
if (virSecuritySELinuxSetTPMFileLabel(mgr, def, def->tpm) < 0)
return -1;
--=20
2.11.0
--
libvir-list mailing list
libvir-list@redhat.com
https://www.redhat.com/mailman/listinfo/libvir-list
From nobody Fri Apr 26 16:12:55 2024
Delivered-To: importer@patchew.org
Received-SPF: pass (zoho.com: domain of redhat.com designates 209.132.183.39
as permitted sender) client-ip=209.132.183.39;
envelope-from=libvir-list-bounces@redhat.com; helo=mx6-phx2.redhat.com;
Authentication-Results: mx.zoho.com;
spf=pass (zoho.com: domain of redhat.com designates 209.132.183.39 as
permitted sender) smtp.mailfrom=libvir-list-bounces@redhat.com;
Return-Path:
Received: from mx6-phx2.redhat.com (mx6-phx2.redhat.com [209.132.183.39]) by
mx.zohomail.com
with SMTPS id 14890758184681000.1990836729823;
Thu, 9 Mar 2017 08:10:18 -0800 (PST)
Received: from lists01.pubmisc.prod.ext.phx2.redhat.com
(lists01.pubmisc.prod.ext.phx2.redhat.com [10.5.19.33])
by mx6-phx2.redhat.com (8.14.4/8.14.4) with ESMTP id v29G6vmG058597;
Thu, 9 Mar 2017 11:06:57 -0500
Received: from smtp.corp.redhat.com (int-mx16.intmail.prod.int.phx2.redhat.com
[10.5.11.28])
by lists01.pubmisc.prod.ext.phx2.redhat.com (8.13.8/8.13.8) with ESMTP
id v29G6fJc032485 for ;
Thu, 9 Mar 2017 11:06:41 -0500
Received: by smtp.corp.redhat.com (Postfix)
id C5C952D5C0; Thu, 9 Mar 2017 16:06:41 +0000 (UTC)
Received: from moe.brq.redhat.com (dhcp129-131.brq.redhat.com [10.34.129.131])
by smtp.corp.redhat.com (Postfix) with ESMTP id 4D8A02D655
for ; Thu, 9 Mar 2017 16:06:41 +0000 (UTC)
From: Michal Privoznik
To: libvir-list@redhat.com
Date: Thu, 9 Mar 2017 17:06:22 +0100
Message-Id:
<7f282fba59754a2f4340239e546e1be86b8c42d5.1489075458.git.mprivozn@redhat.com>
In-Reply-To:
References:
In-Reply-To:
References:
X-Scanned-By: MIMEDefang 2.74 on 10.5.11.28
X-loop: libvir-list@redhat.com
Subject: [libvirt] [PATCH v3 13/17] security: Introduce internal APIs for
memdev labelling
X-BeenThere: libvir-list@redhat.com
X-Mailman-Version: 2.1.12
Precedence: junk
List-Id: Development discussions about the libvirt library & tools
List-Unsubscribe: ,
List-Archive:
List-Post:
List-Help:
List-Subscribe: ,
MIME-Version: 1.0
Content-Transfer-Encoding: quoted-printable
Sender: libvir-list-bounces@redhat.com
Errors-To: libvir-list-bounces@redhat.com
X-ZohoMail: RSF_0 Z_629925259 SPT_0
Content-Type: text/plain; charset="utf-8"
These APIs will be used whenever we are hot (un-)plugging a
memdev.
Signed-off-by: Michal Privoznik
---
src/libvirt_private.syms | 2 ++
src/security/security_driver.h | 9 +++++++
src/security/security_manager.c | 56 +++++++++++++++++++++++++++++++++++++=
++++
src/security/security_manager.h | 7 ++++++
src/security/security_stack.c | 38 ++++++++++++++++++++++++++++
5 files changed, 112 insertions(+)
diff --git a/src/libvirt_private.syms b/src/libvirt_private.syms
index 6c89d44e2..681414266 100644
--- a/src/libvirt_private.syms
+++ b/src/libvirt_private.syms
@@ -1180,6 +1180,7 @@ virSecurityManagerRestoreAllLabel;
virSecurityManagerRestoreDiskLabel;
virSecurityManagerRestoreHostdevLabel;
virSecurityManagerRestoreImageLabel;
+virSecurityManagerRestoreMemoryLabel;
virSecurityManagerRestoreSavedStateLabel;
virSecurityManagerSetAllLabel;
virSecurityManagerSetChildProcessLabel;
@@ -1188,6 +1189,7 @@ virSecurityManagerSetDiskLabel;
virSecurityManagerSetHostdevLabel;
virSecurityManagerSetImageFDLabel;
virSecurityManagerSetImageLabel;
+virSecurityManagerSetMemoryLabel;
virSecurityManagerSetProcessLabel;
virSecurityManagerSetSavedStateLabel;
virSecurityManagerSetSocketLabel;
diff --git a/src/security/security_driver.h b/src/security/security_driver.h
index fa65eb359..0f5cce5f8 100644
--- a/src/security/security_driver.h
+++ b/src/security/security_driver.h
@@ -123,6 +123,12 @@ typedef int (*virSecurityDomainSetImageLabel) (virSecu=
rityManagerPtr mgr,
typedef int (*virSecurityDomainRestoreImageLabel) (virSecurityManagerPtr m=
gr,
virDomainDefPtr def,
virStorageSourcePtr src=
);
+typedef int (*virSecurityDomainSetMemoryLabel) (virSecurityManagerPtr mgr,
+ virDomainDefPtr def,
+ virDomainMemoryDefPtr mem);
+typedef int (*virSecurityDomainRestoreMemoryLabel) (virSecurityManagerPtr =
mgr,
+ virDomainDefPtr def,
+ virDomainMemoryDefPtr =
mem);
typedef int (*virSecurityDomainSetPathLabel) (virSecurityManagerPtr mgr,
virDomainDefPtr def,
const char *path);
@@ -152,6 +158,9 @@ struct _virSecurityDriver {
virSecurityDomainSetImageLabel domainSetSecurityImageLabel;
virSecurityDomainRestoreImageLabel domainRestoreSecurityImageLabel;
=20
+ virSecurityDomainSetMemoryLabel domainSetSecurityMemoryLabel;
+ virSecurityDomainRestoreMemoryLabel domainRestoreSecurityMemoryLabel;
+
virSecurityDomainSetDaemonSocketLabel domainSetSecurityDaemonSocketLab=
el;
virSecurityDomainSetSocketLabel domainSetSecuritySocketLabel;
virSecurityDomainClearSocketLabel domainClearSecuritySocketLabel;
diff --git a/src/security/security_manager.c b/src/security/security_manage=
r.c
index d8c6facc8..6c777db1e 100644
--- a/src/security/security_manager.c
+++ b/src/security/security_manager.c
@@ -1052,3 +1052,59 @@ virSecurityManagerDomainSetPathLabel(virSecurityMana=
gerPtr mgr,
=20
return 0;
}
+
+
+/**
+ * virSecurityManagerSetMemoryLabel:
+ * @mgr: security manager object
+ * @vm: domain definition object
+ * @mem: memory module to operate on
+ *
+ * Labels the host part of a memory module.
+ *
+ * Returns: 0 on success, -1 on error.
+ */
+int
+virSecurityManagerSetMemoryLabel(virSecurityManagerPtr mgr,
+ virDomainDefPtr vm,
+ virDomainMemoryDefPtr mem)
+{
+ if (mgr->drv->domainSetSecurityMemoryLabel) {
+ int ret;
+ virObjectLock(mgr);
+ ret =3D mgr->drv->domainSetSecurityMemoryLabel(mgr, vm, mem);
+ virObjectUnlock(mgr);
+ return ret;
+ }
+
+ virReportUnsupportedError();
+ return -1;
+}
+
+
+/**
+ * virSecurityManagerRestoreMemoryLabel:
+ * @mgr: security manager object
+ * @vm: domain definition object
+ * @mem: memory module to operate on
+ *
+ * Removes security label from the host part of a memory module.
+ *
+ * Returns: 0 on success, -1 on error.
+ */
+int
+virSecurityManagerRestoreMemoryLabel(virSecurityManagerPtr mgr,
+ virDomainDefPtr vm,
+ virDomainMemoryDefPtr mem)
+{
+ if (mgr->drv->domainRestoreSecurityMemoryLabel) {
+ int ret;
+ virObjectLock(mgr);
+ ret =3D mgr->drv->domainRestoreSecurityMemoryLabel(mgr, vm, mem);
+ virObjectUnlock(mgr);
+ return ret;
+ }
+
+ virReportUnsupportedError();
+ return -1;
+}
diff --git a/src/security/security_manager.h b/src/security/security_manage=
r.h
index bae8493ee..238e66cd0 100644
--- a/src/security/security_manager.h
+++ b/src/security/security_manager.h
@@ -162,6 +162,13 @@ int virSecurityManagerRestoreImageLabel(virSecurityMan=
agerPtr mgr,
virDomainDefPtr vm,
virStorageSourcePtr src);
=20
+int virSecurityManagerSetMemoryLabel(virSecurityManagerPtr mgr,
+ virDomainDefPtr vm,
+ virDomainMemoryDefPtr mem);
+int virSecurityManagerRestoreMemoryLabel(virSecurityManagerPtr mgr,
+ virDomainDefPtr vm,
+ virDomainMemoryDefPtr mem);
+
int virSecurityManagerDomainSetPathLabel(virSecurityManagerPtr mgr,
virDomainDefPtr vm,
const char *path);
diff --git a/src/security/security_stack.c b/src/security/security_stack.c
index 6056ae321..b02ee18a8 100644
--- a/src/security/security_stack.c
+++ b/src/security/security_stack.c
@@ -627,6 +627,41 @@ virSecurityStackRestoreImageLabel(virSecurityManagerPt=
r mgr,
return rc;
}
=20
+static int
+virSecurityStackSetMemoryLabel(virSecurityManagerPtr mgr,
+ virDomainDefPtr vm,
+ virDomainMemoryDefPtr mem)
+{
+ virSecurityStackDataPtr priv =3D virSecurityManagerGetPrivateData(mgr);
+ virSecurityStackItemPtr item =3D priv->itemsHead;
+ int rc =3D 0;
+
+ for (; item; item =3D item->next) {
+ if (virSecurityManagerSetMemoryLabel(item->securityManager, vm, me=
m) < 0)
+ rc =3D -1;
+ }
+
+ return rc;
+}
+
+static int
+virSecurityStackRestoreMemoryLabel(virSecurityManagerPtr mgr,
+ virDomainDefPtr vm,
+ virDomainMemoryDefPtr mem)
+{
+ virSecurityStackDataPtr priv =3D virSecurityManagerGetPrivateData(mgr);
+ virSecurityStackItemPtr item =3D priv->itemsHead;
+ int rc =3D 0;
+
+ for (; item; item =3D item->next) {
+ if (virSecurityManagerRestoreMemoryLabel(item->securityManager,
+ vm, mem) < 0)
+ rc =3D -1;
+ }
+
+ return rc;
+}
+
static int
virSecurityStackDomainSetPathLabel(virSecurityManagerPtr mgr,
virDomainDefPtr vm,
@@ -669,6 +704,9 @@ virSecurityDriver virSecurityDriverStack =3D {
.domainSetSecurityImageLabel =3D virSecurityStackSetImageLabel,
.domainRestoreSecurityImageLabel =3D virSecurityStackRestoreImageLa=
bel,
=20
+ .domainSetSecurityMemoryLabel =3D virSecurityStackSetMemoryLabel,
+ .domainRestoreSecurityMemoryLabel =3D virSecurityStackRestoreMemoryL=
abel,
+
.domainSetSecurityDaemonSocketLabel =3D virSecurityStackSetDaemonSocke=
tLabel,
.domainSetSecuritySocketLabel =3D virSecurityStackSetSocketLabel,
.domainClearSecuritySocketLabel =3D virSecurityStackClearSocketLab=
el,
--=20
2.11.0
--
libvir-list mailing list
libvir-list@redhat.com
https://www.redhat.com/mailman/listinfo/libvir-list
From nobody Fri Apr 26 16:12:55 2024
Delivered-To: importer@patchew.org
Received-SPF: pass (zoho.com: domain of redhat.com designates 209.132.183.25
as permitted sender) client-ip=209.132.183.25;
envelope-from=libvir-list-bounces@redhat.com; helo=mx4-phx2.redhat.com;
Authentication-Results: mx.zoho.com;
spf=pass (zoho.com: domain of redhat.com designates 209.132.183.25 as
permitted sender) smtp.mailfrom=libvir-list-bounces@redhat.com;
Return-Path:
Received: from mx4-phx2.redhat.com (mx4-phx2.redhat.com [209.132.183.25]) by
mx.zohomail.com
with SMTPS id 148907582153516.0832350151976;
Thu, 9 Mar 2017 08:10:21 -0800 (PST)
Received: from lists01.pubmisc.prod.ext.phx2.redhat.com
(lists01.pubmisc.prod.ext.phx2.redhat.com [10.5.19.33])
by mx4-phx2.redhat.com (8.13.8/8.13.8) with ESMTP id v29G70gF017877;
Thu, 9 Mar 2017 11:07:00 -0500
Received: from smtp.corp.redhat.com (int-mx16.intmail.prod.int.phx2.redhat.com
[10.5.11.28])
by lists01.pubmisc.prod.ext.phx2.redhat.com (8.13.8/8.13.8) with ESMTP
id v29G6gxW032493 for ;
Thu, 9 Mar 2017 11:06:42 -0500
Received: by smtp.corp.redhat.com (Postfix)
id 9692F2D5C2; Thu, 9 Mar 2017 16:06:42 +0000 (UTC)
Received: from moe.brq.redhat.com (dhcp129-131.brq.redhat.com [10.34.129.131])
by smtp.corp.redhat.com (Postfix) with ESMTP id 1E53E2D655
for ; Thu, 9 Mar 2017 16:06:41 +0000 (UTC)
From: Michal Privoznik
To: libvir-list@redhat.com
Date: Thu, 9 Mar 2017 17:06:23 +0100
Message-Id:
<9c61898b269d3e0369eb783004d11c4d6c306b82.1489075458.git.mprivozn@redhat.com>
In-Reply-To:
References:
In-Reply-To:
References:
X-Scanned-By: MIMEDefang 2.74 on 10.5.11.28
X-loop: libvir-list@redhat.com
Subject: [libvirt] [PATCH v3 14/17] secdrivers: Implement memdev relabel APIs
X-BeenThere: libvir-list@redhat.com
X-Mailman-Version: 2.1.12
Precedence: junk
List-Id: Development discussions about the libvirt library & tools
List-Unsubscribe: ,
List-Archive:
List-Post:
List-Help:
List-Subscribe: ,
MIME-Version: 1.0
Content-Transfer-Encoding: quoted-printable
Sender: libvir-list-bounces@redhat.com
Errors-To: libvir-list-bounces@redhat.com
X-ZohoMail: RSF_0 Z_629925259 SPT_0
Content-Type: text/plain; charset="utf-8"
Signed-off-by: Michal Privoznik
---
src/security/security_dac.c | 3 +++
src/security/security_nop.c | 19 +++++++++++++++++++
src/security/security_selinux.c | 3 +++
3 files changed, 25 insertions(+)
diff --git a/src/security/security_dac.c b/src/security/security_dac.c
index 27aa2bd6a..d6a2daf74 100644
--- a/src/security/security_dac.c
+++ b/src/security/security_dac.c
@@ -1975,6 +1975,9 @@ virSecurityDriver virSecurityDriverDAC =3D {
.domainSetSecurityImageLabel =3D virSecurityDACSetImageLabel,
.domainRestoreSecurityImageLabel =3D virSecurityDACRestoreImageLabe=
l,
=20
+ .domainSetSecurityMemoryLabel =3D virSecurityDACSetMemoryLabel,
+ .domainRestoreSecurityMemoryLabel =3D virSecurityDACRestoreMemoryLab=
el,
+
.domainSetSecurityDaemonSocketLabel =3D virSecurityDACSetDaemonSocketL=
abel,
.domainSetSecuritySocketLabel =3D virSecurityDACSetSocketLabel,
.domainClearSecuritySocketLabel =3D virSecurityDACClearSocketLabel,
diff --git a/src/security/security_nop.c b/src/security/security_nop.c
index 951125dce..0a9b51528 100644
--- a/src/security/security_nop.c
+++ b/src/security/security_nop.c
@@ -236,6 +236,22 @@ virSecurityDomainSetImageLabelNop(virSecurityManagerPt=
r mgr ATTRIBUTE_UNUSED,
return 0;
}
=20
+static int
+virSecurityDomainSetMemoryLabelNop(virSecurityManagerPtr mgr ATTRIBUTE_UNU=
SED,
+ virDomainDefPtr def ATTRIBUTE_UNUSED,
+ virDomainMemoryDefPtr mem ATTRIBUTE_UNU=
SED)
+{
+ return 0;
+}
+
+static int
+virSecurityDomainRestoreMemoryLabelNop(virSecurityManagerPtr mgr ATTRIBUTE=
_UNUSED,
+ virDomainDefPtr def ATTRIBUTE_UNUSE=
D,
+ virDomainMemoryDefPtr mem ATTRIBUTE=
_UNUSED)
+{
+ return 0;
+}
+
=20
virSecurityDriver virSecurityDriverNop =3D {
.privateDataLen =3D 0,
@@ -255,6 +271,9 @@ virSecurityDriver virSecurityDriverNop =3D {
.domainSetSecurityImageLabel =3D virSecurityDomainSetImageLabel=
Nop,
.domainRestoreSecurityImageLabel =3D virSecurityDomainRestoreImageL=
abelNop,
=20
+ .domainSetSecurityMemoryLabel =3D virSecurityDomainSetMemoryLabe=
lNop,
+ .domainRestoreSecurityMemoryLabel =3D virSecurityDomainRestoreMemory=
LabelNop,
+
.domainSetSecurityDaemonSocketLabel =3D virSecurityDomainSetDaemonSock=
etLabelNop,
.domainSetSecuritySocketLabel =3D virSecurityDomainSetSocketLabe=
lNop,
.domainClearSecuritySocketLabel =3D virSecurityDomainClearSocketLa=
belNop,
diff --git a/src/security/security_selinux.c b/src/security/security_selinu=
x.c
index 1be2acd27..e20382a02 100644
--- a/src/security/security_selinux.c
+++ b/src/security/security_selinux.c
@@ -3007,6 +3007,9 @@ virSecurityDriver virSecurityDriverSELinux =3D {
.domainSetSecurityImageLabel =3D virSecuritySELinuxSetImageLabe=
l,
.domainRestoreSecurityImageLabel =3D virSecuritySELinuxRestoreImage=
Label,
=20
+ .domainSetSecurityMemoryLabel =3D virSecuritySELinuxSetMemoryLab=
el,
+ .domainRestoreSecurityMemoryLabel =3D virSecuritySELinuxRestoreMemor=
yLabel,
+
.domainSetSecurityDaemonSocketLabel =3D virSecuritySELinuxSetDaemonSoc=
ketLabel,
.domainSetSecuritySocketLabel =3D virSecuritySELinuxSetSocketLab=
el,
.domainClearSecuritySocketLabel =3D virSecuritySELinuxClearSocketL=
abel,
--=20
2.11.0
--
libvir-list mailing list
libvir-list@redhat.com
https://www.redhat.com/mailman/listinfo/libvir-list
From nobody Fri Apr 26 16:12:55 2024
Delivered-To: importer@patchew.org
Received-SPF: pass (zoho.com: domain of redhat.com designates 209.132.183.25
as permitted sender) client-ip=209.132.183.25;
envelope-from=libvir-list-bounces@redhat.com; helo=mx4-phx2.redhat.com;
Authentication-Results: mx.zoho.com;
spf=pass (zoho.com: domain of redhat.com designates 209.132.183.25 as
permitted sender) smtp.mailfrom=libvir-list-bounces@redhat.com;
Return-Path:
Received: from mx4-phx2.redhat.com (mx4-phx2.redhat.com [209.132.183.25]) by
mx.zohomail.com
with SMTPS id 1489075834197997.70746730706;
Thu, 9 Mar 2017 08:10:34 -0800 (PST)
Received: from lists01.pubmisc.prod.ext.phx2.redhat.com
(lists01.pubmisc.prod.ext.phx2.redhat.com [10.5.19.33])
by mx4-phx2.redhat.com (8.13.8/8.13.8) with ESMTP id v29G72fw017891;
Thu, 9 Mar 2017 11:07:02 -0500
Received: from smtp.corp.redhat.com (int-mx16.intmail.prod.int.phx2.redhat.com
[10.5.11.28])
by lists01.pubmisc.prod.ext.phx2.redhat.com (8.13.8/8.13.8) with ESMTP
id v29G6hL4032503 for ;
Thu, 9 Mar 2017 11:06:43 -0500
Received: by smtp.corp.redhat.com (Postfix)
id 65DC42D5C0; Thu, 9 Mar 2017 16:06:43 +0000 (UTC)
Received: from moe.brq.redhat.com (dhcp129-131.brq.redhat.com [10.34.129.131])
by smtp.corp.redhat.com (Postfix) with ESMTP id E2AFC2D655
for ; Thu, 9 Mar 2017 16:06:42 +0000 (UTC)
From: Michal Privoznik
To: libvir-list@redhat.com
Date: Thu, 9 Mar 2017 17:06:24 +0100
Message-Id:
<0cf44e948b26ac9843213f13641e2b1a63807049.1489075458.git.mprivozn@redhat.com>
In-Reply-To:
References:
In-Reply-To:
References:
X-Scanned-By: MIMEDefang 2.74 on 10.5.11.28
X-loop: libvir-list@redhat.com
Subject: [libvirt] [PATCH v3 15/17] qemu_hotplug: Relabel memdev
X-BeenThere: libvir-list@redhat.com
X-Mailman-Version: 2.1.12
Precedence: junk
List-Id: Development discussions about the libvirt library & tools
List-Unsubscribe: ,
List-Archive:
List-Post:
List-Help:
List-Subscribe: ,
MIME-Version: 1.0
Content-Transfer-Encoding: quoted-printable
Sender: libvir-list-bounces@redhat.com
Errors-To: libvir-list-bounces@redhat.com
X-ZohoMail: RSF_0 Z_629925259 SPT_0
Content-Type: text/plain; charset="utf-8"
Now that we have APIs for relabel memdevs on hotplug, fill in the
missing implementation in qemu hotplug code.
The qemuSecurity wrappers might look like overkill for now,
because qemu namespace code does not deal with the nvdimms yet.
Nor does our cgroup code. But hey, there's cgroup_device_acl
variable in qemu.conf. If users add their /dev/pmem* device in
there, the device is allowed in cgroups and created in the
namespace so they can successfully passthrough it to the domain.
It doesn't look like overkill after all, does it?
Signed-off-by: Michal Privoznik
---
src/qemu/qemu_hotplug.c | 13 +++++++++++
src/qemu/qemu_security.c | 56 ++++++++++++++++++++++++++++++++++++++++++++=
++++
src/qemu/qemu_security.h | 8 +++++++
3 files changed, 77 insertions(+)
diff --git a/src/qemu/qemu_hotplug.c b/src/qemu/qemu_hotplug.c
index 4e416b12e..7e19d2f82 100644
--- a/src/qemu/qemu_hotplug.c
+++ b/src/qemu/qemu_hotplug.c
@@ -2215,6 +2215,7 @@ qemuDomainAttachMemory(virQEMUDriverPtr driver,
char *objalias =3D NULL;
const char *backendType;
bool objAdded =3D false;
+ bool teardownlabel =3D false;
virJSONValuePtr props =3D NULL;
virObjectEventPtr event;
int id;
@@ -2244,6 +2245,10 @@ qemuDomainAttachMemory(virQEMUDriverPtr driver,
priv->qemuCaps, vm->def, mem, NULL, true=
) < 0)
goto cleanup;
=20
+ if (qemuSecuritySetMemoryLabel(driver, vm, mem) < 0)
+ goto cleanup;
+ teardownlabel =3D true;
+
if (virDomainMemoryInsert(vm->def, mem) < 0) {
virJSONValueFree(props);
goto cleanup;
@@ -2288,6 +2293,11 @@ qemuDomainAttachMemory(virQEMUDriverPtr driver,
audit:
virDomainAuditMemory(vm, oldmem, newmem, "update", ret =3D=3D 0);
cleanup:
+ if (mem && ret < 0) {
+ if (teardownlabel && qemuSecurityRestoreMemoryLabel(driver, vm, me=
m) < 0)
+ VIR_WARN("Unable to restore security label on memdev");
+ }
+
virObjectUnref(cfg);
VIR_FREE(devstr);
VIR_FREE(objalias);
@@ -3748,6 +3758,9 @@ qemuDomainRemoveMemoryDevice(virQEMUDriverPtr driver,
if ((idx =3D virDomainMemoryFindByDef(vm->def, mem)) >=3D 0)
virDomainMemoryRemove(vm->def, idx);
=20
+ if (qemuSecurityRestoreMemoryLabel(driver, vm, mem) < 0)
+ VIR_WARN("Unable to restore security label on memdev");
+
virDomainMemoryDefFree(mem);
=20
/* fix the balloon size */
diff --git a/src/qemu/qemu_security.c b/src/qemu/qemu_security.c
index f2931976b..61934f990 100644
--- a/src/qemu/qemu_security.c
+++ b/src/qemu/qemu_security.c
@@ -245,3 +245,59 @@ qemuSecurityRestoreHostdevLabel(virQEMUDriverPtr drive=
r,
virSecurityManagerTransactionAbort(driver->securityManager);
return ret;
}
+
+
+int
+qemuSecuritySetMemoryLabel(virQEMUDriverPtr driver,
+ virDomainObjPtr vm,
+ virDomainMemoryDefPtr mem)
+{
+ int ret =3D -1;
+
+ if (qemuDomainNamespaceEnabled(vm, QEMU_DOMAIN_NS_MOUNT) &&
+ virSecurityManagerTransactionStart(driver->securityManager) < 0)
+ goto cleanup;
+
+ if (virSecurityManagerSetMemoryLabel(driver->securityManager,
+ vm->def,
+ mem) < 0)
+ goto cleanup;
+
+ if (qemuDomainNamespaceEnabled(vm, QEMU_DOMAIN_NS_MOUNT) &&
+ virSecurityManagerTransactionCommit(driver->securityManager,
+ vm->pid) < 0)
+ goto cleanup;
+
+ ret =3D 0;
+ cleanup:
+ virSecurityManagerTransactionAbort(driver->securityManager);
+ return ret;
+}
+
+
+int
+qemuSecurityRestoreMemoryLabel(virQEMUDriverPtr driver,
+ virDomainObjPtr vm,
+ virDomainMemoryDefPtr mem)
+{
+ int ret =3D -1;
+
+ if (qemuDomainNamespaceEnabled(vm, QEMU_DOMAIN_NS_MOUNT) &&
+ virSecurityManagerTransactionStart(driver->securityManager) < 0)
+ goto cleanup;
+
+ if (virSecurityManagerRestoreMemoryLabel(driver->securityManager,
+ vm->def,
+ mem) < 0)
+ goto cleanup;
+
+ if (qemuDomainNamespaceEnabled(vm, QEMU_DOMAIN_NS_MOUNT) &&
+ virSecurityManagerTransactionCommit(driver->securityManager,
+ vm->pid) < 0)
+ goto cleanup;
+
+ ret =3D 0;
+ cleanup:
+ virSecurityManagerTransactionAbort(driver->securityManager);
+ return ret;
+}
diff --git a/src/qemu/qemu_security.h b/src/qemu/qemu_security.h
index d86db3f6b..7b25855bf 100644
--- a/src/qemu/qemu_security.h
+++ b/src/qemu/qemu_security.h
@@ -62,6 +62,14 @@ int qemuSecurityRestoreHostdevLabel(virQEMUDriverPtr dri=
ver,
virDomainObjPtr vm,
virDomainHostdevDefPtr hostdev);
=20
+int qemuSecuritySetMemoryLabel(virQEMUDriverPtr driver,
+ virDomainObjPtr vm,
+ virDomainMemoryDefPtr mem);
+
+int qemuSecurityRestoreMemoryLabel(virQEMUDriverPtr driver,
+ virDomainObjPtr vm,
+ virDomainMemoryDefPtr mem);
+
/* Please note that for these APIs there is no wrapper yet. Do NOT blindly=
add
* new APIs here. If an API can touch a /dev file add a proper wrapper ins=
tead.
*/
--=20
2.11.0
--
libvir-list mailing list
libvir-list@redhat.com
https://www.redhat.com/mailman/listinfo/libvir-list
From nobody Fri Apr 26 16:12:55 2024
Delivered-To: importer@patchew.org
Received-SPF: pass (zoho.com: domain of redhat.com designates 209.132.183.37
as permitted sender) client-ip=209.132.183.37;
envelope-from=libvir-list-bounces@redhat.com; helo=mx5-phx2.redhat.com;
Authentication-Results: mx.zoho.com;
spf=pass (zoho.com: domain of redhat.com designates 209.132.183.37 as
permitted sender) smtp.mailfrom=libvir-list-bounces@redhat.com;
Return-Path:
Received: from mx5-phx2.redhat.com (mx5-phx2.redhat.com [209.132.183.37]) by
mx.zohomail.com
with SMTPS id 1489075836831331.75023796853213;
Thu, 9 Mar 2017 08:10:36 -0800 (PST)
Received: from lists01.pubmisc.prod.ext.phx2.redhat.com
(lists01.pubmisc.prod.ext.phx2.redhat.com [10.5.19.33])
by mx5-phx2.redhat.com (8.14.4/8.14.4) with ESMTP id v29G74tY051507;
Thu, 9 Mar 2017 11:07:05 -0500
Received: from smtp.corp.redhat.com (int-mx16.intmail.prod.int.phx2.redhat.com
[10.5.11.28])
by lists01.pubmisc.prod.ext.phx2.redhat.com (8.13.8/8.13.8) with ESMTP
id v29G6iRD032518 for ;
Thu, 9 Mar 2017 11:06:44 -0500
Received: by smtp.corp.redhat.com (Postfix)
id 348312D5C0; Thu, 9 Mar 2017 16:06:44 +0000 (UTC)
Received: from moe.brq.redhat.com (dhcp129-131.brq.redhat.com [10.34.129.131])
by smtp.corp.redhat.com (Postfix) with ESMTP id B23D42D655
for ; Thu, 9 Mar 2017 16:06:43 +0000 (UTC)
From: Michal Privoznik
To: libvir-list@redhat.com
Date: Thu, 9 Mar 2017 17:06:25 +0100
Message-Id:
In-Reply-To:
References:
In-Reply-To:
References:
X-Scanned-By: MIMEDefang 2.74 on 10.5.11.28
X-loop: libvir-list@redhat.com
Subject: [libvirt] [PATCH v3 16/17] qemu: Allow nvdimm in devices CGroups
X-BeenThere: libvir-list@redhat.com
X-Mailman-Version: 2.1.12
Precedence: junk
List-Id: Development discussions about the libvirt library & tools
List-Unsubscribe: ,
List-Archive:
List-Post:
List-Help:
List-Subscribe: ,
MIME-Version: 1.0
Content-Transfer-Encoding: quoted-printable
Sender: libvir-list-bounces@redhat.com
Errors-To: libvir-list-bounces@redhat.com
X-ZohoMail: RSF_0 Z_629925259 SPT_0
Content-Type: text/plain; charset="utf-8"
Some users might want to pass a blockdev or a chardev as a
backend for NVDIMM. In fact, this is expected to be the mostly
used configuration. Therefore libvirt should allow the device in
devices CGroup then.
Signed-off-by: Michal Privoznik
---
src/qemu/qemu_cgroup.c | 49 +++++++++++++++++++++++++++++++++++++++++++++=
++++
src/qemu/qemu_cgroup.h | 4 ++++
src/qemu/qemu_hotplug.c | 10 ++++++++++
3 files changed, 63 insertions(+)
diff --git a/src/qemu/qemu_cgroup.c b/src/qemu/qemu_cgroup.c
index 42a47a798..36762d4f6 100644
--- a/src/qemu/qemu_cgroup.c
+++ b/src/qemu/qemu_cgroup.c
@@ -348,6 +348,50 @@ qemuTeardownHostdevCgroup(virDomainObjPtr vm,
}
=20
=20
+int
+qemuSetupMemoryDevicesCgroup(virDomainObjPtr vm,
+ virDomainMemoryDefPtr mem)
+{
+ qemuDomainObjPrivatePtr priv =3D vm->privateData;
+ int rv;
+
+ if (mem->model !=3D VIR_DOMAIN_MEMORY_MODEL_NVDIMM)
+ return 0;
+
+ if (!virCgroupHasController(priv->cgroup, VIR_CGROUP_CONTROLLER_DEVICE=
S))
+ return 0;
+
+ VIR_DEBUG("Setting devices Cgroup for NVDIMM device: %s", mem->nvdimmP=
ath);
+ rv =3D virCgroupAllowDevicePath(priv->cgroup, mem->nvdimmPath,
+ VIR_CGROUP_DEVICE_RW, false);
+ virDomainAuditCgroupPath(vm, priv->cgroup, "allow",
+ mem->nvdimmPath, "rw", rv =3D=3D 0);
+
+ return rv;
+}
+
+
+int
+qemuTeardownMemoryDevicesCgroup(virDomainObjPtr vm,
+ virDomainMemoryDefPtr mem)
+{
+ qemuDomainObjPrivatePtr priv =3D vm->privateData;
+ int rv;
+
+ if (mem->model !=3D VIR_DOMAIN_MEMORY_MODEL_NVDIMM)
+ return 0;
+
+ if (!virCgroupHasController(priv->cgroup, VIR_CGROUP_CONTROLLER_DEVICE=
S))
+ return 0;
+
+ rv =3D virCgroupDenyDevicePath(priv->cgroup, mem->nvdimmPath,
+ VIR_CGROUP_DEVICE_RWM, false);
+ virDomainAuditCgroupPath(vm, priv->cgroup,
+ "deny", mem->nvdimmPath, "rwm", rv =3D=3D 0);
+ return rv;
+}
+
+
static int
qemuSetupGraphicsCgroup(virDomainObjPtr vm,
virDomainGraphicsDefPtr gfx)
@@ -647,6 +691,11 @@ qemuSetupDevicesCgroup(virQEMUDriverPtr driver,
goto cleanup;
}
=20
+ for (i =3D 0; i < vm->def->nmems; i++) {
+ if (qemuSetupMemoryDevicesCgroup(vm, vm->def->mems[i]) < 0)
+ goto cleanup;
+ }
+
for (i =3D 0; i < vm->def->ngraphics; i++) {
if (qemuSetupGraphicsCgroup(vm, vm->def->graphics[i]) < 0)
goto cleanup;
diff --git a/src/qemu/qemu_cgroup.h b/src/qemu/qemu_cgroup.h
index 8ae4a72ab..d016ce29d 100644
--- a/src/qemu/qemu_cgroup.h
+++ b/src/qemu/qemu_cgroup.h
@@ -43,6 +43,10 @@ int qemuSetupHostdevCgroup(virDomainObjPtr vm,
int qemuTeardownHostdevCgroup(virDomainObjPtr vm,
virDomainHostdevDefPtr dev)
ATTRIBUTE_RETURN_CHECK;
+int qemuSetupMemoryDevicesCgroup(virDomainObjPtr vm,
+ virDomainMemoryDefPtr mem);
+int qemuTeardownMemoryDevicesCgroup(virDomainObjPtr vm,
+ virDomainMemoryDefPtr mem);
int qemuSetupRNGCgroup(virDomainObjPtr vm,
virDomainRNGDefPtr rng);
int qemuTeardownRNGCgroup(virDomainObjPtr vm,
diff --git a/src/qemu/qemu_hotplug.c b/src/qemu/qemu_hotplug.c
index 7e19d2f82..829b40258 100644
--- a/src/qemu/qemu_hotplug.c
+++ b/src/qemu/qemu_hotplug.c
@@ -2216,6 +2216,7 @@ qemuDomainAttachMemory(virQEMUDriverPtr driver,
const char *backendType;
bool objAdded =3D false;
bool teardownlabel =3D false;
+ bool teardowncgroup =3D false;
virJSONValuePtr props =3D NULL;
virObjectEventPtr event;
int id;
@@ -2245,6 +2246,10 @@ qemuDomainAttachMemory(virQEMUDriverPtr driver,
priv->qemuCaps, vm->def, mem, NULL, true=
) < 0)
goto cleanup;
=20
+ if (qemuSetupMemoryDevicesCgroup(vm, mem) < 0)
+ goto cleanup;
+ teardowncgroup =3D true;
+
if (qemuSecuritySetMemoryLabel(driver, vm, mem) < 0)
goto cleanup;
teardownlabel =3D true;
@@ -2294,6 +2299,8 @@ qemuDomainAttachMemory(virQEMUDriverPtr driver,
virDomainAuditMemory(vm, oldmem, newmem, "update", ret =3D=3D 0);
cleanup:
if (mem && ret < 0) {
+ if (teardowncgroup && qemuTeardownMemoryDevicesCgroup(vm, mem) < 0)
+ VIR_WARN("Unable to remove memory device cgroup ACL on hotplug=
fail");
if (teardownlabel && qemuSecurityRestoreMemoryLabel(driver, vm, me=
m) < 0)
VIR_WARN("Unable to restore security label on memdev");
}
@@ -3761,6 +3768,9 @@ qemuDomainRemoveMemoryDevice(virQEMUDriverPtr driver,
if (qemuSecurityRestoreMemoryLabel(driver, vm, mem) < 0)
VIR_WARN("Unable to restore security label on memdev");
=20
+ if (qemuTeardownMemoryDevicesCgroup(vm, mem) < 0)
+ VIR_WARN("Unable to remove memory device cgroup ACL");
+
virDomainMemoryDefFree(mem);
=20
/* fix the balloon size */
--=20
2.11.0
--
libvir-list mailing list
libvir-list@redhat.com
https://www.redhat.com/mailman/listinfo/libvir-list
From nobody Fri Apr 26 16:12:55 2024
Delivered-To: importer@patchew.org
Received-SPF: pass (zoho.com: domain of redhat.com designates 209.132.183.24
as permitted sender) client-ip=209.132.183.24;
envelope-from=libvir-list-bounces@redhat.com; helo=mx3-phx2.redhat.com;
Authentication-Results: mx.zoho.com;
spf=pass (zoho.com: domain of redhat.com designates 209.132.183.24 as
permitted sender) smtp.mailfrom=libvir-list-bounces@redhat.com;
Return-Path:
Received: from mx3-phx2.redhat.com (mx3-phx2.redhat.com [209.132.183.24]) by
mx.zohomail.com
with SMTPS id 1489075835099323.67539468628763;
Thu, 9 Mar 2017 08:10:35 -0800 (PST)
Received: from lists01.pubmisc.prod.ext.phx2.redhat.com
(lists01.pubmisc.prod.ext.phx2.redhat.com [10.5.19.33])
by mx3-phx2.redhat.com (8.13.8/8.13.8) with ESMTP id v29G762E015252;
Thu, 9 Mar 2017 11:07:06 -0500
Received: from smtp.corp.redhat.com (int-mx16.intmail.prod.int.phx2.redhat.com
[10.5.11.28])
by lists01.pubmisc.prod.ext.phx2.redhat.com (8.13.8/8.13.8) with ESMTP
id v29G6jYC032525 for ;
Thu, 9 Mar 2017 11:06:45 -0500
Received: by smtp.corp.redhat.com (Postfix)
id 04BB72D5C2; Thu, 9 Mar 2017 16:06:45 +0000 (UTC)
Received: from moe.brq.redhat.com (dhcp129-131.brq.redhat.com [10.34.129.131])
by smtp.corp.redhat.com (Postfix) with ESMTP id 812672D653
for ; Thu, 9 Mar 2017 16:06:44 +0000 (UTC)
From: Michal Privoznik
To: libvir-list@redhat.com
Date: Thu, 9 Mar 2017 17:06:26 +0100
Message-Id:
In-Reply-To:
References:
In-Reply-To:
References:
X-Scanned-By: MIMEDefang 2.74 on 10.5.11.28
X-loop: libvir-list@redhat.com
Subject: [libvirt] [PATCH v3 17/17] qemu: Namespaces for NVDIMM
X-BeenThere: libvir-list@redhat.com
X-Mailman-Version: 2.1.12
Precedence: junk
List-Id: Development discussions about the libvirt library & tools
List-Unsubscribe: ,
List-Archive:
List-Post:
List-Help:
List-Subscribe: ,
MIME-Version: 1.0
Content-Transfer-Encoding: quoted-printable
Sender: libvir-list-bounces@redhat.com
Errors-To: libvir-list-bounces@redhat.com
X-ZohoMail: RSF_0 Z_629925259 SPT_0
Content-Type: text/plain; charset="utf-8"
Signed-off-by: Michal Privoznik
---
src/qemu/qemu_domain.c | 76 +++++++++++++++++++++++++++++++++++++++++++++=
++++
src/qemu/qemu_domain.h | 8 ++++++
src/qemu/qemu_hotplug.c | 11 +++++++
3 files changed, 95 insertions(+)
diff --git a/src/qemu/qemu_domain.c b/src/qemu/qemu_domain.c
index 495242981..552523617 100644
--- a/src/qemu/qemu_domain.c
+++ b/src/qemu/qemu_domain.c
@@ -7526,6 +7526,37 @@ qemuDomainSetupAllHostdevs(virQEMUDriverConfigPtr cf=
g,
}
=20
=20
+static int
+qemuDomainSetupMemory(virQEMUDriverConfigPtr cfg ATTRIBUTE_UNUSED,
+ virDomainMemoryDefPtr mem,
+ const char *devPath)
+{
+ if (mem->model !=3D VIR_DOMAIN_MEMORY_MODEL_NVDIMM)
+ return 0;
+
+ return qemuDomainCreateDevice(mem->nvdimmPath, devPath, false);
+}
+
+
+static int
+qemuDomainSetupAllMemories(virQEMUDriverConfigPtr cfg,
+ virDomainObjPtr vm,
+ const char *devPath)
+{
+ size_t i;
+
+ VIR_DEBUG("Setting up memories");
+ for (i =3D 0; i < vm->def->nmems; i++) {
+ if (qemuDomainSetupMemory(cfg,
+ vm->def->mems[i],
+ devPath) < 0)
+ return -1;
+ }
+ VIR_DEBUG("Setup all memories");
+ return 0;
+}
+
+
static int
qemuDomainSetupChardev(virDomainDefPtr def ATTRIBUTE_UNUSED,
virDomainChrDefPtr dev,
@@ -7770,6 +7801,9 @@ qemuDomainBuildNamespace(virQEMUDriverConfigPtr cfg,
if (qemuDomainSetupAllHostdevs(cfg, vm, devPath) < 0)
goto cleanup;
=20
+ if (qemuDomainSetupAllMemories(cfg, vm, devPath) < 0)
+ goto cleanup;
+
if (qemuDomainSetupAllChardevs(cfg, vm, devPath) < 0)
goto cleanup;
=20
@@ -8228,6 +8262,48 @@ qemuDomainNamespaceTeardownHostdev(virQEMUDriverPtr =
driver,
}
=20
=20
+int
+qemuDomainNamespaceSetupMemory(virQEMUDriverPtr driver,
+ virDomainObjPtr vm,
+ virDomainMemoryDefPtr mem)
+{
+ int ret =3D -1;
+
+ if (mem->model !=3D VIR_DOMAIN_MEMORY_MODEL_NVDIMM)
+ return 0;
+
+ if (!qemuDomainNamespaceEnabled(vm, QEMU_DOMAIN_NS_MOUNT))
+ return 0;
+
+ if (qemuDomainAttachDeviceMknod(driver, vm, mem->nvdimmPath) < 0)
+ goto cleanup;
+ ret =3D 0;
+ cleanup:
+ return ret;
+}
+
+
+int
+qemuDomainNamespaceTeardownMemory(virQEMUDriverPtr driver,
+ virDomainObjPtr vm,
+ virDomainMemoryDefPtr mem)
+{
+ int ret =3D -1;
+
+ if (mem->model !=3D VIR_DOMAIN_MEMORY_MODEL_NVDIMM)
+ return 0;
+
+ if (!qemuDomainNamespaceEnabled(vm, QEMU_DOMAIN_NS_MOUNT))
+ return 0;
+
+ if (qemuDomainDetachDeviceUnlink(driver, vm, mem->nvdimmPath) < 0)
+ goto cleanup;
+ ret =3D 0;
+ cleanup:
+ return ret;
+}
+
+
int
qemuDomainNamespaceSetupChardev(virQEMUDriverPtr driver,
virDomainObjPtr vm,
diff --git a/src/qemu/qemu_domain.h b/src/qemu/qemu_domain.h
index 7fa717390..f5b8d3fe7 100644
--- a/src/qemu/qemu_domain.h
+++ b/src/qemu/qemu_domain.h
@@ -834,6 +834,14 @@ int qemuDomainNamespaceTeardownHostdev(virQEMUDriverPt=
r driver,
virDomainObjPtr vm,
virDomainHostdevDefPtr hostdev);
=20
+int qemuDomainNamespaceSetupMemory(virQEMUDriverPtr driver,
+ virDomainObjPtr vm,
+ virDomainMemoryDefPtr memory);
+
+int qemuDomainNamespaceTeardownMemory(virQEMUDriverPtr driver,
+ virDomainObjPtr vm,
+ virDomainMemoryDefPtr memory);
+
int qemuDomainNamespaceSetupChardev(virQEMUDriverPtr driver,
virDomainObjPtr vm,
virDomainChrDefPtr chr);
diff --git a/src/qemu/qemu_hotplug.c b/src/qemu/qemu_hotplug.c
index 829b40258..392b2fd02 100644
--- a/src/qemu/qemu_hotplug.c
+++ b/src/qemu/qemu_hotplug.c
@@ -2217,6 +2217,7 @@ qemuDomainAttachMemory(virQEMUDriverPtr driver,
bool objAdded =3D false;
bool teardownlabel =3D false;
bool teardowncgroup =3D false;
+ bool teardowndevice =3D false;
virJSONValuePtr props =3D NULL;
virObjectEventPtr event;
int id;
@@ -2246,6 +2247,10 @@ qemuDomainAttachMemory(virQEMUDriverPtr driver,
priv->qemuCaps, vm->def, mem, NULL, true=
) < 0)
goto cleanup;
=20
+ if (qemuDomainNamespaceSetupMemory(driver, vm, mem) < 0)
+ goto removedef;
+ teardowndevice =3D true;
+
if (qemuSetupMemoryDevicesCgroup(vm, mem) < 0)
goto cleanup;
teardowncgroup =3D true;
@@ -2303,6 +2308,9 @@ qemuDomainAttachMemory(virQEMUDriverPtr driver,
VIR_WARN("Unable to remove memory device cgroup ACL on hotplug=
fail");
if (teardownlabel && qemuSecurityRestoreMemoryLabel(driver, vm, me=
m) < 0)
VIR_WARN("Unable to restore security label on memdev");
+ if (teardowndevice &&
+ qemuDomainNamespaceTeardownMemory(driver, vm, mem) < 0)
+ VIR_WARN("Unable to remove memory device from /dev");
}
=20
virObjectUnref(cfg);
@@ -3771,6 +3779,9 @@ qemuDomainRemoveMemoryDevice(virQEMUDriverPtr driver,
if (qemuTeardownMemoryDevicesCgroup(vm, mem) < 0)
VIR_WARN("Unable to remove memory device cgroup ACL");
=20
+ if (qemuDomainNamespaceTeardownMemory(driver, vm, mem) < 0)
+ VIR_WARN("Unable to remove memory device from /dev");
+
virDomainMemoryDefFree(mem);
=20
/* fix the balloon size */
--=20
2.11.0
--
libvir-list mailing list
libvir-list@redhat.com
https://www.redhat.com/mailman/listinfo/libvir-list