You've already forked linux-t2-patches
mirror of
https://github.com/t2linux/linux-t2-patches.git
synced 2026-04-30 13:52:11 -07:00
238 lines
7.9 KiB
Diff
238 lines
7.9 KiB
Diff
|
|
From 9e9464bd0b7c6f205d49089503059b90d3f654ce Mon Sep 17 00:00:00 2001
|
||
|
|
From: Aditya Garg <85610623+AdityaGarg8@users.noreply.github.com>
|
||
|
|
Date: Fri, 24 Sep 2021 15:36:45 +0530
|
||
|
|
Subject: [PATCH] Revert nvme to 5.10.66
|
||
|
|
|
||
|
|
---
|
||
|
|
drivers/nvme/host/core.c | 3 +--
|
||
|
|
drivers/nvme/host/nvme.h | 47 +-------------------------------------
|
||
|
|
drivers/nvme/host/pci.c | 2 +-
|
||
|
|
drivers/nvme/host/rdma.c | 4 ++--
|
||
|
|
drivers/nvme/host/tcp.c | 38 ++++++++++++++++++------------
|
||
|
|
drivers/nvme/target/loop.c | 4 ++--
|
||
|
|
6 files changed, 30 insertions(+), 68 deletions(-)
|
||
|
|
|
||
|
|
diff --git a/drivers/nvme/host/core.c b/drivers/nvme/host/core.c
|
||
|
|
index 5a9b2f1b1..ff5a16b17 100644
|
||
|
|
--- a/drivers/nvme/host/core.c
|
||
|
|
+++ b/drivers/nvme/host/core.c
|
||
|
|
@@ -878,8 +878,7 @@ blk_status_t nvme_setup_cmd(struct nvme_ns *ns, struct request *req,
|
||
|
|
return BLK_STS_IOERR;
|
||
|
|
}
|
||
|
|
|
||
|
|
- nvme_req(req)->genctr++;
|
||
|
|
- cmd->common.command_id = nvme_cid(req);
|
||
|
|
+ cmd->common.command_id = req->tag;
|
||
|
|
trace_nvme_setup_cmd(req, cmd);
|
||
|
|
return ret;
|
||
|
|
}
|
||
|
|
diff --git a/drivers/nvme/host/nvme.h b/drivers/nvme/host/nvme.h
|
||
|
|
index 8c735c55c..3cb3c8206 100644
|
||
|
|
--- a/drivers/nvme/host/nvme.h
|
||
|
|
+++ b/drivers/nvme/host/nvme.h
|
||
|
|
@@ -153,7 +153,6 @@ enum nvme_quirks {
|
||
|
|
struct nvme_request {
|
||
|
|
struct nvme_command *cmd;
|
||
|
|
union nvme_result result;
|
||
|
|
- u8 genctr;
|
||
|
|
u8 retries;
|
||
|
|
u8 flags;
|
||
|
|
u16 status;
|
||
|
|
@@ -470,49 +469,6 @@ struct nvme_ctrl_ops {
|
||
|
|
int (*get_address)(struct nvme_ctrl *ctrl, char *buf, int size);
|
||
|
|
};
|
||
|
|
|
||
|
|
-/*
|
||
|
|
- * nvme command_id is constructed as such:
|
||
|
|
- * | xxxx | xxxxxxxxxxxx |
|
||
|
|
- * gen request tag
|
||
|
|
- */
|
||
|
|
-#define nvme_genctr_mask(gen) (gen & 0xf)
|
||
|
|
-#define nvme_cid_install_genctr(gen) (nvme_genctr_mask(gen) << 12)
|
||
|
|
-#define nvme_genctr_from_cid(cid) ((cid & 0xf000) >> 12)
|
||
|
|
-#define nvme_tag_from_cid(cid) (cid & 0xfff)
|
||
|
|
-
|
||
|
|
-static inline u16 nvme_cid(struct request *rq)
|
||
|
|
-{
|
||
|
|
- return nvme_cid_install_genctr(nvme_req(rq)->genctr) | rq->tag;
|
||
|
|
-}
|
||
|
|
-
|
||
|
|
-static inline struct request *nvme_find_rq(struct blk_mq_tags *tags,
|
||
|
|
- u16 command_id)
|
||
|
|
-{
|
||
|
|
- u8 genctr = nvme_genctr_from_cid(command_id);
|
||
|
|
- u16 tag = nvme_tag_from_cid(command_id);
|
||
|
|
- struct request *rq;
|
||
|
|
-
|
||
|
|
- rq = blk_mq_tag_to_rq(tags, tag);
|
||
|
|
- if (unlikely(!rq)) {
|
||
|
|
- pr_err("could not locate request for tag %#x\n",
|
||
|
|
- tag);
|
||
|
|
- return NULL;
|
||
|
|
- }
|
||
|
|
- if (unlikely(nvme_genctr_mask(nvme_req(rq)->genctr) != genctr)) {
|
||
|
|
- dev_err(nvme_req(rq)->ctrl->device,
|
||
|
|
- "request %#x genctr mismatch (got %#x expected %#x)\n",
|
||
|
|
- tag, genctr, nvme_genctr_mask(nvme_req(rq)->genctr));
|
||
|
|
- return NULL;
|
||
|
|
- }
|
||
|
|
- return rq;
|
||
|
|
-}
|
||
|
|
-
|
||
|
|
-static inline struct request *nvme_cid_to_rq(struct blk_mq_tags *tags,
|
||
|
|
- u16 command_id)
|
||
|
|
-{
|
||
|
|
- return blk_mq_tag_to_rq(tags, nvme_tag_from_cid(command_id));
|
||
|
|
-}
|
||
|
|
-
|
||
|
|
#ifdef CONFIG_FAULT_INJECTION_DEBUG_FS
|
||
|
|
void nvme_fault_inject_init(struct nvme_fault_inject *fault_inj,
|
||
|
|
const char *dev_name);
|
||
|
|
@@ -610,8 +566,7 @@ static inline void nvme_put_ctrl(struct nvme_ctrl *ctrl)
|
||
|
|
|
||
|
|
static inline bool nvme_is_aen_req(u16 qid, __u16 command_id)
|
||
|
|
{
|
||
|
|
- return !qid &&
|
||
|
|
- nvme_tag_from_cid(command_id) >= NVME_AQ_BLK_MQ_DEPTH;
|
||
|
|
+ return !qid && command_id >= NVME_AQ_BLK_MQ_DEPTH;
|
||
|
|
}
|
||
|
|
|
||
|
|
void nvme_complete_rq(struct request *req);
|
||
|
|
diff --git a/drivers/nvme/host/pci.c b/drivers/nvme/host/pci.c
|
||
|
|
index 09767a805..fb48a88d1 100644
|
||
|
|
--- a/drivers/nvme/host/pci.c
|
||
|
|
+++ b/drivers/nvme/host/pci.c
|
||
|
|
@@ -1012,7 +1012,7 @@ static inline void nvme_handle_cqe(struct nvme_queue *nvmeq, u16 idx)
|
||
|
|
return;
|
||
|
|
}
|
||
|
|
|
||
|
|
- req = nvme_find_rq(nvme_queue_tagset(nvmeq), command_id);
|
||
|
|
+ req = blk_mq_tag_to_rq(nvme_queue_tagset(nvmeq), command_id);
|
||
|
|
if (unlikely(!req)) {
|
||
|
|
dev_warn(nvmeq->dev->ctrl.device,
|
||
|
|
"invalid id %d completed on queue %d\n",
|
||
|
|
diff --git a/drivers/nvme/host/rdma.c b/drivers/nvme/host/rdma.c
|
||
|
|
index 9c356be7f..c6c2e2361 100644
|
||
|
|
--- a/drivers/nvme/host/rdma.c
|
||
|
|
+++ b/drivers/nvme/host/rdma.c
|
||
|
|
@@ -1738,10 +1738,10 @@ static void nvme_rdma_process_nvme_rsp(struct nvme_rdma_queue *queue,
|
||
|
|
struct request *rq;
|
||
|
|
struct nvme_rdma_request *req;
|
||
|
|
|
||
|
|
- rq = nvme_find_rq(nvme_rdma_tagset(queue), cqe->command_id);
|
||
|
|
+ rq = blk_mq_tag_to_rq(nvme_rdma_tagset(queue), cqe->command_id);
|
||
|
|
if (!rq) {
|
||
|
|
dev_err(queue->ctrl->ctrl.device,
|
||
|
|
- "got bad command_id %#x on QP %#x\n",
|
||
|
|
+ "tag 0x%x on QP %#x not found\n",
|
||
|
|
cqe->command_id, queue->qp->qp_num);
|
||
|
|
nvme_rdma_error_recovery(queue->ctrl);
|
||
|
|
return;
|
||
|
|
diff --git a/drivers/nvme/host/tcp.c b/drivers/nvme/host/tcp.c
|
||
|
|
index c9a925999..5b11d8a23 100644
|
||
|
|
--- a/drivers/nvme/host/tcp.c
|
||
|
|
+++ b/drivers/nvme/host/tcp.c
|
||
|
|
@@ -484,11 +484,11 @@ static int nvme_tcp_process_nvme_cqe(struct nvme_tcp_queue *queue,
|
||
|
|
{
|
||
|
|
struct request *rq;
|
||
|
|
|
||
|
|
- rq = nvme_find_rq(nvme_tcp_tagset(queue), cqe->command_id);
|
||
|
|
+ rq = blk_mq_tag_to_rq(nvme_tcp_tagset(queue), cqe->command_id);
|
||
|
|
if (!rq) {
|
||
|
|
dev_err(queue->ctrl->ctrl.device,
|
||
|
|
- "got bad cqe.command_id %#x on queue %d\n",
|
||
|
|
- cqe->command_id, nvme_tcp_queue_id(queue));
|
||
|
|
+ "queue %d tag 0x%x not found\n",
|
||
|
|
+ nvme_tcp_queue_id(queue), cqe->command_id);
|
||
|
|
nvme_tcp_error_recovery(&queue->ctrl->ctrl);
|
||
|
|
return -EINVAL;
|
||
|
|
}
|
||
|
|
@@ -505,11 +505,11 @@ static int nvme_tcp_handle_c2h_data(struct nvme_tcp_queue *queue,
|
||
|
|
{
|
||
|
|
struct request *rq;
|
||
|
|
|
||
|
|
- rq = nvme_find_rq(nvme_tcp_tagset(queue), pdu->command_id);
|
||
|
|
+ rq = blk_mq_tag_to_rq(nvme_tcp_tagset(queue), pdu->command_id);
|
||
|
|
if (!rq) {
|
||
|
|
dev_err(queue->ctrl->ctrl.device,
|
||
|
|
- "got bad c2hdata.command_id %#x on queue %d\n",
|
||
|
|
- pdu->command_id, nvme_tcp_queue_id(queue));
|
||
|
|
+ "queue %d tag %#x not found\n",
|
||
|
|
+ nvme_tcp_queue_id(queue), pdu->command_id);
|
||
|
|
return -ENOENT;
|
||
|
|
}
|
||
|
|
|
||
|
|
@@ -603,7 +603,7 @@ static int nvme_tcp_setup_h2c_data_pdu(struct nvme_tcp_request *req,
|
||
|
|
data->hdr.plen =
|
||
|
|
cpu_to_le32(data->hdr.hlen + hdgst + req->pdu_len + ddgst);
|
||
|
|
data->ttag = pdu->ttag;
|
||
|
|
- data->command_id = nvme_cid(rq);
|
||
|
|
+ data->command_id = rq->tag;
|
||
|
|
data->data_offset = cpu_to_le32(req->data_sent);
|
||
|
|
data->data_length = cpu_to_le32(req->pdu_len);
|
||
|
|
return 0;
|
||
|
|
@@ -616,11 +616,11 @@ static int nvme_tcp_handle_r2t(struct nvme_tcp_queue *queue,
|
||
|
|
struct request *rq;
|
||
|
|
int ret;
|
||
|
|
|
||
|
|
- rq = nvme_find_rq(nvme_tcp_tagset(queue), pdu->command_id);
|
||
|
|
+ rq = blk_mq_tag_to_rq(nvme_tcp_tagset(queue), pdu->command_id);
|
||
|
|
if (!rq) {
|
||
|
|
dev_err(queue->ctrl->ctrl.device,
|
||
|
|
- "got bad r2t.command_id %#x on queue %d\n",
|
||
|
|
- pdu->command_id, nvme_tcp_queue_id(queue));
|
||
|
|
+ "queue %d tag %#x not found\n",
|
||
|
|
+ nvme_tcp_queue_id(queue), pdu->command_id);
|
||
|
|
return -ENOENT;
|
||
|
|
}
|
||
|
|
req = blk_mq_rq_to_pdu(rq);
|
||
|
|
@@ -699,9 +699,17 @@ static int nvme_tcp_recv_data(struct nvme_tcp_queue *queue, struct sk_buff *skb,
|
||
|
|
unsigned int *offset, size_t *len)
|
||
|
|
{
|
||
|
|
struct nvme_tcp_data_pdu *pdu = (void *)queue->pdu;
|
||
|
|
- struct request *rq =
|
||
|
|
- nvme_cid_to_rq(nvme_tcp_tagset(queue), pdu->command_id);
|
||
|
|
- struct nvme_tcp_request *req = blk_mq_rq_to_pdu(rq);
|
||
|
|
+ struct nvme_tcp_request *req;
|
||
|
|
+ struct request *rq;
|
||
|
|
+
|
||
|
|
+ rq = blk_mq_tag_to_rq(nvme_tcp_tagset(queue), pdu->command_id);
|
||
|
|
+ if (!rq) {
|
||
|
|
+ dev_err(queue->ctrl->ctrl.device,
|
||
|
|
+ "queue %d tag %#x not found\n",
|
||
|
|
+ nvme_tcp_queue_id(queue), pdu->command_id);
|
||
|
|
+ return -ENOENT;
|
||
|
|
+ }
|
||
|
|
+ req = blk_mq_rq_to_pdu(rq);
|
||
|
|
|
||
|
|
while (true) {
|
||
|
|
int recv_len, ret;
|
||
|
|
@@ -793,8 +801,8 @@ static int nvme_tcp_recv_ddgst(struct nvme_tcp_queue *queue,
|
||
|
|
}
|
||
|
|
|
||
|
|
if (pdu->hdr.flags & NVME_TCP_F_DATA_SUCCESS) {
|
||
|
|
- struct request *rq = nvme_cid_to_rq(nvme_tcp_tagset(queue),
|
||
|
|
- pdu->command_id);
|
||
|
|
+ struct request *rq = blk_mq_tag_to_rq(nvme_tcp_tagset(queue),
|
||
|
|
+ pdu->command_id);
|
||
|
|
|
||
|
|
nvme_tcp_end_request(rq, NVME_SC_SUCCESS);
|
||
|
|
queue->nr_cqe++;
|
||
|
|
diff --git a/drivers/nvme/target/loop.c b/drivers/nvme/target/loop.c
|
||
|
|
index ff3258c3e..16d71cc5a 100644
|
||
|
|
--- a/drivers/nvme/target/loop.c
|
||
|
|
+++ b/drivers/nvme/target/loop.c
|
||
|
|
@@ -107,10 +107,10 @@ static void nvme_loop_queue_response(struct nvmet_req *req)
|
||
|
|
} else {
|
||
|
|
struct request *rq;
|
||
|
|
|
||
|
|
- rq = nvme_find_rq(nvme_loop_tagset(queue), cqe->command_id);
|
||
|
|
+ rq = blk_mq_tag_to_rq(nvme_loop_tagset(queue), cqe->command_id);
|
||
|
|
if (!rq) {
|
||
|
|
dev_err(queue->ctrl->ctrl.device,
|
||
|
|
- "got bad command_id %#x on queue %d\n",
|
||
|
|
+ "tag 0x%x on queue %d not found\n",
|
||
|
|
cqe->command_id, nvme_loop_queue_idx(queue));
|
||
|
|
return;
|
||
|
|
}
|