diff options
-rw-r--r-- | usr/src/cmd/nvmeadm/nvmeadm.c | 30 | ||||
-rw-r--r-- | usr/src/cmd/nvmeadm/nvmeadm.h | 3 | ||||
-rw-r--r-- | usr/src/cmd/nvmeadm/nvmeadm_dev.c | 18 | ||||
-rw-r--r-- | usr/src/man/man1m/nvmeadm.1m | 6 | ||||
-rw-r--r-- | usr/src/uts/common/io/nvme/nvme.c | 23 | ||||
-rw-r--r-- | usr/src/uts/common/sys/nvme.h | 3 |
6 files changed, 73 insertions, 10 deletions
diff --git a/usr/src/cmd/nvmeadm/nvmeadm.c b/usr/src/cmd/nvmeadm/nvmeadm.c index b592a2bd25..d288ac1865 100644 --- a/usr/src/cmd/nvmeadm/nvmeadm.c +++ b/usr/src/cmd/nvmeadm/nvmeadm.c @@ -293,6 +293,7 @@ main(int argc, char **argv) } npa.npa_cmd = cmd; + npa.npa_interactive = B_TRUE; optind++; @@ -533,8 +534,12 @@ nvme_process(di_node_t node, di_minor_t minor, void *arg) if (npa->npa_idns == NULL) goto out; - if (npa->npa_isns) - npa->npa_dsk = nvme_dskname(npa); + if (npa->npa_isns) { + npa->npa_ignored = nvme_is_ignored_ns(fd); + if (!npa->npa_ignored) + npa->npa_dsk = nvme_dskname(npa); + } + exitcode += npa->npa_cmd->c_func(fd, npa); @@ -1247,12 +1252,21 @@ do_attach_detach(int fd, const nvme_process_arg_t *npa) nvme_walk(&ns_npa, npa->npa_node); return (exitcode); - } else { - if ((c_name[0] == 'd' ? nvme_detach : nvme_attach)(fd) - == B_FALSE) { - warn("%s failed", c_name); - return (-1); - } + } + + /* + * Unless the user interactively requested a particular namespace to be + * attached or detached, don't even try to attach or detach namespaces + * that are ignored by the driver, thereby avoiding printing pointless + * error messages. + */ + if (!npa->npa_interactive && npa->npa_ignored) + return (0); + + if ((c_name[0] == 'd' ? nvme_detach : nvme_attach)(fd) + == B_FALSE) { + warn("%s failed", c_name); + return (-1); } return (0); diff --git a/usr/src/cmd/nvmeadm/nvmeadm.h b/usr/src/cmd/nvmeadm/nvmeadm.h index 6b620f8fab..e06cd93189 100644 --- a/usr/src/cmd/nvmeadm/nvmeadm.h +++ b/usr/src/cmd/nvmeadm/nvmeadm.h @@ -42,6 +42,8 @@ struct nvme_process_arg { char *npa_nsid; int npa_found; boolean_t npa_isns; + boolean_t npa_ignored; + boolean_t npa_interactive; const nvmeadm_cmd_t *npa_cmd; di_node_t npa_node; di_minor_t npa_minor; @@ -114,6 +116,7 @@ extern boolean_t nvme_detach(int); extern boolean_t nvme_attach(int); extern boolean_t nvme_firmware_load(int, void *, size_t, offset_t, uint16_t *); extern boolean_t nvme_firmware_commit(int, int, int, uint16_t *); +extern boolean_t nvme_is_ignored_ns(int); /* * ofmt related diff --git a/usr/src/cmd/nvmeadm/nvmeadm_dev.c b/usr/src/cmd/nvmeadm/nvmeadm_dev.c index 1617de5da9..6c837d0d8c 100644 --- a/usr/src/cmd/nvmeadm/nvmeadm_dev.c +++ b/usr/src/cmd/nvmeadm/nvmeadm_dev.c @@ -222,6 +222,24 @@ nvme_firmware_commit(int fd, int slot, int action, uint16_t *sc) return (rv); } +boolean_t +nvme_is_ignored_ns(int fd) +{ + boolean_t ret; + uint64_t res = 0; + + /* + * The ioctl shouldn't fail. If it does, we treat it the same as if the + * namespace was ignored. + */ + ret = nvme_ioctl(fd, NVME_IOC_IS_IGNORED_NS, NULL, NULL, 0, &res); + + if (ret) + ret = (res == 0) ? B_FALSE : B_TRUE; + + return (ret); +} + int nvme_open(di_minor_t minor) { diff --git a/usr/src/man/man1m/nvmeadm.1m b/usr/src/man/man1m/nvmeadm.1m index 0ec278936e..422e6f0048 100644 --- a/usr/src/man/man1m/nvmeadm.1m +++ b/usr/src/man/man1m/nvmeadm.1m @@ -390,6 +390,9 @@ currently opened. The detached state will not persist across reboots or reloads of the .Xr nvme 7D driver. +.Pp +It is not an error to detach a namespace that is already detached, any such +request will be silently ignored. .It Xo .Nm .Cm attach @@ -403,6 +406,9 @@ previous .Nm .Cm detach command. +.Pp +It is not an error to attach a namespace that is already attached, any such +request will be silently ignored. .It Xo .Nm .Cm list-firmware diff --git a/usr/src/uts/common/io/nvme/nvme.c b/usr/src/uts/common/io/nvme/nvme.c index c2aeda2e8a..a8a9d0b843 100644 --- a/usr/src/uts/common/io/nvme/nvme.c +++ b/usr/src/uts/common/io/nvme/nvme.c @@ -5272,6 +5272,26 @@ out: } static int +nvme_ioctl_is_ignored_ns(nvme_t *nvme, int nsid, nvme_ioctl_t *nioc, int mode, + cred_t *cred_p) +{ + _NOTE(ARGUNUSED(cred_p)); + + if ((mode & FREAD) == 0) + return (EPERM); + + if (nsid == 0) + return (EINVAL); + + if (nvme->n_ns[nsid - 1].ns_ignore) + nioc->n_arg = 1; + else + nioc->n_arg = 0; + + return (0); +} + +static int nvme_ioctl(dev_t dev, int cmd, intptr_t arg, int mode, cred_t *cred_p, int *rval_p) { @@ -5298,7 +5318,8 @@ nvme_ioctl(dev_t dev, int cmd, intptr_t arg, int mode, cred_t *cred_p, nvme_ioctl_attach, nvme_ioctl_firmware_download, nvme_ioctl_firmware_commit, - nvme_ioctl_passthru + nvme_ioctl_passthru, + nvme_ioctl_is_ignored_ns }; if (nvme == NULL) diff --git a/usr/src/uts/common/sys/nvme.h b/usr/src/uts/common/sys/nvme.h index 83d29d0b8d..bca3102270 100644 --- a/usr/src/uts/common/sys/nvme.h +++ b/usr/src/uts/common/sys/nvme.h @@ -54,7 +54,8 @@ extern "C" { #define NVME_IOC_FIRMWARE_DOWNLOAD (NVME_IOC | 11) #define NVME_IOC_FIRMWARE_COMMIT (NVME_IOC | 12) #define NVME_IOC_PASSTHRU (NVME_IOC | 13) -#define NVME_IOC_MAX NVME_IOC_PASSTHRU +#define NVME_IOC_IS_IGNORED_NS (NVME_IOC | 14) +#define NVME_IOC_MAX NVME_IOC_IS_IGNORED_NS #define IS_NVME_IOC(x) ((x) > NVME_IOC && (x) <= NVME_IOC_MAX) #define NVME_IOC_CMD(x) ((x) & 0xff) |