summaryrefslogtreecommitdiff
path: root/pimd/pim_nht.c
diff options
context:
space:
mode:
authorSarita Patra <saritap@vmware.com>2022-10-18 16:27:14 -0700
committerSarita Patra <saritap@vmware.com>2023-02-24 04:40:38 -0800
commitae5bcac0aee80d99d2fd2adba75733d86d36226f (patch)
treea1ecf026d121b268b1d522a6694506a6bd3acfbf /pimd/pim_nht.c
parent2c6a32f9be3c687fe5c52d055f21912da8364ec6 (diff)
pimd, pim6d: Fix RP Unknown IIF
When route to RP is having nexthop secndary address, neighborship is built with primary address, then pim_neighbor_find() fails, which causes RP IIF Unknown. Fix: Verify pim neighborship on the RP connected interface. Issue: #11526 Signed-off-by: Sarita Patra <saritap@vmware.com>
Diffstat (limited to 'pimd/pim_nht.c')
-rw-r--r--pimd/pim_nht.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/pimd/pim_nht.c b/pimd/pim_nht.c
index ac8445e4ff..d164e7ed81 100644
--- a/pimd/pim_nht.c
+++ b/pimd/pim_nht.c
@@ -561,7 +561,7 @@ static int pim_ecmp_nexthop_search(struct pim_instance *pim,
src)) {
nbr = pim_neighbor_find(
nexthop->interface,
- nexthop->mrib_nexthop_addr);
+ nexthop->mrib_nexthop_addr, true);
if (!nbr
&& !if_is_loopback(nexthop->interface)) {
if (PIM_DEBUG_PIM_NHT)
@@ -603,7 +603,7 @@ static int pim_ecmp_nexthop_search(struct pim_instance *pim,
#else
pim_addr nhaddr = nh_node->gate.ipv6;
#endif
- nbrs[i] = pim_neighbor_find(ifps[i], nhaddr);
+ nbrs[i] = pim_neighbor_find(ifps[i], nhaddr, true);
if (nbrs[i] || pim_if_connected_to_source(ifps[i], src))
num_nbrs++;
}
@@ -954,7 +954,8 @@ int pim_ecmp_nexthop_lookup(struct pim_instance *pim,
pim->vrf->vrf_id);
if (ifps[i]) {
nbrs[i] = pim_neighbor_find(
- ifps[i], nexthop_tab[i].nexthop_addr);
+ ifps[i], nexthop_tab[i].nexthop_addr, true);
+
if (nbrs[i] || pim_if_connected_to_source(ifps[i], src))
num_nbrs++;
}