NVME-ID-NS(1) | NVMe Manual | NVME-ID-NS(1) |
nvme-id-ns - Send NVMe Identify Namespace, return result and structure
nvme id-ns <device> [-v | --vendor-specific] [-b | --raw-binary]
[--namespace-id=<nsid> | -n <nsid>] [-f | --force]
[--human-readable | -H]
[--output-format=<fmt> | -o <fmt>]
For the NVMe device given, sends an identify namespace command and provides the result and returned structure.
The <device> parameter is mandatory and may be either the NVMe character device (ex: /dev/nvme0), or a namespace block device (ex: /dev/nvme0n1). If the character device is given, the '--namespace-id' option is mandatory, otherwise it will use the ns-id of the namespace for the block device you opened. For block devices, the ns-id used can be overridden with the same option.
On success, the structure may be returned in one of several ways depending on the option flags; the structure may be parsed by the program or the raw buffer may be printed to stdout.
-n <nsid>, --namespace-id=<nsid>
-f, --force
-b, --raw-binary
-v, --vendor-specific
-H, --human-readable
-o <format>, --output-format=<format>
# nvme id-ns /dev/nvme0n1
# nvme id-ns /dev/nvme0 -n 1 # nvme id-ns /dev/nvme0n1 -n 1 # nvme id-ns /dev/nvme0 --namespace-id=1
# nvme id-ns /dev/nvme0n1 --vendor-specific # nvme id-ns /dev/nvme0n1 -v
The above will dump the 'vs' buffer in hex since it doesn’t know how to interpret it.
# nvme id-ns /dev/nvme0n1 --raw-binary > id_ns.raw # nvme id-ns /dev/nvme0n1 -b > id_ns.raw
It is probably a bad idea to not redirect stdout when using this mode.
# nvme id-ns /dev/nvme0n1 --raw-binary | nvme_parse_id_ns
The parse program in the above example can be a program that shows the structure in a way you like. The following program is such an example that will parse it and can accept the output through a pipe, '|', as shown in the above example, or you can 'cat' a saved output buffer to it.
/* File: nvme_parse_id_ns.c */ #include <linux/nvme.h> #include <stdio.h> #include <unistd.h> int main(int argc, char **argv) {
unsigned char buf[sizeof(struct nvme_id_ns)];
struct nvme_id_ns *ns = (struct nvme_id_ns *)buf;
if (read(STDIN_FILENO, buf, sizeof(buf)))
return 1;
printf("nsze : %#llx\n", ns->nsze);
printf("ncap : %#llx\n", ns->ncap);
return 0; }
Part of the nvme-user suite
04/24/2020 | NVMe |