mirror of
https://git.proxmox.com/git/mirror_frr
synced 2025-04-30 06:42:17 +00:00
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>
This commit is contained in:
parent
cc54cfee3a
commit
a3d18ce6b0
@ -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. */
|
||||
|
Loading…
Reference in New Issue
Block a user