|
@@ -1110,7 +1110,7 @@ static struct rdma_id_private *cma_new_conn_id(struct rdma_cm_id *listen_id,
|
|
|
if (cma_any_addr((struct sockaddr *) &rt->addr.src_addr)) {
|
|
|
rt->addr.dev_addr.dev_type = ARPHRD_INFINIBAND;
|
|
|
rdma_addr_set_sgid(&rt->addr.dev_addr, &rt->path_rec[0].sgid);
|
|
|
- ib_addr_set_pkey(&rt->addr.dev_addr, rt->path_rec[0].pkey);
|
|
|
+ ib_addr_set_pkey(&rt->addr.dev_addr, be16_to_cpu(rt->path_rec[0].pkey));
|
|
|
} else {
|
|
|
ret = rdma_translate_ip((struct sockaddr *) &rt->addr.src_addr,
|
|
|
&rt->addr.dev_addr);
|
|
@@ -2926,7 +2926,7 @@ static int cma_ib_mc_handler(int status, struct ib_sa_multicast *multicast)
|
|
|
mutex_lock(&id_priv->qp_mutex);
|
|
|
if (!status && id_priv->id.qp)
|
|
|
status = ib_attach_mcast(id_priv->id.qp, &multicast->rec.mgid,
|
|
|
- multicast->rec.mlid);
|
|
|
+ be16_to_cpu(multicast->rec.mlid));
|
|
|
mutex_unlock(&id_priv->qp_mutex);
|
|
|
|
|
|
memset(&event, 0, sizeof event);
|
|
@@ -3187,7 +3187,7 @@ void rdma_leave_multicast(struct rdma_cm_id *id, struct sockaddr *addr)
|
|
|
if (id->qp)
|
|
|
ib_detach_mcast(id->qp,
|
|
|
&mc->multicast.ib->rec.mgid,
|
|
|
- mc->multicast.ib->rec.mlid);
|
|
|
+ be16_to_cpu(mc->multicast.ib->rec.mlid));
|
|
|
if (rdma_node_get_transport(id_priv->cma_dev->device->node_type) == RDMA_TRANSPORT_IB) {
|
|
|
switch (rdma_port_get_link_layer(id->device, id->port_num)) {
|
|
|
case IB_LINK_LAYER_INFINIBAND:
|