[libvirt PATCHv3 06/12] conf: add virtiofs-related elements and attributes
Masayoshi Mizuma
msys.mizuma at gmail.com
Tue Feb 4 19:57:04 UTC 2020
On Thu, Jan 30, 2020 at 06:06:22PM +0100, Ján Tomko wrote:
> Add more elements for tuning the virtiofsd daemon
> and the vhost-user-fs device:
>
> <driver type='virtiofs' queue='1024' xattr='on'>
> <binary>/usr/libexec/virtiofsd</binary>
> <cache mode='always' size='2097152' unit='KiB'/>
> <lock posix='off' flock='off'/>
> </driver>
Above config doesn't work... Following?
<driver type='virtiofs' queue='1024'/>
<binary path='/usr/libexec/virtiofsd' xattr='off'>
<cache mode='always'/>
<lock posix='off' flock='off'/>
</binary>
The code looks good to me.
Reviewed-by: Masayoshi Mizuma <m.mizuma at jp.fujitsu.com>
Thanks,
Masa
>
> Signed-off-by: Ján Tomko <jtomko at redhat.com>
> ---
> docs/formatdomain.html.in | 25 +++-
> docs/schemas/domaincommon.rng | 48 ++++++++
> src/conf/domain_conf.c | 107 +++++++++++++++++-
> src/conf/domain_conf.h | 15 +++
> src/libvirt_private.syms | 1 +
> .../vhost-user-fs-fd-memory.xml | 6 +-
> .../vhost-user-fs-hugepages.xml | 1 +
> 7 files changed, 200 insertions(+), 3 deletions(-)
>
> diff --git a/docs/formatdomain.html.in b/docs/formatdomain.html.in
> index d5565361ab..58e06d21f5 100644
> --- a/docs/formatdomain.html.in
> +++ b/docs/formatdomain.html.in
> @@ -3922,10 +3922,15 @@
> <readonly/>
> </filesystem>
> <filesystem type='mount' accessmode='passthrough'>
> - <driver type='virtiofs'/>
> + <driver type='virtiofs queue='1024'/>
> + <binary path='/usr/libexec/virtiofsd' xattr='on'>
> + <cache mode='always'/>
> + <lock posix='on' flock='on'/>
> + </binary>
> <source dir='/path'/>
> <target dir='mount_tag'/>
> </filesystem>
> +
> ...
> </devices>
> ...</pre>
> @@ -4049,9 +4054,27 @@
> <a href="#elementsVirtio">Virtio-specific options</a> can also be
> set. (<span class="since">Since 3.5.0</span>)
> </li>
> + <li>
> + For <code>virtiofs</code>, the <code>queue</code> attribute can be used
> + to specify the queue size (i.e. how many requests can the queue fit).
> + (<span class="since">Since 6.1.0</span>)
> + </li>
> </ul>
> </dd>
>
> + <dt><code>binary</code></dt>
> + <dd>
> + The optional <code>binary</code> element can tune the options for virtiofsd.
> + The attribute <code>path</code> can be used to override the path to the daemon.
> + Attribute <code>xattr</code> enables the use of filesystem extended attributes.
> + Caching can be tuned via the <code>cache</code> element, possible <code>mode</code>
> + values being <code>none</code> and <code>always</code>.
> + Locking can be controlled via the <code>lock</code>
> + element - attributes <code>posix</code> and <code>flock</code> both accepting
> + values <code>yes</code> or <code>no</code>.
> + (<span class="since">Since 6.1.0</span>)
> + </dd>
> +
> <dt><code>source</code></dt>
> <dd>
> The resource on the host that is being accessed in the guest. The
> diff --git a/docs/schemas/domaincommon.rng b/docs/schemas/domaincommon.rng
> index e30b82c57e..db475a43ca 100644
> --- a/docs/schemas/domaincommon.rng
> +++ b/docs/schemas/domaincommon.rng
> @@ -2480,6 +2480,9 @@
> <optional>
> <ref name="fsDriver"/>
> </optional>
> + <optional>
> + <ref name="fsBinary"/>
> + </optional>
> <interleave>
> <element name="source">
> <attribute name="dir">
> @@ -2629,12 +2632,57 @@
> <attribute name="type">
> <value>virtiofs</value>
> </attribute>
> + <optional>
> + <attribute name="queue">
> + <ref name="unsignedInt"/>
> + </attribute>
> + </optional>
> <ref name='virtioOptions'/>
> </group>
> <empty/>
> </choice>
> </element>
> </define>
> + <define name="fsBinary">
> + <element name="binary">
> + <optional>
> + <attribute name="path">
> + <ref name="absFilePath"/>
> + </attribute>
> + </optional>
> + <optional>
> + <attribute name="xattr">
> + <ref name="virOnOff"/>
> + </attribute>
> + </optional>
> + <optional>
> + <element name="cache">
> + <optional>
> + <attribute name="mode">
> + <choice>
> + <value>none</value>
> + <value>always</value>
> + </choice>
> + </attribute>
> + </optional>
> + </element>
> + </optional>
> + <optional>
> + <element name="lock">
> + <optional>
> + <attribute name="posix">
> + <ref name="virOnOff"/>
> + </attribute>
> + </optional>
> + <optional>
> + <attribute name="flock">
> + <ref name="virOnOff"/>
> + </attribute>
> + </optional>
> + </element>
> + </optional>
> + </element>
> + </define>
>
> <define name="interface-network-attributes">
> <attribute name="network">
> diff --git a/src/conf/domain_conf.c b/src/conf/domain_conf.c
> index d1a6d125d7..5c26e0d06c 100644
> --- a/src/conf/domain_conf.c
> +++ b/src/conf/domain_conf.c
> @@ -501,6 +501,14 @@ VIR_ENUM_IMPL(virDomainFSModel,
> "virtio-non-transitional",
> );
>
> +VIR_ENUM_IMPL(virDomainFSCacheMode,
> + VIR_DOMAIN_FS_CACHE_MODE_LAST,
> + "default",
> + "none",
> + "always",
> +);
> +
> +
> VIR_ENUM_IMPL(virDomainNet,
> VIR_DOMAIN_NET_TYPE_LAST,
> "user",
> @@ -2322,6 +2330,7 @@ void virDomainFSDefFree(virDomainFSDefPtr def)
> VIR_FREE(def->dst);
> virDomainDeviceInfoClear(&def->info);
> VIR_FREE(def->virtio);
> + VIR_FREE(def->binary);
>
> VIR_FREE(def);
> }
> @@ -11254,6 +11263,64 @@ virDomainFSDefParseXML(virDomainXMLOptionPtr xmlopt,
> }
> }
>
> + if (def->fsdriver == VIR_DOMAIN_FS_DRIVER_TYPE_VIRTIOFS) {
> + g_autofree char *queue_size = virXPathString("string(./driver/@queue)", ctxt);
> + g_autofree char *binary = virXPathString("string(./binary/@path)", ctxt);
> + g_autofree char *xattr = virXPathString("string(./binary/@xattr)", ctxt);
> + g_autofree char *cache = virXPathString("string(./binary/cache/@mode)", ctxt);
> + g_autofree char *posix_lock = virXPathString("string(./binary/lock/@posix)", ctxt);
> + g_autofree char *flock = virXPathString("string(./binary/lock/@flock)", ctxt);
> + int val;
> +
> +
> + if (queue_size && virStrToLong_ull(queue_size, NULL, 10, &def->queue_size) < 0) {
> + virReportError(VIR_ERR_XML_ERROR,
> + _("cannot parse queue size '%s' for virtiofs"),
> + queue_size);
> + goto error;
> + }
> +
> + if (binary)
> + def->binary = virFileSanitizePath(binary);
> +
> + if (xattr) {
> + if ((val = virTristateSwitchTypeFromString(xattr)) <= 0) {
> + virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
> + _("unknown xattr value '%s'"), xattr);
> + goto error;
> + }
> + def->xattr = val;
> + }
> +
> + if (cache) {
> + if ((val = virDomainFSCacheModeTypeFromString(cache)) <= 0) {
> + virReportError(VIR_ERR_XML_ERROR,
> + _("cannot parse cache mode '%s' for virtiofs"),
> + cache);
> + goto error;
> + }
> + def->cache = val;
> + }
> +
> + if (posix_lock) {
> + if ((val = virTristateSwitchTypeFromString(posix_lock)) <= 0) {
> + virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
> + _("unknown posix lock value '%s'"), posix_lock);
> + goto error;
> + }
> + def->posix_lock = val;
> + }
> +
> + if (flock) {
> + if ((val = virTristateSwitchTypeFromString(flock)) <= 0) {
> + virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
> + _("unknown flock value '%s'"), flock);
> + goto error;
> + }
> + def->flock = val;
> + }
> + }
> +
> if (format) {
> if ((def->format = virStorageFileFormatTypeFromString(format)) <= 0) {
> virReportError(VIR_ERR_CONFIG_UNSUPPORTED,
> @@ -25053,6 +25120,9 @@ virDomainFSDefFormat(virBufferPtr buf,
> const char *wrpolicy = virDomainFSWrpolicyTypeToString(def->wrpolicy);
> const char *src = def->src->path;
> g_auto(virBuffer) driverAttrBuf = VIR_BUFFER_INITIALIZER;
> + g_auto(virBuffer) driverBuf = VIR_BUFFER_INIT_CHILD(buf);
> + g_auto(virBuffer) binaryAttrBuf = VIR_BUFFER_INITIALIZER;
> + g_auto(virBuffer) binaryBuf = VIR_BUFFER_INIT_CHILD(buf);
>
> if (!type) {
> virReportError(VIR_ERR_INTERNAL_ERROR,
> @@ -25076,6 +25146,8 @@ virDomainFSDefFormat(virBufferPtr buf,
> virBufferAddLit(buf, ">\n");
>
> virBufferAdjustIndent(buf, 2);
> + virBufferAdjustIndent(&driverBuf, 2);
> + virBufferAdjustIndent(&binaryBuf, 2);
> if (def->fsdriver) {
> virBufferAsprintf(&driverAttrBuf, " type='%s'", fsdriver);
>
> @@ -25087,11 +25159,44 @@ virDomainFSDefFormat(virBufferPtr buf,
> if (def->wrpolicy)
> virBufferAsprintf(&driverAttrBuf, " wrpolicy='%s'", wrpolicy);
>
> + if (def->queue_size)
> + virBufferAsprintf(&driverAttrBuf, " queue='%llu'", def->queue_size);
> +
> + }
> +
> + if (def->fsdriver == VIR_DOMAIN_FS_DRIVER_TYPE_VIRTIOFS) {
> + g_auto(virBuffer) lockAttrBuf = VIR_BUFFER_INITIALIZER;
> + virBufferEscapeString(&binaryAttrBuf, " path='%s'", def->binary);
> +
> + if (def->xattr != VIR_TRISTATE_SWITCH_ABSENT) {
> + virBufferAsprintf(&binaryAttrBuf, " xattr='%s'",
> + virTristateSwitchTypeToString(def->xattr));
> + }
> +
> + if (def->cache != VIR_DOMAIN_FS_CACHE_MODE_DEFAULT) {
> + virBufferAsprintf(&binaryBuf, "<cache mode='%s'/>\n",
> + virDomainFSCacheModeTypeToString(def->cache));
> + }
> +
> + if (def->posix_lock != VIR_TRISTATE_SWITCH_ABSENT) {
> + virBufferAsprintf(&lockAttrBuf, " posix='%s'",
> + virTristateSwitchTypeToString(def->posix_lock));
> + }
> +
> + if (def->flock != VIR_TRISTATE_SWITCH_ABSENT) {
> + virBufferAsprintf(&lockAttrBuf, " flock='%s'",
> + virTristateSwitchTypeToString(def->flock));
> + }
> +
> + virXMLFormatElement(&binaryBuf, "lock", &lockAttrBuf, NULL);
> }
>
> +
> virDomainVirtioOptionsFormat(&driverAttrBuf, def->virtio);
>
> - virXMLFormatElement(buf, "driver", &driverAttrBuf, NULL);
> + virXMLFormatElement(buf, "driver", &driverAttrBuf, &driverBuf);
> + virXMLFormatElement(buf, "binary", &binaryAttrBuf, &binaryBuf);
> + virXMLFormatElement(buf, "driver", &driverAttrBuf, &driverBuf);
>
> switch (def->type) {
> case VIR_DOMAIN_FS_TYPE_MOUNT:
> diff --git a/src/conf/domain_conf.h b/src/conf/domain_conf.h
> index de2bd3be93..21a36c34ef 100644
> --- a/src/conf/domain_conf.h
> +++ b/src/conf/domain_conf.h
> @@ -804,6 +804,14 @@ typedef enum {
> VIR_DOMAIN_FS_MODEL_LAST
> } virDomainFSModel;
>
> +typedef enum {
> + VIR_DOMAIN_FS_CACHE_MODE_DEFAULT = 0,
> + VIR_DOMAIN_FS_CACHE_MODE_NONE,
> + VIR_DOMAIN_FS_CACHE_MODE_ALWAYS,
> +
> + VIR_DOMAIN_FS_CACHE_MODE_LAST
> +} virDomainFSCacheMode;
> +
> struct _virDomainFSDef {
> int type;
> int fsdriver; /* enum virDomainFSDriverType */
> @@ -819,6 +827,12 @@ struct _virDomainFSDef {
> unsigned long long space_hard_limit; /* in bytes */
> unsigned long long space_soft_limit; /* in bytes */
> bool symlinksResolved;
> + char *binary;
> + unsigned long long queue_size;
> + virTristateSwitch xattr;
> + virDomainFSCacheMode cache;
> + virTristateSwitch posix_lock;
> + virTristateSwitch flock;
> virDomainVirtioOptionsPtr virtio;
> virObjectPtr privateData;
> };
> @@ -3441,6 +3455,7 @@ VIR_ENUM_DECL(virDomainFSDriver);
> VIR_ENUM_DECL(virDomainFSAccessMode);
> VIR_ENUM_DECL(virDomainFSWrpolicy);
> VIR_ENUM_DECL(virDomainFSModel);
> +VIR_ENUM_DECL(virDomainFSCacheMode);
> VIR_ENUM_DECL(virDomainNet);
> VIR_ENUM_DECL(virDomainNetBackend);
> VIR_ENUM_DECL(virDomainNetVirtioTxMode);
> diff --git a/src/libvirt_private.syms b/src/libvirt_private.syms
> index ebf830791e..30c3b12d79 100644
> --- a/src/libvirt_private.syms
> +++ b/src/libvirt_private.syms
> @@ -395,6 +395,7 @@ virDomainDiskSourceFormat;
> virDomainDiskTranslateSourcePool;
> virDomainFeatureTypeFromString;
> virDomainFeatureTypeToString;
> +virDomainFSCacheModeTypeToString;
> virDomainFSDefFree;
> virDomainFSDefNew;
> virDomainFSDriverTypeToString;
> diff --git a/tests/qemuxml2argvdata/vhost-user-fs-fd-memory.xml b/tests/qemuxml2argvdata/vhost-user-fs-fd-memory.xml
> index a6b6279fb8..f6bb663e97 100644
> --- a/tests/qemuxml2argvdata/vhost-user-fs-fd-memory.xml
> +++ b/tests/qemuxml2argvdata/vhost-user-fs-fd-memory.xml
> @@ -27,7 +27,11 @@
> <controller type='usb' index='0' model='none'/>
> <controller type='pci' index='0' model='pci-root'/>
> <filesystem type='mount' accessmode='passthrough'>
> - <driver type='virtiofs'/>
> + <driver type='virtiofs' queue='1024'/>
> + <binary path='/usr/libexec/virtiofsd' xattr='on'>
> + <cache mode='always'/>
> + <lock posix='off' flock='off'/>
> + </binary>
> <source dir='/path'/>
> <target dir='mount_tag'/>
> <address type='pci' domain='0x0000' bus='0x00' slot='0x02' function='0x0'/>
> diff --git a/tests/qemuxml2argvdata/vhost-user-fs-hugepages.xml b/tests/qemuxml2argvdata/vhost-user-fs-hugepages.xml
> index 70df7b890d..96b9774704 100644
> --- a/tests/qemuxml2argvdata/vhost-user-fs-hugepages.xml
> +++ b/tests/qemuxml2argvdata/vhost-user-fs-hugepages.xml
> @@ -63,6 +63,7 @@
> </controller>
> <filesystem type='mount' accessmode='passthrough'>
> <driver type='virtiofs'/>
> + <binary path='/usr/libexec/virtiofsd'/>
> <source dir='/path'/>
> <target dir='mount_tag'/>
> <address type='pci' domain='0x0000' bus='0x01' slot='0x00' function='0x0'/>
> --
> 2.21.0
>
More information about the libvir-list
mailing list