|
@@ -730,14 +730,15 @@ int mthca_modify_qp(struct ib_qp *ibqp, struct ib_qp_attr *attr, int attr_mask)
|
|
}
|
|
}
|
|
|
|
|
|
if (attr_mask & IB_QP_ACCESS_FLAGS) {
|
|
if (attr_mask & IB_QP_ACCESS_FLAGS) {
|
|
|
|
+ qp_context->params2 |=
|
|
|
|
+ cpu_to_be32(attr->qp_access_flags & IB_ACCESS_REMOTE_WRITE ?
|
|
|
|
+ MTHCA_QP_BIT_RWE : 0);
|
|
|
|
+
|
|
/*
|
|
/*
|
|
- * Only enable RDMA/atomics if we have responder
|
|
|
|
- * resources set to a non-zero value.
|
|
|
|
|
|
+ * Only enable RDMA reads and atomics if we have
|
|
|
|
+ * responder resources set to a non-zero value.
|
|
*/
|
|
*/
|
|
if (qp->resp_depth) {
|
|
if (qp->resp_depth) {
|
|
- qp_context->params2 |=
|
|
|
|
- cpu_to_be32(attr->qp_access_flags & IB_ACCESS_REMOTE_WRITE ?
|
|
|
|
- MTHCA_QP_BIT_RWE : 0);
|
|
|
|
qp_context->params2 |=
|
|
qp_context->params2 |=
|
|
cpu_to_be32(attr->qp_access_flags & IB_ACCESS_REMOTE_READ ?
|
|
cpu_to_be32(attr->qp_access_flags & IB_ACCESS_REMOTE_READ ?
|
|
MTHCA_QP_BIT_RRE : 0);
|
|
MTHCA_QP_BIT_RRE : 0);
|
|
@@ -759,22 +760,19 @@ int mthca_modify_qp(struct ib_qp *ibqp, struct ib_qp_attr *attr, int attr_mask)
|
|
if (qp->resp_depth && !attr->max_dest_rd_atomic) {
|
|
if (qp->resp_depth && !attr->max_dest_rd_atomic) {
|
|
/*
|
|
/*
|
|
* Lowering our responder resources to zero.
|
|
* Lowering our responder resources to zero.
|
|
- * Turn off RDMA/atomics as responder.
|
|
|
|
- * (RWE/RRE/RAE in params2 already zero)
|
|
|
|
|
|
+ * Turn off reads RDMA and atomics as responder.
|
|
|
|
+ * (RRE/RAE in params2 already zero)
|
|
*/
|
|
*/
|
|
- qp_param->opt_param_mask |= cpu_to_be32(MTHCA_QP_OPTPAR_RWE |
|
|
|
|
- MTHCA_QP_OPTPAR_RRE |
|
|
|
|
|
|
+ qp_param->opt_param_mask |= cpu_to_be32(MTHCA_QP_OPTPAR_RRE |
|
|
MTHCA_QP_OPTPAR_RAE);
|
|
MTHCA_QP_OPTPAR_RAE);
|
|
}
|
|
}
|
|
|
|
|
|
if (!qp->resp_depth && attr->max_dest_rd_atomic) {
|
|
if (!qp->resp_depth && attr->max_dest_rd_atomic) {
|
|
/*
|
|
/*
|
|
* Increasing our responder resources from
|
|
* Increasing our responder resources from
|
|
- * zero. Turn on RDMA/atomics as appropriate.
|
|
|
|
|
|
+ * zero. Turn on RDMA reads and atomics as
|
|
|
|
+ * appropriate.
|
|
*/
|
|
*/
|
|
- qp_context->params2 |=
|
|
|
|
- cpu_to_be32(qp->atomic_rd_en & IB_ACCESS_REMOTE_WRITE ?
|
|
|
|
- MTHCA_QP_BIT_RWE : 0);
|
|
|
|
qp_context->params2 |=
|
|
qp_context->params2 |=
|
|
cpu_to_be32(qp->atomic_rd_en & IB_ACCESS_REMOTE_READ ?
|
|
cpu_to_be32(qp->atomic_rd_en & IB_ACCESS_REMOTE_READ ?
|
|
MTHCA_QP_BIT_RRE : 0);
|
|
MTHCA_QP_BIT_RRE : 0);
|
|
@@ -782,8 +780,7 @@ int mthca_modify_qp(struct ib_qp *ibqp, struct ib_qp_attr *attr, int attr_mask)
|
|
cpu_to_be32(qp->atomic_rd_en & IB_ACCESS_REMOTE_ATOMIC ?
|
|
cpu_to_be32(qp->atomic_rd_en & IB_ACCESS_REMOTE_ATOMIC ?
|
|
MTHCA_QP_BIT_RAE : 0);
|
|
MTHCA_QP_BIT_RAE : 0);
|
|
|
|
|
|
- qp_param->opt_param_mask |= cpu_to_be32(MTHCA_QP_OPTPAR_RWE |
|
|
|
|
- MTHCA_QP_OPTPAR_RRE |
|
|
|
|
|
|
+ qp_param->opt_param_mask |= cpu_to_be32(MTHCA_QP_OPTPAR_RRE |
|
|
MTHCA_QP_OPTPAR_RAE);
|
|
MTHCA_QP_OPTPAR_RAE);
|
|
}
|
|
}
|
|
|
|
|