From: Fam Zheng <famz@redhat.com>
To: Jeff Cody <jcody@redhat.com>
Cc: qemu-devel@nongnu.org, kwolf@redhat.com, pbonzini@redhat.com,
qemu-block@nongnu.org
Subject: Re: [Qemu-devel] [PATCH v2 6/7] iscsi: Add blockdev-add support
Date: Tue, 7 Feb 2017 18:23:37 +0800 [thread overview]
Message-ID: <20170207102337.GH19280@lemon.lan> (raw)
In-Reply-To: <f0449fb39181c0c4c45d3deba6faaea5282161e0.1485365834.git.jcody@redhat.com>
On Wed, 01/25 12:42, Jeff Cody wrote:
> From: Kevin Wolf <kwolf@redhat.com>
>
> This adds blockdev-add support for iscsi devices.
>
> Reviewed-by: Daniel P. Berrange <berrange@redhat.com>
> Signed-off-by: Kevin Wolf <kwolf@redhat.com>
> Signed-off-by: Jeff Cody <jcody@redhat.com>
> ---
> block/iscsi.c | 14 ++++++----
> qapi/block-core.json | 74 ++++++++++++++++++++++++++++++++++++++++++++++++----
> 2 files changed, 78 insertions(+), 10 deletions(-)
>
> diff --git a/block/iscsi.c b/block/iscsi.c
> index 4701a27..65484f0 100644
> --- a/block/iscsi.c
> +++ b/block/iscsi.c
> @@ -1282,13 +1282,13 @@ static void apply_header_digest(struct iscsi_context *iscsi, QemuOpts *opts,
> digest = qemu_opt_get(opts, "header-digest");
> if (!digest) {
> iscsi_set_header_digest(iscsi, ISCSI_HEADER_DIGEST_NONE_CRC32C);
> - } else if (!strcmp(digest, "CRC32C")) {
> + } else if (!strcmp(digest, "crc32c")) {
> iscsi_set_header_digest(iscsi, ISCSI_HEADER_DIGEST_CRC32C);
> - } else if (!strcmp(digest, "NONE")) {
> + } else if (!strcmp(digest, "none")) {
> iscsi_set_header_digest(iscsi, ISCSI_HEADER_DIGEST_NONE);
> - } else if (!strcmp(digest, "CRC32C-NONE")) {
> + } else if (!strcmp(digest, "crc32c-none")) {
> iscsi_set_header_digest(iscsi, ISCSI_HEADER_DIGEST_CRC32C_NONE);
> - } else if (!strcmp(digest, "NONE-CRC32C")) {
> + } else if (!strcmp(digest, "none-crc32c")) {
> iscsi_set_header_digest(iscsi, ISCSI_HEADER_DIGEST_NONE_CRC32C);
> } else {
> error_setg(errp, "Invalid header-digest setting : %s", digest);
> @@ -1563,7 +1563,11 @@ static void iscsi_parse_iscsi_option(const char *target, QDict *options)
>
> header_digest = qemu_opt_get(opts, "header-digest");
> if (header_digest) {
> - qdict_set_default_str(options, "header-digest", header_digest);
> + /* -iscsi takes upper case values, but QAPI only supports lower case
> + * enum constant names, so we have to convert here. */
> + char *qapi_value = g_ascii_strdown(header_digest, -1);
> + qdict_set_default_str(options, "header-digest", qapi_value);
> + g_free(qapi_value);
> }
>
> timeout = qemu_opt_get(opts, "timeout");
> diff --git a/qapi/block-core.json b/qapi/block-core.json
> index 1b3e6eb..4ebb8d8 100644
> --- a/qapi/block-core.json
> +++ b/qapi/block-core.json
> @@ -2116,10 +2116,10 @@
> { 'enum': 'BlockdevDriver',
> 'data': [ 'archipelago', 'blkdebug', 'blkverify', 'bochs', 'cloop',
> 'dmg', 'file', 'ftp', 'ftps', 'gluster', 'host_cdrom',
> - 'host_device', 'http', 'https', 'luks', 'nbd', 'nfs', 'null-aio',
> - 'null-co', 'parallels', 'qcow', 'qcow2', 'qed', 'quorum', 'raw',
> - 'replication', 'ssh', 'vdi', 'vhdx', 'vmdk', 'vpc',
> - 'vvfat' ] }
> + 'host_device', 'http', 'https', 'iscsi', 'luks', 'nbd', 'nfs',
> + 'null-aio', 'null-co', 'parallels', 'qcow', 'qcow2', 'qed',
> + 'quorum', 'raw', 'replication', 'ssh', 'vdi', 'vhdx', 'vmdk',
> + 'vpc', 'vvfat' ] }
>
> ##
> # @BlockdevOptionsFile:
> @@ -2601,6 +2601,70 @@
> '*logfile': 'str' } }
>
> ##
> +# @IscsiTransport:
> +#
> +# An enumeration of libiscsi transport types
> +#
> +# Since: 2.9
> +##
> +{ 'enum': 'IscsiTransport',
> + 'data': [ 'tcp', 'iser' ] }
> +
> +##
> +# @IscsiHeaderDigest:
> +#
> +# An enumeration of header digests supported by libiscsi
> +#
> +# Since: 2.9
> +##
> +{ 'enum': 'IscsiHeaderDigest',
> + 'prefix': 'QAPI_ISCSI_HEADER_DIGEST',
> + 'data': [ 'crc32c', 'none', 'crc32c-none', 'none-crc32c' ] }
> +
> +##
> +# @BlockdevOptionsIscsi:
> +#
> +# @transport The iscsi transport type
> +#
> +# @portal The address of the iscsi portal
> +#
> +# @target The target iqn name
> +#
> +# @lun #optional LUN to connect to. Defaults to 0.
> +#
> +# @user #optional User name to log in with. If omitted, no CHAP
> +# authentication is performed.
> +#
> +# @password-secret #optional The ID of a QCryptoSecret object providing
> +# the password for the login. This option is required if
> +# @user is specified.
> +#
> +# @initiator-name #optional The iqn name we want to identify to the target
> +# as. If this option is not specified, an initiator name is
> +# generated automatically.
> +#
> +# @header-digest #optional The desired header digest. Defaults to
> +# none-crc32c.
> +#
> +# @timeout #optional Timeout in seconds after which a request will
> +# timeout. 0 means no timeout and is the default.
> +#
> +# Driver specific block device options for iscsi
> +#
> +# Since: 2.9
> +##
> +{ 'struct': 'BlockdevOptionsIscsi',
> + 'data': { 'transport': 'IscsiTransport',
> + 'portal': 'str',
> + 'target': 'str',
> + '*lun': 'int',
> + '*user': 'str',
> + '*password-secret': 'str',
> + '*initiator-name': 'str',
> + '*header-digest': 'IscsiHeaderDigest',
> + '*timeout': 'int' } }
> +
> +##
> # @ReplicationMode:
> #
> # An enumeration of replication modes.
> @@ -2786,7 +2850,7 @@
> 'host_device':'BlockdevOptionsFile',
> 'http': 'BlockdevOptionsCurl',
> 'https': 'BlockdevOptionsCurl',
> -# TODO iscsi: Wait for structured options
> + 'iscsi': 'BlockdevOptionsIscsi',
> 'luks': 'BlockdevOptionsLUKS',
> 'nbd': 'BlockdevOptionsNbd',
> 'nfs': 'BlockdevOptionsNfs',
> --
> 2.9.3
>
>
Reviewed-by: Fam Zheng <famz@redhat.com>
next prev parent reply other threads:[~2017-02-07 10:23 UTC|newest]
Thread overview: 22+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-01-25 17:42 [Qemu-devel] [PATCH v2 0/7] iscsi: Add blockdev-add support Jeff Cody
2017-01-25 17:42 ` [Qemu-devel] [PATCH v2 1/7] iscsi: Split URL into individual options Jeff Cody
2017-02-07 10:06 ` Fam Zheng
2017-01-25 17:42 ` [Qemu-devel] [PATCH v2 2/7] iscsi: Handle -iscsi user/password in bdrv_parse_filename() Jeff Cody
2017-02-07 10:13 ` Fam Zheng
2017-02-17 13:26 ` Kevin Wolf
2017-02-17 14:09 ` Fam Zheng
2017-02-17 14:10 ` Fam Zheng
2017-01-25 17:42 ` [Qemu-devel] [PATCH v2 3/7] iscsi: Add initiator-name option Jeff Cody
2017-02-07 10:16 ` Fam Zheng
2017-01-25 17:42 ` [Qemu-devel] [PATCH v2 4/7] iscsi: Add header-digest option Jeff Cody
2017-02-07 10:18 ` Fam Zheng
2017-01-25 17:42 ` [Qemu-devel] [PATCH v2 5/7] iscsi: Add timeout option Jeff Cody
2017-02-07 10:21 ` Fam Zheng
2017-01-25 17:42 ` [Qemu-devel] [PATCH v2 6/7] iscsi: Add blockdev-add support Jeff Cody
2017-02-07 10:23 ` Fam Zheng [this message]
2017-02-17 21:40 ` Eric Blake
2017-02-17 21:47 ` Jeff Cody
2017-01-25 17:42 ` [Qemu-devel] [PATCH v2 7/7] QAPI: Fix blockdev-add example documentation Jeff Cody
2017-02-07 10:29 ` Fam Zheng
2017-01-25 17:57 ` [Qemu-devel] [PATCH v2 0/7] iscsi: Add blockdev-add support no-reply
2017-02-17 21:12 ` Jeff Cody
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20170207102337.GH19280@lemon.lan \
--to=famz@redhat.com \
--cc=jcody@redhat.com \
--cc=kwolf@redhat.com \
--cc=pbonzini@redhat.com \
--cc=qemu-block@nongnu.org \
--cc=qemu-devel@nongnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.