From 9ebd155ffe238a1a093aee538369ce8d3080451a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Piotr=20Wo=CC=81jcik?= <3044353+pwojcikdev@users.noreply.github.com> Date: Tue, 26 Nov 2024 19:57:28 +0100 Subject: [PATCH] Early return if target rollback count reached --- nano/node/bounded_backlog.cpp | 10 ++++++++-- nano/node/bounded_backlog.hpp | 2 +- 2 files changed, 9 insertions(+), 3 deletions(-) diff --git a/nano/node/bounded_backlog.cpp b/nano/node/bounded_backlog.cpp index 8140c8d7f4..5a04e65084 100644 --- a/nano/node/bounded_backlog.cpp +++ b/nano/node/bounded_backlog.cpp @@ -228,7 +228,7 @@ void nano::bounded_backlog::run () lock.unlock (); stats.add (nano::stat::type::bounded_backlog, nano::stat::detail::gathered_targets, targets.size ()); - auto processed = perform_rollbacks (targets); + auto processed = perform_rollbacks (targets, target_count); lock.lock (); @@ -285,7 +285,7 @@ bool nano::bounded_backlog::should_rollback (nano::block_hash const & hash) cons return true; } -std::deque nano::bounded_backlog::perform_rollbacks (std::deque const & targets) +std::deque nano::bounded_backlog::perform_rollbacks (std::deque const & targets, size_t max_rollbacks) { stats.inc (nano::stat::type::bounded_backlog, nano::stat::detail::performing_rollbacks); @@ -320,6 +320,12 @@ std::deque nano::bounded_backlog::perform_rollbacks (std::dequ // TODO: Calling block_processor's event here is not ideal, but duplicating these events is even worse block_processor.rolled_back.notify (rollback_list, root); }); + + // Return early if we reached the maximum number of rollbacks + if (processed.size () >= max_rollbacks) + { + break; + } } else { diff --git a/nano/node/bounded_backlog.hpp b/nano/node/bounded_backlog.hpp index 179c086622..2d6981c190 100644 --- a/nano/node/bounded_backlog.hpp +++ b/nano/node/bounded_backlog.hpp @@ -135,7 +135,7 @@ class bounded_backlog std::deque gather_targets (size_t max_count) const; bool should_rollback (nano::block_hash const &) const; - std::deque perform_rollbacks (std::deque const & targets); + std::deque perform_rollbacks (std::deque const & targets, size_t max_rollbacks); void run_scan ();