aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNeale <nranns@cisco.com>2016-06-14 18:44:02 +0100
committerDamjan Marion <damarion@cisco.com>2016-06-15 09:18:26 +0000
commit2a34b9e1a64f65d9f91c027de0d975701f6dceb6 (patch)
treea226d6872cb1f86fcc67c8d45ea655f516fd569f
parent820e363a8d60ec05f1cf18c0c3bf7a200f5a896d (diff)
VPP-137: VPP sends ARP with wrong requested IP
Change-Id: I01802f3dab04c940e65236ba6e680f1e504a0a5f Signed-off-by: Neale <nranns@cisco.com>
-rw-r--r--vpp/api/api.c14
1 files changed, 13 insertions, 1 deletions
diff --git a/vpp/api/api.c b/vpp/api/api.c
index f398e4f9fb1..77635a9d1ff 100644
--- a/vpp/api/api.c
+++ b/vpp/api/api.c
@@ -974,7 +974,18 @@ static int ip4_add_del_route_t_handler (vl_api_ip_add_del_route_t *mp)
}
nh_adj = ip_get_adjacency (lm, ai);
- vec_add1 (add_adj, nh_adj[0]);
+ if (nh_adj->lookup_next_index == IP_LOOKUP_NEXT_ARP &&
+ nh_adj->arp.next_hop.ip4.as_u32 == 0) {
+ /* the next-hop resovles via a glean adj. create and use
+ * a ARP adj for the next-hop */
+ a.adj_index = vnet_arp_glean_add(fib_index, &next_hop_address);
+ a.add_adj = NULL;
+ a.n_add_adj = 0;
+ ip4_add_del_route (im, &a);
+
+ goto done;
+ }
+ vec_add1 (add_adj, nh_adj[0]);
if (mp->lookup_in_vrf) {
p = hash_get (im->fib_index_by_table_id, ntohl(mp->lookup_in_vrf));
if (p)
@@ -1016,6 +1027,7 @@ do_add_del:
vec_free (add_adj);
+done:
dsunlock (sm);
return 0;
}