diff options
Diffstat (limited to 'drivers/infiniband')
-rw-r--r-- | drivers/infiniband/core/addr.c | 12 | ||||
-rw-r--r-- | drivers/infiniband/core/cma.c | 7 | ||||
-rw-r--r-- | drivers/infiniband/hw/cxgb3/iwch_cm.c | 2 |
3 files changed, 11 insertions, 10 deletions
diff --git a/drivers/infiniband/core/addr.c b/drivers/infiniband/core/addr.c index 5381c80de10a..a58ad8a470f9 100644 --- a/drivers/infiniband/core/addr.c +++ b/drivers/infiniband/core/addr.c | |||
@@ -110,7 +110,7 @@ int rdma_translate_ip(struct sockaddr *addr, struct rdma_dev_addr *dev_addr) | |||
110 | __be32 ip = ((struct sockaddr_in *) addr)->sin_addr.s_addr; | 110 | __be32 ip = ((struct sockaddr_in *) addr)->sin_addr.s_addr; |
111 | int ret; | 111 | int ret; |
112 | 112 | ||
113 | dev = ip_dev_find(ip); | 113 | dev = ip_dev_find(&init_net, ip); |
114 | if (!dev) | 114 | if (!dev) |
115 | return -EADDRNOTAVAIL; | 115 | return -EADDRNOTAVAIL; |
116 | 116 | ||
@@ -158,7 +158,7 @@ static void addr_send_arp(struct sockaddr_in *dst_in) | |||
158 | 158 | ||
159 | memset(&fl, 0, sizeof fl); | 159 | memset(&fl, 0, sizeof fl); |
160 | fl.nl_u.ip4_u.daddr = dst_ip; | 160 | fl.nl_u.ip4_u.daddr = dst_ip; |
161 | if (ip_route_output_key(&rt, &fl)) | 161 | if (ip_route_output_key(&init_net, &rt, &fl)) |
162 | return; | 162 | return; |
163 | 163 | ||
164 | neigh_event_send(rt->u.dst.neighbour, NULL); | 164 | neigh_event_send(rt->u.dst.neighbour, NULL); |
@@ -179,7 +179,7 @@ static int addr_resolve_remote(struct sockaddr_in *src_in, | |||
179 | memset(&fl, 0, sizeof fl); | 179 | memset(&fl, 0, sizeof fl); |
180 | fl.nl_u.ip4_u.daddr = dst_ip; | 180 | fl.nl_u.ip4_u.daddr = dst_ip; |
181 | fl.nl_u.ip4_u.saddr = src_ip; | 181 | fl.nl_u.ip4_u.saddr = src_ip; |
182 | ret = ip_route_output_key(&rt, &fl); | 182 | ret = ip_route_output_key(&init_net, &rt, &fl); |
183 | if (ret) | 183 | if (ret) |
184 | goto out; | 184 | goto out; |
185 | 185 | ||
@@ -261,15 +261,15 @@ static int addr_resolve_local(struct sockaddr_in *src_in, | |||
261 | __be32 dst_ip = dst_in->sin_addr.s_addr; | 261 | __be32 dst_ip = dst_in->sin_addr.s_addr; |
262 | int ret; | 262 | int ret; |
263 | 263 | ||
264 | dev = ip_dev_find(dst_ip); | 264 | dev = ip_dev_find(&init_net, dst_ip); |
265 | if (!dev) | 265 | if (!dev) |
266 | return -EADDRNOTAVAIL; | 266 | return -EADDRNOTAVAIL; |
267 | 267 | ||
268 | if (ZERONET(src_ip)) { | 268 | if (ipv4_is_zeronet(src_ip)) { |
269 | src_in->sin_family = dst_in->sin_family; | 269 | src_in->sin_family = dst_in->sin_family; |
270 | src_in->sin_addr.s_addr = dst_ip; | 270 | src_in->sin_addr.s_addr = dst_ip; |
271 | ret = rdma_copy_addr(addr, dev, dev->dev_addr); | 271 | ret = rdma_copy_addr(addr, dev, dev->dev_addr); |
272 | } else if (LOOPBACK(src_ip)) { | 272 | } else if (ipv4_is_loopback(src_ip)) { |
273 | ret = rdma_translate_ip((struct sockaddr *)dst_in, addr); | 273 | ret = rdma_translate_ip((struct sockaddr *)dst_in, addr); |
274 | if (!ret) | 274 | if (!ret) |
275 | memcpy(addr->dst_dev_addr, dev->dev_addr, MAX_ADDR_LEN); | 275 | memcpy(addr->dst_dev_addr, dev->dev_addr, MAX_ADDR_LEN); |
diff --git a/drivers/infiniband/core/cma.c b/drivers/infiniband/core/cma.c index 637efead97a0..1eff1b2c0e08 100644 --- a/drivers/infiniband/core/cma.c +++ b/drivers/infiniband/core/cma.c | |||
@@ -630,7 +630,8 @@ static inline int cma_zero_addr(struct sockaddr *addr) | |||
630 | struct in6_addr *ip6; | 630 | struct in6_addr *ip6; |
631 | 631 | ||
632 | if (addr->sa_family == AF_INET) | 632 | if (addr->sa_family == AF_INET) |
633 | return ZERONET(((struct sockaddr_in *) addr)->sin_addr.s_addr); | 633 | return ipv4_is_zeronet( |
634 | ((struct sockaddr_in *)addr)->sin_addr.s_addr); | ||
634 | else { | 635 | else { |
635 | ip6 = &((struct sockaddr_in6 *) addr)->sin6_addr; | 636 | ip6 = &((struct sockaddr_in6 *) addr)->sin6_addr; |
636 | return (ip6->s6_addr32[0] | ip6->s6_addr32[1] | | 637 | return (ip6->s6_addr32[0] | ip6->s6_addr32[1] | |
@@ -640,7 +641,7 @@ static inline int cma_zero_addr(struct sockaddr *addr) | |||
640 | 641 | ||
641 | static inline int cma_loopback_addr(struct sockaddr *addr) | 642 | static inline int cma_loopback_addr(struct sockaddr *addr) |
642 | { | 643 | { |
643 | return LOOPBACK(((struct sockaddr_in *) addr)->sin_addr.s_addr); | 644 | return ipv4_is_loopback(((struct sockaddr_in *) addr)->sin_addr.s_addr); |
644 | } | 645 | } |
645 | 646 | ||
646 | static inline int cma_any_addr(struct sockaddr *addr) | 647 | static inline int cma_any_addr(struct sockaddr *addr) |
@@ -1288,7 +1289,7 @@ static int iw_conn_req_handler(struct iw_cm_id *cm_id, | |||
1288 | atomic_inc(&conn_id->dev_remove); | 1289 | atomic_inc(&conn_id->dev_remove); |
1289 | conn_id->state = CMA_CONNECT; | 1290 | conn_id->state = CMA_CONNECT; |
1290 | 1291 | ||
1291 | dev = ip_dev_find(iw_event->local_addr.sin_addr.s_addr); | 1292 | dev = ip_dev_find(&init_net, iw_event->local_addr.sin_addr.s_addr); |
1292 | if (!dev) { | 1293 | if (!dev) { |
1293 | ret = -EADDRNOTAVAIL; | 1294 | ret = -EADDRNOTAVAIL; |
1294 | cma_enable_remove(conn_id); | 1295 | cma_enable_remove(conn_id); |
diff --git a/drivers/infiniband/hw/cxgb3/iwch_cm.c b/drivers/infiniband/hw/cxgb3/iwch_cm.c index f8cb0fe748c3..e9a08fa3dffe 100644 --- a/drivers/infiniband/hw/cxgb3/iwch_cm.c +++ b/drivers/infiniband/hw/cxgb3/iwch_cm.c | |||
@@ -332,7 +332,7 @@ static struct rtable *find_route(struct t3cdev *dev, __be32 local_ip, | |||
332 | } | 332 | } |
333 | }; | 333 | }; |
334 | 334 | ||
335 | if (ip_route_output_flow(&rt, &fl, NULL, 0)) | 335 | if (ip_route_output_flow(&init_net, &rt, &fl, NULL, 0)) |
336 | return NULL; | 336 | return NULL; |
337 | return rt; | 337 | return rt; |
338 | } | 338 | } |