diff options
author | James Smart <james.smart@broadcom.com> | 2016-08-02 03:40:01 -0400 |
---|---|---|
committer | Sagi Grimberg <sagi@grimberg.me> | 2016-09-23 18:37:37 -0400 |
commit | 0fe51ff269da745078e0ab2b90dfdf2a58d6f3e7 (patch) | |
tree | e66199ea634195b6fd24751d7a244076ac9ba65d | |
parent | 005043ac31ba5bf6721b4ddca10ff2066e2ee2fe (diff) |
nvme-fabrics: rework nvmf_get_address() for variable options
Revise nvmf_get_address() string to account for not all options being
present.
Signed-off-by: James Smart <james.smart@broadcom.com>
Acked-by: Johannes Thumshirn <jth@kernel.org>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Sagi Grimberg <sagi@grimberg.me>
-rw-r--r-- | drivers/nvme/host/fabrics.c | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/drivers/nvme/host/fabrics.c b/drivers/nvme/host/fabrics.c index dc996761042f..2867b92cbdfb 100644 --- a/drivers/nvme/host/fabrics.c +++ b/drivers/nvme/host/fabrics.c | |||
@@ -109,8 +109,16 @@ static void nvmf_host_put(struct nvmf_host *host) | |||
109 | */ | 109 | */ |
110 | int nvmf_get_address(struct nvme_ctrl *ctrl, char *buf, int size) | 110 | int nvmf_get_address(struct nvme_ctrl *ctrl, char *buf, int size) |
111 | { | 111 | { |
112 | return snprintf(buf, size, "traddr=%s,trsvcid=%s\n", | 112 | int len = 0; |
113 | ctrl->opts->traddr, ctrl->opts->trsvcid); | 113 | |
114 | if (ctrl->opts->mask & NVMF_OPT_TRADDR) | ||
115 | len += snprintf(buf, size, "traddr=%s", ctrl->opts->traddr); | ||
116 | if (ctrl->opts->mask & NVMF_OPT_TRSVCID) | ||
117 | len += snprintf(buf + len, size - len, "%strsvcid=%s", | ||
118 | (len) ? "," : "", ctrl->opts->trsvcid); | ||
119 | len += snprintf(buf + len, size - len, "\n"); | ||
120 | |||
121 | return len; | ||
114 | } | 122 | } |
115 | EXPORT_SYMBOL_GPL(nvmf_get_address); | 123 | EXPORT_SYMBOL_GPL(nvmf_get_address); |
116 | 124 | ||