summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDonald Sharp <sharpd@nvidia.com>2025-03-24 14:28:38 -0400
committerMergify <37929162+mergify[bot]@users.noreply.github.com>2025-03-25 07:39:31 +0000
commitdc7ab1dfc68b24031e959ec49eac1cd3bbd19488 (patch)
treeb4446ff541797e663d8a27da60b0d96d60ccc2f6
parentb02ecbff27fd3332b37241392f723ee1b9ff8f26 (diff)
bgpd: Fix holdtime not working properly when busymergify/bp/stable/10.3/pr-18483
Commit: cc9f21da2218d95567eff1501482ce58e6600f54 Modified the bgp_fsm code to dissallow the extension of the hold time when the system is under extremely heavy load. This was a attempt to remove the return code but it was too aggressive and messed up this bit of code. Put the behavior back that was introduced in: d0874d195d0127009a7d9c06920c52c95319eff9 Signed-off-by: Donald Sharp <sharpd@nvidia.com> (cherry picked from commit 9a26a56c5188fd1c95e244932bc17f97b9051935)
-rw-r--r--bgpd/bgp_fsm.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/bgpd/bgp_fsm.c b/bgpd/bgp_fsm.c
index c7a4c6928a..24957204a4 100644
--- a/bgpd/bgp_fsm.c
+++ b/bgpd/bgp_fsm.c
@@ -528,9 +528,11 @@ static void bgp_holdtime_timer(struct event *thread)
frr_with_mutex (&connection->io_mtx) {
inq_count = atomic_load_explicit(&connection->ibuf->count, memory_order_relaxed);
}
- if (inq_count)
+ if (inq_count) {
BGP_TIMER_ON(connection->t_holdtime, bgp_holdtime_timer,
peer->v_holdtime);
+ return;
+ }
EVENT_VAL(thread) = Hold_Timer_expired;
bgp_event(thread); /* bgp_event unlocks peer */