From bb47181d0b577b0193c4ef5db677154997539f05 Mon Sep 17 00:00:00 2001 From: UdjinM6 Date: Sun, 17 Dec 2023 22:39:48 +0300 Subject: [PATCH] refactor: add and use `max_cycles()` helper --- src/llmq/quorums.cpp | 5 ++--- src/llmq/utils.h | 8 ++++++-- 2 files changed, 8 insertions(+), 5 deletions(-) diff --git a/src/llmq/quorums.cpp b/src/llmq/quorums.cpp index f55f20434ce6c2..3a5fffb097e31a 100644 --- a/src/llmq/quorums.cpp +++ b/src/llmq/quorums.cpp @@ -535,12 +535,11 @@ std::vector CQuorumManager::ScanQuorums(Consensus::LLMQType llmqTyp for (const auto& llmq : Params().GetConsensus().llmqs) { // NOTE: We store it for each block hash in the DKG mining phase here // and not for a single quorum hash per quorum like we do for other caches. - // And we only do this for MAX_CYCLES of the most recent quorums + // And we only do this for max_cycles() of the most recent quorums // because signing by old quorums requires the exact quorum hash to be specified // and quorum scanning isn't needed there. - const int MAX_CYCLES = llmq.useRotation ? llmq.keepOldConnections / llmq.signingActiveQuorumCount : llmq.keepOldConnections; scanQuorumsCache.emplace(std::piecewise_construct, std::forward_as_tuple(llmq.type), - std::forward_as_tuple(MAX_CYCLES * (llmq.dkgMiningWindowEnd - llmq.dkgMiningWindowStart))); + std::forward_as_tuple(utils::max_cycles(llmq, llmq.keepOldConnections) * (llmq.dkgMiningWindowEnd - llmq.dkgMiningWindowStart))); } } auto& cache = scanQuorumsCache[llmqType]; diff --git a/src/llmq/utils.h b/src/llmq/utils.h index 6f69e3c6155c48..77f95a92dd12a0 100644 --- a/src/llmq/utils.h +++ b/src/llmq/utils.h @@ -119,11 +119,15 @@ void IterateNodesRandom(NodesContainer& nodeStates, Continue&& cont, Callback&& template void InitQuorumsCache(CacheType& cache, bool limit_by_connections = true); +[[ nodiscard ]] static constexpr int max_cycles(const Consensus::LLMQParams& llmqParams, int limit) +{ + return llmqParams.useRotation ? limit / llmqParams.signingActiveQuorumCount : limit; +} + [[ nodiscard ]] static constexpr int max_store_depth(const Consensus::LLMQParams& llmqParams) { // For how many blocks recent DKG info should be kept - const int MAX_CYCLES = llmqParams.useRotation ? llmqParams.keepOldKeys / llmqParams.signingActiveQuorumCount : llmqParams.keepOldKeys; - return MAX_CYCLES * llmqParams.dkgInterval; + return max_cycles(llmqParams, llmqParams.keepOldKeys) * llmqParams.dkgInterval; } } // namespace utils