NVME-FW-DOWNLOAD(1) | NVMe Manual | NVME-FW-DOWNLOAD(1) |
NAME¶
nvme-fw-download - Download all or a portion of an nvme firmware image.
SYNOPSIS¶
nvme fw-download <device> [--fw=<firmware-file> | -f <firmware-file>]
[--xfer=<transfer-size> | -x <transfer-size>]
[--offset=<offset> | -O <offset>]
[--output-format=<fmt> | -o <fmt>] [--verbose | -v]
[--timeout=<timeout> | -t <timeout>]
DESCRIPTION¶
The Firmware Image Download command is used to download all or a portion of the firmware image for a future update to the controller. The Firmware Image Download command may be submitted while other commands on the Admin Submission Queue or I/O Submission Queues are outstanding. The Firmware Image Download command copies the new firmware image (in whole or in part) to the controller.
The firmware image may be constructed of multiple pieces that are individually downloaded with separate Firmware Image Download commands. Each Firmware Image Download command includes a Dword Offset and Number of Dwords that specify a Dword range. The host software shall ensure that firmware pieces do not have Dword ranges that overlap. Firmware portions may be submitted out of order to the controller.
The new firmware image is not applied as part of the Firmware Image Download command. It is applied following a reset, where the image to apply and the firmware slot it should be committed to is specified with the Firmware Commit command (nvme fw-commit <args>).
Note: nvme-cli must allocate a contiguous (linear) memory buffer and map the firmware binary into it. To do this, nvme-cli first attempts to allocate the buffer using huge TLB pages. If allocation using huge pages fails, it falls back to using posix_memalign() combined with madvise(), though this is also likely to fail.
To increase the likelihood of success, you may want to pre-allocate a number of huge pages before initiating the firmware download:
echo 20 > /proc/sys/vm/nr_hugepages
For more details, refer to: https://www.kernel.org/doc/Documentation/vm/hugetlbpage.txt
OPTIONS¶
-f <firmware-file>, --fw=<firmware-file>
-x <transfer-size>, --xfer=<transfer-size>
-O <offset>, --offset=<offset>
-o <fmt>, --output-format=<fmt>
-v, --verbose
-t <timeout>, --timeout=<timeout>
EXAMPLES¶
# nvme fw-download /dev/nvme0 --fw=/path/to/nvme.fw --xfer=0x20000
NVME¶
Part of the nvme-user suite
08/10/2025 | NVMe |