From d513c1f908492cf35666914274594a6696763ee5 Mon Sep 17 00:00:00 2001 From: Konstantin Akimov Date: Fri, 29 Sep 2023 00:33:32 +0700 Subject: [PATCH 1/7] fix: possible assert call if nHeight in CDeterministicMNListDiff is higher than Tip Example of new log: ``` 2023-09-28T17:35:50Z GetProjectedMNPayeesAtChainTip WARNING pindex is nullptr due to height=914160 chain height=914159 ``` instead assert call: ``` ... #6 0x00007ffff7a33b86 in __assert_fail (assertion=0x55555783afd2 "pindex", file=0x5555577f2ed8 "llmq/utils.cpp", line=730, function=0x5555577f2448 "bool llmq::utils::IsMNRewardReallocationActive(const CBlockIndex*)") at ./assert/assert.c:101 #7 0x0000555555ab7daf in llmq::utils::IsMNRewardReallocationActive (pindex=) at llmq/utils.cpp:730 #8 0x00005555559458ad in CDeterministicMNList::GetProjectedMNPayees (this=this@entry=0x7fffffffc690, pindex=0x0, nCount=, nCount@entry=2147483647) at evo/deterministicmns.cpp:231 #9 0x000055555594614f in CDeterministicMNList::GetProjectedMNPayeesAtChainTip (this=this@entry=0x7fffffffc690, nCount=nCount@entry=2147483647) at evo/deterministicmns.cpp:216 #10 0x00005555558c9f51 in MasternodeList::updateDIP3List (this=this@entry=0x55555908cfd0) at qt/masternodelist.cpp:194 #11 0x00005555558ca9a0 in MasternodeList::updateDIP3ListScheduled (this=0x55555908cfd0) at qt/masternodelist.cpp:157 #12 0x000055555684a60f in void doActivate(QObject*, int, void**) () #13 0x00005555568525b1 in QTimer::timerEvent(QTimerEvent*) () #14 0x0000555556844ce5 in QObject::event(QEvent*) () #15 0x0000555556ac3252 in QApplicationPrivate::notify_helper(QObject*, QEvent*) () #16 0x000055555681e6b8 in QCoreApplication::sendEvent(QObject*, QEvent*) () #17 0x000055555686de2a in QTimerInfoList::activateTimers() () #18 0x000055555686be84 in QEventDispatcherUNIX::processEvents(QFlags) () #19 0x00005555569bf8a2 in QXcbUnixEventDispatcher::processEvents(QFlags) () #20 0x000055555681caf6 in QEventLoop::exec(QFlags) () #21 0x0000555556825f8a in QCoreApplication::exec() () ... ``` --- src/evo/deterministicmns.cpp | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/src/evo/deterministicmns.cpp b/src/evo/deterministicmns.cpp index ad0e01b7ba5fb..28884326473b7 100644 --- a/src/evo/deterministicmns.cpp +++ b/src/evo/deterministicmns.cpp @@ -213,7 +213,12 @@ CDeterministicMNCPtr CDeterministicMNList::GetMNPayee(const CBlockIndex* pIndex) std::vector CDeterministicMNList::GetProjectedMNPayeesAtChainTip(int nCount) const { - return GetProjectedMNPayees(::ChainActive()[nHeight], nCount); + const CBlockIndex* const pindex = ::ChainActive()[nHeight]; + if (pindex == nullptr) { + LogPrintf("GetProjectedMNPayeesAtChainTip WARNING pindex is nullptr due to height=%lld chain height=%lld\n", nHeight, ::ChainActive().Tip()->nHeight); + return {}; + } + return GetProjectedMNPayees(pindex, nCount); } std::vector CDeterministicMNList::GetProjectedMNPayees(const CBlockIndex* const pindex, int nCount) const From ca61600719638ae4ea55ff8f2327bfca658e65ca Mon Sep 17 00:00:00 2001 From: Konstantin Akimov Date: Fri, 29 Sep 2023 01:09:10 +0700 Subject: [PATCH 2/7] fix: use g_chainman.m_blockman.LookupBlockIndex for any known block (even wrong tip) --- src/evo/deterministicmns.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/evo/deterministicmns.cpp b/src/evo/deterministicmns.cpp index 28884326473b7..486ac707ba606 100644 --- a/src/evo/deterministicmns.cpp +++ b/src/evo/deterministicmns.cpp @@ -213,9 +213,9 @@ CDeterministicMNCPtr CDeterministicMNList::GetMNPayee(const CBlockIndex* pIndex) std::vector CDeterministicMNList::GetProjectedMNPayeesAtChainTip(int nCount) const { - const CBlockIndex* const pindex = ::ChainActive()[nHeight]; + const CBlockIndex* const pindex = WITH_LOCK(::cs_main, return g_chainman.m_blockman.LookupBlockIndex(blockHash)); if (pindex == nullptr) { - LogPrintf("GetProjectedMNPayeesAtChainTip WARNING pindex is nullptr due to height=%lld chain height=%lld\n", nHeight, ::ChainActive().Tip()->nHeight); + LogPrintf("GetProjectedMNPayeesAtChainTip WARNING pindex is nullptr on height=%lld blockhash=%s tip height=%lld tip hash=%s\n", nHeight, blockHash.ToString(), ::ChainActive().Tip()->nHeight, ::ChainActive().Tip()->GetBlockHash().ToString()); return {}; } return GetProjectedMNPayees(pindex, nCount); From 8e63c16ef188a55ee2c5085c31e4293629275939 Mon Sep 17 00:00:00 2001 From: UdjinM6 Date: Sat, 21 Oct 2023 16:45:42 +0300 Subject: [PATCH 3/7] fix: handle GetProjectedMNPayees's failures in `MasternodeList::updateDIP3List()` --- src/qt/masternodelist.cpp | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/src/qt/masternodelist.cpp b/src/qt/masternodelist.cpp index 7ceca4aaafa6d..790b9d7ccb06f 100644 --- a/src/qt/masternodelist.cpp +++ b/src/qt/masternodelist.cpp @@ -167,6 +167,14 @@ void MasternodeList::updateDIP3List() } auto mnList = clientModel->getMasternodeList(); + auto projectedPayees = mnList.GetProjectedMNPayeesAtChainTip(); + + if (projectedPayees.empty() && mnList.GetValidMNsCount() > 0) { + // GetProjectedMNPayees failed to provide results for a list with valid mns. + // Keep current list and let it try again later. + return; + } + std::map mapCollateralDests; { @@ -191,7 +199,6 @@ void MasternodeList::updateDIP3List() nTimeUpdatedDIP3 = GetTime(); - auto projectedPayees = mnList.GetProjectedMNPayeesAtChainTip(); std::map nextPayments; for (size_t i = 0; i < projectedPayees.size(); i++) { const auto& dmn = projectedPayees[i]; From 2ca24de7a7168064e8237c45e7fb8efcd3b5f732 Mon Sep 17 00:00:00 2001 From: UdjinM6 Date: Sat, 21 Oct 2023 16:47:41 +0300 Subject: [PATCH 4/7] fix: resulting vector in GetProjectedMNPayees grows to the weighted count, should reserve memory accordingly --- src/evo/deterministicmns.cpp | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/src/evo/deterministicmns.cpp b/src/evo/deterministicmns.cpp index 486ac707ba606..6e73009fb6ee0 100644 --- a/src/evo/deterministicmns.cpp +++ b/src/evo/deterministicmns.cpp @@ -226,10 +226,11 @@ std::vector CDeterministicMNList::GetProjectedMNPayees(con if (nCount < 0 ) { return {}; } - nCount = std::min(nCount, int(GetValidWeightedMNsCount())); + const auto weighted_count = GetValidWeightedMNsCount(); + nCount = std::min(nCount, int(weighted_count)); std::vector result; - result.reserve(nCount); + result.reserve(weighted_count); auto remaining_evo_payments = 0; CDeterministicMNCPtr evo_to_be_skipped = nullptr; From 660a5ca6577925e8e558c6e1376474408c171b49 Mon Sep 17 00:00:00 2001 From: UdjinM6 Date: Sat, 21 Oct 2023 22:15:44 +0300 Subject: [PATCH 5/7] fix: avoid useless loop in GetProjectedMNPayees after mn_rr activation --- src/evo/deterministicmns.cpp | 31 ++++++++++++++++--------------- 1 file changed, 16 insertions(+), 15 deletions(-) diff --git a/src/evo/deterministicmns.cpp b/src/evo/deterministicmns.cpp index 6e73009fb6ee0..37ff1a11ca268 100644 --- a/src/evo/deterministicmns.cpp +++ b/src/evo/deterministicmns.cpp @@ -232,23 +232,24 @@ std::vector CDeterministicMNList::GetProjectedMNPayees(con std::vector result; result.reserve(weighted_count); - auto remaining_evo_payments = 0; - CDeterministicMNCPtr evo_to_be_skipped = nullptr; - bool isMNRewardReallocation = llmq::utils::IsMNRewardReallocationActive(pindex); - ForEachMNShared(true, [&](const CDeterministicMNCPtr& dmn) { - if (dmn->pdmnState->nLastPaidHeight == nHeight) { - // We found the last MN Payee. - // If the last payee is an EvoNode, we need to check its consecutive payments and pay him again if needed - if (!isMNRewardReallocation && dmn->nType == MnType::Evo && dmn->pdmnState->nConsecutivePayments < dmn_types::Evo.voting_weight) { - remaining_evo_payments = dmn_types::Evo.voting_weight - dmn->pdmnState->nConsecutivePayments; - for ([[maybe_unused]] auto _ : irange::range(remaining_evo_payments)) { - result.emplace_back(dmn); - evo_to_be_skipped = dmn; + int remaining_evo_payments{0}; + CDeterministicMNCPtr evo_to_be_skipped{nullptr}; + const bool isMNRewardReallocation = llmq::utils::IsMNRewardReallocationActive(pindex); + if (!isMNRewardReallocation) { + ForEachMNShared(true, [&](const CDeterministicMNCPtr& dmn) { + if (dmn->pdmnState->nLastPaidHeight == nHeight) { + // We found the last MN Payee. + // If the last payee is an EvoNode, we need to check its consecutive payments and pay him again if needed + if (dmn->nType == MnType::Evo && dmn->pdmnState->nConsecutivePayments < dmn_types::Evo.voting_weight) { + remaining_evo_payments = dmn_types::Evo.voting_weight - dmn->pdmnState->nConsecutivePayments; + for ([[maybe_unused]] auto _ : irange::range(remaining_evo_payments)) { + result.emplace_back(dmn); + evo_to_be_skipped = dmn; + } } } - } - return; - }); + }); + } ForEachMNShared(true, [&](const CDeterministicMNCPtr& dmn) { if (dmn == evo_to_be_skipped) return; From e258c36e0e34637dc21a280fb064e084357c783d Mon Sep 17 00:00:00 2001 From: Konstantin Akimov Date: Thu, 26 Oct 2023 19:45:38 +0700 Subject: [PATCH 6/7] fix: pass proper CBlockIndex from ClientModel --- src/evo/deterministicmns.cpp | 14 ++------------ src/evo/deterministicmns.h | 1 - src/governance/governance.cpp | 6 ++++-- src/interfaces/node.h | 6 ++++-- src/node/interfaces.cpp | 13 +++++++++---- src/qt/clientmodel.cpp | 17 ++++++++++------- src/qt/clientmodel.h | 5 +++-- src/qt/governancelist.cpp | 2 +- src/qt/masternodelist.cpp | 7 +++---- src/qt/rpcconsole.cpp | 4 ++-- src/rpc/masternode.cpp | 5 +++-- src/ui_interface.cpp | 2 +- src/ui_interface.h | 2 +- 13 files changed, 43 insertions(+), 41 deletions(-) diff --git a/src/evo/deterministicmns.cpp b/src/evo/deterministicmns.cpp index 37ff1a11ca268..af35c02f538e0 100644 --- a/src/evo/deterministicmns.cpp +++ b/src/evo/deterministicmns.cpp @@ -211,16 +211,6 @@ CDeterministicMNCPtr CDeterministicMNList::GetMNPayee(const CBlockIndex* pIndex) return best; } -std::vector CDeterministicMNList::GetProjectedMNPayeesAtChainTip(int nCount) const -{ - const CBlockIndex* const pindex = WITH_LOCK(::cs_main, return g_chainman.m_blockman.LookupBlockIndex(blockHash)); - if (pindex == nullptr) { - LogPrintf("GetProjectedMNPayeesAtChainTip WARNING pindex is nullptr on height=%lld blockhash=%s tip height=%lld tip hash=%s\n", nHeight, blockHash.ToString(), ::ChainActive().Tip()->nHeight, ::ChainActive().Tip()->GetBlockHash().ToString()); - return {}; - } - return GetProjectedMNPayees(pindex, nCount); -} - std::vector CDeterministicMNList::GetProjectedMNPayees(const CBlockIndex* const pindex, int nCount) const { if (nCount < 0 ) { @@ -637,7 +627,7 @@ bool CDeterministicMNManager::ProcessBlock(const CBlock& block, const CBlockInde // Don't hold cs while calling signals if (diff.HasChanges()) { GetMainSignals().NotifyMasternodeListChanged(false, oldList, diff, connman); - uiInterface.NotifyMasternodeListChanged(newList); + uiInterface.NotifyMasternodeListChanged(newList, pindex); } if (nHeight == consensusParams.DIP0003EnforcementHeight) { @@ -678,7 +668,7 @@ bool CDeterministicMNManager::UndoBlock(const CBlockIndex* pindex) if (diff.HasChanges()) { auto inversedDiff = curList.BuildDiff(prevList); GetMainSignals().NotifyMasternodeListChanged(true, curList, inversedDiff, connman); - uiInterface.NotifyMasternodeListChanged(prevList); + uiInterface.NotifyMasternodeListChanged(prevList, pindex->pprev); } const auto& consensusParams = Params().GetConsensus(); diff --git a/src/evo/deterministicmns.h b/src/evo/deterministicmns.h index 1e74c82cdd5d3..ed01f43b58acd 100644 --- a/src/evo/deterministicmns.h +++ b/src/evo/deterministicmns.h @@ -348,7 +348,6 @@ class CDeterministicMNList * @return */ [[nodiscard]] std::vector GetProjectedMNPayees(const CBlockIndex* const pindex, int nCount = std::numeric_limits::max()) const; - [[nodiscard]] std::vector GetProjectedMNPayeesAtChainTip(int nCount = std::numeric_limits::max()) const; /** * Calculate a quorum based on the modifier. The resulting list is deterministically sorted by score diff --git a/src/governance/governance.cpp b/src/governance/governance.cpp index ddf5515ed7c45..35abdf4035295 100644 --- a/src/governance/governance.cpp +++ b/src/governance/governance.cpp @@ -675,8 +675,10 @@ void CGovernanceManager::CreateGovernanceTrigger(const CSuperblock& sb, CConnman if (identical_sb == nullptr) { // Nobody submitted a trigger we'd like to see, // so let's do it but only if we are the payee - auto mnList = deterministicMNManager->GetListAtChainTip(); - auto mn_payees = mnList.GetProjectedMNPayeesAtChainTip(); + + const CBlockIndex *tip = WITH_LOCK(::cs_main, return ::ChainActive().Tip()); + auto mnList = deterministicMNManager->GetListForBlock(tip); + auto mn_payees = mnList.GetProjectedMNPayees(tip); if (mn_payees.empty()) return; { LOCK(activeMasternodeInfoCs); diff --git a/src/interfaces/node.h b/src/interfaces/node.h index cd50480b07089..720a5c97a4339 100644 --- a/src/interfaces/node.h +++ b/src/interfaces/node.h @@ -21,6 +21,7 @@ #include class BanMan; +class CBlockIndex; class CCoinControl; class CDeterministicMNList; class CFeeRate; @@ -45,7 +46,7 @@ class EVO { public: virtual ~EVO() {} - virtual CDeterministicMNList getListAtChainTip() = 0; + virtual std::pair getListAtChainTip() = 0; }; //! Interface for the src/governance part of a dash node (dashd process). @@ -355,7 +356,8 @@ class Node //! Register handler for masternode list update messages. using NotifyMasternodeListChangedFn = - std::function; + std::function; virtual std::unique_ptr handleNotifyMasternodeListChanged(NotifyMasternodeListChangedFn fn) = 0; //! Register handler for additional data sync progress update messages. diff --git a/src/node/interfaces.cpp b/src/node/interfaces.cpp index 09a69afc03f04..a993e982a954d 100644 --- a/src/node/interfaces.cpp +++ b/src/node/interfaces.cpp @@ -79,9 +79,14 @@ namespace { class EVOImpl : public EVO { public: - CDeterministicMNList getListAtChainTip() override + std::pair getListAtChainTip() override { - return deterministicMNManager == nullptr ? CDeterministicMNList() : deterministicMNManager->GetListAtChainTip(); + const CBlockIndex *tip = WITH_LOCK(::cs_main, return ::ChainActive().Tip()); + CDeterministicMNList mnList{}; + if (tip != nullptr && deterministicMNManager != nullptr) { + mnList = deterministicMNManager->GetListForBlock(tip); + } + return {std::move(mnList), tip}; } }; @@ -499,8 +504,8 @@ class NodeImpl : public Node std::unique_ptr handleNotifyMasternodeListChanged(NotifyMasternodeListChangedFn fn) override { return MakeHandler( - ::uiInterface.NotifyMasternodeListChanged_connect([fn](const CDeterministicMNList& newList) { - fn(newList); + ::uiInterface.NotifyMasternodeListChanged_connect([fn](const CDeterministicMNList& newList, const CBlockIndex* pindex) { + fn(newList, pindex); })); } std::unique_ptr handleNotifyAdditionalDataSyncProgressChanged(NotifyAdditionalDataSyncProgressChangedFn fn) override diff --git a/src/qt/clientmodel.cpp b/src/qt/clientmodel.cpp index 24a805852444a..8491b64170615 100644 --- a/src/qt/clientmodel.cpp +++ b/src/qt/clientmodel.cpp @@ -82,26 +82,29 @@ int ClientModel::getNumConnections(unsigned int flags) const return m_node.getNodeCount(connections); } -void ClientModel::setMasternodeList(const CDeterministicMNList& mnList) +void ClientModel::setMasternodeList(const CDeterministicMNList& mnList, const CBlockIndex* tip) { LOCK(cs_mnlinst); if (mnListCached->GetBlockHash() == mnList.GetBlockHash()) { return; } mnListCached = std::make_shared(mnList); + mnListTip = tip; Q_EMIT masternodeListChanged(); } -CDeterministicMNList ClientModel::getMasternodeList() const +std::pair ClientModel::getMasternodeList() const { LOCK(cs_mnlinst); - return *mnListCached; + return {*mnListCached, mnListTip}; } void ClientModel::refreshMasternodeList() { + auto [mnList, tip] = m_node.evo().getListAtChainTip(); + LOCK(cs_mnlinst); - setMasternodeList(m_node.evo().getListAtChainTip()); + setMasternodeList(mnList, tip); } int ClientModel::getHeaderTipHeight() const @@ -332,9 +335,9 @@ static void NotifyChainLock(ClientModel *clientmodel, const std::string& bestCha assert(invoked); } -static void NotifyMasternodeListChanged(ClientModel *clientmodel, const CDeterministicMNList& newList) +static void NotifyMasternodeListChanged(ClientModel *clientmodel, const CDeterministicMNList& newList, const CBlockIndex* pindex) { - clientmodel->setMasternodeList(newList); + clientmodel->setMasternodeList(newList, pindex); } static void NotifyAdditionalDataSyncProgressChanged(ClientModel *clientmodel, double nSyncProgress) @@ -355,7 +358,7 @@ void ClientModel::subscribeToCoreSignals() m_handler_notify_block_tip = m_node.handleNotifyBlockTip(std::bind(BlockTipChanged, this, std::placeholders::_1, std::placeholders::_2, std::placeholders::_3, false)); m_handler_notify_chainlock = m_node.handleNotifyChainLock(std::bind(NotifyChainLock, this, std::placeholders::_1, std::placeholders::_2)); m_handler_notify_header_tip = m_node.handleNotifyHeaderTip(std::bind(BlockTipChanged, this, std::placeholders::_1, std::placeholders::_2, std::placeholders::_3, true)); - m_handler_notify_masternodelist_changed = m_node.handleNotifyMasternodeListChanged(std::bind(NotifyMasternodeListChanged, this, std::placeholders::_1)); + m_handler_notify_masternodelist_changed = m_node.handleNotifyMasternodeListChanged(std::bind(NotifyMasternodeListChanged, this, std::placeholders::_1, std::placeholders::_2)); m_handler_notify_additional_data_sync_progess_changed = m_node.handleNotifyAdditionalDataSyncProgressChanged(std::bind(NotifyAdditionalDataSyncProgressChanged, this, std::placeholders::_1)); } diff --git a/src/qt/clientmodel.h b/src/qt/clientmodel.h index 9af75010351ac..01238cba36969 100644 --- a/src/qt/clientmodel.h +++ b/src/qt/clientmodel.h @@ -67,8 +67,8 @@ class ClientModel : public QObject int getHeaderTipHeight() const; int64_t getHeaderTipTime() const; - void setMasternodeList(const CDeterministicMNList& mnList); - CDeterministicMNList getMasternodeList() const; + void setMasternodeList(const CDeterministicMNList& mnList, const CBlockIndex* tip); + std::pair getMasternodeList() const; void refreshMasternodeList(); void getAllGovernanceObjects(std::vector &obj); @@ -119,6 +119,7 @@ class ClientModel : public QObject // representation of the list in UI during initial sync/reindex, so we cache it here too. mutable RecursiveMutex cs_mnlinst; // protects mnListCached CDeterministicMNListPtr mnListCached; + const CBlockIndex* mnListTip; void subscribeToCoreSignals(); void unsubscribeFromCoreSignals(); diff --git a/src/qt/governancelist.cpp b/src/qt/governancelist.cpp index 8cbbe58bcf62a..d291e83ba41cc 100644 --- a/src/qt/governancelist.cpp +++ b/src/qt/governancelist.cpp @@ -347,7 +347,7 @@ void GovernanceList::updateProposalList() // A proposal is considered passing if (YES votes - NO votes) >= (Total Weight of Masternodes / 10), // count total valid (ENABLED) masternodes to determine passing threshold. // Need to query number of masternodes here with access to clientModel. - const int nWeightedMnCount = clientModel->getMasternodeList().GetValidWeightedMNsCount(); + const int nWeightedMnCount = clientModel->getMasternodeList().first.GetValidWeightedMNsCount(); const int nAbsVoteReq = std::max(Params().GetConsensus().nGovernanceMinQuorum, nWeightedMnCount / 10); proposalModel->setVotingParams(nAbsVoteReq); diff --git a/src/qt/masternodelist.cpp b/src/qt/masternodelist.cpp index 790b9d7ccb06f..ae9775e510b99 100644 --- a/src/qt/masternodelist.cpp +++ b/src/qt/masternodelist.cpp @@ -166,8 +166,8 @@ void MasternodeList::updateDIP3List() return; } - auto mnList = clientModel->getMasternodeList(); - auto projectedPayees = mnList.GetProjectedMNPayeesAtChainTip(); + auto [mnList, pindex] = clientModel->getMasternodeList(); + auto projectedPayees = mnList.GetProjectedMNPayees(pindex); if (projectedPayees.empty() && mnList.GetValidMNsCount() > 0) { // GetProjectedMNPayees failed to provide results for a list with valid mns. @@ -356,8 +356,7 @@ CDeterministicMNCPtr MasternodeList::GetSelectedDIP3MN() uint256 proTxHash; proTxHash.SetHex(strProTxHash); - auto mnList = clientModel->getMasternodeList(); - return mnList.GetMN(proTxHash); + return clientModel->getMasternodeList().first.GetMN(proTxHash);; } void MasternodeList::extraInfoDIP3_clicked() diff --git a/src/qt/rpcconsole.cpp b/src/qt/rpcconsole.cpp index 0770dc94de7a6..574f62bf9ca32 100644 --- a/src/qt/rpcconsole.cpp +++ b/src/qt/rpcconsole.cpp @@ -970,7 +970,7 @@ void RPCConsole::updateMasternodeCount() if (!clientModel) { return; } - auto mnList = clientModel->getMasternodeList(); + auto mnList = clientModel->getMasternodeList().first; size_t total_mn_count = mnList.GetAllMNsCount(); size_t total_enabled_mn_count = mnList.GetValidMNsCount(); size_t total_evo_count = mnList.GetAllEvoCount(); @@ -1250,7 +1250,7 @@ void RPCConsole::updateNodeDetail(const CNodeCombinedStats *stats) ui->peerHeight->setText(QString::number(stats->nodeStats.nStartingHeight)); ui->peerWhitelisted->setText(stats->nodeStats.m_legacyWhitelisted ? tr("Yes") : tr("No")); ui->peerMappedAS->setText(stats->nodeStats.m_mapped_as != 0 ? QString::number(stats->nodeStats.m_mapped_as) : tr("N/A")); - auto dmn = clientModel->getMasternodeList().GetMNByService(stats->nodeStats.addr); + auto dmn = clientModel->getMasternodeList().first.GetMNByService(stats->nodeStats.addr); if (dmn == nullptr) { ui->peerNodeType->setText(tr("Regular")); ui->peerPoSeScore->setText(tr("N/A")); diff --git a/src/rpc/masternode.cpp b/src/rpc/masternode.cpp index 2317411a0f89b..412be9bf88c46 100644 --- a/src/rpc/masternode.cpp +++ b/src/rpc/masternode.cpp @@ -135,8 +135,9 @@ static UniValue masternode_count(const JSONRPCRequest& request) static UniValue GetNextMasternodeForPayment(int heightShift) { - auto mnList = deterministicMNManager->GetListAtChainTip(); - auto payees = mnList.GetProjectedMNPayeesAtChainTip(heightShift); + const CBlockIndex *tip = WITH_LOCK(::cs_main, return ::ChainActive().Tip()); + auto mnList = deterministicMNManager->GetListForBlock(tip); + auto payees = mnList.GetProjectedMNPayees(tip, heightShift); if (payees.empty()) return "unknown"; auto payee = payees.back(); diff --git a/src/ui_interface.cpp b/src/ui_interface.cpp index c702698818942..c53bedf2b9707 100644 --- a/src/ui_interface.cpp +++ b/src/ui_interface.cpp @@ -58,7 +58,7 @@ void CClientUIInterface::ShowProgress(const std::string& title, int nProgress, b void CClientUIInterface::NotifyBlockTip(bool b, const CBlockIndex* i) { return g_ui_signals.NotifyBlockTip(b, i); } void CClientUIInterface::NotifyChainLock(const std::string& bestChainLockHash, int bestChainLockHeight) { return g_ui_signals.NotifyChainLock(bestChainLockHash, bestChainLockHeight); } void CClientUIInterface::NotifyHeaderTip(bool b, const CBlockIndex* i) { return g_ui_signals.NotifyHeaderTip(b, i); } -void CClientUIInterface::NotifyMasternodeListChanged(const CDeterministicMNList& list) { return g_ui_signals.NotifyMasternodeListChanged(list); } +void CClientUIInterface::NotifyMasternodeListChanged(const CDeterministicMNList& list, const CBlockIndex* i) { return g_ui_signals.NotifyMasternodeListChanged(list, i); } void CClientUIInterface::NotifyAdditionalDataSyncProgressChanged(double nSyncProgress) { return g_ui_signals.NotifyAdditionalDataSyncProgressChanged(nSyncProgress); } void CClientUIInterface::BannedListChanged() { return g_ui_signals.BannedListChanged(); } diff --git a/src/ui_interface.h b/src/ui_interface.h index c0e8aadcf4e26..0e6226986942f 100644 --- a/src/ui_interface.h +++ b/src/ui_interface.h @@ -118,7 +118,7 @@ class CClientUIInterface ADD_SIGNALS_DECL_WRAPPER(NotifyHeaderTip, void, bool, const CBlockIndex*); /** Masternode list has changed */ - ADD_SIGNALS_DECL_WRAPPER(NotifyMasternodeListChanged, void, const CDeterministicMNList&); + ADD_SIGNALS_DECL_WRAPPER(NotifyMasternodeListChanged, void, const CDeterministicMNList&, const CBlockIndex*); /** Additional data sync progress changed */ ADD_SIGNALS_DECL_WRAPPER(NotifyAdditionalDataSyncProgressChanged, void, double nSyncProgress); From 41560f0e2f0a9f6a2ced74048a48f3a15c6bed8a Mon Sep 17 00:00:00 2001 From: UdjinM6 Date: Thu, 26 Oct 2023 17:06:09 +0300 Subject: [PATCH 7/7] fix statusItem --- src/qt/masternodelist.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/qt/masternodelist.cpp b/src/qt/masternodelist.cpp index ae9775e510b99..717b921e5a048 100644 --- a/src/qt/masternodelist.cpp +++ b/src/qt/masternodelist.cpp @@ -229,7 +229,7 @@ void MasternodeList::updateDIP3List() QByteArray addr_ba(reinterpret_cast(addr_key.data()), addr_key.size()); QTableWidgetItem* addressItem = new CMasternodeListWidgetItem(QString::fromStdString(dmn.pdmnState->addr.ToString()), addr_ba); QTableWidgetItem* typeItem = new QTableWidgetItem(QString::fromStdString(std::string(GetMnType(dmn.nType).description))); - QTableWidgetItem* statusItem = new QTableWidgetItem(mnList.IsMNValid(dmn) ? tr("ENABLED") : (mnList.IsMNPoSeBanned(dmn) ? tr("POSE_BANNED") : tr("UNKNOWN"))); + QTableWidgetItem* statusItem = new QTableWidgetItem(dmn.pdmnState->IsBanned() ? tr("POSE_BANNED") : tr("ENABLED")); QTableWidgetItem* PoSeScoreItem = new CMasternodeListWidgetItem(QString::number(dmn.pdmnState->nPoSePenalty), dmn.pdmnState->nPoSePenalty); QTableWidgetItem* registeredItem = new CMasternodeListWidgetItem(QString::number(dmn.pdmnState->nRegisteredHeight), dmn.pdmnState->nRegisteredHeight); QTableWidgetItem* lastPaidItem = new CMasternodeListWidgetItem(QString::number(dmn.pdmnState->nLastPaidHeight), dmn.pdmnState->nLastPaidHeight);