diff options
-rw-r--r-- | drivers/infiniband/core/cm.c | 38 |
1 files changed, 24 insertions, 14 deletions
diff --git a/drivers/infiniband/core/cm.c b/drivers/infiniband/core/cm.c index 3fe6f4754fa8..389fecbaf662 100644 --- a/drivers/infiniband/core/cm.c +++ b/drivers/infiniband/core/cm.c | |||
@@ -135,6 +135,7 @@ struct cm_id_private { | |||
135 | __be64 tid; | 135 | __be64 tid; |
136 | __be32 local_qpn; | 136 | __be32 local_qpn; |
137 | __be32 remote_qpn; | 137 | __be32 remote_qpn; |
138 | enum ib_qp_type qp_type; | ||
138 | __be32 sq_psn; | 139 | __be32 sq_psn; |
139 | __be32 rq_psn; | 140 | __be32 rq_psn; |
140 | int timeout_ms; | 141 | int timeout_ms; |
@@ -926,6 +927,7 @@ int ib_send_cm_req(struct ib_cm_id *cm_id, | |||
926 | cm_id_priv->responder_resources = param->responder_resources; | 927 | cm_id_priv->responder_resources = param->responder_resources; |
927 | cm_id_priv->retry_count = param->retry_count; | 928 | cm_id_priv->retry_count = param->retry_count; |
928 | cm_id_priv->path_mtu = param->primary_path->mtu; | 929 | cm_id_priv->path_mtu = param->primary_path->mtu; |
930 | cm_id_priv->qp_type = param->qp_type; | ||
929 | 931 | ||
930 | ret = cm_alloc_msg(cm_id_priv, &cm_id_priv->msg); | 932 | ret = cm_alloc_msg(cm_id_priv, &cm_id_priv->msg); |
931 | if (ret) | 933 | if (ret) |
@@ -1320,6 +1322,7 @@ static int cm_req_handler(struct cm_work *work) | |||
1320 | cm_req_get_primary_local_ack_timeout(req_msg); | 1322 | cm_req_get_primary_local_ack_timeout(req_msg); |
1321 | cm_id_priv->retry_count = cm_req_get_retry_count(req_msg); | 1323 | cm_id_priv->retry_count = cm_req_get_retry_count(req_msg); |
1322 | cm_id_priv->rnr_retry_count = cm_req_get_rnr_retry_count(req_msg); | 1324 | cm_id_priv->rnr_retry_count = cm_req_get_rnr_retry_count(req_msg); |
1325 | cm_id_priv->qp_type = cm_req_get_qp_type(req_msg); | ||
1323 | 1326 | ||
1324 | cm_format_req_event(work, cm_id_priv, &listen_cm_id_priv->id); | 1327 | cm_format_req_event(work, cm_id_priv, &listen_cm_id_priv->id); |
1325 | cm_process_work(cm_id_priv, work); | 1328 | cm_process_work(cm_id_priv, work); |
@@ -3079,10 +3082,10 @@ static int cm_init_qp_init_attr(struct cm_id_private *cm_id_priv, | |||
3079 | case IB_CM_ESTABLISHED: | 3082 | case IB_CM_ESTABLISHED: |
3080 | *qp_attr_mask = IB_QP_STATE | IB_QP_ACCESS_FLAGS | | 3083 | *qp_attr_mask = IB_QP_STATE | IB_QP_ACCESS_FLAGS | |
3081 | IB_QP_PKEY_INDEX | IB_QP_PORT; | 3084 | IB_QP_PKEY_INDEX | IB_QP_PORT; |
3082 | qp_attr->qp_access_flags = IB_ACCESS_LOCAL_WRITE; | 3085 | qp_attr->qp_access_flags = IB_ACCESS_LOCAL_WRITE | |
3086 | IB_ACCESS_REMOTE_WRITE; | ||
3083 | if (cm_id_priv->responder_resources) | 3087 | if (cm_id_priv->responder_resources) |
3084 | qp_attr->qp_access_flags |= IB_ACCESS_REMOTE_WRITE | | 3088 | qp_attr->qp_access_flags |= IB_ACCESS_REMOTE_READ; |
3085 | IB_ACCESS_REMOTE_READ; | ||
3086 | qp_attr->pkey_index = cm_id_priv->av.pkey_index; | 3089 | qp_attr->pkey_index = cm_id_priv->av.pkey_index; |
3087 | qp_attr->port_num = cm_id_priv->av.port->port_num; | 3090 | qp_attr->port_num = cm_id_priv->av.port->port_num; |
3088 | ret = 0; | 3091 | ret = 0; |
@@ -3112,14 +3115,18 @@ static int cm_init_qp_rtr_attr(struct cm_id_private *cm_id_priv, | |||
3112 | case IB_CM_MRA_REP_RCVD: | 3115 | case IB_CM_MRA_REP_RCVD: |
3113 | case IB_CM_ESTABLISHED: | 3116 | case IB_CM_ESTABLISHED: |
3114 | *qp_attr_mask = IB_QP_STATE | IB_QP_AV | IB_QP_PATH_MTU | | 3117 | *qp_attr_mask = IB_QP_STATE | IB_QP_AV | IB_QP_PATH_MTU | |
3115 | IB_QP_DEST_QPN | IB_QP_RQ_PSN | | 3118 | IB_QP_DEST_QPN | IB_QP_RQ_PSN; |
3116 | IB_QP_MAX_DEST_RD_ATOMIC | IB_QP_MIN_RNR_TIMER; | ||
3117 | qp_attr->ah_attr = cm_id_priv->av.ah_attr; | 3119 | qp_attr->ah_attr = cm_id_priv->av.ah_attr; |
3118 | qp_attr->path_mtu = cm_id_priv->path_mtu; | 3120 | qp_attr->path_mtu = cm_id_priv->path_mtu; |
3119 | qp_attr->dest_qp_num = be32_to_cpu(cm_id_priv->remote_qpn); | 3121 | qp_attr->dest_qp_num = be32_to_cpu(cm_id_priv->remote_qpn); |
3120 | qp_attr->rq_psn = be32_to_cpu(cm_id_priv->rq_psn); | 3122 | qp_attr->rq_psn = be32_to_cpu(cm_id_priv->rq_psn); |
3121 | qp_attr->max_dest_rd_atomic = cm_id_priv->responder_resources; | 3123 | if (cm_id_priv->qp_type == IB_QPT_RC) { |
3122 | qp_attr->min_rnr_timer = 0; | 3124 | *qp_attr_mask |= IB_QP_MAX_DEST_RD_ATOMIC | |
3125 | IB_QP_MIN_RNR_TIMER; | ||
3126 | qp_attr->max_dest_rd_atomic = | ||
3127 | cm_id_priv->responder_resources; | ||
3128 | qp_attr->min_rnr_timer = 0; | ||
3129 | } | ||
3123 | if (cm_id_priv->alt_av.ah_attr.dlid) { | 3130 | if (cm_id_priv->alt_av.ah_attr.dlid) { |
3124 | *qp_attr_mask |= IB_QP_ALT_PATH; | 3131 | *qp_attr_mask |= IB_QP_ALT_PATH; |
3125 | qp_attr->alt_ah_attr = cm_id_priv->alt_av.ah_attr; | 3132 | qp_attr->alt_ah_attr = cm_id_priv->alt_av.ah_attr; |
@@ -3148,14 +3155,17 @@ static int cm_init_qp_rts_attr(struct cm_id_private *cm_id_priv, | |||
3148 | case IB_CM_REP_SENT: | 3155 | case IB_CM_REP_SENT: |
3149 | case IB_CM_MRA_REP_RCVD: | 3156 | case IB_CM_MRA_REP_RCVD: |
3150 | case IB_CM_ESTABLISHED: | 3157 | case IB_CM_ESTABLISHED: |
3151 | *qp_attr_mask = IB_QP_STATE | IB_QP_TIMEOUT | IB_QP_RETRY_CNT | | 3158 | *qp_attr_mask = IB_QP_STATE | IB_QP_SQ_PSN; |
3152 | IB_QP_RNR_RETRY | IB_QP_SQ_PSN | | ||
3153 | IB_QP_MAX_QP_RD_ATOMIC; | ||
3154 | qp_attr->timeout = cm_id_priv->local_ack_timeout; | ||
3155 | qp_attr->retry_cnt = cm_id_priv->retry_count; | ||
3156 | qp_attr->rnr_retry = cm_id_priv->rnr_retry_count; | ||
3157 | qp_attr->sq_psn = be32_to_cpu(cm_id_priv->sq_psn); | 3159 | qp_attr->sq_psn = be32_to_cpu(cm_id_priv->sq_psn); |
3158 | qp_attr->max_rd_atomic = cm_id_priv->initiator_depth; | 3160 | if (cm_id_priv->qp_type == IB_QPT_RC) { |
3161 | *qp_attr_mask |= IB_QP_TIMEOUT | IB_QP_RETRY_CNT | | ||
3162 | IB_QP_RNR_RETRY | | ||
3163 | IB_QP_MAX_QP_RD_ATOMIC; | ||
3164 | qp_attr->timeout = cm_id_priv->local_ack_timeout; | ||
3165 | qp_attr->retry_cnt = cm_id_priv->retry_count; | ||
3166 | qp_attr->rnr_retry = cm_id_priv->rnr_retry_count; | ||
3167 | qp_attr->max_rd_atomic = cm_id_priv->initiator_depth; | ||
3168 | } | ||
3159 | if (cm_id_priv->alt_av.ah_attr.dlid) { | 3169 | if (cm_id_priv->alt_av.ah_attr.dlid) { |
3160 | *qp_attr_mask |= IB_QP_PATH_MIG_STATE; | 3170 | *qp_attr_mask |= IB_QP_PATH_MIG_STATE; |
3161 | qp_attr->path_mig_state = IB_MIG_REARM; | 3171 | qp_attr->path_mig_state = IB_MIG_REARM; |