Skip to content

Commit 783793b

Browse files
paravmellanoxjgunthorpe
authored andcommitted
RDMA/core: Use common code flow for IPv4/6 for addr resolve
Use common code flow for resolving neighbour and for finding source addresses. Signed-off-by: Parav Pandit <parav@mellanox.com> Reviewed-by: Daniel Jurgens <danielj@mellanox.com> Signed-off-by: Leon Romanovsky <leonro@mellanox.com> Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
1 parent 77addc5 commit 783793b

File tree

1 file changed

+15
-17
lines changed

1 file changed

+15
-17
lines changed

drivers/infiniband/core/addr.c

Lines changed: 15 additions & 17 deletions
Original file line numberDiff line numberDiff line change
@@ -500,8 +500,8 @@ static int addr_resolve(struct sockaddr *src_in,
500500
bool resolve_neigh,
501501
u32 seq)
502502
{
503+
struct dst_entry *dst = NULL;
503504
struct rtable *rt = NULL;
504-
struct dst_entry *dst;
505505
int ret;
506506

507507
if (!addr->net) {
@@ -510,28 +510,26 @@ static int addr_resolve(struct sockaddr *src_in,
510510
}
511511

512512
if (src_in->sa_family == AF_INET) {
513-
514513
ret = addr4_resolve(src_in, dst_in, addr, &rt);
515-
if (ret)
516-
return ret;
517-
518-
ret = rdma_set_src_addr(&rt->dst, dst_in, addr);
519-
if (!ret && resolve_neigh)
520-
ret = addr_resolve_neigh(&rt->dst, dst_in, addr, seq);
521-
522-
ip_rt_put(rt);
514+
dst = &rt->dst;
523515
} else {
524516
ret = addr6_resolve(src_in, dst_in, addr, &dst);
525-
if (ret)
526-
return ret;
517+
}
518+
if (ret)
519+
return ret;
527520

528-
ret = rdma_set_src_addr(dst, dst_in, addr);
529-
if (!ret && resolve_neigh)
530-
ret = addr_resolve_neigh(dst, dst_in, addr, seq);
521+
ret = rdma_set_src_addr(dst, dst_in, addr);
522+
/*
523+
* Resolve neighbor destination address if requested and
524+
* only if src addr translation didn't fail.
525+
*/
526+
if (!ret && resolve_neigh)
527+
ret = addr_resolve_neigh(dst, dst_in, addr, seq);
531528

529+
if (src_in->sa_family == AF_INET)
530+
ip_rt_put(rt);
531+
else
532532
dst_release(dst);
533-
}
534-
535533
return ret;
536534
}
537535

0 commit comments

Comments
 (0)