Commit 0445e1b5 authored by Sagi Grimberg's avatar Sagi Grimberg Committed by Jens Axboe

nvmet: don't override treq upon modification.

Only override the allowed parts of it.
Reviewed-by: default avatarHannes Reinecke <hare@suse.com>
Signed-off-by: default avatarSagi Grimberg <sagi@grimberg.me>
[hch: slight tweak to the NVME_TREQ_SECURE_CHANNEL_MASK definition]
Signed-off-by: default avatarChristoph Hellwig <hch@lst.de>
Signed-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent e6a622fd
...@@ -153,7 +153,8 @@ CONFIGFS_ATTR(nvmet_, addr_traddr); ...@@ -153,7 +153,8 @@ CONFIGFS_ATTR(nvmet_, addr_traddr);
static ssize_t nvmet_addr_treq_show(struct config_item *item, static ssize_t nvmet_addr_treq_show(struct config_item *item,
char *page) char *page)
{ {
switch (to_nvmet_port(item)->disc_addr.treq) { switch (to_nvmet_port(item)->disc_addr.treq &
NVME_TREQ_SECURE_CHANNEL_MASK) {
case NVMF_TREQ_NOT_SPECIFIED: case NVMF_TREQ_NOT_SPECIFIED:
return sprintf(page, "not specified\n"); return sprintf(page, "not specified\n");
case NVMF_TREQ_REQUIRED: case NVMF_TREQ_REQUIRED:
...@@ -169,6 +170,7 @@ static ssize_t nvmet_addr_treq_store(struct config_item *item, ...@@ -169,6 +170,7 @@ static ssize_t nvmet_addr_treq_store(struct config_item *item,
const char *page, size_t count) const char *page, size_t count)
{ {
struct nvmet_port *port = to_nvmet_port(item); struct nvmet_port *port = to_nvmet_port(item);
u8 treq = port->disc_addr.treq & ~NVME_TREQ_SECURE_CHANNEL_MASK;
if (port->enabled) { if (port->enabled) {
pr_err("Cannot modify address while enabled\n"); pr_err("Cannot modify address while enabled\n");
...@@ -177,15 +179,16 @@ static ssize_t nvmet_addr_treq_store(struct config_item *item, ...@@ -177,15 +179,16 @@ static ssize_t nvmet_addr_treq_store(struct config_item *item,
} }
if (sysfs_streq(page, "not specified")) { if (sysfs_streq(page, "not specified")) {
port->disc_addr.treq = NVMF_TREQ_NOT_SPECIFIED; treq |= NVMF_TREQ_NOT_SPECIFIED;
} else if (sysfs_streq(page, "required")) { } else if (sysfs_streq(page, "required")) {
port->disc_addr.treq = NVMF_TREQ_REQUIRED; treq |= NVMF_TREQ_REQUIRED;
} else if (sysfs_streq(page, "not required")) { } else if (sysfs_streq(page, "not required")) {
port->disc_addr.treq = NVMF_TREQ_NOT_REQUIRED; treq |= NVMF_TREQ_NOT_REQUIRED;
} else { } else {
pr_err("Invalid value '%s' for treq\n", page); pr_err("Invalid value '%s' for treq\n", page);
return -EINVAL; return -EINVAL;
} }
port->disc_addr.treq = treq;
return count; return count;
} }
......
...@@ -61,6 +61,8 @@ enum { ...@@ -61,6 +61,8 @@ enum {
NVMF_TREQ_NOT_SPECIFIED = 0, /* Not specified */ NVMF_TREQ_NOT_SPECIFIED = 0, /* Not specified */
NVMF_TREQ_REQUIRED = 1, /* Required */ NVMF_TREQ_REQUIRED = 1, /* Required */
NVMF_TREQ_NOT_REQUIRED = 2, /* Not Required */ NVMF_TREQ_NOT_REQUIRED = 2, /* Not Required */
#define NVME_TREQ_SECURE_CHANNEL_MASK \
(NVMF_TREQ_REQUIRED | NVMF_TREQ_NOT_REQUIRED)
}; };
/* RDMA QP Service Type codes for Discovery Log Page entry TSAS /* RDMA QP Service Type codes for Discovery Log Page entry TSAS
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment