summaryrefslogtreecommitdiff
path: root/zebra/zebra_rib.c
diff options
context:
space:
mode:
authorRenato Westphal <renato@opensourcerouting.org>2017-08-31 17:28:05 -0300
committerRenato Westphal <renato@opensourcerouting.org>2017-08-31 22:13:14 -0300
commita3d18ce6b0810ad91e3d99bcb86e56cb6d6903a0 (patch)
tree923fa888e294535dc751c8bec15c602811eae380 /zebra/zebra_rib.c
parentcc54cfee3a67aa0192c62736cd567b562bb5597b (diff)
zebra: fix detection of duplicate system routes
Fixes the following bugs: 1) % ip -6 route add 5000::/64 via 3000::2 % ip -6 route replace 5000::/64 via 3000::2 % ip -6 route replace 5000::/64 via 3000::2 % ip -6 route replace 5000::/64 via 3000::2 % ip -6 route replace 5000::/64 via 3000::2 % % vtysh -c "show ipv6 route" [snip] K * 5000::/64 [0/1024] via 3000::2, rt1-eth0 K * 5000::/64 [0/1024] via 3000::2, rt1-eth0 K * 5000::/64 [0/1024] via 3000::2, rt1-eth0 K * 5000::/64 [0/1024] via 3000::2, rt1-eth0 K>* 5000::/64 [0/1024] via 3000::2, rt1-eth0 2) % ip -6 route add 7000::/64 via 3000::2 % ip -6 route replace 7000::/64 via 3000::3 % ip -6 ro | grep 7000 7000::/64 via 3000::3 dev rt1-eth0 metric 1024 pref medium % % vtysh -c "show ipv6 route" [snip] K * 7000::/64 [0/1024] via 3000::3, rt1-eth0 K>* 7000::/64 [0/1024] via 3000::2, rt1-eth0 NOTE: the check for ROUTE_ENTRY_REMOVED was redundant as it was already performed at the beginning of the loop. Signed-off-by: Renato Westphal <renato@opensourcerouting.org>
Diffstat (limited to 'zebra/zebra_rib.c')
-rw-r--r--zebra/zebra_rib.c9
1 files changed, 4 insertions, 5 deletions
diff --git a/zebra/zebra_rib.c b/zebra/zebra_rib.c
index c9e770e204..59b693435d 100644
--- a/zebra/zebra_rib.c
+++ b/zebra/zebra_rib.c
@@ -2469,12 +2469,11 @@ int rib_add(afi_t afi, safi_t safi, vrf_id_t vrf_id, int type, u_short instance,
break;
}
/* Duplicate system route comes in. */
- else if ((rtnh = re->nexthop)
- && rtnh->type == NEXTHOP_TYPE_IFINDEX
- && rtnh->ifindex == nh->ifindex
- && !CHECK_FLAG(re->status, ROUTE_ENTRY_REMOVED)) {
+ rtnh = re->nexthop;
+ if (nexthop_same_no_recurse(rtnh, nh))
return 0;
- }
+ else
+ same = re;
}
/* Allocate new re structure. */