mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-12 00:00:00 +00:00
Merge branch 'for-jens' of git://git.infradead.org/nvme into for-linus
Pull NVMe fixes from Keith for 4.16-rc. * 'for-jens' of git://git.infradead.org/nvme: nvmet: fix PSDT field check in command format nvme-multipath: fix sysfs dangerously created links nvme-pci: Fix nvme queue cleanup if IRQ setup fails nvmet-loop: use blk_rq_payload_bytes for sgl selection nvme-rdma: use blk_rq_payload_bytes instead of blk_rq_bytes nvme-fabrics: don't check for non-NULL module in nvmf_register_transport
This commit is contained in:
commit
468f098734
@ -2844,7 +2844,7 @@ out:
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int nvme_init_ns_head(struct nvme_ns *ns, unsigned nsid,
|
static int nvme_init_ns_head(struct nvme_ns *ns, unsigned nsid,
|
||||||
struct nvme_id_ns *id, bool *new)
|
struct nvme_id_ns *id)
|
||||||
{
|
{
|
||||||
struct nvme_ctrl *ctrl = ns->ctrl;
|
struct nvme_ctrl *ctrl = ns->ctrl;
|
||||||
bool is_shared = id->nmic & (1 << 0);
|
bool is_shared = id->nmic & (1 << 0);
|
||||||
@ -2860,8 +2860,6 @@ static int nvme_init_ns_head(struct nvme_ns *ns, unsigned nsid,
|
|||||||
ret = PTR_ERR(head);
|
ret = PTR_ERR(head);
|
||||||
goto out_unlock;
|
goto out_unlock;
|
||||||
}
|
}
|
||||||
|
|
||||||
*new = true;
|
|
||||||
} else {
|
} else {
|
||||||
struct nvme_ns_ids ids;
|
struct nvme_ns_ids ids;
|
||||||
|
|
||||||
@ -2873,8 +2871,6 @@ static int nvme_init_ns_head(struct nvme_ns *ns, unsigned nsid,
|
|||||||
ret = -EINVAL;
|
ret = -EINVAL;
|
||||||
goto out_unlock;
|
goto out_unlock;
|
||||||
}
|
}
|
||||||
|
|
||||||
*new = false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
list_add_tail(&ns->siblings, &head->list);
|
list_add_tail(&ns->siblings, &head->list);
|
||||||
@ -2945,7 +2941,6 @@ static void nvme_alloc_ns(struct nvme_ctrl *ctrl, unsigned nsid)
|
|||||||
struct nvme_id_ns *id;
|
struct nvme_id_ns *id;
|
||||||
char disk_name[DISK_NAME_LEN];
|
char disk_name[DISK_NAME_LEN];
|
||||||
int node = dev_to_node(ctrl->dev), flags = GENHD_FL_EXT_DEVT;
|
int node = dev_to_node(ctrl->dev), flags = GENHD_FL_EXT_DEVT;
|
||||||
bool new = true;
|
|
||||||
|
|
||||||
ns = kzalloc_node(sizeof(*ns), GFP_KERNEL, node);
|
ns = kzalloc_node(sizeof(*ns), GFP_KERNEL, node);
|
||||||
if (!ns)
|
if (!ns)
|
||||||
@ -2971,7 +2966,7 @@ static void nvme_alloc_ns(struct nvme_ctrl *ctrl, unsigned nsid)
|
|||||||
if (id->ncap == 0)
|
if (id->ncap == 0)
|
||||||
goto out_free_id;
|
goto out_free_id;
|
||||||
|
|
||||||
if (nvme_init_ns_head(ns, nsid, id, &new))
|
if (nvme_init_ns_head(ns, nsid, id))
|
||||||
goto out_free_id;
|
goto out_free_id;
|
||||||
nvme_setup_streams_ns(ctrl, ns);
|
nvme_setup_streams_ns(ctrl, ns);
|
||||||
|
|
||||||
@ -3037,8 +3032,7 @@ static void nvme_alloc_ns(struct nvme_ctrl *ctrl, unsigned nsid)
|
|||||||
pr_warn("%s: failed to register lightnvm sysfs group for identification\n",
|
pr_warn("%s: failed to register lightnvm sysfs group for identification\n",
|
||||||
ns->disk->disk_name);
|
ns->disk->disk_name);
|
||||||
|
|
||||||
if (new)
|
nvme_mpath_add_disk(ns->head);
|
||||||
nvme_mpath_add_disk(ns->head);
|
|
||||||
nvme_mpath_add_disk_links(ns);
|
nvme_mpath_add_disk_links(ns);
|
||||||
return;
|
return;
|
||||||
out_unlink_ns:
|
out_unlink_ns:
|
||||||
|
@ -493,7 +493,7 @@ EXPORT_SYMBOL_GPL(nvmf_should_reconnect);
|
|||||||
*/
|
*/
|
||||||
int nvmf_register_transport(struct nvmf_transport_ops *ops)
|
int nvmf_register_transport(struct nvmf_transport_ops *ops)
|
||||||
{
|
{
|
||||||
if (!ops->create_ctrl || !ops->module)
|
if (!ops->create_ctrl)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
down_write(&nvmf_transports_rwsem);
|
down_write(&nvmf_transports_rwsem);
|
||||||
|
@ -198,11 +198,16 @@ void nvme_mpath_add_disk(struct nvme_ns_head *head)
|
|||||||
{
|
{
|
||||||
if (!head->disk)
|
if (!head->disk)
|
||||||
return;
|
return;
|
||||||
device_add_disk(&head->subsys->dev, head->disk);
|
|
||||||
if (sysfs_create_group(&disk_to_dev(head->disk)->kobj,
|
mutex_lock(&head->subsys->lock);
|
||||||
&nvme_ns_id_attr_group))
|
if (!(head->disk->flags & GENHD_FL_UP)) {
|
||||||
pr_warn("%s: failed to create sysfs group for identification\n",
|
device_add_disk(&head->subsys->dev, head->disk);
|
||||||
head->disk->disk_name);
|
if (sysfs_create_group(&disk_to_dev(head->disk)->kobj,
|
||||||
|
&nvme_ns_id_attr_group))
|
||||||
|
pr_warn("%s: failed to create sysfs group for identification\n",
|
||||||
|
head->disk->disk_name);
|
||||||
|
}
|
||||||
|
mutex_unlock(&head->subsys->lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
void nvme_mpath_add_disk_links(struct nvme_ns *ns)
|
void nvme_mpath_add_disk_links(struct nvme_ns *ns)
|
||||||
|
@ -1459,7 +1459,7 @@ static int nvme_create_queue(struct nvme_queue *nvmeq, int qid)
|
|||||||
nvmeq->cq_vector = qid - 1;
|
nvmeq->cq_vector = qid - 1;
|
||||||
result = adapter_alloc_cq(dev, qid, nvmeq);
|
result = adapter_alloc_cq(dev, qid, nvmeq);
|
||||||
if (result < 0)
|
if (result < 0)
|
||||||
return result;
|
goto release_vector;
|
||||||
|
|
||||||
result = adapter_alloc_sq(dev, qid, nvmeq);
|
result = adapter_alloc_sq(dev, qid, nvmeq);
|
||||||
if (result < 0)
|
if (result < 0)
|
||||||
@ -1473,9 +1473,12 @@ static int nvme_create_queue(struct nvme_queue *nvmeq, int qid)
|
|||||||
return result;
|
return result;
|
||||||
|
|
||||||
release_sq:
|
release_sq:
|
||||||
|
dev->online_queues--;
|
||||||
adapter_delete_sq(dev, qid);
|
adapter_delete_sq(dev, qid);
|
||||||
release_cq:
|
release_cq:
|
||||||
adapter_delete_cq(dev, qid);
|
adapter_delete_cq(dev, qid);
|
||||||
|
release_vector:
|
||||||
|
nvmeq->cq_vector = -1;
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1051,7 +1051,7 @@ static void nvme_rdma_unmap_data(struct nvme_rdma_queue *queue,
|
|||||||
struct nvme_rdma_device *dev = queue->device;
|
struct nvme_rdma_device *dev = queue->device;
|
||||||
struct ib_device *ibdev = dev->dev;
|
struct ib_device *ibdev = dev->dev;
|
||||||
|
|
||||||
if (!blk_rq_bytes(rq))
|
if (!blk_rq_payload_bytes(rq))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (req->mr) {
|
if (req->mr) {
|
||||||
@ -1166,7 +1166,7 @@ static int nvme_rdma_map_data(struct nvme_rdma_queue *queue,
|
|||||||
|
|
||||||
c->common.flags |= NVME_CMD_SGL_METABUF;
|
c->common.flags |= NVME_CMD_SGL_METABUF;
|
||||||
|
|
||||||
if (!blk_rq_bytes(rq))
|
if (!blk_rq_payload_bytes(rq))
|
||||||
return nvme_rdma_set_sg_null(c);
|
return nvme_rdma_set_sg_null(c);
|
||||||
|
|
||||||
req->sg_table.sgl = req->first_sgl;
|
req->sg_table.sgl = req->first_sgl;
|
||||||
|
@ -520,9 +520,12 @@ bool nvmet_req_init(struct nvmet_req *req, struct nvmet_cq *cq,
|
|||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* either variant of SGLs is fine, as we don't support metadata */
|
/*
|
||||||
if (unlikely((flags & NVME_CMD_SGL_ALL) != NVME_CMD_SGL_METABUF &&
|
* For fabrics, PSDT field shall describe metadata pointer (MPTR) that
|
||||||
(flags & NVME_CMD_SGL_ALL) != NVME_CMD_SGL_METASEG)) {
|
* contains an address of a single contiguous physical buffer that is
|
||||||
|
* byte aligned.
|
||||||
|
*/
|
||||||
|
if (unlikely((flags & NVME_CMD_SGL_ALL) != NVME_CMD_SGL_METABUF)) {
|
||||||
status = NVME_SC_INVALID_FIELD | NVME_SC_DNR;
|
status = NVME_SC_INVALID_FIELD | NVME_SC_DNR;
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
@ -184,7 +184,7 @@ static blk_status_t nvme_loop_queue_rq(struct blk_mq_hw_ctx *hctx,
|
|||||||
return BLK_STS_OK;
|
return BLK_STS_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (blk_rq_bytes(req)) {
|
if (blk_rq_payload_bytes(req)) {
|
||||||
iod->sg_table.sgl = iod->first_sgl;
|
iod->sg_table.sgl = iod->first_sgl;
|
||||||
if (sg_alloc_table_chained(&iod->sg_table,
|
if (sg_alloc_table_chained(&iod->sg_table,
|
||||||
blk_rq_nr_phys_segments(req),
|
blk_rq_nr_phys_segments(req),
|
||||||
@ -193,7 +193,7 @@ static blk_status_t nvme_loop_queue_rq(struct blk_mq_hw_ctx *hctx,
|
|||||||
|
|
||||||
iod->req.sg = iod->sg_table.sgl;
|
iod->req.sg = iod->sg_table.sgl;
|
||||||
iod->req.sg_cnt = blk_rq_map_sg(req->q, req, iod->sg_table.sgl);
|
iod->req.sg_cnt = blk_rq_map_sg(req->q, req, iod->sg_table.sgl);
|
||||||
iod->req.transfer_len = blk_rq_bytes(req);
|
iod->req.transfer_len = blk_rq_payload_bytes(req);
|
||||||
}
|
}
|
||||||
|
|
||||||
blk_mq_start_request(req);
|
blk_mq_start_request(req);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user