From: james_p_freyensee@linux.intel.com (J Freyensee)
Subject: [PATCH nvme-cli v1 1/2] nvme-cli: Add nvme hostnqn generation option
Date: Tue, 08 Nov 2016 09:36:15 -0800 [thread overview]
Message-ID: <1478626575.9959.17.camel@linux.intel.com> (raw)
In-Reply-To: <1478602108-29571-2-git-send-email-sagi@grimberg.me>
On Tue, 2016-11-08@12:48 +0200, Sagi Grimberg wrote:
> Add option to generate a NVMe qualified name of a given host
> (in the form of: nqn.2014-08.org.nvmexpress:NVMf:uuid:<some_uuid>).
> This hostnqn will be used for fabrics discovery and connect
> functions.
>
> Signed-off-by: Sagi Grimberg <sagi at grimberg.me>
> ---
> ?Makefile???????|??1 +
> ?nvme-builtin.h |??1 +
> ?nvme.c?????????| 14 ++++++++++++++
> ?3 files changed, 16 insertions(+)
>
> diff --git a/Makefile b/Makefile
> index 117cbbea886f..cc0245ad576d 100644
> --- a/Makefile
> +++ b/Makefile
> @@ -1,5 +1,6 @@
> ?CFLAGS += -std=gnu99 -O2 -g -Wall -Werror
> ?CPPFLAGS += -D_GNU_SOURCE -D__CHECK_ENDIAN__
> +LDFLAGS += -luuid
> ?NVME = nvme
> ?INSTALL ?= install
> ?DESTDIR =
> diff --git a/nvme-builtin.h b/nvme-builtin.h
> index dc314cbbb371..b182b1e01f5b 100644
> --- a/nvme-builtin.h
> +++ b/nvme-builtin.h
> @@ -49,6 +49,7 @@ COMMAND_LIST(
> ? ENTRY("connect-all", "Discover and Connect to NVMeoF
> subsystems", connect_all_cmd)
> ? ENTRY("connect", "Connect to NVMeoF subsystem", connect_cmd)
> ? ENTRY("disconnect", "Disconnect from NVMeoF subsystem",
> disconnect_cmd)
> + ENTRY("gen-hostnqn", "Generate NVMeoF host NQN",
> gen_hostnqn_cmd)
> ?);
> ?
> ?#endif
> diff --git a/nvme.c b/nvme.c
> index a9e78aae50a9..fa9765cddc79 100644
> --- a/nvme.c
> +++ b/nvme.c
> @@ -44,6 +44,7 @@
> ?#include <sys/types.h>
> ?#include <sys/stat.h>
> ?#include <sys/time.h>
> +#include <uuid/uuid.h>
> ?
> ?#include "nvme-print.h"
> ?#include "nvme-ioctl.h"
> @@ -2704,6 +2705,19 @@ static int admin_passthru(int argc, char
> **argv, struct command *cmd, struct plu
> ? return passthru(argc, argv, NVME_IOCTL_ADMIN_CMD, desc,
> cmd);
> ?}
> ?
> +static int gen_hostnqn_cmd(int argc, char **argv, struct command
> *command, struct plugin *plugin)
> +{
> + char hostnqn[NVMF_NQN_SIZE];
> + uuid_t uuid;
> + char uuid_str[37]; /* e.g. 1b4e28ba-2fa1-11d2-883f-
> 0016d3cca427 + \0 */
> +
> + uuid_generate_random(uuid);
> + uuid_unparse_lower(uuid, uuid_str);
> + sprintf(hostnqn, "nqn.2014-08.org.nvmexpress:NVMf:uuid:%s",
> uuid_str);
Let's do what the driver does, use a snprintf() and limit the size via
NVMF_NQN_SIZE used by hostnqn[].
next prev parent reply other threads:[~2016-11-08 17:36 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-11-08 10:48 [PATCH nvme-cli v1 0/2] auto generate hostnqn file on installation Sagi Grimberg
2016-11-08 10:48 ` [PATCH nvme-cli v1 1/2] nvme-cli: Add nvme hostnqn generation option Sagi Grimberg
2016-11-08 17:36 ` J Freyensee [this message]
2016-11-16 17:11 ` Christoph Hellwig
2016-11-08 10:48 ` [PATCH nvme-cli v1 2/2] nvme.spec/debian: Auto generate host nqn as part of install Sagi Grimberg
2016-11-08 17:41 ` J Freyensee
2016-11-14 14:58 ` Gabriel Krisman Bertazi
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=1478626575.9959.17.camel@linux.intel.com \
--to=james_p_freyensee@linux.intel.com \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).