mirror of https://github.com/xemu-project/xemu.git
hw/block/nvme: reject invalid nsid values in active namespace id list
Reject the nsid broadcast value (0xffffffff) and 0xfffffffe in the Active Namespace ID list. Signed-off-by: Klaus Jensen <k.jensen@samsung.com> Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com> Reviewed-by: Dmitry Fomichev <dmitry.fomichev@wdc.com> Reviewed-by: Maxim Levitsky <mlevitsk@redhat.com> Message-Id: <20200706061303.246057-16-its@irrelevant.dk>
This commit is contained in:
parent
464eaa7292
commit
38a58e7ce3
|
@ -1007,6 +1007,16 @@ static uint16_t nvme_identify_nslist(NvmeCtrl *n, NvmeIdentify *c)
|
||||||
|
|
||||||
trace_pci_nvme_identify_nslist(min_nsid);
|
trace_pci_nvme_identify_nslist(min_nsid);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Both 0xffffffff (NVME_NSID_BROADCAST) and 0xfffffffe are invalid values
|
||||||
|
* since the Active Namespace ID List should return namespaces with ids
|
||||||
|
* *higher* than the NSID specified in the command. This is also specified
|
||||||
|
* in the spec (NVM Express v1.3d, Section 5.15.4).
|
||||||
|
*/
|
||||||
|
if (min_nsid >= NVME_NSID_BROADCAST - 1) {
|
||||||
|
return NVME_INVALID_NSID | NVME_DNR;
|
||||||
|
}
|
||||||
|
|
||||||
list = g_malloc0(data_len);
|
list = g_malloc0(data_len);
|
||||||
for (i = 0; i < n->num_namespaces; i++) {
|
for (i = 0; i < n->num_namespaces; i++) {
|
||||||
if (i < min_nsid) {
|
if (i < min_nsid) {
|
||||||
|
|
Loading…
Reference in New Issue