mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-10 07:00:48 +00:00
NVMe: Set number of queues correctly
The number of submission & completion queues should be set by calling Set Features, not Get Features. Reported-by: Kwok Kong <Kwok.Kong@idt.com> Signed-off-by: Matthew Wilcox <matthew.r.wilcox@intel.com>
This commit is contained in:
parent
366e8217e5
commit
df34813990
@ -840,7 +840,7 @@ static int nvme_identify(struct nvme_dev *dev, unsigned nsid, unsigned cns,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int nvme_get_features(struct nvme_dev *dev, unsigned fid,
|
static int nvme_get_features(struct nvme_dev *dev, unsigned fid,
|
||||||
unsigned dword11, dma_addr_t dma_addr, u32 *result)
|
unsigned dword11, dma_addr_t dma_addr)
|
||||||
{
|
{
|
||||||
struct nvme_command c;
|
struct nvme_command c;
|
||||||
|
|
||||||
@ -850,6 +850,20 @@ static int nvme_get_features(struct nvme_dev *dev, unsigned fid,
|
|||||||
c.features.fid = cpu_to_le32(fid);
|
c.features.fid = cpu_to_le32(fid);
|
||||||
c.features.dword11 = cpu_to_le32(dword11);
|
c.features.dword11 = cpu_to_le32(dword11);
|
||||||
|
|
||||||
|
return nvme_submit_admin_cmd(dev, &c, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int nvme_set_features(struct nvme_dev *dev, unsigned fid,
|
||||||
|
unsigned dword11, dma_addr_t dma_addr, u32 *result)
|
||||||
|
{
|
||||||
|
struct nvme_command c;
|
||||||
|
|
||||||
|
memset(&c, 0, sizeof(c));
|
||||||
|
c.features.opcode = nvme_admin_set_features;
|
||||||
|
c.features.prp1 = cpu_to_le64(dma_addr);
|
||||||
|
c.features.fid = cpu_to_le32(fid);
|
||||||
|
c.features.dword11 = cpu_to_le32(dword11);
|
||||||
|
|
||||||
return nvme_submit_admin_cmd(dev, &c, result);
|
return nvme_submit_admin_cmd(dev, &c, result);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1365,7 +1379,7 @@ static int set_queue_count(struct nvme_dev *dev, int count)
|
|||||||
u32 result;
|
u32 result;
|
||||||
u32 q_count = (count - 1) | ((count - 1) << 16);
|
u32 q_count = (count - 1) | ((count - 1) << 16);
|
||||||
|
|
||||||
status = nvme_get_features(dev, NVME_FEAT_NUM_QUEUES, q_count, 0,
|
status = nvme_set_features(dev, NVME_FEAT_NUM_QUEUES, q_count, 0,
|
||||||
&result);
|
&result);
|
||||||
if (status)
|
if (status)
|
||||||
return -EIO;
|
return -EIO;
|
||||||
@ -1482,7 +1496,7 @@ static int __devinit nvme_dev_add(struct nvme_dev *dev)
|
|||||||
continue;
|
continue;
|
||||||
|
|
||||||
res = nvme_get_features(dev, NVME_FEAT_LBA_RANGE, i,
|
res = nvme_get_features(dev, NVME_FEAT_LBA_RANGE, i,
|
||||||
dma_addr + 4096, NULL);
|
dma_addr + 4096);
|
||||||
if (res)
|
if (res)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user