Skip to content

Commit

Permalink
RDMA/core: Use common code flow for IPv4/6 for addr resolve
Browse files Browse the repository at this point in the history
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>
  • Loading branch information
Parav Pandit authored and Jason Gunthorpe committed Sep 12, 2018
1 parent 77addc5 commit 783793b
Showing 1 changed file with 15 additions and 17 deletions.
32 changes: 15 additions & 17 deletions drivers/infiniband/core/addr.c
Original file line number Diff line number Diff line change
Expand Up @@ -500,8 +500,8 @@ static int addr_resolve(struct sockaddr *src_in,
bool resolve_neigh,
u32 seq)
{
struct dst_entry *dst = NULL;
struct rtable *rt = NULL;
struct dst_entry *dst;
int ret;

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

if (src_in->sa_family == AF_INET) {

ret = addr4_resolve(src_in, dst_in, addr, &rt);
if (ret)
return ret;

ret = rdma_set_src_addr(&rt->dst, dst_in, addr);
if (!ret && resolve_neigh)
ret = addr_resolve_neigh(&rt->dst, dst_in, addr, seq);

ip_rt_put(rt);
dst = &rt->dst;
} else {
ret = addr6_resolve(src_in, dst_in, addr, &dst);
if (ret)
return ret;
}
if (ret)
return ret;

ret = rdma_set_src_addr(dst, dst_in, addr);
if (!ret && resolve_neigh)
ret = addr_resolve_neigh(dst, dst_in, addr, seq);
ret = rdma_set_src_addr(dst, dst_in, addr);
/*
* Resolve neighbor destination address if requested and
* only if src addr translation didn't fail.
*/
if (!ret && resolve_neigh)
ret = addr_resolve_neigh(dst, dst_in, addr, seq);

if (src_in->sa_family == AF_INET)
ip_rt_put(rt);
else
dst_release(dst);
}

return ret;
}

Expand Down

0 comments on commit 783793b

Please sign in to comment.