mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-04 16:23:55 -06:00
hw/nvme: Abort copy command when format is one while pif
As per the NVMe Command Set specification Section 3.2.2, if
i) The namespace is formatted to use 16b Guard Protection
Information (i.e., pif = 0) and
ii) The Descriptor Format is not cleared to 0h
Then the copy command should be aborted with the status code of Invalid
Namespace or Format
Fixes: 44219b6029
("hw/nvme: 64-bit pi support")
Signed-off-by: Francis Pravin Antony Michael Raj <francis.michael@solidigm.com>
Signed-off-by: Jonathan Derrick <jonathan.derrick@solidigm.com>
Reviewed-by: Klaus Jensen <k.jensen@samsung.com>
Signed-off-by: Klaus Jensen <k.jensen@samsung.com>
This commit is contained in:
parent
d38cc6fd1c
commit
632cb6cf07
1 changed files with 2 additions and 1 deletions
|
@ -3034,7 +3034,8 @@ static uint16_t nvme_copy(NvmeCtrl *n, NvmeRequest *req)
|
|||
goto invalid;
|
||||
}
|
||||
|
||||
if (ns->pif && format != 0x1) {
|
||||
if ((ns->pif == 0x0 && format != 0x0) ||
|
||||
(ns->pif != 0x0 && format != 0x1)) {
|
||||
status = NVME_INVALID_FORMAT | NVME_DNR;
|
||||
goto invalid;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue