aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/infiniband
diff options
context:
space:
mode:
authorOr Gerlitz <ogerlitz@voltaire.com>2008-07-15 02:48:53 -0400
committerRoland Dreier <rolandd@cisco.com>2008-07-15 02:48:53 -0400
commit64c5e613b9dd34ef1281ed6d22478609667ae36a (patch)
treeba749c73291bbb98954c08581b93d5bd6a931813 /drivers/infiniband
parent4ab928f69208d240d3681336f34589e4b151824f (diff)
RDMA/addr: Keep pointer to netdevice in struct rdma_dev_addr
Keep a pointer to the local (src) netdevice in struct rdma_dev_addr, and copy it in as part of rdma_copy_addr(). Use rdma_translate_ip() in cma_new_conn_id() to reduce some code duplication and also make sure the src_dev member gets set. In a high-availability configuration the netdevice pointer can be used by the RDMA CM to align RDMA sessions to use the same links as the IP stack does under fail-over and route change cases. Signed-off-by: Or Gerlitz <ogerlitz@voltaire.com> Signed-off-by: Roland Dreier <rolandd@cisco.com>
Diffstat (limited to 'drivers/infiniband')
-rw-r--r--drivers/infiniband/core/addr.c1
-rw-r--r--drivers/infiniband/core/cma.c8
2 files changed, 6 insertions, 3 deletions
diff --git a/drivers/infiniband/core/addr.c b/drivers/infiniband/core/addr.c
index e4eb8be3bb0..09a2bec7fd3 100644
--- a/drivers/infiniband/core/addr.c
+++ b/drivers/infiniband/core/addr.c
@@ -105,6 +105,7 @@ int rdma_copy_addr(struct rdma_dev_addr *dev_addr, struct net_device *dev,
105 memcpy(dev_addr->broadcast, dev->broadcast, MAX_ADDR_LEN); 105 memcpy(dev_addr->broadcast, dev->broadcast, MAX_ADDR_LEN);
106 if (dst_dev_addr) 106 if (dst_dev_addr)
107 memcpy(dev_addr->dst_dev_addr, dst_dev_addr, MAX_ADDR_LEN); 107 memcpy(dev_addr->dst_dev_addr, dst_dev_addr, MAX_ADDR_LEN);
108 dev_addr->src_dev = dev;
108 return 0; 109 return 0;
109} 110}
110EXPORT_SYMBOL(rdma_copy_addr); 111EXPORT_SYMBOL(rdma_copy_addr);
diff --git a/drivers/infiniband/core/cma.c b/drivers/infiniband/core/cma.c
index 44d190f6781..5fb506a4177 100644
--- a/drivers/infiniband/core/cma.c
+++ b/drivers/infiniband/core/cma.c
@@ -1002,6 +1002,7 @@ static struct rdma_id_private *cma_new_conn_id(struct rdma_cm_id *listen_id,
1002 union cma_ip_addr *src, *dst; 1002 union cma_ip_addr *src, *dst;
1003 __be16 port; 1003 __be16 port;
1004 u8 ip_ver; 1004 u8 ip_ver;
1005 int ret;
1005 1006
1006 if (cma_get_net_info(ib_event->private_data, listen_id->ps, 1007 if (cma_get_net_info(ib_event->private_data, listen_id->ps,
1007 &ip_ver, &port, &src, &dst)) 1008 &ip_ver, &port, &src, &dst))
@@ -1026,10 +1027,11 @@ static struct rdma_id_private *cma_new_conn_id(struct rdma_cm_id *listen_id,
1026 if (rt->num_paths == 2) 1027 if (rt->num_paths == 2)
1027 rt->path_rec[1] = *ib_event->param.req_rcvd.alternate_path; 1028 rt->path_rec[1] = *ib_event->param.req_rcvd.alternate_path;
1028 1029
1029 ib_addr_set_sgid(&rt->addr.dev_addr, &rt->path_rec[0].sgid);
1030 ib_addr_set_dgid(&rt->addr.dev_addr, &rt->path_rec[0].dgid); 1030 ib_addr_set_dgid(&rt->addr.dev_addr, &rt->path_rec[0].dgid);
1031 ib_addr_set_pkey(&rt->addr.dev_addr, be16_to_cpu(rt->path_rec[0].pkey)); 1031 ret = rdma_translate_ip(&id->route.addr.src_addr,
1032 rt->addr.dev_addr.dev_type = RDMA_NODE_IB_CA; 1032 &id->route.addr.dev_addr);
1033 if (ret)
1034 goto destroy_id;
1033 1035
1034 id_priv = container_of(id, struct rdma_id_private, id); 1036 id_priv = container_of(id, struct rdma_id_private, id);
1035 id_priv->state = CMA_CONNECT; 1037 id_priv->state = CMA_CONNECT;