diff options
author | Or Gerlitz <ogerlitz@voltaire.com> | 2008-07-15 02:48:53 -0400 |
---|---|---|
committer | Roland Dreier <rolandd@cisco.com> | 2008-07-15 02:48:53 -0400 |
commit | 64c5e613b9dd34ef1281ed6d22478609667ae36a (patch) | |
tree | ba749c73291bbb98954c08581b93d5bd6a931813 /drivers/infiniband | |
parent | 4ab928f69208d240d3681336f34589e4b151824f (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.c | 1 | ||||
-rw-r--r-- | drivers/infiniband/core/cma.c | 8 |
2 files changed, 6 insertions, 3 deletions
diff --git a/drivers/infiniband/core/addr.c b/drivers/infiniband/core/addr.c index e4eb8be3bb0c..09a2bec7fd32 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 | } |
110 | EXPORT_SYMBOL(rdma_copy_addr); | 111 | EXPORT_SYMBOL(rdma_copy_addr); |
diff --git a/drivers/infiniband/core/cma.c b/drivers/infiniband/core/cma.c index 44d190f67810..5fb506a41776 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; |