* [PATCH nvme-cli v1 0/2] auto generate hostnqn file on installation
@ 2016-11-08 10:48 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 10:48 ` [PATCH nvme-cli v1 2/2] nvme.spec/debian: Auto generate host nqn as part of install Sagi Grimberg
0 siblings, 2 replies; 7+ messages in thread
From: Sagi Grimberg @ 2016-11-08 10:48 UTC (permalink / raw)
This set is designed to help the user by auto-generating a hostnqn and
placing it in /etc/nvme/hostnqn file upon installation of nvme-cli (in
case such a file doesn't exist).
The user can re-generate different hostnqns on demand by running:
$ nvme gen-hostnqn
Only the deb package is tested.
Changes from v0 (rfc):
- Moved hostnqn generation to nvme with the command gen-hostnqn
- Cleanup hostnqn file only on purge in debian
Sagi Grimberg (2):
nvme-cli: Add nvme hostnqn generation option
nvme.spec/debian: Auto generate host nqn as part of install
Makefile | 1 +
debian/postinst | 20 ++++++++++++++++++++
debian/postrm | 5 +++++
nvme-builtin.h | 1 +
nvme.c | 14 ++++++++++++++
nvme.spec.in | 12 ++++++++++++
6 files changed, 53 insertions(+)
create mode 100644 debian/postinst
create mode 100644 debian/postrm
--
2.7.4
^ permalink raw reply [flat|nested] 7+ messages in thread
* [PATCH nvme-cli v1 1/2] nvme-cli: Add nvme hostnqn generation option
2016-11-08 10:48 [PATCH nvme-cli v1 0/2] auto generate hostnqn file on installation Sagi Grimberg
@ 2016-11-08 10:48 ` Sagi Grimberg
2016-11-08 17:36 ` J Freyensee
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
1 sibling, 2 replies; 7+ messages in thread
From: Sagi Grimberg @ 2016-11-08 10:48 UTC (permalink / raw)
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);
+ printf("%s\n", hostnqn);
+ return 0;
+}
+
static int discover_cmd(int argc, char **argv, struct command *command, struct plugin *plugin)
{
const char *desc = "Send Get Log Page request to Discovery Controller.";
--
2.7.4
^ permalink raw reply related [flat|nested] 7+ messages in thread
* [PATCH nvme-cli v1 2/2] nvme.spec/debian: Auto generate host nqn as part of install
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 10:48 ` Sagi Grimberg
2016-11-08 17:41 ` J Freyensee
2016-11-14 14:58 ` Gabriel Krisman Bertazi
1 sibling, 2 replies; 7+ messages in thread
From: Sagi Grimberg @ 2016-11-08 10:48 UTC (permalink / raw)
The installation will generate a hostnqn and store it in
/etc/nvme/hostnqn file (in case it doesn't exist).
This file will be removed upon uninstallation (purge on for debian).
Signed-off-by: Sagi Grimberg <sagi at grimberg.me>
---
debian/postinst | 20 ++++++++++++++++++++
debian/postrm | 5 +++++
nvme.spec.in | 12 ++++++++++++
3 files changed, 37 insertions(+)
create mode 100644 debian/postinst
create mode 100644 debian/postrm
diff --git a/debian/postinst b/debian/postinst
new file mode 100644
index 000000000000..b258cf569c3e
--- /dev/null
+++ b/debian/postinst
@@ -0,0 +1,20 @@
+#!/bin/sh
+
+set -e
+
+case "$1" in
+ configure|install)
+ if [ ! -f /etc/nvme/hostnqn ]; then
+ install -D /dev/null /etc/nvme/hostnqn
+ echo $(nvme gen-hostnqn) > /etc/nvme/hostnqn
+ fi
+ ;;
+
+ upgrade|abort-upgrade)
+ ;;
+ *)
+ echo "postinst called with unknown argument \`$1'" >&2
+ exit 0
+ ;;
+esac
+exit 0
diff --git a/debian/postrm b/debian/postrm
new file mode 100644
index 000000000000..d678fc8a90ac
--- /dev/null
+++ b/debian/postrm
@@ -0,0 +1,5 @@
+#!/bin/sh
+
+if [ "$1" = "purge" ]; then
+ rm -rf /etc/nvme
+fi
diff --git a/nvme.spec.in b/nvme.spec.in
index a4718773a962..8bda97d819ba 100644
--- a/nvme.spec.in
+++ b/nvme.spec.in
@@ -33,6 +33,18 @@ make install DESTDIR=%{buildroot} PREFIX=/usr
%clean
rm -rf $RPM_BUILD_ROOT
+%post
+if [ $1 = 1 ]; then # 1 : This package is being installed for the first time
+ if [ ! -f /etc/nvme/hostnqn ]; then
+ install -D /dev/null /etc/nvme/hostnqn
+ echo $(nvme gen-hostnqn) > /etc/nvme/hostnqn
+ fi
+fi
+
+%preun
+if [ "$1" = "remove" ]; then
+ rm -rf /etc/nvme
+fi
%changelog
* Thu Oct 15 2015 Keith Busch <keith.busch at intel.com>
- Initial RPM spec
--
2.7.4
^ permalink raw reply related [flat|nested] 7+ messages in thread
* [PATCH nvme-cli v1 1/2] nvme-cli: Add nvme hostnqn generation option
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
2016-11-16 17:11 ` Christoph Hellwig
1 sibling, 0 replies; 7+ messages in thread
From: J Freyensee @ 2016-11-08 17:36 UTC (permalink / raw)
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[].
^ permalink raw reply [flat|nested] 7+ messages in thread
* [PATCH nvme-cli v1 2/2] nvme.spec/debian: Auto generate host nqn as part of install
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
1 sibling, 0 replies; 7+ messages in thread
From: J Freyensee @ 2016-11-08 17:41 UTC (permalink / raw)
On Tue, 2016-11-08@12:48 +0200, Sagi Grimberg wrote:
> The installation will generate a hostnqn and store it in
> /etc/nvme/hostnqn file (in case it doesn't exist).
> This file will be removed upon uninstallation (purge on for debian).
>
> Signed-off-by: Sagi Grimberg <sagi at grimberg.me>
> ---
> ?debian/postinst | 20 ++++++++++++++++++++
> ?debian/postrm???|??5 +++++
> ?nvme.spec.in????| 12 ++++++++++++
> ?3 files changed, 37 insertions(+)
> ?create mode 100644 debian/postinst
> ?create mode 100644 debian/postrm
>
> diff --git a/debian/postinst b/debian/postinst
> new file mode 100644
> index 000000000000..b258cf569c3e
> --- /dev/null
> +++ b/debian/postinst
> @@ -0,0 +1,20 @@
> +#!/bin/sh
> +
> +set -e
> +
> +case "$1" in
> +????configure|install)
> + if [ ! -f /etc/nvme/hostnqn ]; then
> + install -D /dev/null /etc/nvme/hostnqn
Would it just be easier to do "mkdir -p /etc/nvme/hostnqn"? ?
> + echo $(nvme gen-hostnqn) > /etc/nvme/hostnqn
> +????????fi
> +????????;;
> +
> +????upgrade|abort-upgrade)
> +????????;;
> +????*)
> +????????echo "postinst called with unknown argument \`$1'" >&2
> +????????exit 0
> +????????;;
> +esac
> +exit 0
> diff --git a/debian/postrm b/debian/postrm
> new file mode 100644
> index 000000000000..d678fc8a90ac
> --- /dev/null
> +++ b/debian/postrm
> @@ -0,0 +1,5 @@
> +#!/bin/sh
> +
> +if [ "$1" = "purge" ]; then
> +????rm -rf /etc/nvme
> +fi
> diff --git a/nvme.spec.in b/nvme.spec.in
> index a4718773a962..8bda97d819ba 100644
> --- a/nvme.spec.in
> +++ b/nvme.spec.in
> @@ -33,6 +33,18 @@ make install DESTDIR=%{buildroot} PREFIX=/usr
> ?%clean
> ?rm -rf $RPM_BUILD_ROOT
> ?
> +%post
> +if [ $1 = 1 ]; then # 1 : This package is being installed for the
> first time
> + if [ ! -f /etc/nvme/hostnqn ]; then
> + install -D /dev/null /etc/nvme/hostnqn
> + echo $(nvme gen-hostnqn) > /etc/nvme/hostnqn
> +????????fi
> +fi
> +
> +%preun
> +if [ "$1" = "remove" ]; then
> +????rm -rf /etc/nvme
This could remove a 'discovery.conf' file that is also located in
/etc/nvme, which would be bad. ?Let's just remove the file
/ete/nvme/hostnqn that this will generate.
^ permalink raw reply [flat|nested] 7+ messages in thread
* [PATCH nvme-cli v1 2/2] nvme.spec/debian: Auto generate host nqn as part of install
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
1 sibling, 0 replies; 7+ messages in thread
From: Gabriel Krisman Bertazi @ 2016-11-14 14:58 UTC (permalink / raw)
Sagi Grimberg <sagi at grimberg.me> writes:
> The installation will generate a hostnqn and store it in
> /etc/nvme/hostnqn file (in case it doesn't exist).
> This file will be removed upon uninstallation (purge on for debian).
>
> Signed-off-by: Sagi Grimberg <sagi at grimberg.me>
> ---
> debian/postinst | 20 ++++++++++++++++++++
> debian/postrm | 5 +++++
> nvme.spec.in | 12 ++++++++++++
> 3 files changed, 37 insertions(+)
> create mode 100644 debian/postinst
> create mode 100644 debian/postrm
>
> diff --git a/debian/postinst b/debian/postinst
> new file mode 100644
> index 000000000000..b258cf569c3e
> --- /dev/null
> +++ b/debian/postinst
> @@ -0,0 +1,20 @@
> +#!/bin/sh
> +
> +set -e
> +
> +case "$1" in
> + configure|install)
> + if [ ! -f /etc/nvme/hostnqn ]; then
> + install -D /dev/null /etc/nvme/hostnqn
> + echo $(nvme gen-hostnqn) > /etc/nvme/hostnqn
> + fi
> + ;;
> +
> + upgrade|abort-upgrade)
> + ;;
> + *)
> + echo "postinst called with unknown argument \`$1'" >&2
> + exit 0
> + ;;
> +esac
> +exit 0
> diff --git a/debian/postrm b/debian/postrm
> new file mode 100644
> index 000000000000..d678fc8a90ac
> --- /dev/null
> +++ b/debian/postrm
> @@ -0,0 +1,5 @@
> +#!/bin/sh
> +
> +if [ "$1" = "purge" ]; then
> + rm -rf /etc/nvme
> +fi
Oh, here it is. Didn't see your v1 before responding to the rfc. :)
> diff --git a/nvme.spec.in b/nvme.spec.in
> index a4718773a962..8bda97d819ba 100644
> --- a/nvme.spec.in
> +++ b/nvme.spec.in
> @@ -33,6 +33,18 @@ make install DESTDIR=%{buildroot} PREFIX=/usr
> %clean
> rm -rf $RPM_BUILD_ROOT
>
> +%post
> +if [ $1 = 1 ]; then # 1 : This package is being installed for the first time
> + if [ ! -f /etc/nvme/hostnqn ]; then
> + install -D /dev/null /etc/nvme/hostnqn
> + echo $(nvme gen-hostnqn) > /etc/nvme/hostnqn
> + fi
> +fi
> +
> +%preun
> +if [ "$1" = "remove" ]; then
> + rm -rf /etc/nvme
> +fi
> %changelog
> * Thu Oct 15 2015 Keith Busch <keith.busch at intel.com>
> - Initial RPM spec
--
Gabriel Krisman Bertazi
^ permalink raw reply [flat|nested] 7+ messages in thread
* [PATCH nvme-cli v1 1/2] nvme-cli: Add nvme hostnqn generation option
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
@ 2016-11-16 17:11 ` Christoph Hellwig
1 sibling, 0 replies; 7+ messages in thread
From: Christoph Hellwig @ 2016-11-16 17:11 UTC (permalink / raw)
On Tue, Nov 08, 2016@12:48:27PM +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.
Keith - should we have any special prefixes for nvme-cli commands
that don't map to NVMe commands?
> +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);
> + printf("%s\n", hostnqn);
Shouldn't the sprintf and printf get merged into one? No need for the
local variable here. That would also take care of the snprintf nitpick
from Jay ;-)
^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2016-11-16 17:11 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
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
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
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).