diff options
| author | Donald Sharp <sharpd@nvidia.com> | 2023-12-11 10:46:53 -0500 | 
|---|---|---|
| committer | Donald Sharp <sharpd@nvidia.com> | 2023-12-12 13:48:10 -0500 | 
| commit | bdb5ae8bce94432eb5e581f04f48dc4aa5db7ca4 (patch) | |
| tree | b6e69610e816dc9c162e37f9eae02415c2a06da8 /bgpd/bgp_fsm.c | |
| parent | 315262cab3fd7bed9c93cf3e01fb4e45893c4232 (diff) | |
bgpd: Make `suppress-fib-pending` clear peering
When a peer has come up and already started installing
routes into the rib and `suppress-fib-pending` is either
turned on or off.  BGP is left with some routes that
may need to be withdrawn from peers and routes that
it does not know the status of.  Clear the BGP peers
for the interesting parties and let's let us come
up to speed as needed.
Signed-off-by: Donald Sharp <sharpd@nvidia.com>
Diffstat (limited to 'bgpd/bgp_fsm.c')
| -rw-r--r-- | bgpd/bgp_fsm.c | 75 | 
1 files changed, 39 insertions, 36 deletions
diff --git a/bgpd/bgp_fsm.c b/bgpd/bgp_fsm.c index caa1131397..3959a47279 100644 --- a/bgpd/bgp_fsm.c +++ b/bgpd/bgp_fsm.c @@ -562,42 +562,45 @@ void bgp_delayopen_timer(struct event *thread)  }  /* BGP Peer Down Cause */ -const char *const peer_down_str[] = {"", -				     "Router ID changed", -				     "Remote AS changed", -				     "Local AS change", -				     "Cluster ID changed", -				     "Confederation identifier changed", -				     "Confederation peer changed", -				     "RR client config change", -				     "RS client config change", -				     "Update source change", -				     "Address family activated", -				     "Admin. shutdown", -				     "User reset", -				     "BGP Notification received", -				     "BGP Notification send", -				     "Peer closed the session", -				     "Neighbor deleted", -				     "Peer-group add member", -				     "Peer-group delete member", -				     "Capability changed", -				     "Passive config change", -				     "Multihop config change", -				     "NSF peer closed the session", -				     "Intf peering v6only config change", -				     "BFD down received", -				     "Interface down", -				     "Neighbor address lost", -				     "No path to specified Neighbor", -				     "Waiting for Peer IPv6 LLA", -				     "Waiting for VRF to be initialized", -				     "No AFI/SAFI activated for peer", -				     "AS Set config change", -				     "Waiting for peer OPEN", -				     "Reached received prefix count", -				     "Socket Error", -				     "Admin. shutdown (RTT)"}; +const char *const peer_down_str[] = { +	"", +	"Router ID changed", +	"Remote AS changed", +	"Local AS change", +	"Cluster ID changed", +	"Confederation identifier changed", +	"Confederation peer changed", +	"RR client config change", +	"RS client config change", +	"Update source change", +	"Address family activated", +	"Admin. shutdown", +	"User reset", +	"BGP Notification received", +	"BGP Notification send", +	"Peer closed the session", +	"Neighbor deleted", +	"Peer-group add member", +	"Peer-group delete member", +	"Capability changed", +	"Passive config change", +	"Multihop config change", +	"NSF peer closed the session", +	"Intf peering v6only config change", +	"BFD down received", +	"Interface down", +	"Neighbor address lost", +	"No path to specified Neighbor", +	"Waiting for Peer IPv6 LLA", +	"Waiting for VRF to be initialized", +	"No AFI/SAFI activated for peer", +	"AS Set config change", +	"Waiting for peer OPEN", +	"Reached received prefix count", +	"Socket Error", +	"Admin. shutdown (RTT)", +	"Suppress Fib Turned On or Off", +};  static void bgp_graceful_restart_timer_off(struct peer_connection *connection,  					   struct peer *peer)  | 
