IB/hns: Modify the macro for the timeout when cmd process
authorWei Hu (Xavier) <xavier.huwei@huawei.com>
Wed, 23 Nov 2016 19:41:05 +0000 (19:41 +0000)
committerDoug Ledford <dledford@redhat.com>
Sat, 3 Dec 2016 19:20:42 +0000 (14:20 -0500)
This patch modified the macro for the timeout when cmd is
processing as follows:
Before modification:
 enum {
HNS_ROCE_CMD_TIME_CLASS_A       = 10000,
HNS_ROCE_CMD_TIME_CLASS_B       = 10000,
HNS_ROCE_CMD_TIME_CLASS_C       = 10000,
 };
After modification:
 #define HNS_ROCE_CMD_TIMEOUT_MSECS 10000

Signed-off-by: Wei Hu (Xavier) <xavier.huwei@huawei.com>
Signed-off-by: Salil Mehta <salil.mehta@huawei.com>
Signed-off-by: Doug Ledford <dledford@redhat.com>
drivers/infiniband/hw/hns/hns_roce_cmd.h
drivers/infiniband/hw/hns/hns_roce_cq.c
drivers/infiniband/hw/hns/hns_roce_hw_v1.c
drivers/infiniband/hw/hns/hns_roce_mr.c

index e3997d3..ed14ad3 100644 (file)
@@ -34,6 +34,7 @@
 #define _HNS_ROCE_CMD_H
 
 #define HNS_ROCE_MAILBOX_SIZE          4096
+#define HNS_ROCE_CMD_TIMEOUT_MSECS     10000
 
 enum {
        /* TPT commands */
@@ -57,12 +58,6 @@ enum {
        HNS_ROCE_CMD_QUERY_QP           = 0x22,
 };
 
-enum {
-       HNS_ROCE_CMD_TIME_CLASS_A       = 10000,
-       HNS_ROCE_CMD_TIME_CLASS_B       = 10000,
-       HNS_ROCE_CMD_TIME_CLASS_C       = 10000,
-};
-
 struct hns_roce_cmd_mailbox {
        void                   *buf;
        dma_addr_t              dma;
index 5dc8d92..461a273 100644 (file)
@@ -77,7 +77,7 @@ static int hns_roce_sw2hw_cq(struct hns_roce_dev *dev,
                             unsigned long cq_num)
 {
        return hns_roce_cmd_mbox(dev, mailbox->dma, 0, cq_num, 0,
-                           HNS_ROCE_CMD_SW2HW_CQ, HNS_ROCE_CMD_TIME_CLASS_A);
+                           HNS_ROCE_CMD_SW2HW_CQ, HNS_ROCE_CMD_TIMEOUT_MSECS);
 }
 
 static int hns_roce_cq_alloc(struct hns_roce_dev *hr_dev, int nent,
@@ -176,7 +176,7 @@ static int hns_roce_hw2sw_cq(struct hns_roce_dev *dev,
 {
        return hns_roce_cmd_mbox(dev, 0, mailbox ? mailbox->dma : 0, cq_num,
                                 mailbox ? 0 : 1, HNS_ROCE_CMD_HW2SW_CQ,
-                                HNS_ROCE_CMD_TIME_CLASS_A);
+                                HNS_ROCE_CMD_TIMEOUT_MSECS);
 }
 
 static void hns_roce_free_cq(struct hns_roce_dev *hr_dev,
index 528cb84..f7e0fdf 100644 (file)
@@ -1871,12 +1871,12 @@ static int hns_roce_v1_qp_modify(struct hns_roce_dev *hr_dev,
        if (op[cur_state][new_state] == HNS_ROCE_CMD_2RST_QP)
                return hns_roce_cmd_mbox(hr_dev, 0, 0, hr_qp->qpn, 2,
                                         HNS_ROCE_CMD_2RST_QP,
-                                        HNS_ROCE_CMD_TIME_CLASS_A);
+                                        HNS_ROCE_CMD_TIMEOUT_MSECS);
 
        if (op[cur_state][new_state] == HNS_ROCE_CMD_2ERR_QP)
                return hns_roce_cmd_mbox(hr_dev, 0, 0, hr_qp->qpn, 2,
                                         HNS_ROCE_CMD_2ERR_QP,
-                                        HNS_ROCE_CMD_TIME_CLASS_A);
+                                        HNS_ROCE_CMD_TIMEOUT_MSECS);
 
        mailbox = hns_roce_alloc_cmd_mailbox(hr_dev);
        if (IS_ERR(mailbox))
@@ -1886,7 +1886,7 @@ static int hns_roce_v1_qp_modify(struct hns_roce_dev *hr_dev,
 
        ret = hns_roce_cmd_mbox(hr_dev, mailbox->dma, 0, hr_qp->qpn, 0,
                                op[cur_state][new_state],
-                               HNS_ROCE_CMD_TIME_CLASS_C);
+                               HNS_ROCE_CMD_TIMEOUT_MSECS);
 
        hns_roce_free_cmd_mailbox(hr_dev, mailbox);
        return ret;
@@ -2681,7 +2681,7 @@ static int hns_roce_v1_query_qpc(struct hns_roce_dev *hr_dev,
 
        ret = hns_roce_cmd_mbox(hr_dev, 0, mailbox->dma, hr_qp->qpn, 0,
                                HNS_ROCE_CMD_QUERY_QP,
-                               HNS_ROCE_CMD_TIME_CLASS_A);
+                               HNS_ROCE_CMD_TIMEOUT_MSECS);
        if (!ret)
                memcpy(hr_context, mailbox->buf, sizeof(*hr_context));
        else
index d87d189..a5bd645 100644 (file)
@@ -53,7 +53,7 @@ static int hns_roce_sw2hw_mpt(struct hns_roce_dev *hr_dev,
 {
        return hns_roce_cmd_mbox(hr_dev, mailbox->dma, 0, mpt_index, 0,
                                 HNS_ROCE_CMD_SW2HW_MPT,
-                                HNS_ROCE_CMD_TIME_CLASS_B);
+                                HNS_ROCE_CMD_TIMEOUT_MSECS);
 }
 
 static int hns_roce_hw2sw_mpt(struct hns_roce_dev *hr_dev,
@@ -62,7 +62,7 @@ static int hns_roce_hw2sw_mpt(struct hns_roce_dev *hr_dev,
 {
        return hns_roce_cmd_mbox(hr_dev, 0, mailbox ? mailbox->dma : 0,
                                 mpt_index, !mailbox, HNS_ROCE_CMD_HW2SW_MPT,
-                                HNS_ROCE_CMD_TIME_CLASS_B);
+                                HNS_ROCE_CMD_TIMEOUT_MSECS);
 }
 
 static int hns_roce_buddy_alloc(struct hns_roce_buddy *buddy, int order,