mirror of https://github.com/xemu-project/xemu.git
hw/block/nvme: reject io commands if only admin command set selected
If the host sets CC.CSS to 111b, all commands submitted to I/O queues should be completed with status Invalid Command Opcode. Note that this is technically a v1.4 feature, but it does not hurt to implement before we finally bump the reported version implemented. Reviewed-by: Dmitry Fomichev <dmitry.fomichev@wdc.com> Signed-off-by: Klaus Jensen <k.jensen@samsung.com> Signed-off-by: Keith Busch <kbusch@kernel.org>
This commit is contained in:
parent
8c5cea8593
commit
1b48e4611a
|
@ -1026,6 +1026,10 @@ static uint16_t nvme_io_cmd(NvmeCtrl *n, NvmeRequest *req)
|
||||||
trace_pci_nvme_io_cmd(nvme_cid(req), nsid, nvme_sqid(req),
|
trace_pci_nvme_io_cmd(nvme_cid(req), nsid, nvme_sqid(req),
|
||||||
req->cmd.opcode, nvme_io_opc_str(req->cmd.opcode));
|
req->cmd.opcode, nvme_io_opc_str(req->cmd.opcode));
|
||||||
|
|
||||||
|
if (NVME_CC_CSS(n->bar.cc) == NVME_CC_CSS_ADMIN_ONLY) {
|
||||||
|
return NVME_INVALID_OPCODE | NVME_DNR;
|
||||||
|
}
|
||||||
|
|
||||||
if (!nvme_nsid_valid(n, nsid)) {
|
if (!nvme_nsid_valid(n, nsid)) {
|
||||||
return NVME_INVALID_NSID | NVME_DNR;
|
return NVME_INVALID_NSID | NVME_DNR;
|
||||||
}
|
}
|
||||||
|
|
|
@ -115,6 +115,11 @@ enum NvmeCcMask {
|
||||||
#define NVME_CC_IOSQES(cc) ((cc >> CC_IOSQES_SHIFT) & CC_IOSQES_MASK)
|
#define NVME_CC_IOSQES(cc) ((cc >> CC_IOSQES_SHIFT) & CC_IOSQES_MASK)
|
||||||
#define NVME_CC_IOCQES(cc) ((cc >> CC_IOCQES_SHIFT) & CC_IOCQES_MASK)
|
#define NVME_CC_IOCQES(cc) ((cc >> CC_IOCQES_SHIFT) & CC_IOCQES_MASK)
|
||||||
|
|
||||||
|
enum NvmeCcCss {
|
||||||
|
NVME_CC_CSS_NVM = 0x0,
|
||||||
|
NVME_CC_CSS_ADMIN_ONLY = 0x7,
|
||||||
|
};
|
||||||
|
|
||||||
enum NvmeCstsShift {
|
enum NvmeCstsShift {
|
||||||
CSTS_RDY_SHIFT = 0,
|
CSTS_RDY_SHIFT = 0,
|
||||||
CSTS_CFS_SHIFT = 1,
|
CSTS_CFS_SHIFT = 1,
|
||||||
|
|
Loading…
Reference in New Issue